Changeset 2f9fdbf in github


Ignore:
Timestamp:
Nov 14, 2011 6:21:39 AM (19 months ago)
Author:
alecpl <alec@…>
Branches:
master, HEAD, courier-fix, dev-browser-capabilities, pdo, release-0.8
Children:
854fbf6
Parents:
be58b50
Message:
  • Fix sorting autocomplete results to preserve email address significance (#1488084)
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • CHANGELOG

    rbd34cad r2f9fdbf  
    22=========================== 
    33 
     4- Fix sorting autocomplete results (#1488084) 
    45- Add option to set session name (#1486433) 
    56- Add option to skip alternative email addresses in autocompletion 
  • program/steps/mail/autocomplete.inc

    r710b1bd r2f9fdbf  
    5555if (!empty($book_types) && strlen($search)) { 
    5656  $contacts  = array(); 
     57  $sort_keys = array(); 
    5758  $books_num = count($book_types); 
    5859  $search_lc = mb_strtolower($search); 
     
    6768        $email_arr = (array)$abook->get_col_values('email', $sql_arr, true); 
    6869        $email_cnt = count($email_arr); 
     70        $idx = 0; 
    6971        foreach ($email_arr as $email) { 
    7072          if (empty($email)) { 
     
    8183          // skip duplicates 
    8284          if (!in_array($contact, $contacts)) { 
    83             $contacts[] = $contact; 
     85            $contacts[]  = $contact; 
     86            $sort_keys[] = sprintf('%s %03d', $sql_arr['name'] , $idx++); 
     87 
    8488            if (count($contacts) >= $MAXNUM) 
    8589              break 2; 
     
    103107        // group (distribution list) with email address(es) 
    104108        if ($group_prop['email']) { 
     109            $idx = 0; 
    105110            foreach ((array)$group_prop['email'] as $email) { 
    106                 $contacts[] = format_email_recipient($email, $group['name']); 
     111                $contacts[]  = format_email_recipient($email, $group['name']); 
     112                $sort_keys[] = sprintf('%s %03d', $group['name'] , $idx++); 
     113 
    107114                if (count($contacts) >= $MAXNUM) 
    108115                  break 2; 
     
    111118        // show group with count 
    112119        else if (($result = $abook->count()) && $result->count) { 
    113           $contacts[] = array('name' => $group['name'] . ' (' . intval($result->count) . ')', 'id' => $group['ID'], 'source' => $id); 
     120          $contacts[]  = array('name' => $group['name'] . ' (' . intval($result->count) . ')', 'id' => $group['ID'], 'source' => $id); 
     121          $sort_keys[] = $group['name']; 
     122 
    114123          if (count($contacts) >= $MAXNUM) 
    115124            break; 
     
    119128  } 
    120129 
    121   usort($contacts, 'contact_results_sort'); 
     130  if (count($contacts)) { 
     131    // sort contacts index 
     132    asort($sort_keys, SORT_LOCALE_STRING); 
     133    // re-sort contacts according to index 
     134    foreach ($sort_keys as $idx => $val) { 
     135      $sort_keys[$idx] = $contacts[$idx]; 
     136    } 
     137    $contacts = array_values($sort_keys); 
     138  } 
    122139} 
    123140 
    124141$OUTPUT->command('ksearch_query_results', $contacts, $search, $sid); 
    125142$OUTPUT->send(); 
    126  
    127  
    128 function contact_results_sort($a, $b) 
    129 { 
    130   $name_a = is_array($a) ? $a['name'] : $a; 
    131   $name_b = is_array($b) ? $b['name'] : $b; 
    132   return strcoll(trim($name_a, '" '), trim($name_b, '" ')); 
    133 } 
    134  
Note: See TracChangeset for help on using the changeset viewer.