X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;ds=sidebyside;f=modules%2Flists%2Flists.inc.php;h=c0ffb09564b9c03aafac6afa60bacadd3b513286;hb=f311e7ab18d2949b0101060e3c17067d621cb875;hp=b8216c7660a5fb122e8b6281cf7e09e9e868c96b;hpb=8040946cd3e7577fa797b8b65718ab885ce68ec6;p=platal.git diff --git a/modules/lists/lists.inc.php b/modules/lists/lists.inc.php index b8216c7..c0ffb09 100644 --- a/modules/lists/lists.inc.php +++ b/modules/lists/lists.inc.php @@ -1,6 +1,6 @@ mail->domain || $dom == $globals->mail->domain2) { - $res = XDB::query('SELECT prenom,IF(nom_usage="", nom, nom_usage), promo - FROM auth_user_md5 AS u - INNER JOIN aliases AS a ON u.user_id = a.id - WHERE a.alias = {?}', $m); - if(list($prenom, $nom, $promo) = $res->fetchOneRow()) { - $key = $tri_promo ? $promo : strtoupper($nom{0}); - $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => (!$tri_promo ? $promo : null)); - } else { - $membres[0][] = Array('l' => $mem); - } + // $membres' structure is the following: $sortKey => $key => $listMember + $membres = array(); + + foreach($members as $member) { + $user = User::getSilent($member); + if (!$user) { + $membres[0][$member] = array('name' => null, 'email' => $member, 'category' => null, 'uid' => null, 'lost' => null, 'hasProfile' => null); } else { - $res = XDB::query('SELECT m2.uid, m1.prenom, m1.nom - FROM groupex.membres AS m1 - LEFT JOIN groupex.membres AS m2 ON(m1.email=m2.email AND m2.asso_id={?}) - WHERE m1.email={?}', $globals->asso('id'), $mem); - if (list($uid, $prenom, $nom) = $res->fetchOneRow()) { - $key = $tri_promo ? 0 : strtoupper($nom{0}); - $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $mem, 'x' => $uid, 'p' => (!$tri_promo ? 'non-X' : null)); - } else { - $membres[0][] = Array('l' => $mem, 'p' => (!$tri_promo ? 'non-X' : null)); + $hasProfile = $user->hasProfile(); + $uid = $user->id(); + $name = $user->directoryName(); + $category = $user->category(); + $key = $tri_promo ? ($category ? $category : 'AAAAA') : strtoupper($name{0}); + if (!$category) { + $category = 'extérieurs'; } + $membres[$key][$name] = array('name' => $name, 'email' => $member, 'category' => $category, + 'uid' => $uid, 'lost' => $user->lost, 'hasProfile' => $hasProfile); } } ksort($membres); - foreach($membres as $key=>$val) ksort($membres[$key]); + foreach($membres as &$membre) { + uksort($membre, 'strcasecmp'); + } return $membres; } // }}} +// {{{ list_extract_member + +function _list_extract_member($member) +{ + return $member[1]; +} + +function list_extract_members($members) +{ + return array_map('_list_extract_member', $members); +} + +// }}} // {{{ function list_sort_members -function list_sort_members(&$members, $tri_promo = true) { - $member_list = array_map(create_function('$arr', 'return $arr[1];'), $members); - return list_sort_owners($member_list, $tri_promo); +function list_sort_members($members, $tri_promo = true) +{ + $m = list_extract_members($members); + return list_sort_owners($m, $tri_promo); +} + +// }}} +// {{{ function list_fetch_basic_info + +function list_fetch_basic_info($members) +{ + $res = array(); + foreach ($members as $member) { + $user = User::getSilent($member); + if (!$user) { + $res[] = $member . ';;'; + } else { + $res[] = $user->lastName() . ';' . $user->firstName() . ';' . $user->promo(); + } + } + return $res; } // }}} @@ -71,14 +97,18 @@ function list_sort_members(&$members, $tri_promo = true) { function _list_header_decode($charset, $c, $str) { $s = ($c == 'Q' || $c == 'q') ? quoted_printable_decode($str) : base64_decode($str); - $s = iconv($charset, 'iso-8859-15', $s); + $s = iconv($charset, 'UTF-8', $s); return str_replace('_', ' ', $s); } function list_header_decode($value) { + if (!$value) { + return "[pas de sujet]"; + } $val = preg_replace('/(=\?[^?]*\?[BQbq]\?[^?]*\?=) (=\?[^?]*\?[BQbq]\?[^?]*\?=)/', '\1\2', $value); return preg_replace('/=\?([^?]*)\?([BQbq])\?([^?]*)\?=/e', '_list_header_decode("\1", "\2", "\3")', $val); } // }}} +// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: ?>