X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=include%2Fuserset.inc.php;h=6153836989c9b1bc925f06f7318080071bbea805;hb=304cdf32d7c38afbd381909545021fc44c8a0e05;hp=2c58419d8a48074cee505a486b710dc10f54b4aa;hpb=d82359a556779137f8a90d0312b3098a2db6f482;p=platal.git diff --git a/include/userset.inc.php b/include/userset.inc.php index 2c58419..6153836 100644 --- a/include/userset.inc.php +++ b/include/userset.inc.php @@ -123,26 +123,31 @@ class AdvancedSearchSet extends SearchSet } } -/** Simple set based on an array of User objects +/** Simple set based on an array of User emails */ -class ArraySet extends ProfileSet +class UserArraySet extends UserSet { - public function __construct(array $users) + public function __construct(array $emails) { - $hruids = User::getBulkHruid($users, array('User', '_silent_user_callback')); - if (is_null($hruids) || count($hruids) == 0) { - $cond = new PFC_False(); - } else { - $cond = new UFC_Hruid($hruids); - } - parent::__construct($cond); + parent::__construct(new UFC_Email($emails)); } } -/** A multipage view for profiles +/** Simple set based on an array of Profile emails + */ +class ProfileArraySet extends ProfileSet +{ + public function __construct(array $emails) + { + parent::__construct(new UFC_Email($emails)); + } +} + + +/** A multipage view for profiles or users * Allows the display of bounds when sorting by name or promo. */ -abstract class ProfileView extends MultipageView +abstract class MixedView extends MultipageView { protected function getBoundValue($obj) { @@ -156,6 +161,20 @@ abstract class ProfileView extends MultipageView default: return null; } + } elseif ($obj instanceof User) { + switch ($this->bound_field) { + case 'name': + $name = $obj->lastName(); + return strtoupper($name); + case 'promo': + if ($obj->hasProfile()) { + return $obj->profile()->promo(); + } else { + return 'ext'; + } + default: + return null; + } } return null; } @@ -189,7 +208,7 @@ abstract class ProfileView extends MultipageView * - with_score: whether to allow ordering by score (set only for a quick search) * - starts_with: show only names beginning with the given letter */ -class MinificheView extends ProfileView +class MinificheView extends MixedView { public function __construct(PlSet $set, array $params) { @@ -226,8 +245,7 @@ class MinificheView extends ProfileView && $this->params['starts_with'] != null) { $this->set->addCond( - new UFC_Name(Profile::LASTNAME, - $this->params['starts_with'], UFC_Name::PREFIX) + new UFC_NameInitial($this->params['starts_with']) ); } return parent::apply($page); @@ -239,7 +257,7 @@ class MinificheView extends ProfileView } } -class MentorView extends ProfileView +class MentorView extends MixedView { public function __construct(PlSet $set, array $params) { @@ -264,7 +282,45 @@ class MentorView extends ProfileView } } -class TrombiView extends ProfileView +class GroupMemberView extends MixedView +{ + public function __construct(PlSet $set, array $params) + { + $this->entriesPerPage = 20; + $this->addSort(new PlViewOrder('name', array(new UFO_Name(Profile::DN_SORT)), 'nom')); + $this->addSort(new PlViewOrder('promo', array( + new UFO_Promo(UserFilter::DISPLAY, true), + new UFO_Name(Profile::DN_SORT), + ), 'promotion')); + parent::__construct($set, $params); + } + + public function templateName() + { + return 'include/plview.groupmember.tpl'; + } +} + +class ListMemberView extends MixedView +{ + public function __construct(PlSet $set, array $params) + { + $this->entriesPerPage = 100; + $this->addSort(new PlViewOrder('name', array(new UFO_Name(Profile::DN_SORT)), 'nom')); + $this->addSort(new PlViewOrder('promo', array( + new UFO_Promo(UserFilter::DISPLAY, true), + new UFO_Name(Profile::DN_SORT), + ), 'promotion')); + parent::__construct($set, $params); + } + + public function templateName() + { + return 'include/plview.listmember.tpl'; + } +} + +class TrombiView extends MixedView { public function __construct(PlSet $set, array $params) { @@ -302,6 +358,37 @@ class TrombiView extends ProfileView } } +class MapView implements PlView +{ + private $set; + + public function __construct(PlSet $set, array $params) + { + $this->set = $set; + } + + public function apply(PlPage $page) + { + Platal::load('geoloc'); + + if (Get::b('ajax')) { + $pids = $this->set->getIds(new PlLimit()); + GeolocModule::assign_json_to_map($page, $pids); + $page->runJSON(); + exit; + } else { + $this->set->getIds(new PlLimit()); + GeolocModule::prepare_map($page); + return 'geoloc/index.tpl'; + } + } + + public function args() + { + return $this->set->args(); + } +} + class GadgetView implements PlView { public function __construct(PlSet $set, array $params)