Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 95 | Rev 113 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 95 Rev 96
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Classe Controleur du module Fiche.
4
 * Classe Controleur du module Fiche.
5
 *
5
 *
6
 * @package		Collection
6
 * @package		Collection
7
 * @category	Php 5.2
7
 * @category	Php 5.2
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id: Fiche.php 95 2010-06-21 14:36:04Z jpm $
12
 * @version		SVN: $Id: Fiche.php 96 2010-06-21 16:46:31Z jpm $
13
 */
13
 */
14
class Fiche extends ColControleur {
14
class Fiche extends ColControleur {
15
	
15
	
16
	private $structureDao = null;
16
	private $structureDao = null;
17
	private $collectionDao = null;
17
	private $collectionDao = null;
18
	
18
	
19
	public function __construct()  {
19
	public function __construct()  {
20
		parent::__construct();
20
		parent::__construct();
21
		$this->structureDao = $this->getModele('StructureDao');
21
		$this->structureDao = $this->getModele('StructureDao');
22
		$this->collectionDao = $this->getModele('CollectionDao');
22
		$this->collectionDao = $this->getModele('CollectionDao');
23
	}
23
	}
24
	
24
	
25
	//+----------------------------------------------------------------------------------------------------------------+
25
	//+----------------------------------------------------------------------------------------------------------------+
26
	// Méthodes
26
	// Méthodes
27
	/**
27
	/**
28
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
28
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
29
	 */
29
	 */
30
	public function executerActionParDefaut() {
30
	public function executerActionParDefaut() {
31
		return $this->afficherStructure();
31
		return $this->afficherStructure();
32
	}
32
	}
33
	
33
	
34
	// +---------------------------------------------------------------------------------------------------------------+
34
	// +---------------------------------------------------------------------------------------------------------------+
35
	// FICHE STRUCTURE
35
	// FICHE STRUCTURE
36
	public function afficherStructure() {
36
	public function afficherStructure() {
37
		$donnees = array();
37
		$donnees = array();
38
		
38
		
39
		// Gestion des actions par défaut
39
		// Gestion des actions par défaut
40
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
40
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
41
		
41
		
42
		// Gestion des données de la requête
42
		// Gestion des données de la requête
43
		if (!isset($_GET['id'])) {
43
		if (!isset($_GET['id'])) {
44
			
44
			
45
		} else {
45
		} else {
46
			// Gestion des données
46
			// Gestion des données
47
			$donnees['id'] = $_GET['id'];
47
			$donnees['id'] = $_GET['id'];
48
			$donnees['info'] = $this->structureDao->getStructure($donnees['id']);
48
			$donnees['info'] = $this->structureDao->getStructure($donnees['id']);
49
			$donnees['personnel'] = $this->structureDao->getPersonnel($donnees['id']);
49
			$donnees['personnel'] = $this->structureDao->getPersonnel($donnees['id']);
50
			$donnees['collections'] = $this->collectionDao->getParIdStructure($donnees['id']);
50
			$donnees['collections'] = $this->collectionDao->getParIdStructure($donnees['id']);
51
			$this->traiterDonneesStructure($donnees['info']);
51
			$this->traiterDonneesStructure($donnees['info']);
52
			$this->traiterPersonnel($donnees['personnel']);
52
			$this->traiterPersonnel($donnees['personnel']);
53
			$this->traiterDonneesStructureConservation($donnees['info']);
53
			$this->traiterDonneesStructureConservation($donnees['info']);
54
			$this->traiterDonneesStructureValorisation($donnees['info']);
54
			$this->traiterDonneesStructureValorisation($donnees['info']);
55
			$this->traiterDonneesStructureCollections($donnees['collections']);
55
			$this->traiterDonneesStructureCollections($donnees['collections']);
56
			$this->postraiterDonnees($donnees);
56
			$this->postraiterDonnees($donnees);
57
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
57
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
58
			
58
			
59
			// Création des méta-données de la page
59
			// Création des méta-données de la page
60
			$titre = $donnees['info']['cs_nom'];
60
			$titre = $donnees['info']['cs_nom'];
61
			$description = $donnees['info']['cs_description'];
61
			$description = $donnees['info']['cs_description'];
62
			$tags = "Structure, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
62
			$tags = "Structure, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
63
			
63
			
64
			// Envoie à la sortie
64
			// Envoie à la sortie
65
			//Debug::printr($donnees);
65
			//Debug::printr($donnees);
66
			$this->setSortie(self::META_TITRE, $titre);
66
			$this->setSortie(self::META_TITRE, $titre);
67
			$this->setSortie(self::META_DESCRIPTION, $description);
67
			$this->setSortie(self::META_DESCRIPTION, $description);
68
			$this->setSortie(self::META_TAGS, $tags);
68
			$this->setSortie(self::META_TAGS, $tags);
69
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_structure', $donnees));
69
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_structure', $donnees));
70
			$this->chargerPiedDePage(); 
70
			$this->chargerPiedDePage(); 
71
		}
71
		}
72
	}
72
	}
73
	
73
	
74
	private function traiterDonneesStructure(&$donnees) {
74
	private function traiterDonneesStructure(&$donnees) {
75
		// liste 01 : Liste des états des enregistrements de la base de données
75
		// liste 01 : Liste des états des enregistrements de la base de données
76
		Ontologie::chargerListe(1001);
76
		Ontologie::chargerListe(1001);
77
		// liste 12 : Liste des types de structure privé
77
		// liste 12 : Liste des types de structure privé
78
		Ontologie::chargerListe(1015);
78
		Ontologie::chargerListe(1015);
79
		// liste 13 : Liste des types de structure public
79
		// liste 13 : Liste des types de structure public
80
		Ontologie::chargerListe(1016);
80
		Ontologie::chargerListe(1016);
81
		// liste 71 : Liste des pays du standard ISO-3166-1
81
		// liste 71 : Liste des pays du standard ISO-3166-1
82
		Ontologie::chargerListe(1074);
82
		Ontologie::chargerListe(1074);
83
		
83
		
84
		$guid_id_valeur = Config::get('guid_id_collection').$donnees['cs_id_structure'];
84
		$guid_id_valeur = Config::get('guid_id_collection').$donnees['cs_id_structure'];
85
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
85
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
86
		$donnees['_date_fondation_'] = $this->formaterDate($donnees['cs_date_fondation'], ColControleur::FMT_DATE);
86
		$donnees['_date_fondation_'] = $this->formaterDate($donnees['cs_date_fondation'], ColControleur::FMT_DATE);
-
 
87
		$donnees['_nbre_personne_'] = (empty($donnees['cs_nbre_personne'])) ? '' : $donnees['cs_nbre_personne']; 
87
		$donnees['_acronyme_'] = $this->construireTxtTruck($donnees['cs_truk_identifiant_alternatif']);
88
		$donnees['_acronyme_'] = $this->construireTxtTruck($donnees['cs_truk_identifiant_alternatif']);
88
		$donnees['_telephone_fax_'] = $this->construireTxtTruck($donnees['cs_truk_telephone']);
89
		$donnees['_telephone_fax_'] = $this->construireTxtTruck($donnees['cs_truk_telephone']);
89
		$donnees['_type_prive_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_prive']);
90
		$donnees['_type_prive_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_prive']);
90
		$donnees['_type_public_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_public']);
91
		$donnees['_type_public_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_public']);
91
		$donnees['_region_'] = Ontologie::getValeurNom($donnees['cs_ce_truk_region']);
92
		$donnees['_region_'] = Ontologie::getValeurNom($donnees['cs_ce_truk_region']);
92
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_pays']);
93
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_pays']);
93
		$donnees['_web_'] = $this->construireTxtTruckSansMajuscule($donnees['cs_truk_url']);
94
		$donnees['_web_'] = $this->construireTxtTruckSansMajuscule($donnees['cs_truk_url']);
94
		$donnees['_web_'] = $this->traiterTxtTruck($donnees['cs_truk_url']);
-
 
95
		$donnees['_courriel_'] = $this->formaterCourriels($donnees['cs_courriel']);
95
		$donnees['_courriel_'] = $this->formaterCourriels($donnees['cs_courriel']);
-
 
96
		
96
		
97
		$latitude = $donnees['cs_latitude'];
97
		$longitude = $donnees['cs_longitude'];
98
		$longitude = $donnees['cs_longitude'];
-
 
99
		$donnees['_latitude_longitude_'] = ($longitude != '' && $latitude != '') ? "$latitude / $longitude" : '';
-
 
100
		$donnees['_latitude_dcm_en_'] = ($latitude != '') ? str_replace(',', '.', $latitude) : '';
-
 
101
		$donnees['_longitude_dcm_en_'] = ($longitude != '') ? str_replace(',', '.', $longitude) : '';
-
 
102
		$donnees['_lien_carte_'] = sprintf(Config::get('lien_vers_carte'), $donnees['_latitude_dcm_en_'], $donnees['_longitude_dcm_en_']);
-
 
103
		$donnees['_url_img_carte_'] = sprintf(Config::get('url_img'), Config::get('img_carte'));
98
		$donnees['_latitude_longitude_'] = ($longitude != '' && $latitude != '') ? $latitude+' / '+$longitude : '';
104
		
99
	}
105
	}
100
	
106
	
101
	private function traiterDonneesStructureConservation(&$donnees) {
107
	private function traiterDonneesStructureConservation(&$donnees) {
102
		// liste 15 : Liste des types de local de stockage de collections
108
		// liste 15 : Liste des types de local de stockage de collections
103
		Ontologie::chargerListe(1018);
109
		Ontologie::chargerListe(1018);
104
		// liste 16 : Liste des types de mobilier de stockage de collections
110
		// liste 16 : Liste des types de mobilier de stockage de collections
105
		Ontologie::chargerListe(1019);
111
		Ontologie::chargerListe(1019);
106
		// liste 17 : Liste des paramètres de contrôle environnemental d'un local
112
		// liste 17 : Liste des paramètres de contrôle environnemental d'un local
107
		Ontologie::chargerListe(1020);
113
		Ontologie::chargerListe(1020);
108
		// liste 18 : Liste des types de collection non botanique
114
		// liste 18 : Liste des types de collection non botanique
109
		Ontologie::chargerListe(1021);
115
		Ontologie::chargerListe(1021);
110
		// liste 19 : Liste des types d'opération de restauration pour les collections botaniques
116
		// liste 19 : Liste des types d'opération de restauration pour les collections botaniques
111
		Ontologie::chargerListe(1022);
117
		Ontologie::chargerListe(1022);
112
		// liste 20 : Liste oui/non/en partie
118
		// liste 20 : Liste oui/non/en partie
113
		Ontologie::chargerListe(1023);
119
		Ontologie::chargerListe(1023);
114
		// liste 21 : Liste du matériel dit de nom conservation des parts d'herbier
120
		// liste 21 : Liste du matériel dit de nom conservation des parts d'herbier
115
		Ontologie::chargerListe(1024);
121
		Ontologie::chargerListe(1024);
116
		
122
		
117
		$donnees['_formation_'] = $this->formaterOuiNon($donnees['csc_mark_formation']);
123
		$donnees['_formation_'] = $this->formaterOuiNon($donnees['csc_mark_formation']);
118
		$donnees['_formation_info_'] = $this->formaterParenthese($donnees['csc_formation']);
124
		$donnees['_formation_info_'] = $this->formaterParenthese($donnees['csc_formation']);
119
		$donnees['_formation_info_'] = $this->formaterSautDeLigne($donnees['_formation_info_']);
125
		$donnees['_formation_info_'] = $this->formaterSautDeLigne($donnees['_formation_info_']);
120
		$donnees['_formation_interet_'] = $this->formaterOuiNon($donnees['csc_mark_formation_interet']);
126
		$donnees['_formation_interet_'] = $this->formaterOuiNon($donnees['csc_mark_formation_interet']);
121
		$donnees['_stockage_local_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_local']);
127
		$donnees['_stockage_local_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_local']);
122
		$donnees['_stockage_meuble_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_meuble']);
128
		$donnees['_stockage_meuble_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_meuble']);
123
		$donnees['_stockage_parametre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_parametre']);
129
		$donnees['_stockage_parametre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_parametre']);
124
		$donnees['_collection_commune_'] = $this->formaterOuiNon($donnees['csc_mark_collection_commune']);
130
		$donnees['_collection_commune_'] = $this->formaterOuiNon($donnees['csc_mark_collection_commune']);
125
		$donnees['_collection_commune_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_collection_autre']);
131
		$donnees['_collection_commune_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_collection_autre']);
126
		$donnees['_collection_commune_autre_'] = $this->formaterParenthese($donnees['_collection_commune_autre_']);
132
		$donnees['_collection_commune_autre_'] = $this->formaterParenthese($donnees['_collection_commune_autre_']);
127
		$donnees['_acces_controle_'] = $this->formaterOuiNon($donnees['csc_mark_acces_controle']);
133
		$donnees['_acces_controle_'] = $this->formaterOuiNon($donnees['csc_mark_acces_controle']);
128
		$donnees['_restauration_'] = $this->formaterOuiNon($donnees['csc_mark_restauration']);
134
		$donnees['_restauration_'] = $this->formaterOuiNon($donnees['csc_mark_restauration']);
129
		$donnees['_restauration_operation_'] = $this->construireTxtListeOntologie($donnees['csc_truk_restauration_operation']);
135
		$donnees['_restauration_operation_'] = $this->construireTxtListeOntologie($donnees['csc_truk_restauration_operation']);
130
		$donnees['_restauration_operation_'] = $this->formaterParenthese($donnees['_restauration_operation_']);
136
		$donnees['_restauration_operation_'] = $this->formaterParenthese($donnees['_restauration_operation_']);
131
		$donnees['_materiel_conservation_'] = $this->construireTxtListeOntologie($donnees['csc_ce_materiel_conservation']);
137
		$donnees['_materiel_conservation_'] = $this->construireTxtListeOntologie($donnees['csc_ce_materiel_conservation']);
132
		$donnees['_materiel_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_materiel_autre']);
138
		$donnees['_materiel_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_materiel_autre']);
133
		$donnees['_materiel_autre_'] = $this->formaterParenthese($donnees['_materiel_autre_']);
139
		$donnees['_materiel_autre_'] = $this->formaterParenthese($donnees['_materiel_autre_']);
134
		$donnees['_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_traitement']);
140
		$donnees['_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_traitement']);
135
		$donnees['_traitement_liste_'] = $this->construireTxtListeOntologie($donnees['csc_truk_traitement']);
141
		$donnees['_traitement_liste_'] = $this->construireTxtListeOntologie($donnees['csc_truk_traitement']);
136
		$donnees['_traitement_liste_'] = $this->formaterParenthese($donnees['_traitement_liste_']);
142
		$donnees['_traitement_liste_'] = $this->formaterParenthese($donnees['_traitement_liste_']);
137
		$donnees['_acquisition_collection_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_collection']);
143
		$donnees['_acquisition_collection_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_collection']);
138
		$donnees['_acquisition_echantillon_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_echantillon']);
144
		$donnees['_acquisition_echantillon_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_echantillon']);
139
		if ($donnees['csc_mark_acquisition_echantillon'] == '1') {
145
		if ($donnees['csc_mark_acquisition_echantillon'] == '1') {
140
			$donnees['_acquisition_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_traitement']);
146
			$donnees['_acquisition_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_traitement']);
141
			if ($donnees['csc_mark_acquisition_traitement'] == '1') {
147
			if ($donnees['csc_mark_acquisition_traitement'] == '1') {
142
				$donnees['_acquisition_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_poison']);
148
				$donnees['_acquisition_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_poison']);
143
				$donnees['_acquisition_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_insecte']);
149
				$donnees['_acquisition_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_insecte']);
144
			}
150
			}
145
		}
151
		}
146
	}
152
	}
147
	
153
	
148
	private function traiterDonneesStructureValorisation(&$donnees) {
154
	private function traiterDonneesStructureValorisation(&$donnees) {
149
		// liste 24 : Liste des actions de valorisation des collections
155
		// liste 24 : Liste des actions de valorisation des collections
150
		Ontologie::chargerListe(1027);
156
		Ontologie::chargerListe(1027);
151
		// liste 25 : Liste des continents habités incluant aussi le pays France
157
		// liste 25 : Liste des continents habités incluant aussi le pays France
152
		Ontologie::chargerListe(1028);
158
		Ontologie::chargerListe(1028);
153
		// liste 26 : Liste des types de recherche nécessitant la consultation de collection botanique
159
		// liste 26 : Liste des types de recherche nécessitant la consultation de collection botanique
154
		Ontologie::chargerListe(1029);
160
		Ontologie::chargerListe(1029);
155
		
161
		
156
		$donnees['_action_'] = $this->formaterOuiNon($donnees['csv_mark_action']);
162
		$donnees['_action_'] = $this->formaterOuiNon($donnees['csv_mark_action']);
157
		$donnees['_action_info_'] = $this->construireTxtListeOntologie($donnees['csv_truk_action']);
163
		$donnees['_action_info_'] = $this->construireTxtListeOntologie($donnees['csv_truk_action']);
158
		$donnees['_action_info_'] = $this->formaterParenthese($donnees['_action_info_']);
164
		$donnees['_action_info_'] = $this->formaterParenthese($donnees['_action_info_']);
159
		$donnees['_collection_autre_'] = $this->construireTxtListeOntologie($donnees['csv_collection_autre']);
165
		$donnees['_collection_autre_'] = $this->construireTxtListeOntologie($donnees['csv_collection_autre']);
160
		$donnees['_action_future_'] = $this->formaterOuiNon($donnees['csv_mark_action_future']);
166
		$donnees['_action_future_'] = $this->formaterOuiNon($donnees['csv_mark_action_future']);
161
		$donnees['_action_future_info_'] = $this->formaterParenthese($donnees['csv_action_future']);
167
		$donnees['_action_future_info_'] = $this->formaterParenthese($donnees['csv_action_future']);
162
		$donnees['_recherche_'] = $this->formaterOuiNon($donnees['csv_mark_recherche']);
168
		$donnees['_recherche_'] = $this->formaterOuiNon($donnees['csv_mark_recherche']);
163
		if ($donnees['csv_mark_recherche'] == '1') {
169
		if ($donnees['csv_mark_recherche'] == '1') {
164
			$donnees['_recherche_provenance_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_provenance']);
170
			$donnees['_recherche_provenance_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_provenance']);
165
			$donnees['_recherche_type_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_type']);
171
			$donnees['_recherche_type_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_type']);
166
		}
172
		}
167
		$donnees['_acces_ss_motif_'] = $this->formaterOuiNon($donnees['csv_mark_acces_ss_motif']);
173
		$donnees['_acces_ss_motif_'] = $this->formaterOuiNon($donnees['csv_mark_acces_ss_motif']);
168
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
174
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
169
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
175
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
170
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
176
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
171
	}
177
	}
172
	
178
	
173
	private function traiterDonneesStructureCollections(&$collections) {
179
	private function traiterDonneesStructureCollections(&$collections) {
174
		foreach ($collections as &$collection) {
180
		foreach ($collections as &$collection) {
175
			$collection['_url_'] = $this->obtenirUrlFicheCollection($collection['cc_id_collection']);
181
			$collection['_url_'] = $this->obtenirUrlFicheCollection($collection['cc_id_collection']);
176
		}
182
		}
177
	}
183
	}
178
	
184
	
179
	private function traiterPersonnel(&$donnees) {
185
	private function traiterPersonnel(&$donnees) {
180
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
186
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
181
		Ontologie::chargerListe(1012);
187
		Ontologie::chargerListe(1012);
182
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
188
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
183
		Ontologie::chargerListe(1013);
189
		Ontologie::chargerListe(1013);
184
		
190
		
185
		foreach ($donnees as &$personnel) {
191
		foreach ($donnees as &$personnel) {
186
			$personnel['_fonction_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_fonction']);
192
			$personnel['_fonction_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_fonction']);
187
			$personnel['_statut_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_statut']);
193
			$personnel['_statut_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_statut']);
188
			$personnel['_tel_fax_'] = $this->construireTxtListeOntologie($personnel['cp_truk_telephone']);
194
			$personnel['_tel_fax_'] = $this->construireTxtListeOntologie($personnel['cp_truk_telephone']);
189
			$personnel['_courriel_'] = $this->traiterTxtTruck($personnel['cp_truk_courriel']);
195
			$personnel['_courriel_'] = $this->traiterTxtTruck($personnel['cp_truk_courriel']);
190
			$personnel['_courriel_'] = $this->formaterCourriels($personnel['_courriel_']);
196
			$personnel['_courriel_'] = $this->formaterCourriels($personnel['_courriel_']);
191
			$personnel['_contact_'] = $this->formaterOuiNon($personnel['csap_mark_contact']);
197
			$personnel['_contact_'] = $this->formaterOuiNon($personnel['csap_mark_contact']);
192
			$personnel['_specialite_'] = $this->construireTxtListeOntologie($personnel['cp_ce_truk_specialite']);
198
			$personnel['_specialite_'] = $this->construireTxtListeOntologie($personnel['cp_ce_truk_specialite']);
193
		}
199
		}
194
	}
200
	}
195
	
201
	
196
	private function obtenirNomCompletPersonne($personne_id) {
202
	private function obtenirNomCompletPersonne($personne_id) {
197
		$personneDao = $this->getModele('PersonneDao');
203
		$personneDao = $this->getModele('PersonneDao');
198
		$personne_nom = $personneDao->getPersonneNomComplet($personne_id);
204
		$personne_nom = $personneDao->getPersonneNomComplet($personne_id);
199
		return $personne_nom;
205
		return $personne_nom;
200
	}
206
	}
201
	
207
	
202
	private function obtenirCourrielsPersonne($personne_id) {
208
	private function obtenirCourrielsPersonne($personne_id) {
203
		$personneDao = $this->getModele('PersonneDao');
209
		$personneDao = $this->getModele('PersonneDao');
204
		$courriels = $personneDao->getPersonneCourriels($personne_id);
210
		$courriels = $personneDao->getPersonneCourriels($personne_id);
205
		$courriels = $this->traiterTxtTruck($courriels);
211
		$courriels = $this->traiterTxtTruck($courriels);
206
		$courriels = $this->formaterCourriels($courriels);
212
		$courriels = $this->formaterCourriels($courriels);
207
		return $courriels;
213
		return $courriels;
208
	}
214
	}
209
	
215
	
210
	// +---------------------------------------------------------------------------------------------------------------+
216
	// +---------------------------------------------------------------------------------------------------------------+
211
	// FICHE COLLECTION
217
	// FICHE COLLECTION
212
	public function afficherCollection() {
218
	public function afficherCollection() {
213
		$donnees = array();
219
		$donnees = array();
214
 
220
 
215
		// Gestion des actions par défaut
221
		// Gestion des actions par défaut
216
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
222
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
217
		
223
		
218
		// Gestion des données de la requête
224
		// Gestion des données de la requête
219
		if (!isset($_GET['id'])) {
225
		if (!isset($_GET['id'])) {
220
			
226
			
221
		} else {
227
		} else {
222
			// Récupération des données
228
			// Récupération des données
223
			$donnees['id'] = $_GET['id'];
229
			$donnees['id'] = $_GET['id'];
224
			$collectionDao = $this->getModele('CollectionDao');
230
			$collectionDao = $this->getModele('CollectionDao');
225
			$donnees['info'] = $collectionDao->getCollection($donnees['id']);
231
			$donnees['info'] = $collectionDao->getCollection($donnees['id']);
226
			$donnees['personnes'] = $collectionDao->getCollectionAPersonne($donnees['id']);
232
			$donnees['personnes'] = $collectionDao->getCollectionAPersonne($donnees['id']);
227
			$donnees['publications'] = $collectionDao->getCollectionAPublication($donnees['id']);
233
			$donnees['publications'] = $collectionDao->getCollectionAPublication($donnees['id']);
228
			$donnees['commentaires'] = $collectionDao->getCollectionACommentaire($donnees['id']);
234
			$donnees['commentaires'] = $collectionDao->getCollectionACommentaire($donnees['id']);
229
			
235
			
230
			// Traitements des données
236
			// Traitements des données
231
			$this->traiterDonneesCollection($donnees['info']);
237
			$this->traiterDonneesCollection($donnees['info']);
232
			$this->traiterDonneesCollectionAPersonne($donnees['personnes']);
238
			$this->traiterDonneesCollectionAPersonne($donnees['personnes']);
233
			$this->traiterDonneesElementAPublication($donnees['publications']);
239
			$this->traiterDonneesElementAPublication($donnees['publications']);
234
			$this->traiterDonneesCollectionDescription($donnees['info']);
240
			$this->traiterDonneesCollectionDescription($donnees['info']);
235
			$this->traiterDonneesCollectionContenu($donnees['info']);
241
			$this->traiterDonneesCollectionContenu($donnees['info']);
236
			$this->traiterDonneesCollectionInventaire($donnees['info']);
242
			$this->traiterDonneesCollectionInventaire($donnees['info']);
237
			$this->traiterDonneesCollectionACommentaire($donnees['commentaires']);
243
			$this->traiterDonneesCollectionACommentaire($donnees['commentaires']);
238
			$this->postraiterDonnees($donnees);
244
			$this->postraiterDonnees($donnees);
239
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
245
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
240
			
246
			
241
			// Création des méta-données de la page
247
			// Création des méta-données de la page
242
			$titre = $donnees['info']['cc_nom'];
248
			$titre = $donnees['info']['cc_nom'];
243
			$description = $donnees['info']['cc_description'];
249
			$description = $donnees['info']['cc_description'];
244
			$tags = "Collection, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
250
			$tags = "Collection, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
245
			
251
			
246
			// Envoie à la sortie
252
			// Envoie à la sortie
247
			//Debug::printr($donnees);
253
			//Debug::printr($donnees);
248
			$this->setSortie(self::META_TITRE, $titre);
254
			$this->setSortie(self::META_TITRE, $titre);
249
			$this->setSortie(self::META_DESCRIPTION, $description);
255
			$this->setSortie(self::META_DESCRIPTION, $description);
250
			$this->setSortie(self::META_TAGS, $tags);
256
			$this->setSortie(self::META_TAGS, $tags);
251
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_collection', $donnees));
257
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_collection', $donnees));
252
			$this->chargerPiedDePage();
258
			$this->chargerPiedDePage();
253
		}
259
		}
254
	}
260
	}
255
 
261
 
256
	private function traiterDonneesCollection(&$donnees) {
262
	private function traiterDonneesCollection(&$donnees) {
257
		// liste 29 : Liste des types de collection dans le standard NCD
263
		// liste 29 : Liste des types de collection dans le standard NCD
258
		Ontologie::chargerListe(1032);
264
		Ontologie::chargerListe(1032);
259
		// liste 30 : Liste des types de dépôt de collection
265
		// liste 30 : Liste des types de dépôt de collection
260
		Ontologie::chargerListe(1033);
266
		Ontologie::chargerListe(1033);
261
		// liste 31 : Liste des principes de groupement d'une collection dans le standard NCD
267
		// liste 31 : Liste des principes de groupement d'une collection dans le standard NCD
262
		Ontologie::chargerListe(1034);
268
		Ontologie::chargerListe(1034);
263
		// liste 32 : Liste des buts de réalisation d'une collection dans le standard NCD
269
		// liste 32 : Liste des buts de réalisation d'une collection dans le standard NCD
264
		Ontologie::chargerListe(1035);
270
		Ontologie::chargerListe(1035);
265
		// liste 38 : Liste indéterminé/peut-être/oui/non
271
		// liste 38 : Liste indéterminé/peut-être/oui/non
266
		Ontologie::chargerListe(1041);
272
		Ontologie::chargerListe(1041);
267
		// liste 39 : Liste des types de classement des spécimens types dans une collection
273
		// liste 39 : Liste des types de classement des spécimens types dans une collection
268
		Ontologie::chargerListe(1042);
274
		Ontologie::chargerListe(1042);
269
		// liste 79 : Liste exact/approximatif
275
		// liste 79 : Liste exact/approximatif
270
		Ontologie::chargerListe(1082);
276
		Ontologie::chargerListe(1082);
271
		
277
		
272
		$guid_id_valeur = Config::get('guid_id_collection').$donnees['cc_id_collection'];
278
		$guid_id_valeur = Config::get('guid_id_collection').$donnees['cc_id_collection'];
273
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
279
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
274
		$donnees['_structure_url_'] = $this->obtenirUrlFicheStructure($donnees['cc_ce_structure']);
280
		$donnees['_structure_url_'] = $this->obtenirUrlFicheStructure($donnees['cc_ce_structure']);
275
		$donnees['_nom_alternatif_'] = $this->construireTxtTruck($donnees['cc_truk_nom_alternatif']);
281
		$donnees['_nom_alternatif_'] = $this->construireTxtTruck($donnees['cc_truk_nom_alternatif']);
276
		$donnees['_type_ncd_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type']);
282
		$donnees['_type_ncd_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type']);
277
		$donnees['_type_depot_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type_depot']);
283
		$donnees['_type_depot_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type_depot']);
278
		$donnees['_identifiant_alternatif_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_identifiant_alternatif']);
284
		$donnees['_identifiant_alternatif_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_identifiant_alternatif']);
279
		$donnees['_code_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_code']);
285
		$donnees['_code_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_code']);
280
		$donnees['_url_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_url']);
286
		$donnees['_url_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_url']);
281
		
287
		
282
		$donnees['_specimen_type_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type']);
288
		$donnees['_specimen_type_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type']);
283
		$donnees['_specimen_type_nbre_'] = ($donnees['cc_specimen_type_nbre'] == 0) ? '' : $donnees['cc_specimen_type_nbre']; 
289
		$donnees['_specimen_type_nbre_'] = ($donnees['cc_specimen_type_nbre'] == 0) ? '' : $donnees['cc_specimen_type_nbre']; 
284
		$donnees['_specimen_type_nbre_precision_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_nbre_precision']);
290
		$donnees['_specimen_type_nbre_precision_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_nbre_precision']);
285
		$donnees['_specimen_type_nbre_precision_'] = $this->formaterParenthese($donnees['_specimen_type_nbre_precision_']);
291
		$donnees['_specimen_type_nbre_precision_'] = $this->formaterParenthese($donnees['_specimen_type_nbre_precision_']);
286
		$donnees['_specimen_type_classement_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_classement']);
292
		$donnees['_specimen_type_classement_'] = $this->construireTxtListeOntologie($donnees['cc_ce_specimen_type_classement']);
287
		
293
		
288
		$donnees['_groupement_principe_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_principe']);
294
		$donnees['_groupement_principe_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_principe']);
289
		$donnees['_groupement_but_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_but']);
295
		$donnees['_groupement_but_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_but']);
290
		$donnees['_couverture_lieu_'] = $this->construireTxtTruck($donnees['cc_truk_couverture_lieu']);
296
		$donnees['_couverture_lieu_'] = $this->construireTxtTruck($donnees['cc_truk_couverture_lieu']);
291
	}
297
	}
292
	
298
	
293
	private function traiterDonneesCollectionAPersonne(&$personnes) {
299
	private function traiterDonneesCollectionAPersonne(&$personnes) {
294
		// liste 27 : Liste des relations entre une collection et une personne
300
		// liste 27 : Liste des relations entre une collection et une personne
295
		Ontologie::chargerListe(1030);
301
		Ontologie::chargerListe(1030);
296
		// liste 77 : Liste indéterminé/oui/non
302
		// liste 77 : Liste indéterminé/oui/non
297
		Ontologie::chargerListe(1080);
303
		Ontologie::chargerListe(1080);
298
		
304
		
299
		foreach ($personnes as &$personne) {
305
		foreach ($personnes as &$personne) {
300
			$personne['_role_'] = $this->construireTxtListeOntologie($personne['ccap_id_role']);
306
			$personne['_role_'] = $this->construireTxtListeOntologie($personne['ccap_id_role']);
301
			$personne['_deces_'] = $this->construireTxtListeOntologie($personne['cp_ce_deces']);
307
			$personne['_deces_'] = $this->construireTxtListeOntologie($personne['cp_ce_deces']);
302
			$personne['_naissance_date_'] = $this->formaterDate($personne['cp_naissance_date'], ColControleur::FMT_DATE);
308
			$personne['_naissance_date_'] = $this->formaterDate($personne['cp_naissance_date'], ColControleur::FMT_DATE);
303
			$personne['_deces_date_'] = $this->formaterDate($personne['cp_deces_date'], ColControleur::FMT_DATE);
309
			$personne['_deces_date_'] = $this->formaterDate($personne['cp_deces_date'], ColControleur::FMT_DATE);
304
			$personne['_url_'] = $this->obtenirUrlFichePersonne($personne['ccap_id_personne']);
310
			$personne['_url_'] = $this->obtenirUrlFichePersonne($personne['ccap_id_personne']);
305
		}
311
		}
306
	}
312
	}
307
	
313
	
308
 
314
 
309
	
315
	
310
	private function traiterDonneesCollectionDescription(&$donnees) {
316
	private function traiterDonneesCollectionDescription(&$donnees) {
311
		// liste 22 : Liste de traitement anti-insecte pour les collections botaniques
317
		// liste 22 : Liste de traitement anti-insecte pour les collections botaniques
312
		Ontologie::chargerListe(1025);
318
		Ontologie::chargerListe(1025);
313
		// liste 23 : Liste des poisons utilisés pour les collections botaniques
319
		// liste 23 : Liste des poisons utilisés pour les collections botaniques
314
		Ontologie::chargerListe(1026);
320
		Ontologie::chargerListe(1026);
315
		// liste 38 : Liste indéterminé/peut-être/oui/non
321
		// liste 38 : Liste indéterminé/peut-être/oui/non
316
		Ontologie::chargerListe(1041);
322
		Ontologie::chargerListe(1041);
317
		// liste 41 : Liste des types d'unité de rangement pour les collections botaniques
323
		// liste 41 : Liste des types d'unité de rangement pour les collections botaniques
318
		Ontologie::chargerListe(1044);
324
		Ontologie::chargerListe(1044);
319
		// liste 42 : Liste des états
325
		// liste 42 : Liste des états
320
		Ontologie::chargerListe(1045);
326
		Ontologie::chargerListe(1045);
321
		// liste 43 : Liste des types de support pour les spécimens des collections botaniques
327
		// liste 43 : Liste des types de support pour les spécimens des collections botaniques
322
		Ontologie::chargerListe(1046);
328
		Ontologie::chargerListe(1046);
323
		// liste 44 : Liste des types de papier de support pour les spécimens des collections botaniques
329
		// liste 44 : Liste des types de papier de support pour les spécimens des collections botaniques
324
		Ontologie::chargerListe(1047);
330
		Ontologie::chargerListe(1047);
325
		// liste 45 : Liste des méthodes de rangement des supports pour les spécimens des collections botaniques
331
		// liste 45 : Liste des méthodes de rangement des supports pour les spécimens des collections botaniques
326
		Ontologie::chargerListe(1048);
332
		Ontologie::chargerListe(1048);
327
		// liste 46 : Liste des méthodes de fixation sur le support pour les collections botaniques
333
		// liste 46 : Liste des méthodes de fixation sur le support pour les collections botaniques
328
		Ontologie::chargerListe(1049);
334
		Ontologie::chargerListe(1049);
329
		// liste 47 : Liste des méthodes de fixation des étiquettes sur les spécimens pour les collections botaniques
335
		// liste 47 : Liste des méthodes de fixation des étiquettes sur les spécimens pour les collections botaniques
330
		Ontologie::chargerListe(1050);
336
		Ontologie::chargerListe(1050);
331
		// liste 48 : Liste des types d'écriture d'étiquette
337
		// liste 48 : Liste des types d'écriture d'étiquette
332
		Ontologie::chargerListe(1051);
338
		Ontologie::chargerListe(1051);
333
		// liste 49 : Liste des	origines des dégradations des spécimens de collections botaniques
339
		// liste 49 : Liste des	origines des dégradations des spécimens de collections botaniques
334
		Ontologie::chargerListe(1052);
340
		Ontologie::chargerListe(1052);
335
		// liste 50 : Liste des origines des dégradations des supports de collections botaniques
341
		// liste 50 : Liste des origines des dégradations des supports de collections botaniques
336
		Ontologie::chargerListe(1053);
342
		Ontologie::chargerListe(1053);
337
		// liste 51 : Liste des niveaux de détermination des spécimens de collections botaniques
343
		// liste 51 : Liste des niveaux de détermination des spécimens de collections botaniques
338
		Ontologie::chargerListe(1054);
344
		Ontologie::chargerListe(1054);
339
 
345
 
340
		$donnees['_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_type']);
346
		$donnees['_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_type']);
341
		$donnees['_unite_rangement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_unite_rangement_etat']);
347
		$donnees['_unite_rangement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_unite_rangement_etat']);
342
		$donnees['_rangements_'] = $this->parserValeurUniteRangement($donnees['ccb_truk_unite_rangement']);
348
		$donnees['_rangements_'] = $this->parserValeurUniteRangement($donnees['ccb_truk_unite_rangement']);
343
		$donnees['_unites_base_'] = $this->parserValeurUniteBase($donnees['ccb_truk_unite_base']);
349
		$donnees['_unites_base_'] = $this->parserValeurUniteBase($donnees['ccb_truk_unite_base']);
344
		$donnees['_conservation_papier_type_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_papier_type']);
350
		$donnees['_conservation_papier_type_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_papier_type']);
345
		$donnees['_conservation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_methode']);
351
		$donnees['_conservation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_conservation_methode']);
346
		$donnees['_specimen_fixation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_specimen_fixation_methode']);
352
		$donnees['_specimen_fixation_methode_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_specimen_fixation_methode']);
347
		$donnees['_etiquette_fixation_support_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_support']);
353
		$donnees['_etiquette_fixation_support_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_support']);
348
		$donnees['_etiquette_fixation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_specimen']);
354
		$donnees['_etiquette_fixation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_fixation_specimen']);
349
		$donnees['_etiquette_ecriture_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_ecriture']);
355
		$donnees['_etiquette_ecriture_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_etiquette_ecriture']);
350
		$donnees['_traitement_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_traitement']);
356
		$donnees['_traitement_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_traitement']);
351
		$donnees['_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_poison']);
357
		$donnees['_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_poison']);
352
		$donnees['_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_insecte']);
358
		$donnees['_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_traitement_insecte']);
353
		$donnees['_etat_general_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_etat_general']);
359
		$donnees['_etat_general_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_etat_general']);
354
		$valeurEstOntologie = false;
360
		$valeurEstOntologie = false;
355
		$typeEstOntologie = true;
361
		$typeEstOntologie = true;
356
		$donneeEstOntologie = true;
362
		$donneeEstOntologie = true;
357
		$donnees['_degradation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_specimen'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
363
		$donnees['_degradation_specimen_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_specimen'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
358
		$donnees['_degradation_presentation_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_presentation'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
364
		$donnees['_degradation_presentation_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_degradation_presentation'], $valeurEstOntologie, $typeEstOntologie, $donneeEstOntologie);
359
		$donnees['_determination_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_determination']);
365
		$donnees['_determination_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_determination']);
360
		
366
		
361
	}
367
	}
362
	
368
	
363
	private function traiterDonneesCollectionContenu(&$donnees) {
369
	private function traiterDonneesCollectionContenu(&$donnees) {
364
		// liste 20 : Liste oui/non/en partie
370
		// liste 20 : Liste oui/non/en partie
365
		Ontologie::chargerListe(1023);
371
		Ontologie::chargerListe(1023);
366
		// liste 37 : Liste des siècles pour les collections naturalistes
372
		// liste 37 : Liste des siècles pour les collections naturalistes
367
		Ontologie::chargerListe(1040);
373
		Ontologie::chargerListe(1040);
368
		// liste 38 : Liste indéterminé/peut-être/oui/non
374
		// liste 38 : Liste indéterminé/peut-être/oui/non
369
		Ontologie::chargerListe(1041);
375
		Ontologie::chargerListe(1041);
370
		// liste 42 : Liste des états
376
		// liste 42 : Liste des états
371
		Ontologie::chargerListe(1045);
377
		Ontologie::chargerListe(1045);
372
		// liste 52 : Liste des types de date de début
378
		// liste 52 : Liste des types de date de début
373
		Ontologie::chargerListe(1055);
379
		Ontologie::chargerListe(1055);
374
		// liste 53 : Liste des types de date de fin
380
		// liste 53 : Liste des types de date de fin
375
		Ontologie::chargerListe(1056);
381
		Ontologie::chargerListe(1056);
376
		// liste 80 : Liste des types de collection botanique
382
		// liste 80 : Liste des types de collection botanique
377
		Ontologie::chargerListe(1083);
383
		Ontologie::chargerListe(1083);
378
		
384
		
379
		$donnees['_nature_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_nature']);
385
		$donnees['_nature_'] = $this->construireTxtListeOntologie($donnees['ccb_truk_nature']);
380
		$donnees['_periode_constitution_'] = $this->construireTxtListeOntologie($donnees['cc_truk_periode_constitution']);
386
		$donnees['_periode_constitution_'] = $this->construireTxtListeOntologie($donnees['cc_truk_periode_constitution']);
381
		$donnees['_recolte_date_debut_'] = $this->formaterDate($donnees['ccb_recolte_date_debut'], ColControleur::FMT_DATE);
387
		$donnees['_recolte_date_debut_'] = $this->formaterDate($donnees['ccb_recolte_date_debut'], ColControleur::FMT_DATE);
382
		$donnees['_recolte_date_debut_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_debut_type']);
388
		$donnees['_recolte_date_debut_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_debut_type']);
383
		$donnees['_recolte_date_debut_type_'] = $this->formaterParenthese($donnees['_recolte_date_debut_type_']);
389
		$donnees['_recolte_date_debut_type_'] = $this->formaterParenthese($donnees['_recolte_date_debut_type_']);
384
		$donnees['_recolte_date_fin_'] = $this->formaterDate($donnees['ccb_recolte_date_fin'], ColControleur::FMT_DATE);
390
		$donnees['_recolte_date_fin_'] = $this->formaterDate($donnees['ccb_recolte_date_fin'], ColControleur::FMT_DATE);
385
		$donnees['_recolte_date_fin_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_fin_type']);
391
		$donnees['_recolte_date_fin_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_recolte_date_fin_type']);
386
		$donnees['_recolte_date_fin_type_'] = $this->formaterParenthese($donnees['_recolte_date_fin_type_']);
392
		$donnees['_recolte_date_fin_type_'] = $this->formaterParenthese($donnees['_recolte_date_fin_type_']);
387
		$donnees['_classement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_classement_etat']);
393
		$donnees['_classement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_classement_etat']);
388
		$donnees['_etiquette_renseignement_'] = $this->construireTxtEtiquetteRenseignement($donnees['ccb_truk_etiquette_renseignement']);
394
		$donnees['_etiquette_renseignement_'] = $this->construireTxtEtiquetteRenseignement($donnees['ccb_truk_etiquette_renseignement']);
389
		$donnees['_precision_localite_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_localite']);
395
		$donnees['_precision_localite_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_localite']);
390
		$donnees['_precision_date_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_date']);
396
		$donnees['_precision_date_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_precision_date']);
391
		$donnees['_collection_integre_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre']);
397
		$donnees['_collection_integre_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre']);
392
		$donnees['_collection_integre_info_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre_info']);
398
		$donnees['_collection_integre_info_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_collection_integre_info']);
393
	}
399
	}
394
	
400
	
395
	private function traiterDonneesCollectionInventaire(&$donnees) {
401
	private function traiterDonneesCollectionInventaire(&$donnees) {
396
		// liste 38 : Liste indéterminé/peut-être/oui/non
402
		// liste 38 : Liste indéterminé/peut-être/oui/non
397
		Ontologie::chargerListe(1041);
403
		Ontologie::chargerListe(1041);
398
		// liste 57 : Liste indéterminé/parfois/oui/non
404
		// liste 57 : Liste indéterminé/parfois/oui/non
399
		Ontologie::chargerListe(1060);
405
		Ontologie::chargerListe(1060);
400
		// liste 58 : Liste des formes d'inventaire
406
		// liste 58 : Liste des formes d'inventaire
401
		Ontologie::chargerListe(1061);
407
		Ontologie::chargerListe(1061);
402
		// liste 59 : Liste des types de logiciel pour les inventaires informatiques
408
		// liste 59 : Liste des types de logiciel pour les inventaires informatiques
403
		Ontologie::chargerListe(1062);
409
		Ontologie::chargerListe(1062);
404
		// liste 60 : Liste des états d'inventaire
410
		// liste 60 : Liste des états d'inventaire
405
		Ontologie::chargerListe(1063);
411
		Ontologie::chargerListe(1063);
406
		
412
		
407
		$donnees['_inventaire_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire']);
413
		$donnees['_inventaire_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire']);
408
		$donnees['_inventaire_auteur_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_auteur']);
414
		$donnees['_inventaire_auteur_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_auteur']);
409
		$donnees['_inventaire_forme_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_forme']);
415
		$donnees['_inventaire_forme_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_forme']);
410
		$donnees['_inventaire_digital_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_inventaire_digital']);
416
		$donnees['_inventaire_digital_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_inventaire_digital']);
411
		$donnees['_inventaire_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_etat']);
417
		$donnees['_inventaire_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_inventaire_etat']);
412
	}
418
	}
413
	
419
	
414
	private function traiterDonneesCollectionACommentaire(&$commentaires) {
420
	private function traiterDonneesCollectionACommentaire(&$commentaires) {
415
		// liste 65 : Liste des types de commentaires associés à une collection
421
		// liste 65 : Liste des types de commentaires associés à une collection
416
		Ontologie::chargerListe(1068);
422
		Ontologie::chargerListe(1068);
417
		
423
		
418
		foreach ($commentaires as &$commentaire) {
424
		foreach ($commentaires as &$commentaire) {
419
			$commentaire['_type_'] = $this->construireTxtListeOntologie($commentaire['ccac_truk_type']);
425
			$commentaire['_type_'] = $this->construireTxtListeOntologie($commentaire['ccac_truk_type']);
420
		}
426
		}
421
	}
427
	}
422
	
428
	
423
	private function construireTxtEtiquetteRenseignement($valeur) {
429
	private function construireTxtEtiquetteRenseignement($valeur) {
424
		$etiquetteRenseignements = '';
430
		$etiquetteRenseignements = '';
425
		$infos = $this->parserEtiquetteRenseignement($valeur);
431
		$infos = $this->parserEtiquetteRenseignement($valeur);
426
		if (count($infos) > 0) {
432
		if (count($infos) > 0) {
427
			foreach ($infos as $cle => $info) {
433
			foreach ($infos as $cle => $info) {
428
				if ($cle == 'AT') {
434
				if ($cle == 'AT') {
429
					$etiquetteRenseignements .= 'auteur de la collection';
435
					$etiquetteRenseignements .= 'auteur de la collection';
430
				} else if ($cle == 'F') {
436
				} else if ($cle == 'F') {
431
					$etiquetteRenseignements .= 'famille';
437
					$etiquetteRenseignements .= 'famille';
432
				} else if ($cle == 'G') {
438
				} else if ($cle == 'G') {
433
					$etiquetteRenseignements .= 'genre';
439
					$etiquetteRenseignements .= 'genre';
434
				} else if ($cle == 'SP') {
440
				} else if ($cle == 'SP') {
435
					$etiquetteRenseignements .= 'espèce';
441
					$etiquetteRenseignements .= 'espèce';
436
				} else if ($cle == 'ASP') {
442
				} else if ($cle == 'ASP') {
437
					$etiquetteRenseignements .= "auteur de l'espèce";
443
					$etiquetteRenseignements .= "auteur de l'espèce";
438
				} else if ($cle == 'L') {
444
				} else if ($cle == 'L') {
439
					$etiquetteRenseignements .= 'localité';
445
					$etiquetteRenseignements .= 'localité';
440
				} else if ($cle == 'D') {
446
				} else if ($cle == 'D') {
441
					$etiquetteRenseignements .= 'date de récolte';
447
					$etiquetteRenseignements .= 'date de récolte';
442
				} else {
448
				} else {
443
					$etiquetteRenseignements .= 'Inconnue';
449
					$etiquetteRenseignements .= 'Inconnue';
444
				}
450
				}
445
				$etiquetteRenseignements .= ': '.$info.'%, ';
451
				$etiquetteRenseignements .= ': '.$info.'%, ';
446
			}
452
			}
447
			$etiquetteRenseignements = rtrim($etiquetteRenseignements, ', ').'.';
453
			$etiquetteRenseignements = rtrim($etiquetteRenseignements, ', ').'.';
448
		}
454
		}
449
		return $etiquetteRenseignements;
455
		return $etiquetteRenseignements;
450
	}
456
	}
451
	
457
	
452
	private function parserEtiquetteRenseignement($valeurTruk) {
458
	private function parserEtiquetteRenseignement($valeurTruk) {
453
		$infos = array();
459
		$infos = array();
454
		if ($valeurTruk != '') {
460
		if ($valeurTruk != '') {
455
			$pourcentages = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
461
			$pourcentages = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
456
			foreach ($pourcentages as $pourcentage) {
462
			foreach ($pourcentages as $pourcentage) {
457
				$pourcentageIdValeur = explode(self::SEPARATEUR_TYPE_VALEUR, $pourcentage);
463
				$pourcentageIdValeur = explode(self::SEPARATEUR_TYPE_VALEUR, $pourcentage);
458
				$id = $pourcentageIdValeur[0];
464
				$id = $pourcentageIdValeur[0];
459
				$valeur = $pourcentageIdValeur[1];
465
				$valeur = $pourcentageIdValeur[1];
460
				$infos[$id] = $valeur;
466
				$infos[$id] = $valeur;
461
			}
467
			}
462
		}
468
		}
463
		return $infos;
469
		return $infos;
464
	}
470
	}
465
	
471
	
466
	private function parserValeurUniteBase($valeurTruk) {
472
	private function parserValeurUniteBase($valeurTruk) {
467
		$unitesEnregistrees = array();
473
		$unitesEnregistrees = array();
468
		if ($valeurTruk != '') {
474
		if ($valeurTruk != '') {
469
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
475
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
470
			$unites_nbre = count($unites);
476
			$unites_nbre = count($unites);
471
			for ($i = 0; $i < $unites_nbre; $i++) {
477
			for ($i = 0; $i < $unites_nbre; $i++) {
472
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
478
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
473
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
479
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
474
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
480
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
475
				$uniteDonneesNbre = count($uniteDonnees);
481
				$uniteDonneesNbre = count($uniteDonnees);
476
				
482
				
477
				$uniteBase = array();
483
				$uniteBase = array();
478
				if ($uniteDonneesNbre > 0) {
484
				if ($uniteDonneesNbre > 0) {
479
					$uniteBase['nbre'] = $uniteDonnees[0];
485
					$uniteBase['nbre'] = $uniteDonnees[0];
480
				}
486
				}
481
				
487
				
482
				if ($uniteBase['nbre'] > 0) {
488
				if ($uniteBase['nbre'] > 0) {
483
					if ($uniteDonneesNbre > 1) {
489
					if ($uniteDonneesNbre > 1) {
484
						$uniteBase['precision'] = self::getPrecisionNom($uniteDonnees[1]);
490
						$uniteBase['precision'] = self::getPrecisionNom($uniteDonnees[1]);
485
					}
491
					}
486
					if ($uniteDonneesNbre > 2) {
492
					if ($uniteDonneesNbre > 2) {
487
						$uniteBase['format'] = $uniteDonnees[2];
493
						$uniteBase['format'] = $uniteDonnees[2];
488
					}
494
					}
489
					if ($uniteDonneesNbre > 3) {
495
					if ($uniteDonneesNbre > 3) {
490
						$uniteBase['part_nbre'] = $uniteDonnees[3];
496
						$uniteBase['part_nbre'] = $uniteDonnees[3];
491
					}
497
					}
492
					if ($uniteDonneesNbre > 4) {
498
					if ($uniteDonneesNbre > 4) {
493
						$uniteBase['part_precision'] = self::getPrecisionNom($uniteDonnees[4]);
499
						$uniteBase['part_precision'] = self::getPrecisionNom($uniteDonnees[4]);
494
					}
500
					}
495
					if ($uniteDonneesNbre > 5) {
501
					if ($uniteDonneesNbre > 5) {
496
						$uniteBase['sp_nbre'] = $uniteDonnees[5];
502
						$uniteBase['sp_nbre'] = $uniteDonnees[5];
497
					}
503
					}
498
					if ($uniteDonneesNbre > 6) {
504
					if ($uniteDonneesNbre > 6) {
499
						$uniteBase['sp_precision'] = self::getPrecisionNom($uniteDonnees[6]);
505
						$uniteBase['sp_precision'] = self::getPrecisionNom($uniteDonnees[6]);
500
					}
506
					}
501
					
507
					
502
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
508
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
503
						$uniteBase['id'] = $uniteTypeIdDonnees[0];
509
						$uniteBase['id'] = $uniteTypeIdDonnees[0];
504
						$uniteBase['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
510
						$uniteBase['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
505
					} else {
511
					} else {
506
						$uniteBase['type'] = $uniteTypeIdDonnees[0];
512
						$uniteBase['type'] = $uniteTypeIdDonnees[0];
507
					}
513
					}
508
					$unitesEnregistrees[] = $uniteBase;
514
					$unitesEnregistrees[] = $uniteBase;
509
				}
515
				}
510
			}
516
			}
511
		}
517
		}
512
		return $unitesEnregistrees;
518
		return $unitesEnregistrees;
513
	}
519
	}
514
	
520
	
515
	private function parserValeurUniteRangement($valeurTruk) {
521
	private function parserValeurUniteRangement($valeurTruk) {
516
		$unitesEnregistrees = array();
522
		$unitesEnregistrees = array();
517
		if ($valeurTruk != '') {
523
		if ($valeurTruk != '') {
518
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
524
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
519
			$unites_nbre = count($unites);
525
			$unites_nbre = count($unites);
520
			for ($i = 0; $i < $unites_nbre; $i++) {
526
			for ($i = 0; $i < $unites_nbre; $i++) {
521
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
527
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
522
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
528
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
523
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
529
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
524
				$uniteDonneesNbre = count($uniteDonnees);
530
				$uniteDonneesNbre = count($uniteDonnees);
525
				
531
				
526
				$uniteRangement = array();
532
				$uniteRangement = array();
527
				if ($uniteDonneesNbre > 0) {
533
				if ($uniteDonneesNbre > 0) {
528
					$uniteRangement['nbre'] = $uniteDonnees[0];
534
					$uniteRangement['nbre'] = $uniteDonnees[0];
529
				}
535
				}
530
				
536
				
531
				if ($uniteRangement['nbre'] > 0) {
537
				if ($uniteRangement['nbre'] > 0) {
532
					if ($uniteDonneesNbre > 1) {
538
					if ($uniteDonneesNbre > 1) {
533
						$uniteRangement['precision'] = self::getPrecisionNom($uniteDonnees[1]);
539
						$uniteRangement['precision'] = self::getPrecisionNom($uniteDonnees[1]);
534
					}
540
					}
535
					if ($uniteDonneesNbre > 2) {
541
					if ($uniteDonneesNbre > 2) {
536
						$uniteRangement['format'] = $uniteDonnees[2];
542
						$uniteRangement['format'] = $uniteDonnees[2];
537
					}
543
					}
538
					
544
					
539
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
545
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
540
						$uniteRangement['id'] = $uniteTypeIdDonnees[0];
546
						$uniteRangement['id'] = $uniteTypeIdDonnees[0];
541
						$uniteRangement['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
547
						$uniteRangement['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
542
					} else {
548
					} else {
543
						$uniteRangement['type'] = $uniteTypeIdDonnees[0];
549
						$uniteRangement['type'] = $uniteTypeIdDonnees[0];
544
					}
550
					}
545
					$unitesEnregistrees[] = $uniteRangement;
551
					$unitesEnregistrees[] = $uniteRangement;
546
				}
552
				}
547
			}
553
			}
548
		}
554
		}
549
		return $unitesEnregistrees;
555
		return $unitesEnregistrees;
550
	}
556
	}
551
	
557
	
552
	private static function getPrecisionNom($precisionAbr) {
558
	private static function getPrecisionNom($precisionAbr) {
553
		$precision_nom = '';
559
		$precision_nom = '';
554
		if ($precisionAbr != 'NULL') {
560
		if ($precisionAbr != 'NULL') {
555
			// liste 79 : Liste exact/approximatif
561
			// liste 79 : Liste exact/approximatif
556
			$precisions = Ontologie::getListeFormatee(1082);
562
			$precisions = Ontologie::getListeFormatee(1082);
557
			foreach ($precisions as $precision) {
563
			foreach ($precisions as $precision) {
558
				if ($precision['abreviation'] == $precisionAbr) {
564
				if ($precision['abreviation'] == $precisionAbr) {
559
					$precision_nom = $precision['nom'];
565
					$precision_nom = $precision['nom'];
560
					break;
566
					break;
561
				}
567
				}
562
			}
568
			}
563
		}
569
		}
564
		return $precision_nom;
570
		return $precision_nom;
565
	}
571
	}
566
	
572
	
567
	// +---------------------------------------------------------------------------------------------------------------+
573
	// +---------------------------------------------------------------------------------------------------------------+
568
	// FICHE PERSONNE
574
	// FICHE PERSONNE
569
	
575
	
570
	public function afficherPersonne() {
576
	public function afficherPersonne() {
571
		$donnees = array();
577
		$donnees = array();
572
 
578
 
573
		// Gestion des actions par défaut
579
		// Gestion des actions par défaut
574
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
580
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
575
		
581
		
576
		// Gestion des données de la requête
582
		// Gestion des données de la requête
577
		if (!isset($_GET['id'])) {
583
		if (!isset($_GET['id'])) {
578
			
584
			
579
		} else {
585
		} else {
580
			// Récupération des données
586
			// Récupération des données
581
			$donnees['id'] = $_GET['id'];
587
			$donnees['id'] = $_GET['id'];
582
			$personneDao = $this->getModele('PersonneDao');
588
			$personneDao = $this->getModele('PersonneDao');
583
			$donnees['info'] = $personneDao->getPersonne($donnees['id']);
589
			$donnees['info'] = $personneDao->getPersonne($donnees['id']);
584
			$donnees['publications'] = $personneDao->getPersonneAPublication($donnees['id']);
590
			$donnees['publications'] = $personneDao->getPersonneAPublication($donnees['id']);
585
			
591
			
586
			// Traitement des données
592
			// Traitement des données
587
			$this->traiterDonneesPersonne($donnees['info']);
593
			$this->traiterDonneesPersonne($donnees['info']);
588
			$this->traiterDonneesPersonneAPublication($donnees['publications']);
594
			$this->traiterDonneesPersonneAPublication($donnees['publications']);
589
			$this->postraiterDonnees($donnees);
595
			$this->postraiterDonnees($donnees);
590
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
596
			$donnees['metadonnees'] = $this->traiterMetaDonnees($donnees['info']);
591
			
597
			
592
			// Création des méta-données de la page
598
			// Création des méta-données de la page
593
			$titre = $donnees['info']['cp_fmt_nom_complet'];
599
			$titre = $donnees['info']['cp_fmt_nom_complet'];
594
			$description = $donnees['info']['cp_description'];
600
			$description = $donnees['info']['cp_description'];
595
			$tags = "Botaniste, naturaliste, personne, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
601
			$tags = "Botaniste, naturaliste, personne, id:{$donnees['id']}, {$donnees['info']['_guid_']}";
596
			
602
			
597
			// Envoie à la sortie
603
			// Envoie à la sortie
598
			//Debug::printr($donnees);
604
			//Debug::printr($donnees);
599
			$this->setSortie(self::META_TITRE, $titre);
605
			$this->setSortie(self::META_TITRE, $titre);
600
			$this->setSortie(self::META_DESCRIPTION, $description);
606
			$this->setSortie(self::META_DESCRIPTION, $description);
601
			$this->setSortie(self::META_TAGS, $tags);
607
			$this->setSortie(self::META_TAGS, $tags);
602
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_personne', $donnees));
608
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_personne', $donnees));
603
			$this->chargerPiedDePage();
609
			$this->chargerPiedDePage();
604
		}
610
		}
605
	}
611
	}
606
	
612
	
607
	private function traiterDonneesPersonne(&$donnees) {
613
	private function traiterDonneesPersonne(&$donnees) {
608
		// Liste des préfixes
614
		// Liste des préfixes
609
		Ontologie::chargerListe(1004);
615
		Ontologie::chargerListe(1004);
610
		// Liste des suffixes
616
		// Liste des suffixes
611
		Ontologie::chargerListe(1005);
617
		Ontologie::chargerListe(1005);
612
		// Liste tel:
618
		// Liste tel:
613
		Ontologie::chargerListe(1007);
619
		Ontologie::chargerListe(1007);
614
		// Liste sexe:
620
		// Liste sexe:
615
		Ontologie::chargerListe(1067);
621
		Ontologie::chargerListe(1067);
616
		// liste 77 : Liste indéterminé/oui/non
622
		// liste 77 : Liste indéterminé/oui/non
617
		Ontologie::chargerListe(1080);
623
		Ontologie::chargerListe(1080);
618
		// Liste des types de publication vis à vis d'une personne
624
		// Liste des types de publication vis à vis d'une personne
619
		//relationPersonnePublication:1065,
625
		//relationPersonnePublication:1065,
620
		
626
		
621
		$guid_id_valeur = Config::get('guid_id_personne').$donnees['cp_id_personne'];
627
		$guid_id_valeur = Config::get('guid_id_personne').$donnees['cp_id_personne'];
622
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
628
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $guid_id_valeur);
623
		
629
		
624
		$donnees['_sexe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_sexe']);
630
		$donnees['_sexe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_sexe']);
625
		$donnees['_prefixe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_prefix']);
631
		$donnees['_prefixe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_prefix']);
626
		$donnees['_suffixe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_suffix']);
632
		$donnees['_suffixe_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_suffix']);
627
		$donnees['_autre_noms_'] = $this->construireTxtTruck($donnees['cp_truk_nom_autre']);
633
		$donnees['_autre_noms_'] = $this->construireTxtTruck($donnees['cp_truk_nom_autre']);
628
		$donnees['_autre_abreviations_'] = $this->construireTxtTruck($donnees['cp_truk_abreviation_autre']);
634
		$donnees['_autre_abreviations_'] = $this->construireTxtTruck($donnees['cp_truk_abreviation_autre']);
629
		$donnees['_deces_'] = $this->construireTxtListeOntologie($donnees['cp_ce_deces']);
635
		$donnees['_deces_'] = $this->construireTxtListeOntologie($donnees['cp_ce_deces']);
630
		$donnees['_naissance_date_'] = $this->formaterDate($donnees['cp_naissance_date'], ColControleur::FMT_DATE);
636
		$donnees['_naissance_date_'] = $this->formaterDate($donnees['cp_naissance_date'], ColControleur::FMT_DATE);
631
		$donnees['_deces_date_'] = $this->formaterDate($donnees['cp_deces_date'], ColControleur::FMT_DATE);
637
		$donnees['_deces_date_'] = $this->formaterDate($donnees['cp_deces_date'], ColControleur::FMT_DATE);
632
		$donnees['_telephones_'] = $this->construireTxtListeOntologie($donnees['cp_truk_telephone']);
638
		$donnees['_telephones_'] = $this->construireTxtListeOntologie($donnees['cp_truk_telephone']);
633
		$donnees['_courriels_'] = $this->traiterTxtTruck($donnees['cp_truk_courriel']);
639
		$donnees['_courriels_'] = $this->traiterTxtTruck($donnees['cp_truk_courriel']);
634
		$donnees['_courriels_'] = $this->formaterCourriels($donnees['_courriels_']);
640
		$donnees['_courriels_'] = $this->formaterCourriels($donnees['_courriels_']);
635
		$donnees['_sites_web_'] = $this->getTableauTruck($donnees['cp_truk_url']);
641
		$donnees['_sites_web_'] = $this->getTableauTruck($donnees['cp_truk_url']);
636
		$donnees['_image_principale_url_'] = $this->getTxtTruckParPosition($donnees['cp_truk_logo'], 1);
642
		$donnees['_image_principale_url_'] = $this->getTxtTruckParPosition($donnees['cp_truk_logo'], 1);
637
		
643
		
638
		$donnees['_region_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_region']);
644
		$donnees['_region_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_region']);
639
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_pays']);
645
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_pays']);
640
		
646
		
641
		$donnees['_specialites_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_specialite']);
647
		$donnees['_specialites_'] = $this->construireTxtListeOntologie($donnees['cp_ce_truk_specialite']);
642
		$donnees['_recoltes_'] = $this->construireTxtListeOntologie($donnees['cp_truk_recolte']);
648
		$donnees['_recoltes_'] = $this->construireTxtListeOntologie($donnees['cp_truk_recolte']);
643
		
649
		
644
		$donnees['_logos_'] = $this->getTableauTruck($donnees['cp_truk_logo']);
650
		$donnees['_logos_'] = $this->getTableauTruck($donnees['cp_truk_logo']);
645
	}
651
	}
646
	
652
	
647
	private function traiterDonneesPersonneAPublication(&$publications) {
653
	private function traiterDonneesPersonneAPublication(&$publications) {
648
		$this->traiterDonneesElementAPublication($publications);
654
		$this->traiterDonneesElementAPublication($publications);
649
		// liste 62 : Liste des types de publication vis à vis d'une personne
655
		// liste 62 : Liste des types de publication vis à vis d'une personne
650
		Ontologie::chargerListe(1065);
656
		Ontologie::chargerListe(1065);
651
		foreach ($publications as &$publication) {
657
		foreach ($publications as &$publication) {
652
			$publication['_role_'] = $this->construireTxtListeOntologie($publication['cpuap_id_role']);
658
			$publication['_role_'] = $this->construireTxtListeOntologie($publication['cpuap_id_role']);
653
		}
659
		}
654
		
660
		
655
		
661
		
656
	}
662
	}
657
	
663
	
658
	// +---------------------------------------------------------------------------------------------------------------+
664
	// +---------------------------------------------------------------------------------------------------------------+
659
	// MÉTHODES GÉNÉRIQUES
665
	// MÉTHODES GÉNÉRIQUES
660
	
666
	
661
	private function traiterDonneesElementAPublication(&$publications) {
667
	private function traiterDonneesElementAPublication(&$publications) {
662
		foreach ($publications as &$publication) {
668
		foreach ($publications as &$publication) {
663
			$publication['_editeur_'] = $this->construireTxtTruck($publication['cpu_ce_truk_editeur']);
669
			$publication['_editeur_'] = $this->construireTxtTruck($publication['cpu_ce_truk_editeur']);
664
			$publication['_date_parution_'] = rtrim($publication['cpu_date_parution'],'-00-00');
670
			$publication['_date_parution_'] = rtrim($publication['cpu_date_parution'],'-00-00');
665
		}
671
		}
666
	}
672
	}
667
	
673
	
668
	private function traiterMetaDonnees(&$donnees) {
674
	private function traiterMetaDonnees(&$donnees) {
669
		$meta = array();
675
		$meta = array();
670
		$meta['_guid_'] = $donnees['_guid_'];
676
		$meta['_guid_'] = $donnees['_guid_'];
671
		$meta['_notes_'] = $donnees['cmhl_notes'];
677
		$meta['_notes_'] = $donnees['cmhl_notes'];
672
		$meta['_source_'] = $donnees['cmhl_source'];
678
		$meta['_source_'] = $donnees['cmhl_source'];
673
		$meta['_date_modification_'] = $donnees['cmhl_date_modification'];
679
		$meta['_date_modification_'] = $donnees['cmhl_date_modification'];
674
		$meta['_modifier_par_'] = $this->obtenirNomCompletPersonne($donnees['cmhl_ce_modifier_par']);
680
		$meta['_modifier_par_'] = $this->obtenirNomCompletPersonne($donnees['cmhl_ce_modifier_par']);
675
		$meta['_modifier_par_courriel_'] = $this->obtenirCourrielsPersonne($donnees['cmhl_ce_modifier_par']);
681
		$meta['_modifier_par_courriel_'] = $this->obtenirCourrielsPersonne($donnees['cmhl_ce_modifier_par']);
676
		$meta['_etat_'] = $this->construireTxtListeOntologie($donnees['cmhl_ce_etat']);
682
		$meta['_etat_'] = $this->construireTxtListeOntologie($donnees['cmhl_ce_etat']);
677
		return $this->getVue('metadonnees', $meta);
683
		return $this->getVue('metadonnees', $meta);
678
	}
684
	}
679
}
685
}