Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 96 | Rev 114 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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