Subversion Repositories eFlore/Applications.coel-consultation

Compare Revisions

Ignore whitespace Rev 6 → Rev 7

/trunk/controleurs/Recherche.php
New file
0,0 → 1,105
<?php
// declare(encoding='UTF-8');
/**
* classe Controleur du module Recherche.
*
* @package Collection
* @category Php5
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
* @copyright 2010 Tela-Botanica
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
* @license http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
* @version SVN: $$Id: AdminAdministrateur.php 128 2009-09-02 12:20:55Z aurelien $$
*/
class Recherche extends Controleur {
private $parametres = array();
private $url = null;
public function __construct() {
$registre = Registre::getInstance();
$this->parametres = $registre->get('parametres');
$this->url = $this->parametres['url'];
parent::__construct();
}
/**
* Fonction d'affichage par défaut, elle appelle la liste des administrateurs
*/
public function executerActionParDefaut() {
return $this->chargerMoteurRecherche();
}
/**
* Charge le moteur de recherche et l'envoie à la vue.
* @return string la vue correspondante
*/
public function chargerMoteurRecherche() {
$donnees = array();
// Gestion de l'url
$this->url->setVariableRequete('module', 'Recherche');
$this->url->setVariableRequete('action', 'rechercher');
$donnees['url_form'] = $this->url->getUrl();
$donnees['url_module'] = 'Recherche';
$donnees['url_action'] = 'rechercher';
// Gestion du squelette
$this->chargerVue('moteur', $donnees);
 
// Attribution des morceaux de HTML à la sortie
$sortie['corps'] = $this->moteur;
return $sortie;
}
/**
* Recherche des collections.
* @return string la vue correspondante
*/
public function rechercher() {
$donnees = array();
$rechercheDao = $this->getModele('RechercheDao');
$parametres = array('mots' => '');
// Récupération des paramêtres de l'url
if (isset($_GET['recherche'])) {
$parametres['mots'] = $_GET['recherche'];
}
 
// Gestion du nombre de résultats
$donnees_total = $rechercheDao->chercherStructureNbre($parametres);
// Gestion du fragmenteur
$options = array(
'url' => $this->url,
'donnees_total' => $donnees_total);
$fragmenteur = Composant::fabrique('fragmenteur', $options);
$donnees['fragmenteur'] = $fragmenteur->executer();
list($de, $a) = $fragmenteur->getDeplacementParPageId();
 
// Gestion de l'accès aux données
$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
$resultats = $rechercheDao->chercher($parametres);
// Post-traitement des résultats pour l'affichage
foreach ($resultats as $resultat) {
$structure_id = $resultat['cs_id_structure'];
if (!isset($donnees['infos'][$structure_id])) {
$structure = array(
'nom' => $resultat['cs_nom'],
'ville' => $resultat['cs_ville']);
$donnees['infos'][$structure_id]['structure'] = $structure;
}
$collection = array('nom' => $resultat['cc_nom']);
$donnees['infos'][$structure_id]['collections'][] = $collection;
}
// Gestion des squelettes
$this->chargerVue('resultat', $donnees);
$sortie_moteur = $this->chargerMoteurRecherche();
 
// Attribution des morceaux de HTML à la sortie
$sortie['corps'] = $sortie_moteur['corps'].$this->resultat;
return $sortie;
}
}
/trunk/controleurs/Collection.php
New file
0,0 → 1,133
<?php
// declare(encoding='UTF-8');
/**
* Collection est le controlleur principal de l'application.
* Elle repartie les demandes utilisateurs dans les différents modules, executent les actions et redistribue le code
* html dans les différentes fonctions d'affichage.
* C'est une Singleton.
*
* @category PHP5
* @package Collection
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
* @copyright 2010 Tela-Botanica
* @license GPL-v3 et CECILL-v2
* @version SVN:<svn_id>
*/
 
class Collection {
/**
* Instance de la classe pointant sur elle même (pour le pattern singleton)
*/
private static $instance = null;
/**
* Paramètres pour les collections
*/
private static $parametres = array();
/**
* Constructeur vide
*/
private function __construct() {
$meta = array('titre' => '', 'description' => '', 'tags' => '');
$sortie = array('metadonnees' => $meta, 'corps' => '', 'tete' => '', 'pied' => '', 'navigation' => '');
$url = new Url(Config::get('url_base'));
self::$parametres = array( 'module' => 'Recherche',
'action' => 'executerActionParDefaut',
'sortie' => $sortie,
'url' => $url);
}
/**
* Initialisation du controleur principal en fonction des paramêtres de l'url.
*/
public static function initialiser() {
self::verifierCreationInstance();
if (isset($_GET['module'])) {
self::$parametres['module'] = $_GET['module'];
}
self::$parametres['url']->setVariableRequete('module', self::$parametres['module']);
if (isset($_GET['action'])) {
self::$parametres['action'] = $_GET['action'];
}
self::$parametres['url']->setVariableRequete('action', self::$parametres['action']);
$registre = Registre::getInstance();
$registre->set('parametres', &self::$parametres);
$ClasseModule = self::$parametres['module'];
$action = self::$parametres['action'];
$module = new $ClasseModule();
self::fusionnerSortie($module->$action());
}
/**
* Fusionne un tableau de sortie par défaut avec le tableau renvoyé par l'action du module.
* @param array le tableau à fusionner
*/
private static function fusionnerSortie($sortie) {
self::$parametres['sortie'] = array_merge(self::$parametres['sortie'], $sortie);
}
/**
* Vérifie si l'instance de classe à été crée, si non la crée.
*/
private static function verifierCreationInstance() {
if (empty(self::$instance)) {
self::$instance = new Collection();
}
}
/**
* Retourne le titre du contenu de l'application.
*/
public static function getMetaTitre() {
return self::$parametres['sortie']['metadonnees']['titre'];
}
/**
* Retourne la description du contenu de l'application.
*/
public static function getMetaDescription() {
return self::$parametres['sortie']['metadonnees']['description'];
}
/**
* Retourne les mots-clés (tags) du contenu de l'application.
*/
public static function getMetaTags() {
return self::$parametres['sortie']['metadonnees']['tags'];
}
/**
* Retourne le contenu du corps de l'application.
*/
public static function getContenuCorps() {
return self::$parametres['sortie']['corps'];
}
/**
* Retourne le contenu de la tête de l'application.
*/
public static function getContenuTete() {
return self::$parametres['sortie']['tete'];
}
/**
* Retourne le contenu du pied de l'application.
*/
public static function getContenuPied() {
return self::$parametres['sortie']['pied'];
}
/**
* Retourne les éléments de navigation de l'application.
*/
public static function getContenuNavigation() {
return self::$parametres['sortie']['navigation'];
}
}