Subversion Repositories eFlore/Applications.coel-consultation

Rev

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

<?php
// declare(encoding='UTF-8');
/**
 * Classe Controleur du module Fiche Collection.
 *
 * @category    Php 5.2
 * @package             Collection
 * @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 96 2010-06-21 16:46:31Z jpm $
 */
class FicheCollection extends Fiche {
        
        //+----------------------------------------------------------------------------------------------------------------+
        // Méthodes
        /**
         * Fonction d'affichage par défaut
         */
        public function executerActionParDefaut() {
                return $this->afficherCollection();
        }
        
        // +---------------------------------------------------------------------------------------------------------------+
        // FICHE COLLECTION
        public function afficherCollection() {
                $donnees = array();

                // Gestion des actions par défaut
                $this->executerAction('Recherche', 'chargerMoteurRecherche');
                
                // Gestion des données de la requête
                if (!isset($_GET['id'])) {
                        
                } else {
                        // Récupération des données
                        $donnees['id'] = $_GET['id'];
                        $collectionDao = $this->getModele('CollectionDao');
                        $donnees['info'] = $collectionDao->getCollection($donnees['id']);
                        $donnees['personnes'] = $collectionDao->getCollectionAPersonne($donnees['id']);
                        $donnees['publications'] = $collectionDao->getCollectionAPublication($donnees['id']);
                        $donnees['commentaires'] = $collectionDao->getCollectionACommentaire($donnees['id']);
                        
                        // Traitements des données
                        $this->traiterDonneesCollection($donnees['info']);
                        $this->traiterDonneesCollectionAPersonne($donnees['personnes']);
                        $this->traiterDonneesElementAPublication($donnees['publications']);
                        $this->traiterDonneesCollectionDescription($donnees['info']);
                        $this->traiterDonneesCollectionContenu($donnees['info']);
                        $this->traiterDonneesCollectionInventaire($donnees['info']);
                        $this->traiterDonneesCollectionACommentaire($donnees['commentaires']);
                        $this->postraiterDonnees($donnees);
                        $donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
                        
                        // Création des méta-données de la page
                        $titre = $donnees['info']['cc_nom'];
                        $description = $donnees['info']['cc_description'];
                        $tags = "Collection, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
                        
                        // Envoie à la sortie
                        //Debug::printr($donnees);
                        $this->setSortie(self::META_TITRE, $titre);
                        $this->setSortie(self::META_DESCRIPTION, $description);
                        $this->setSortie(self::META_TAGS, $tags);
                        $this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_collection', $donnees));
                        $this->chargerPiedDePage();
                }
        }

        private function traiterDonneesCollection(&$donnees) {
                // liste 29 : Liste des types de collection dans le standard NCD
                Ontologie::chargerListe(1032);
                // liste 30 : Liste des types de dépôt de collection
                Ontologie::chargerListe(1033);
                // liste 31 : Liste des principes de groupement d'une collection dans le standard NCD
                Ontologie::chargerListe(1034);
                // liste 32 : Liste des buts de réalisation d'une collection dans le standard NCD
                Ontologie::chargerListe(1035);
                // liste 38 : Liste indéterminé/peut-être/oui/non
                Ontologie::chargerListe(1041);
                // liste 39 : Liste des types de classement des spécimens types dans une collection
                Ontologie::chargerListe(1042);
                // liste 79 : Liste exact/approximatif
                Ontologie::chargerListe(1082);
                
                $guid_id_valeur = Config::get('guid_id_collection').$donnees['cc_id_collection'];
                $donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
                $donnees['_structure_url_'] = $this->obtenirUrlFicheStructure($donnees['cc_ce_structure']);
                $donnees['_nom_alternatif_'] = $this->construireTxtTruck($donnees['cc_truk_nom_alternatif']);
                $donnees['_type_ncd_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type']);
                $donnees['_type_depot_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type_depot']);
                $donnees['_identifiant_alternatif_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_identifiant_alternatif']);
                $donnees['_code_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_code']);
                $donnees['_url_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_url']);
                
                $donnees['_specimen_type_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type']);
                $donnees['_specimen_type_nbre_'] = ($donnees['cc_specimen_type_nbre'] == 0) ? '' : $donnees['cc_specimen_type_nbre']; 
                $donnees['_specimen_type_nbre_precision_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_nbre_precision']);
                $donnees['_specimen_type_nbre_precision_'] = $this->formaterParenthese($donnees['_specimen_type_nbre_precision_']);
                $donnees['_specimen_type_classement_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_classement']);
                
                $donnees['_groupement_principe_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_principe']);
                $donnees['_groupement_but_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_but']);
                $donnees['_couverture_lieu_'] = $this->construireTxtTruck($donnees['cc_truk_couverture_lieu']);
        }
        
        private function traiterDonneesCollectionAPersonne(&$personnes) {
                // liste 27 : Liste des relations entre une collection et une personne
                Ontologie::chargerListe(1030);
                // liste 77 : Liste indéterminé/oui/non
                Ontologie::chargerListe(1080);
                
                foreach ($personnes as &$personne) {
                        $personne['_role_'] = $this->construireTxtListeOntologie($personne['ccap_id_role']);
                        $personne['_deces_'] = $this->construireTxtListeOntologie($personne['cp_ce_deces']);
                        $personne['_naissance_date_'] = $this->formaterDate($personne['cp_naissance_date'], aControleur::FMT_DATE);
                        $personne['_deces_date_'] = $this->formaterDate($personne['cp_deces_date'], aControleur::FMT_DATE);
                        $personne['_url_'] = $this->obtenirUrlFichePersonne($personne['ccap_id_personne']);
                }
        }
        
        private function traiterDonneesCollectionDescription(&$donnees) {
                // liste 22 : Liste de traitement anti-insecte pour les collections botaniques
                Ontologie::chargerListe(1025);
                // liste 23 : Liste des poisons utilisés pour les collections botaniques
                Ontologie::chargerListe(1026);
                // liste 38 : Liste indéterminé/peut-être/oui/non
                Ontologie::chargerListe(1041);
                // liste 41 : Liste des types d'unité de rangement pour les collections botaniques
                Ontologie::chargerListe(1044);
                // liste 42 : Liste des états
                Ontologie::chargerListe(1045);
                // liste 43 : Liste des types de support pour les spécimens des collections botaniques
                Ontologie::chargerListe(1046);
                // liste 44 : Liste des types de papier de support pour les spécimens des collections botaniques
                Ontologie::chargerListe(1047);
                // liste 45 : Liste des méthodes de rangement des supports pour les spécimens des collections botaniques
                Ontologie::chargerListe(1048);
                // liste 46 : Liste des méthodes de fixation sur le support pour les collections botaniques
                Ontologie::chargerListe(1049);
                // liste 47 : Liste des méthodes de fixation des étiquettes sur les spécimens pour les collections botaniques
                Ontologie::chargerListe(1050);
                // liste 48 : Liste des types d'écriture d'étiquette
                Ontologie::chargerListe(1051);
                // liste 49 : Liste des origines des dégradations des spécimens de collections botaniques
                Ontologie::chargerListe(1052);
                // liste 50 : Liste des origines des dégradations des supports de collections botaniques
                Ontologie::chargerListe(1053);
                // liste 51 : Liste des niveaux de détermination des spécimens de collections botaniques
                Ontologie::chargerListe(1054);

                $donnees['_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_type']);
                $donnees['_unite_rangement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_unite_rangement_etat']);
                $donnees['_rangements_'] = $this->parserValeurUniteRangement($donnees['ccb_truk_unite_rangement']);
                $donnees['_unites_base_'] = $this->parserValeurUniteBase($donnees['ccb_truk_unite_base']);
                $donnees['_conservation_papier_type_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_papier_type']);
                $donnees['_conservation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_methode']);
                $donnees['_specimen_fixation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_specimen_fixation_methode']);
                $donnees['_etiquette_fixation_support_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_support']);
                $donnees['_etiquette_fixation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_specimen']);
                $donnees['_etiquette_ecriture_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_ecriture']);
                $donnees['_traitement_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_traitement']);
                $donnees['_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_poison']);
                $donnees['_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_insecte']);
                $donnees['_etat_general_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_etat_general']);
                $valeurEstOntologie = false;
                $typeEstOntologie = true;
                $donneeEstOntologie = true;
                $donnees['_degradation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_specimen'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
                $donnees['_degradation_presentation_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_presentation'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
                $donnees['_determination_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_determination']);
                
        }
        
        private function traiterDonneesCollectionContenu(&$donnees) {
                // liste 20 : Liste oui/non/en partie
                Ontologie::chargerListe(1023);
                // liste 37 : Liste des siècles pour les collections naturalistes
                Ontologie::chargerListe(1040);
                // liste 38 : Liste indéterminé/peut-être/oui/non
                Ontologie::chargerListe(1041);
                // liste 42 : Liste des états
                Ontologie::chargerListe(1045);
                // liste 52 : Liste des types de date de début
                Ontologie::chargerListe(1055);
                // liste 53 : Liste des types de date de fin
                Ontologie::chargerListe(1056);
                // liste 80 : Liste des types de collection botanique
                Ontologie::chargerListe(1083);
                
                $donnees['_nature_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_nature']);
                $donnees['_periode_constitution_'] = $this->construireTxtListeOntologie($donnees['cc_truk_periode_constitution']);
                $donnees['_recolte_date_debut_'] = $this->formaterDate($donnees['ccb_recolte_date_debut'], aControleur::FMT_DATE);
                $donnees['_recolte_date_debut_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_debut_type']);
                $donnees['_recolte_date_debut_type_'] = $this->formaterParenthese($donnees['_recolte_date_debut_type_']);
                $donnees['_recolte_date_fin_'] = $this->formaterDate($donnees['ccb_recolte_date_fin'], aControleur::FMT_DATE);
                $donnees['_recolte_date_fin_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_fin_type']);
                $donnees['_recolte_date_fin_type_'] = $this->formaterParenthese($donnees['_recolte_date_fin_type_']);
                $donnees['_classement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_classement_etat']);
                $donnees['_etiquette_renseignement_'] = $this->construireTxtEtiquetteRenseignement($donnees['ccb_truk_etiquette_renseignement']);
                $donnees['_precision_localite_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_localite']);
                $donnees['_precision_date_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_date']);
                $donnees['_collection_integre_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre']);
                $donnees['_collection_integre_info_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre_info']);
        }
        
        private function traiterDonneesCollectionInventaire(&$donnees) {
                // liste 38 : Liste indéterminé/peut-être/oui/non
                Ontologie::chargerListe(1041);
                // liste 57 : Liste indéterminé/parfois/oui/non
                Ontologie::chargerListe(1060);
                // liste 58 : Liste des formes d'inventaire
                Ontologie::chargerListe(1061);
                // liste 59 : Liste des types de logiciel pour les inventaires informatiques
                Ontologie::chargerListe(1062);
                // liste 60 : Liste des états d'inventaire
                Ontologie::chargerListe(1063);
                
                $donnees['_inventaire_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire']);
                $donnees['_inventaire_auteur_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_auteur']);
                $donnees['_inventaire_forme_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_forme']);
                $donnees['_inventaire_digital_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_inventaire_digital']);
                $donnees['_inventaire_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_etat']);
        }
        
        private function traiterDonneesCollectionACommentaire(&$commentaires) {
                // liste 65 : Liste des types de commentaires associés à une collection
                Ontologie::chargerListe(1068);
                
                foreach ($commentaires as &$commentaire) {
                        $commentaire['_type_'] = $this->construireTxtListeOntologie($commentaire['ccac_truk_type']);
                }
        }
        
        private function construireTxtEtiquetteRenseignement($valeur) {
                $etiquetteRenseignements = '';
                $infos = $this->parserEtiquetteRenseignement($valeur);
                if (count($infos) > 0) {
                        foreach ($infos as $cle => $info) {
                                if ($cle == 'AT') {
                                        $etiquetteRenseignements .= 'auteur de la collection';
                                } else if ($cle == 'F') {
                                        $etiquetteRenseignements .= 'famille';
                                } else if ($cle == 'G') {
                                        $etiquetteRenseignements .= 'genre';
                                } else if ($cle == 'SP') {
                                        $etiquetteRenseignements .= 'espèce';
                                } else if ($cle == 'ASP') {
                                        $etiquetteRenseignements .= "auteur de l'espèce";
                                } else if ($cle == 'L') {
                                        $etiquetteRenseignements .= 'localité';
                                } else if ($cle == 'D') {
                                        $etiquetteRenseignements .= 'date de récolte';
                                } else {
                                        $etiquetteRenseignements .= 'Inconnue';
                                }
                                $etiquetteRenseignements .= ': '.$info.'%, ';
                        }
                        $etiquetteRenseignements = rtrim($etiquetteRenseignements, ', ').'.';
                }
                return $etiquetteRenseignements;
        }
        
        private function parserEtiquetteRenseignement($valeurTruk) {
                $infos = array();
                if ($valeurTruk != '') {
                        $pourcentages = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
                        foreach ($pourcentages as $pourcentage) {
                                $pourcentageIdValeur = explode(self::SEPARATEUR_TYPE_VALEUR, $pourcentage);
                                $id = $pourcentageIdValeur[0];
                                $valeur = $pourcentageIdValeur[1];
                                $infos[$id] = $valeur;
                        }
                }
                return $infos;
        }
        
        private function parserValeurUniteBase($valeurTruk) {
                $unitesEnregistrees = array();
                if ($valeurTruk != '') {
                        $unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
                        $unites_nbre = count($unites);
                        for ($i = 0; $i < $unites_nbre; $i++) {
                                $uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
                                $uniteChaineDonnees = $uniteTypeIdDonnees[1];
                                $uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
                                $uniteDonneesNbre = count($uniteDonnees);
                                
                                $uniteBase = array();
                                if ($uniteDonneesNbre > 0) {
                                        $uniteBase['nbre'] = $uniteDonnees[0];
                                }
                                
                                if ($uniteBase['nbre'] > 0) {
                                        if ($uniteDonneesNbre > 1) {
                                                $uniteBase['precision'] = self::getPrecisionNom($uniteDonnees[1]);
                                        }
                                        if ($uniteDonneesNbre > 2) {
                                                $uniteBase['format'] = $uniteDonnees[2];
                                        }
                                        if ($uniteDonneesNbre > 3) {
                                                $uniteBase['part_nbre'] = $uniteDonnees[3];
                                        }
                                        if ($uniteDonneesNbre > 4) {
                                                $uniteBase['part_precision'] = self::getPrecisionNom($uniteDonnees[4]);
                                        }
                                        if ($uniteDonneesNbre > 5) {
                                                $uniteBase['sp_nbre'] = $uniteDonnees[5];
                                        }
                                        if ($uniteDonneesNbre > 6) {
                                                $uniteBase['sp_precision'] = self::getPrecisionNom($uniteDonnees[6]);
                                        }
                                        
                                        if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
                                                $uniteBase['id'] = $uniteTypeIdDonnees[0];
                                                $uniteBase['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
                                        } else {
                                                $uniteBase['type'] = $uniteTypeIdDonnees[0];
                                        }
                                        $unitesEnregistrees[] = $uniteBase;
                                }
                        }
                }
                return $unitesEnregistrees;
        }
        
        private function parserValeurUniteRangement($valeurTruk) {
                $unitesEnregistrees = array();
                if ($valeurTruk != '') {
                        $unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
                        $unites_nbre = count($unites);
                        for ($i = 0; $i < $unites_nbre; $i++) {
                                $uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
                                $uniteChaineDonnees = $uniteTypeIdDonnees[1];
                                $uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
                                $uniteDonneesNbre = count($uniteDonnees);
                                
                                $uniteRangement = array();
                                if ($uniteDonneesNbre > 0) {
                                        $uniteRangement['nbre'] = $uniteDonnees[0];
                                }
                                
                                if ($uniteRangement['nbre'] > 0) {
                                        if ($uniteDonneesNbre > 1) {
                                                $uniteRangement['precision'] = self::getPrecisionNom($uniteDonnees[1]);
                                        }
                                        if ($uniteDonneesNbre > 2) {
                                                $uniteRangement['format'] = $uniteDonnees[2];
                                        }
                                        
                                        if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
                                                $uniteRangement['id'] = $uniteTypeIdDonnees[0];
                                                $uniteRangement['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
                                        } else {
                                                $uniteRangement['type'] = $uniteTypeIdDonnees[0];
                                        }
                                        $unitesEnregistrees[] = $uniteRangement;
                                }
                        }
                }
                return $unitesEnregistrees;
        }
        
        private static function getPrecisionNom($precisionAbr) {
                $precision_nom = '';
                if ($precisionAbr != 'NULL') {
                        // liste 79 : Liste exact/approximatif
                        $precisions = Ontologie::getListeFormatee(1082);
                        foreach ($precisions as $precision) {
                                if ($precision['abreviation'] == $precisionAbr) {
                                        $precision_nom = $precision['nom'];
                                        break;
                                }
                        }
                }
                return $precision_nom;
        }
}