Subversion Repositories eFlore/Applications.coel-consultation

Rev

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