Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 85 | Rev 93 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

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