}
}
-/** 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)
{
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;
}
* - 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)
{
}
}
-class MentorView extends ProfileView
+class MentorView extends MixedView
{
public function __construct(PlSet $set, array $params)
{
}
}
-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)
{
}
}
-/** A multipage view for users
- * Allows the display of bounds when sorting by name or promo.
- */
-abstract class UserView extends MultipageView
+class MapView implements PlView
{
- protected function getBoundValue($user)
- {
- if ($user instanceof User) {
- switch ($this->bound_field) {
- case 'name':
- $name = $user->lastName();
- return strtoupper($name);
- case 'promo':
- if ($user->hasProfile()) {
- return $user->profile()->promo();
- } else {
- return null;
- }
- default:
- return null;
- }
- }
- return null;
- }
+ private $set;
- public function bounds()
+ public function __construct(PlSet $set, array $params)
{
- $order = Env::v('order', $this->defaultkey);
- $show_bounds = 0;
- if (($order == "name") || ($order == "-name")) {
- $this->bound_field = "name";
- $show_bounds = 1;
- } elseif (($order == "promo") || ($order == "-promo")) {
- $this->bound_field = "promo";
- $show_bounds = -1;
- }
- if ($order{0} == '-') {
- $show_bounds = -$show_bounds;
- }
- return $show_bounds;
+ $this->set = $set;
}
-}
-class XnetFicheView extends UserView
-{
- public function __construct(PlSet $set, array $params)
+ public function apply(PlPage $page)
{
- $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);
+ 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 templateName()
+ public function args()
{
- return 'include/plview.xnetuser.tpl';
+ return $this->set->args();
}
}