Subversion Repositories Applications.annuaire

Rev

Rev 4 | Rev 7 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
/**
* PHP Version 5
*
* @category  PHP
* @package   annuaire
* @author    aurelien <aurelien@tela-botanica.org>
* @copyright 2010 Tela-Botanica
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
* @version   SVN: <svn_id>
* @link      /doc/annuaire/
*/

class OntologieControleur extends Controleur {

        /**
         * (fonction héritée de la classe Controleur)
         * Avant chaque chargement de vue, on ajoute l'url de la page dans
         * les variables à insérer.
         * @param Array $donnes les données à insérer dans la vue
         * @return Array $donnees les données modifiées
         */
        public function preTraiterDonnees($donnees) {
                $donnees['base_url'] = Registre::getInstance()->get('base_url_application');
                return $donnees;
        }

/**--------Fonctions de gestion des ontologies --------------------------------*/

        /**
         * charge et renvoie la vue contenant la liste des listes
         * @return string le html contenant la liste des listes
         */
        public function chargerListeListe() {

                $this->chargerModele('OntologieModele');
                $data['ontologie'] = $this->OntologieModele->chargerListeListes();
                $data['titre'] = 'Liste des listes';
                $this->chargerVue('liste_des_listes', $data);

                return $this->liste_des_listes;
        }

        /**
         * charge et renvoie la vue contenant la liste ontologie et ses éléments dont l'identifiant est passé en paramètre
         * @param int $identifiant l'identifiant de la liste d'ontologie
         * @return string le html contenant la liste et ses éléments
         */
        public function chargerListeOntologie($identifiant) {

                $this->chargerModele('OntologieModele');

                // On charge les informations de la liste (nom description etc...)
                $data['informations'] =  $this->OntologieModele->chargerInformationsOntologie($identifiant);
                $data['ontologie'] = $this->OntologieModele->chargerListeOntologie($identifiant);

                $this->chargerVue('liste_ontologie', $data);

                return $this->liste_ontologie;
        }

        /**
         * Affiche le formulaire d'ajout de liste ontologie
         * @param Array $valeurs un tableau de valeurs (dans le cas du retour erreur)
         * @return string le formulaire de liste d'ontologie
         */
        public function afficherFormulaireAjoutListeOntologie($valeurs) {

                if(!isset($valeurs['amo_nom'])) {
                        $valeurs['amo_nom'] = '';
                }

                if(!isset($valeurs['amo_abreviation'])) {
                                $valeurs['amo_abreviation'] = '';
                }

                if(!isset($valeurs['amo_description'])) {
                                $valeurs['amo_description'] = '';
                }

                if(!isset($valeurs['amo_ce_parent'])) {
                                $valeurs['amo_ce_parent'] = '';
                }

                $this->chargerVue('liste_ontologie_ajout', $valeurs);
                return $this->liste_ontologie_ajout;
        }

        /**
         * Affiche le formulaire de modification de liste ontologie
         * @param Array un tableau de valeurs contenant l'id de la liste (et les élements pour le retour erreur)
         * @return string le formulaire de modification ou la liste des liste si l'id est invalide
         */
        public function afficherFormulaireModificationListeOntologie($id_ontologie) {

                if(trim($id_ontologie) != '') {
                        $this->chargerModele('OntologieModele');
                        $data['valeurs'] = $this->OntologieModele->chargerInformationsOntologie($id_ontologie);
                        $this->chargerVue('liste_ontologie_modification', $data);
                        return $this->liste_ontologie_modification;
                } else {
                        return $this->chargerListeListe();
                }
        }

        /**
         * Ajoute une nouvelle liste d'ontologie
         * @param Array $valeurs les valeurs à ajouter
         * @return string la vue contenant la liste des liste, ou bien le formulaire d'ajout en cas d'erreur
         */
        public function ajouterNouvelleListeOntologie($valeurs) {

                // TODO faire une vérification plus complète du formulaire
                if(isset($valeurs['amo_nom'])
                        && isset($valeurs['amo_abreviation'])
                        && isset($valeurs['amo_description'])
                        && isset($valeurs['amo_ce_parent'])) {
                        $this->chargerModele('OntologieModele');
                        $this->OntologieModele->ajouterNouvelleListeOntologie($valeurs);
                } else  {
                        return $this->afficherFormulaireAjoutListeOntologie($valeurs);
                }
                return $this->chargerListeListe();
        }

        /**
         * Affiche le formulaire d'ajout ou de modification de liste ontologie
         * @param Array $valeurs les valeurs à modifier
         * @return String la vue contenant liste des liste, ou le formulaire de modification si erreur
         */
        public function modifierListeOntologie($valeurs) {

                if(isset($valeurs['amo_nom']) &&isset($valeurs['amo_abreviation']) && isset($valeurs['amo_description'])) {
                        $this->chargerModele('OntologieModele');
                        $this->OntologieModele->modifierListeOntologie($valeurs);
                } else  {
                        // TODO: afficher une erreur si la modification n'a pas fonctionné
                        return $this->afficherFormulaireListeOntologie($valeurs, true);
                }

                return $this->chargerListeListe();
        }

        /**
         * Supprime une liste d'ontologie
         * @param int $id_ontologie l'identifant de la liste à supprimer
         * @return string la vue contenant la liste des listes
         */
        public function supprimerListeOntologie($id_ontologie) {

                if(trim($id_ontologie) != '') {
                        $this->chargerModele('OntologieModele');
                        $this->OntologieModele->supprimerListeOntologie($id_ontologie);
                } else  {
                        // TODO: afficher une erreur si la suppression n'a pas fonctionné
                        return $this->chargerListeListe();
                }
                return $this->chargerListeListe();
        }
}
?>