* @author Julio Montoya - Cleaning code * @author Ricardo Rodriguez - Separated the function and code * @package chamilo.library */ class Accessurledituserstourl { /** * Search users by username, firstname or lastname, based on the given * search string * @param string Search string * @param int Deprecated param * @return string Xajax response block * @assert () === false */ function search_users($needle, $id) { $tbl_user = Database::get_main_table(TABLE_MAIN_USER); $xajax_response = new xajaxResponse(); $return = ''; if (!empty($needle)) { // xajax send utf8 datas... datas in db can be non-utf8 datas $charset = api_get_system_encoding(); $needle = api_convert_encoding($needle, $charset, 'utf-8'); $needle = Database::escape_string($needle); // search users where username or firstname or lastname begins likes $needle $order_clause = api_sort_by_first_name() ? ' ORDER BY firstname, lastname, username' : ' ORDER BY lastname, firstname, username'; $sql = 'SELECT u.user_id, username, lastname, firstname FROM '.$tbl_user.' u '. ' WHERE (username LIKE "'.$needle.'%" '. ' OR firstname LIKE "'.$needle.'%" '. ' OR lastname LIKE "'.$needle.'%") '. $order_clause . ' LIMIT 11'; $rs = Database::query($sql); $i=0; while ($user = Database :: fetch_array($rs)) { $i++; if ($i<=10) { $return .= ''.api_get_person_name($user['firstname'], $user['lastname']).' ('.$user['username'].')
'; } else { $return .= '...
'; } } } $xajax_response -> addAssign('ajax_list_users','innerHTML',api_utf8_encode($return)); return $xajax_response; } }