Subversion Repositories Sites.obs-saisons.fr

Compare Revisions

Ignore whitespace Rev 30 → Rev 31

/trunk/applications/saisie/controleurs/Station.php
New file
0,0 → 1,182
<?php
// declare(encoding='UTF-8');
/**
* Classe de test des Controleurs.
*
* @package Collection
* @category Php 5.2
* @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: Fiche.php 152 2010-09-06 16:19:12Z jpm $
*/
class Station extends aControleur {
 
private $id_station_en_cours = null;
public function __construct() {
parent::__construct();
$this->initialiser();
}
public function initialiser() {
$this->id_station_en_cours = $_GET['id_station'];
$this->setNavigation();
}
public function executerActionParDefaut() {
return $this->afficherFormulaireSaisieStation();
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES D'AFFICHAGE DE FORMULAIRE
public function afficherFormulaireSaisieStation() {
$donnees = array();
$formulaire = $this->getVue('formulaires/station_saisie',$donnees);
$this->setSortie(self::RENDU_CORPS, $formulaire);
}
public function afficherFormulaireModificationStation() {
$donnees = array();
$id_station = $this->id_station_en_cours;
$donnees['infos_station'] = $this->getInformationsStation($id_station);
$formulaire = $this->getVue('formulaires/station_modification',$donnees);
$this->setSortie(self::RENDU_CORPS, $formulaire);
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES APPELEES LORS DE LA VALIDATION D'UN FORMULAIRE
public function validerFormulaireSaisieStation() {
$valeurs_formulaires = $_POST['form_saisie_station'];
$valeurs_verifiees = $this->collecterValeursFormulaireSaisieStation();
$station_dao = new StationDao();
$station_dao->ajouterStation($valeurs_verifiees);
}
private function collecterValeursFormulaireSaisieStation() {
$valeurs_verifiees['station_commune'] = $_POST['station_commune'];
$valeurs_verifiees['station_milieu'] = $_POST['station_milieu'];
$valeurs_verifiees['station_nom'] = $_POST['station_nom'];
$valeurs_verifiees['station_lat'] = $_POST['station_lat'];
$valeurs_verifiees['station_lon'] = $_POST['station_lon'];
//TODO: verifier valeurs plus complètement
return $valeurs_verifiees;
}
public function validerFormulaireModificationStation() {
$valeurs_formulaires = $_POST['form_modif_station'];
$valeurs_verifiees = array();
$station_dao = new StationDao();
$station_dao->modifierStation($valeurs_verifiees);
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES D'AFFICHAGES D'INFORMATION
public function afficherlisteStation($param = null) {
$id_utilisateur = AppControleur::getIdUtilisateur();
$donnees['stations'] = $this->getListeStations($id_utilisateur);
$this->setSortie(self::RENDU_CORPS, $this->getVue('listes/station_liste', $donnees));
}
public function afficherInformationsStation() {
$id_station = $this->id_station_en_cours;
$donnees['id_station'] = $id_station;
$donnees['infos_station'] = $this->getInformationsStation($id_station);
$this->setSortie(self::RENDU_CORPS, $this->getVue('fiches/station_fiche', $donnees));
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES POUR FABRIQUER LE MENU
public function construireMenuNavigation($espece_en_cours = null) {
$id_station_en_cours = $this->id_station_en_cours;
$stations = $this->getListeStations();
foreach($stations as &$station) {
$station['url'] = aControleur::getUrlConsultationFicheStation($station['id']);
}
if($id_station_en_cours != null) {
$especes_station_en_cours = $this->getEspecesStation($id_station_en_cours);
foreach($especes_station_en_cours as &$espece) {
$espece['url'] = aControleur::getUrlConsultationEspeceStation($id_station_en_cours, $espece['id']);
}
$stations[$id_station_en_cours]['especes'] = $especes_station_en_cours;
}
$donnees['stations'] = $stations;
$donnees['id_station_en_cours'] = $id_station_en_cours;
if($id_espece_en_cours != null) {
$donnees['id_espece_en_cours'] = $id_espece;
}
$menu_navigation = $this->getVue('navigation/menu', $donnees);
return $menu_navigation;
}
public function setNavigation() {
$this->setSortie(self::RENDU_NAVIGATION, $this->construireMenuNavigation());
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODE D'APPELS AUX DAOS
protected function getListeStations() {
$station_dao = new StationDao();
return $station_dao->getListeStations();
}
private function getInformationsStation($id_station) {
$station_dao = new StationDao();
$infos_station = $station_dao->getInformationsStation($id_station);
$infos_station['individus'] = $this->getIndividusStation($id_station);
return $infos_station;
}
private function getEspecesStation($id_station) {
$espece_dao = new EspeceDao();
$liste_especes = $espece_dao->getListeEspecesPourStation($id_station);
return $liste_especes;
}
public function getIndividusStation($id_station) {
$individu_dao = new IndividuDao();
$liste_individus = $individu_dao->getListeIndividusPourStation($id_station);
return $liste_individus;
}
}
/trunk/applications/saisie/controleurs/DrupalUtilisateur.php
New file
0,0 → 1,28
<?php
class DrupalUtilisateur extends Utilisateur {
public function getIdentifiantNumerique() {
return $GLOBALS['user']->uid;
}
public function getEmail() {
return $GLOBALS['user']-mail;
}
public function getNom() {
return $GLOBALS['user']->name;
}
public function getPrenom() {
return '';
}
public function estAdmin() {
return in_array('3',array_keys($GLOBALS['user']->roles));
}
public function estIdentifie() {
return in_array('2',array_keys($GLOBALS['user']->roles));
}
}
?>
/trunk/applications/saisie/controleurs/Espece.php
New file
0,0 → 1,59
<?php
// declare(encoding='UTF-8');
/**
* Classe de gestion des epeces.
*
* @package Collection
* @category Php 5.2
* @author Aurélien PERONNET <aurelien@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: Espece.php 152 2010-09-06 16:19:12Z jpm $
*/
class Espece extends aControleur {
private $id_espece_en_cours = null;
public function __construct() {
parent::__construct();
$this->initialiser();
}
public function initialiser() {
$this->id_espece_en_cours = $_GET['$id_espece'];
$this->setNavigation();
}
private function setNavigation() {
$station = new Station();
$this->setSortie(self::RENDU_NAVIGATION, $station->construireMenuNavigation());
}
public function executerActionParDefaut() {
return $this->afficherFormulaireSaisieIndividu();
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES D'AFFICHAGE DE FORMULAIRE
public function afficherFormulaireSaisieEspece() {
$donnees = array();
$espece_dao = new EspeceDao();
$donnees['types'] = $espece_dao->getListeEspecesParType();
$formulaire = $this->getVue('formulaires/espece_saisie',$donnees);
$this->setSortie(self::RENDU_CORPS, $formulaire);
}
public function getListeEvenementPourEspece($id_espece) {
$evenementDao = new EvenementDao();
$liste_evenements = $evenementDao->getListeEvenementPourEspece($id_espece);
return $liste_evenements;
}
}
/trunk/applications/saisie/controleurs/Evenement.php
New file
0,0 → 1,3
<?php
 
?>
/trunk/applications/saisie/controleurs/Utilisateur.php
New file
0,0 → 1,24
<?php
abstract class Utilisateur extends aControleur {
public function getIdentifiantNumerique() {
return 0;
}
public function getEmail() {
return '';
}
public function getNom() {
return '';
}
public function getPrenom() {
return '';
}
public function estAdmin() {
return false;
}
}
?>
/trunk/applications/saisie/controleurs/Individu.php
New file
0,0 → 1,101
<?php
// declare(encoding='UTF-8');
/**
* Classe de test des Controleurs.
*
* @package Collection
* @category Php 5.2
* @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: Fiche.php 152 2010-09-06 16:19:12Z jpm $
*/
class Individu extends aControleur {
private $id_individu_en_cours = null;
public function __construct() {
parent::__construct();
$this->initialiser();
}
public function initialiser() {
$this->id_individu_en_cours = $_GET['id_individu'];
$this->setNavigation();
}
public function executerActionParDefaut() {
return $this->afficherFormulaireAjoutIndividu();
}
public function afficherFormulaireAjoutIndividu() {
$donnees = array();
$formulaire = $this->getVue('formulaires/individu_saisie',$donnees);
$this->setSortie(self::RENDU_CORPS, $formulaire);
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES GENERIQUES
public function afficherListeIndividu($id_espece) {
$id_utilisateur = AppControleur::getUtilisateur()->getIdentifiantNumerique();
$espece = new Espece();
$evenements = $espece->getListeEvenementPourEspece($id_espece);
$individus = $this->getListeIndividus($id_utilisateur);
foreach($individus as &$individu) {
$observation = new Observation();
$individu['observations'] = $observation->getListeObservationsPourIndividu($individu['id']);
$individu['url'] = aControleur::getUrlConsultationFicheIndividu($individu['id'],$individu['id']);
}
 
$donnees['evenements'] = $evenements;
$donnees['individus'] = $individus;
$donnees['id_station'] = $_GET['id_station'];
$donnees['id_espece'] = $_GET['id_espece'];
 
$this->setSortie(self::RENDU_CORPS, $this->getVue('listes/evenement_liste', $donnees));
}
public function afficherInformationsIndividu() {
$id_individu = $this->id_individu_en_cours;
$id_espece = $_GET['id_individu'];
$donnees['infos_individu'] = $this->getInformationsIndividu($id_individu);
$espece_dao = new EspeceDao();
$donnees['infos_espece'] = $espece_dao->getInformationsEspece($id_espece);
$this->setSortie(self::RENDU_CORPS, $this->getVue('fiches/individu_fiche', $donnees));
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES POUR FABRIQUER LE MENU
public function setNavigation() {
$station = new Station();
$this->setSortie(self::RENDU_NAVIGATION, $station->construireMenuNavigation());
}
protected function getListeIndividus($id_utilisateur) {
$individu_dao = new IndividuDao();
return $individu_dao->getListeIndividusPourStation($id_utilisateur);
}
private function getInformationsIndividu($id_individu) {
$individu_dao = new IndividuDao();
$infos_individu = $individu_dao->getInformationsIndividu($id_individu);
return $infos_individu;
}
}
/trunk/applications/saisie/controleurs/Observation.php
New file
0,0 → 1,105
<?php
// declare(encoding='UTF-8');
/**
* Classe de gestion des observations.
*
* @package ODS_saisie
* @category Php 5.2
* @author Aurélien Peronnet <aurelien@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: Fiche.php 152 2010-09-06 16:19:12Z jpm $
*/
class Observation extends aControleur {
private $id_observation_en_cours = null;
public function __construct() {
parent::__construct();
$this->initialiser();
}
public function initialiser() {
$this->id_observation_en_cours = $_GET['id_observation'];
}
public function executerActionParDefaut() {
return $this->afficherFormulaireAjoutIndividu();
}
public function afficherFormulaireAjoutObservation($id_individu) {
$donnees = array();
$formulaire = $this->getVue('formulaires/observation_saisie',$donnees);
$this->setSortie(self::RENDU_CORPS, $formulaire);
}
public function afficherFormulaireModificationObservation() {
$id_individu_a_modifier_observation = $_GET['id_individu'];
$id_espece = $_GET['id_espece'];
$id_station = $_GET['id_station'];
$id_utilisateur = AppControleur::getUtilisateur()->getIdentifiantNumerique();
$espece = new Espece();
$evenements = $espece->getListeEvenementPourEspece($id_espece);
$station = new Station();
$individus = $station->getIndividusStation($id_station);
foreach($individus as &$individu) {
$observation = new Observation();
$individu['observations'] = $observation->getListeObservationsPourIndividu($individu['id']);
$individu['url'] = aControleur::getUrlConsultationFicheIndividu($individu['id'],$individu['id']);
}
echo $id_individu_a_modifier_observation;
 
$donnees['evenements'] = $evenements;
$donnees['individus'] = $individus;
$donnees['id_station'] = $_GET['id_station'];
$donnees['id_espece'] = $_GET['id_espece'];
$donnees['id_individu_a_modifier_observation'] = $id_individu_a_modifier_observation;
 
$this->setSortie(self::RENDU_CORPS, $this->getVue('formulaires/evenement_modification', $donnees));
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES APPELEES LORS DE LA VALIDATION D'UN FORMULAIRE
public function validerFormulaireAjoutObservation() {
$valeurs_formulaires = $_POST['form_saisie_observation'];
$valeurs_verifiees = array();
$observation_dao = new ObservationDao();
$observation_dao->ajouterObservation($valeurs_verifiees);
}
public function validerFormulaireModificationObservation() {
$valeurs_formulaires = $_POST['form_modif_observation'];
$valeurs_verifiees = array();
$observation_dao = new ObservationDao();
$observation_dao->modifierObservation($valeurs_verifiees);
}
// +---------------------------------------------------------------------------------------------------------------+
// METHODES DE RECHERCHE DE DONNEES
public function getListeObservationsPourIndividu($id_individu, $annee = null) {
$observation_dao = new ObservationDao();
$observations_pour_individu = $observation_dao->getListeObservationsPourIndividu($id_individu, $annee);
return $observations_pour_individu;
}
}
/trunk/applications/saisie/controleurs/AppControleur.php
New file
0,0 → 1,232
<?php
// declare(encoding='UTF-8');
/**
* Classe mère des controleurs 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 PHP 5.2
* @package saisie
* @author Aurélien Peronnet <aurelien@tela-botanica.org>
* @copyright 2010 Tela-Botanica
* @license GPL-v3 et CECILL-v2
* @version $Id: AppControleur.php 160 2010-09-13 13:10:41Z aurelien $
*/
 
class AppControleur extends Controleur {
/**
* Instance de la classe pointant sur elle même (pour le pattern singleton)
*/
private static $instance = null;
/**
* Instance de l'utilisateur en cours
*/
private static $utilisateur = null;
/**
* Paramètres
*/
private static $parametres = array();
/**
* Constructeur vide
*/
public function __construct() {
$sortie = array('titre' => '', 'description' => '', 'tags' => '',
'corps' => '', 'tete' => '', 'pied' => '', 'navigation' => '');
$url = new Url(Config::get('url_base_index'));
self::$parametres = array( 'module' => 'Station',
'action' => 'executerActionParDefaut',
'sortie' => $sortie,
'url' => $url);
parent::__construct();
}
/**
* Initialisation du controleur principal en fonction des paramètres de l'url.
*/
public static function initialiser() {
self::verifierCreationInstance();
self::gererSession();
self::gererUtilisateur();
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();
$module->$action();
self::fusionnerSortie($module->getSortie());
}
private static function gererSession() {
if (Config::get('session_demarrage')) {
// Attribution d'un nom à la session
session_name(Config::get('session_nom'));
// Démarrage de la session
session_start();
}
}
private static function gererUtilisateur() {
$classe_utilisateur = Config::get('objet_utilisateur');
if(!class_exists($classe_utilisateur)) {
trigger_error('Aucune classe n\'a été définie pour gérer les utilisateurs', E_USER_ERROR);
}
self::$utilisateur = new $classe_utilisateur();
}
public static function getUtilisateur() {
if(self::$utilisateur == null) {
self::gererUtilisateur();
}
return self::$utilisateur;
}
public static function getIdUtilisateur() {
return self::getUtilisateur()->getIdentifiantNumerique();
}
/**
* 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 AppControleur();
}
}
public static function getInstance() {
self::verifierCreationInstance();
return self::$instance;
}
/**
* Retourne le titre du contenu de l'application.
*/
public static function getMetaTitre() {
$sortie = self::$parametres['sortie']['titre'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne la description du contenu de l'application.
*/
public static function getMetaDescription() {
$sortie = self::$parametres['sortie']['description'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne les mots-clés (tags) du contenu de l'application.
*/
public static function getMetaTags() {
$sortie = self::$parametres['sortie']['tags'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne le contenu du corps de l'application.
*/
public static function getContenuCorps() {
$sortie = self::$parametres['sortie']['corps'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne le contenu de la tête de l'application.
*/
public static function getContenuTete() {
$sortie = self::$parametres['sortie']['tete'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne le contenu du pied de l'application.
*/
public static function getContenuPied() {
$sortie = self::$parametres['sortie']['pied'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne les éléments de navigation de l'application.
*/
public static function getContenuNavigation() {
$sortie = self::$parametres['sortie']['navigation'];
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne les chronos pris dans l'appli
*/
public static function getChrono() {
$sortie = '';
if (Config::get('chronometrage')) {
$chrono = Chronometre::afficherChrono();
$sortie = mb_convert_encoding($chrono, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
/**
* Retourne les messages d'exceptions et d'erreurs.
*/
public static function getExceptions() {
$sortie = (Config::get('fw_debogage')) ? GestionnaireException::getExceptions() : '';
if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
$sortie = mb_convert_encoding($sortie, Config::get('sortie_encodage'), Config::get('appli_encodage'));
}
return $sortie;
}
}
/trunk/applications/saisie/controleurs/aControleur.php
New file
0,0 → 1,272
<?php
// declare(encoding='UTF-8');
/**
* Classe Controleur générale de l'application saisie.
*
* @category php5.2
* @package saisie
* @author Aurélien Peronnet <aurelien@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: aControleur.php 152 2010-09-06 16:19:12Z aurelien $
*/
abstract class aControleur extends Controleur {
const FMT_DATE = '%d/%m/%Y';// Supporte les formats de dates non valides (1989-00-00)
const FMT_DATE_TXT = '%A %d %B %Y';
const FMT_DATE_HEURE = '%d/%m/%Y %H:%i:%s';// Supporte les formats de dates non valides (1989-00-00 00:00:00)
const FMT_DATE_HEURE_TXT = '%A %d %B %Yà%H:%M';
const META_TITRE = 'titre';
const META_DESCRIPTION = 'description';
const META_TAGS = 'tags';
const RENDU_TETE = 'tete';
const RENDU_CORPS = 'corps';
const RENDU_PIED = 'pied';
const RENDU_NAVIGATION = 'navigation';
const TYPE_AUTRE = 'AUTRE';
const TYPE_TOTAL = 'TOTAL';
const SEPARATEUR_TYPE_VALEUR = '##';
const SEPARATEUR_VALEURS = ';;';
const SEPARATEUR_DONNEES = '||';
const VALEUR_NULL = 'NC';
private $sortie = array();
private $parametres = array();
protected static $hierarchie_appels = array();
// FIXME : voir s'il est plus intéressant d'utiliser une méthode dans les classes filles
protected $url = null;
public function __construct() {
$registre = Registre::getInstance();
$this->parametres = $registre->get('parametres');
$this->url = $this->parametres['url'];
parent::__construct();
}
/**
* Attribue une position de sortie à un contenu.
*/
protected function setSortie($position, $contenu, $fusionner = false) {
if ($this->verifierExistenceTypeSortie($position)) {
if ($fusionner) {
$this->sortie[$position] .= $contenu;
} else {
$this->sortie[$position] = $contenu;
}
}
}
/**
* Vérifie l'existence du type de sortie indiqué pour son utilisation dans le tableau de sortie.
* @param string le type de sortie à tester.
* @return bool true si le type de sortie est valide, sinon false.
*/
private function verifierExistenceTypeSortie($type) {
$existe = true;
if ($type != self::RENDU_TETE &&
$type != self::RENDU_NAVIGATION &&
$type != self::RENDU_CORPS &&
$type != self::RENDU_PIED &&
$type != self::META_TITRE &&
$type != self::META_DESCRIPTION &&
$type != self::META_TAGS) {
trigger_error("Le type de sortie '$type' n'est pas une valeur prédéfinie.", E_USER_WARNING);
$existe = false;
}
return $existe;
}
/**
* Retourne le tableau de sortie à utiliser dans le controleur principal de l'application.
*/
public function getSortie() {
return $this->sortie;
}
 
/**
* Execute l'action d'un module donnée et fusionne le résultat avec le tableau de sortie.
*/
protected function executerAction($ClasseModule, $action) {
$module = new $ClasseModule();
$module->$action();
$this->fusionnerSortie($module->getSortie());
}
/**
* Fusionne un tableau de sortie par défaut avec le tableau passé en paramètre.
* @param array le tableauàfusionner
*/
private function fusionnerSortie($sortie) {
$this->sortie = array_merge($this->sortie, $sortie);
}
protected function formaterParenthese($chaine_a_afficher) {
if ($chaine_a_afficher != '') {
$chaine_a_afficher = '('.$chaine_a_afficher.')';
}
return $chaine_a_afficher;
}
protected function formaterSautDeLigne($chaine_a_formater) {
$txt_a_retourner = preg_replace('/\n/', '<br />', $chaine_a_formater);
return $txt_a_retourner;
}
protected function formaterTableauDeTxt($tableau_de_txt, $majuscule = true, $point_final = true) {
$chaine_a_afficher = '';
$taille_du_tableau = count($tableau_de_txt);
if ($taille_du_tableau > 0) {
$index_avt_dernier = $taille_du_tableau - 1;
for ($i = 0; $i < $taille_du_tableau; $i++) {
$mot = $tableau_de_txt[$i];
if ($i != $index_avt_dernier) {
$chaine_a_afficher .= $mot.', ';
} else {
$chaine_a_afficher .= $this->nettoyerPointFinal($mot);
if ($point_final) {
$chaine_a_afficher .= '.';
}
}
}
}
if ($majuscule) {
$chaine_a_afficher = ucfirst($chaine_a_afficher);
}
return $chaine_a_afficher;
}
protected function formaterOuiNon($chaine_a_formater) {
$txt_a_retourner = '';
if ($chaine_a_formater == '0') {
$txt_a_retourner = 'non';
} else if ($chaine_a_formater == '1') {
$txt_a_retourner = 'oui';
}
return $txt_a_retourner;
}
protected function formaterDate($date, $format = self::FMT_DATE_HEURE) {
if ($date == '' || $date == '0000-00-00' || $date == '0000-00-00 00:00:00') {
$date = 'Inconnue';
} else {
if (preg_match('/^([0-9]{4})-([0-9]{2})-([0-9]{2})(?: ([0-9]{2}):([0-9]{2}):([0-9]{2})|)$/', $date, $match)) {// Date Heure
$annee = $match[1];
$mois = $match[2];
$jour = $match[3];
$heure = (isset($match[4])) ? $match[4] : '00';
$minute = (isset($match[5])) ? $match[5] : '00';
$seconde = (isset($match[6])) ? $match[6] : '00';
if ($format == self::FMT_DATE && $jour == '00' && $mois == '00') {
$date = $annee;
} else if ($format == self::FMT_DATE && $jour == '00') {
$date = strftime('%b', mktime(0, 0, 0, $mois, 1)).' '.$annee;
} else {
$timestamp = strtotime($date);
if ($timestamp !== false) {
$date = strftime($format, $timestamp);
}
}
} else {
$e = "La chaine '$date' n'est pas reconnue.";
trigger_error($e, E_USER_WARNING);
}
}
return $date;
}
protected function formaterCourriels($courriels) {
$fmt_courriels = '';
if (!empty($courriels)) {
$courriels = (is_array($courriels)) ? $courriels : array($courriels);
foreach ($courriels as $cle => $courriel) {
$courriel = preg_replace('/@/', ' [arrobase] ', $courriel);
$courriel = preg_replace('/[.]([^.]+)$/', " [point] $1", $courriel);
$fmt_courriels[] = $this->getVue('courriel', array('courriel' => $courriel));
}
$fmt_courriels = implode(', ', $fmt_courriels);
}
return $fmt_courriels;
}
protected function nettoyerPointFinal($mot) {
$mot = preg_replace('/[.]$/', '', $mot);
return $mot;
}
protected function postraiterDonnees(&$tableau) {
if (count($tableau) > 0) {
foreach ($tableau as $cle => &$valeur) {
if ($valeur == '') {
$valeur = '&nbsp;';
} else if (is_string($valeur)) {
$valeur = $this->remplacerEsperluette($valeur);
} else if (is_array($valeur)) {
$this->postraiterDonnees($valeur);
}
}
}
}
private function remplacerEsperluette($txt) {
$txt = preg_replace('/&(?!([a-z]+|#[0-9]+|#x[0-9a-f]+);)/i', '&amp;', $txt, -1);
return $txt;
}
protected function chargerPiedDePage() {
$donnees['appli'] = Application::getInfo();
$this->setSortie(self::RENDU_PIED, $this->getVue('pied', $donnees));
}
public static function getUrlConsultationFicheStation($id_station) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Station&action=afficherInformationsStation&id_station='.$id_station;
}
public static function getUrlFormulaireSaisieStation() {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Station&action=afficherFormulaireSaisieStation';
}
public static function getUrlValidationFormulaireSaisieStation() {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Station&action=validerFormulaireSaisieStation';
}
public static function getUrlFormulaireModificationStation($id_station) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Station&action=afficherFormulaireModificationStation&id_station='.$id_station;
}
public static function getUrlConsultationFicheIndividu($id_station, $id_individu) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Individu&action=afficherInformationsIndividu&id_station='.$id_station.'&id_individu='.$id_individu;
}
public static function getUrlFormulaireAjoutIndividu($id_station, $id_espece) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Individu&action=afficherFormulaireAjoutIndividu&id_station='.$id_station.'&id_espece='.$id_espece;
}
public static function getUrlConsultationEspeceStation($id_station, $id_espece) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Individu&action=afficherListeIndividu&id_station='.$id_station.'&id_espece='.$id_espece;
}
 
public static function getUrlFormulaireAjoutEspece($id_station) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Espece&action=afficherFormulaireSaisieEspece&id_station='.$id_station;
}
public static function getUrlFormulaireModificationObservation($id_individu) {
// TODO: gérer les urls comme dans l'annuaire
return '?module=Observation&action=afficherFormulaireModificationObservation&id_individu='.$id_individu;
}
}