+ $page->assign('list', $ids);
+ }
+
+ function handler_referent($page, $action = null, $subaction = null)
+ {
+ global $globals;
+
+ $wp = new PlWikiPage('Docs.Emploi');
+ $wp->buildCache();
+
+ $page->setTitle('Emploi et Carrières');
+ $page->addJsLink('jquery.ui.xorg.js');
+
+ // Count mentors
+ $res = XDB::query("SELECT count(distinct pid) FROM profile_mentor_term");
+ $page->assign('mentors_number', $res->fetchOneCell());
+
+ // Search for mentors matching filters
+ require_once 'ufbuilder.inc.php';
+ $ufb = new UFB_MentorSearch();
+ if (!$ufb->isEmpty()) {
+ require_once 'userset.inc.php';
+ $ufc = $ufb->getUFC();
+ $set = new ProfileSet($ufc);
+ $set->addMod('mentor', 'Référents');
+ $set->apply('referent/search', $page, $action, $subaction);
+ $nb_tot = $set->count();
+ if ($nb_tot > $globals->search->private_max) {
+ $this->form_prepare();
+ $page->trigError('Recherche trop générale.');
+ $page->assign('plset_count', 0);
+ } else if ($nb_tot == 0) {
+ $this->form_prepare();
+ $page->trigError('Il n\'existe personne correspondant à ces critères dans la base.');
+ }
+ }
+
+ $page->changeTpl('search/referent.tpl');
+ }
+
+ /**
+ * Builds a select field to choose among countries that referents
+ * know about. Only referents linked to term (jtid) are displayed.
+ * @param $jtid id of job term to restrict referents
+ */
+ function handler_referent_countries($page, $jtid = null)
+ {
+ pl_content_headers("text/xml");
+ $page->changeTpl('include/field.select.tpl', NO_SKIN);
+ $page->assign('name', 'country');
+ $it = XDB::iterator("SELECT gc.iso_3166_1_a2 AS id, gc.country AS field
+ FROM geoloc_countries AS gc
+ INNER JOIN profile_mentor_country AS mp ON (mp.country = gc.iso_3166_1_a2)
+ INNER JOIN profile_mentor_term AS mt ON (mt.pid = mp.pid)
+ INNER JOIN profile_job_term_relation AS jtr ON (jtr.jtid_2 = mt.jtid)
+ WHERE jtr.jtid_1 = {?}
+ GROUP BY gc.iso_3166_1_a2
+ ORDER BY gc.country", $jtid);
+ $page->assign('list', $it);