<?php
/***************************************************************************
- * Copyright (C) 2003-2010 Polytechnique.org *
+ * Copyright (C) 2003-2011 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
class UserSet extends PlSet
{
- public function __construct(PlFilterCondition &$cond, $orders = null)
+ public function __construct(PlFilterCondition $cond, $orders = null)
{
parent::__construct($cond, $orders);
}
- protected function buildFilter(PlFilterCondition &$cond, $orders)
+ protected function buildFilter(PlFilterCondition $cond, $orders)
{
return new UserFilter($cond, $orders);
}
class ProfileSet extends PlSet
{
- public function __construct(PlFilterCondition &$cond, $orders = null)
+ public function __construct(PlFilterCondition $cond, $orders = null)
{
parent::__construct($cond, $orders);
}
- protected function buildFilter(PlFilterCondition &$cond, $orders)
+ protected function buildFilter(PlFilterCondition $cond, $orders)
{
return new ProfileFilter($cond, $orders);
}
}
+require_once "ufbuilder.inc.php";
+
class SearchSet extends ProfileSet
{
- public $advanced = false;
- private $score = null;
- private $quick = false;
- private $valid = true;
+ protected $score = null;
+ protected $valid = true;
- public function __construct($quick = false, PlFilterCondition $cond = null)
+ public function __construct(UserFilterBuilder $ufb, PlFilterCondition $cond = null)
{
- if (isset($no_search)) {
- return;
- }
-
- $this->quick = $quick;
-
if (is_null($cond)) {
$conds = new PFC_And();
} else if ($cond instanceof PFC_And) {
$conds = new PFC_And($cond);
}
- if ($quick) {
- $this->getQuick($conds);
- } else {
- $this->getAdvanced($conds);
- }
- }
-
- public function isValid()
- {
- return $this->valid;
- }
-
- /** Sets up the conditions for a Quick Search
- * @param $conds Additional conds (as a PFC_And)
- */
- private function getQuick($conds)
- {
- if (!S::logged()) {
- Env::kill('with_soundex');
- }
-
- require_once 'ufbuilder.inc.php';
- $ufb = new UFB_QuickSearch();
-
if (!$ufb->isValid()) {
$this->valid = false;
return;
$orders = $ufb->getOrders();
- if (S::logged() && Env::has('nonins')) {
- $conds = new PFC_And($conds,
- new PFC_Not(new UFC_Dead()),
- new PFC_Not(new UFC_Registered())
- );
- }
-
parent::__construct($conds, $orders);
}
- /** Sets up the conditions for an Advanced Search
- * @param $conds Additional conds (as a PFC_And)
- */
- private function getAdvanced($conds)
+ public function isValid()
{
- $this->advanced = true;
- require_once 'ufbuilder.inc.php';
- $ufb = new UFB_AdvancedSearch();
-
- if (!$ufb->isValid()) {
- $this->valid = false;
- return;
- }
-
- $ufc = $ufb->getUFC();
- $conds->addChild($ufc);
-
- $orders = $ufb->getOrders();
-
- parent::__construct($conds, $orders);
+ return $this->valid;
}
/** Add a "rechercher=Chercher" field to the query to simulate the POST
return $args;
}
- protected function &getFilterResults(PlFilter &$pf, PlLimit $limit)
+ protected function &getFilterResults(PlFilter $pf, PlLimit $limit)
{
$profiles = $pf->getProfiles($limit, Profile::FETCH_MINIFICHES);
return $profiles;
}
}
+// Specialized SearchSet for quick search.
+class QuickSearchSet extends SearchSet
+{
+ public function __construct(PlFilterCondition $cond = null)
+ {
+ if (!S::logged()) {
+ Env::kill('with_soundex');
+ }
+
+ parent::__construct(new UFB_QuickSearch(), $cond);
+ }
+}
+
+// Specialized SearchSet for advanced search.
+class AdvancedSearchSet extends SearchSet
+{
+ public function __construct($xorg_admin_fields, $ax_admin_fields,
+ PlFilterCondition $cond = null)
+ {
+ parent::__construct(new UFB_AdvancedSearch($xorg_admin_fields, $ax_admin_fields),
+ $cond);
+ }
+}
+
/** Simple set based on an array of User objects
*/
class ArraySet extends ProfileSet
*/
class MinificheView extends ProfileView
{
- public function __construct(PlSet &$set, array $params)
+ public function __construct(PlSet $set, array $params)
{
global $globals;
$this->entriesPerPage = $globals->search->per_page;
parent::__construct($set, $params);
}
- public function apply(PlPage &$page)
+ public function apply(PlPage $page)
{
if (array_key_exists('starts_with', $this->params)
&& $this->params['starts_with'] != ""
class MentorView extends ProfileView
{
- public function __construct(PlSet &$set, array $params)
+ public function __construct(PlSet $set, array $params)
{
$this->entriesPerPage = 10;
$this->addSort(new PlViewOrder('rand', array(new PFO_Random(S::i('uid'))), 'aléatoirement'));
class TrombiView extends ProfileView
{
- public function __construct(PlSet &$set, array $params)
+ public function __construct(PlSet $set, array $params)
{
$this->entriesPerPage = 24;
$this->defaultkey = 'name';
return 'include/plview.trombi.tpl';
}
- public function apply(PlPage &$page)
+ public function apply(PlPage $page)
{
if (!empty($GLOBALS['IS_XNET_SITE'])) {
global $globals;
}
}
+/** A multipage view for users
+ * Allows the display of bounds when sorting by name or promo.
+ */
+abstract class UserView extends MultipageView
+{
+ 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;
+ }
+
+ public function bounds()
+ {
+ $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;
+ }
+}
+
+class XnetFicheView extends UserView
+{
+ 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.xnetuser.tpl';
+ }
+}
+
class GadgetView implements PlView
{
- public function __construct(PlSet &$set, array $params)
+ public function __construct(PlSet $set, array $params)
{
$this->set =& $set;
}
- public function apply(PlPage &$page)
+ public function apply(PlPage $page)
{
$page->assign_by_ref('set', $this->set->get(new PlLimit(5, 0)));
}
{
private $set;
- public function __construct(PlSet &$set, array $params)
+ public function __construct(PlSet $set, array $params)
{
$this->set =& $set;
}
- public function apply(PlPage &$page)
+ public function apply(PlPage $page)
{
$pids = $this->set->getIds(new PlLimit());
$visibility = new ProfileVisibility(ProfileVisibility::VIS_AX);
- pl_content_headers('text/x-csv');
+ pl_cached_content_headers('text/x-csv', 1);
$csv = fopen('php://output', 'w');
fputcsv($csv, array('adresses'), ';');
}
}
+class JSonView implements PlView
+{
+ private $set;
+ private $params;
+
+ public function __construct(PlSet $set, array $params)
+ {
+ $this->set = $set;
+ $this->params = $params;
+ }
+
+ public function apply(PlPage $page)
+ {
+ $export = array();
+ $start = isset($this->params['offset']) ? $this->params['offset'] : 0;
+ $count = isset($this->params['count']) ? $this->params['count'] : 10;
+ $profiles = $this->set->get(new PlLimit($start, $count));
+ foreach ($profiles as $profile) {
+ $export[] = $profile->export();
+ }
+ $page->jsonAssign('profile_count', $this->set->count());
+ $page->jsonAssign('profiles', $export);
+ }
+
+ public function args()
+ {
+ return $this->set->args();
+ }
+}
+
// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
?>