Subversion Repositories eFlore/Applications.coel-consultation

Rev

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

Rev 17 Rev 18
Line 7... Line 7...
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 17 2010-03-22 17:04:04Z jpm $
12
 * @version		SVN: $Id: Fiche.php 18 2010-03-23 18:14:32Z jpm $
13
 */
13
 */
14
class Fiche extends ColControleur {
14
class Fiche extends ColControleur {
Line -... Line 15...
-
 
15
	
-
 
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
	}
15
	
24
	
16
	//+----------------------------------------------------------------------------------------------------------------+
25
	//+----------------------------------------------------------------------------------------------------------------+
17
	// Méthodes
26
	// Méthodes
18
	/**
27
	/**
19
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
28
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
Line 31... Line 40...
31
		// Gestion des données de la requête
40
		// Gestion des données de la requête
32
		if (!isset($_GET['id'])) {
41
		if (!isset($_GET['id'])) {
Line 33... Line 42...
33
			
42
			
34
		} else {
43
		} else {
35
			$donnees['id'] = $_GET['id'];
44
			$donnees['id'] = $_GET['id'];
36
			$structureDao = $this->getModele('StructureDao');
45
			$donnees['info'] = $this->structureDao->getStructure($donnees['id']);
37
			$donnees['info'] = $structureDao->getStructure($donnees['id']);
46
			$donnees['personnel'] = $this->structureDao->getPersonnel($donnees['id']);
38
			$donnees['personnel'] = $structureDao->getPersonnel($donnees['id']);
47
			$donnees['collections'] = $this->collectionDao->getParIdStructure($donnees['id']);
39
			$this->traiterMetaDonnees($donnees['info']);
48
			$this->traiterMetaDonnees($donnees['info']);
40
			$this->traiterDonneesStructure($donnees['info']);
49
			$this->traiterDonneesStructure($donnees['info']);
41
			$this->traiterPersonnel($donnees['personnel']);
50
			$this->traiterPersonnel($donnees['personnel']);
42
			$this->traiterDonneesStructureConservation($donnees['info']);
51
			$this->traiterDonneesStructureConservation($donnees['info']);
-
 
52
			$this->traiterDonneesStructureValorisation($donnees['info']);
-
 
53
			$this->traiterDonneesStructureCollections($donnees['collections']);
43
			$this->traiterDonneesStructureValorisation($donnees['info']);
54
			//Debug::printr($donnees['collections']);
44
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_structure', $donnees)); 
55
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_structure', $donnees)); 
45
		}
56
		}
Line 46... Line 57...
46
	}
57
	}
Line 143... Line 154...
143
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
154
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
144
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
155
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
145
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
156
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
146
	}
157
	}
Line -... Line 158...
-
 
158
	
-
 
159
	private function traiterDonneesStructureCollections(&$collections) {
-
 
160
		foreach ($collections as &$collection) {
-
 
161
			$collection['_url_'] = $this->obtenirUrlFicheColletion($collection['cc_id_collection']);
-
 
162
		}
-
 
163
	}
147
	
164
	
148
	private function traiterPersonnel(&$donnees) {
165
	private function traiterPersonnel(&$donnees) {
149
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
166
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
150
		Ontologie::chargerListe(1012);
167
		Ontologie::chargerListe(1012);
151
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
168
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
Line 184... Line 201...
184
			$donnees['publications'] = $collectionDao->getCollectionAPublication($donnees['id']);
201
			$donnees['publications'] = $collectionDao->getCollectionAPublication($donnees['id']);
185
			$this->traiterMetaDonnees($donnees['info']);
202
			$this->traiterMetaDonnees($donnees['info']);
186
			$this->traiterDonneesCollection($donnees['info']);
203
			$this->traiterDonneesCollection($donnees['info']);
187
			$this->traiterDonneesCollectionAPersonne($donnees['personnes']);
204
			$this->traiterDonneesCollectionAPersonne($donnees['personnes']);
188
			$this->traiterDonneesCollectionAPublication($donnees['publications']);
205
			$this->traiterDonneesCollectionAPublication($donnees['publications']);
-
 
206
			$this->traiterDonneesCollectionDescription($donnees['info']);
189
			Debug::printr($donnees);
207
			Debug::printr($donnees);
190
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_collection', $donnees));
208
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_collection', $donnees));
191
		}
209
		}
192
	}
210
	}
Line -... Line 211...
-
 
211
	
-
 
212
	private function traiterDonneesCollectionDescription(&$donnees) {
-
 
213
		// liste 41 : Liste des types d'unité de rangement pour les collections botaniques
-
 
214
		Ontologie::chargerListe(1044);
-
 
215
		// liste 42 : Liste des états
-
 
216
		Ontologie::chargerListe(1045);
-
 
217
		// liste 43 : Liste des types de support pour les spécimens des collections botaniques
-
 
218
		Ontologie::chargerListe(1046);
-
 
219
		// liste 80 : Liste des types de collection botanique
-
 
220
		Ontologie::chargerListe(1083);
-
 
221
 
-
 
222
		$donnees['_type_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_truk_type']);
-
 
223
		$donnees['_unite_rangement_etat_'] = $this->construireTxtListeOntologie($donnees['ccb_ce_unite_rangement_etat']);
-
 
224
		$donnees['_rangements_'] = $this->parserValeurUniteRangement($donnees['ccb_truk_unite_rangement']);
-
 
225
		$donnees['_unites_base_'] = $this->parserValeurUniteBase($donnees['ccb_truk_unite_base']);
-
 
226
 
-
 
227
	}
193
	
228
	
194
	private function traiterDonneesCollectionAPublication(&$publications) {
229
	private function traiterDonneesCollectionAPublication(&$publications) {
195
		foreach ($publications as &$publication) {
230
		foreach ($publications as &$publication) {
196
			$publication['_editeur_'] = $this->construireTxtTruck($publication['cpu_ce_truk_editeur']);
231
			$publication['_editeur_'] = $this->construireTxtTruck($publication['cpu_ce_truk_editeur']);
197
			$publication['_date_parution_'] = rtrim($publication['cpu_date_parution'],'-00-00');
232
			$publication['_date_parution_'] = rtrim($publication['cpu_date_parution'],'-00-00');
Line 226... Line 261...
226
		// liste 39 : Liste des types de classement des spécimens types dans une collection
261
		// liste 39 : Liste des types de classement des spécimens types dans une collection
227
		Ontologie::chargerListe(1042);
262
		Ontologie::chargerListe(1042);
228
		// liste 79 : Liste exact/approximatif
263
		// liste 79 : Liste exact/approximatif
229
		Ontologie::chargerListe(1082);
264
		Ontologie::chargerListe(1082);
Line -... Line 265...
-
 
265
		
230
		
266
		$donnees['_structure_url_'] = $this->obtenirUrlFicheStructure($donnees['cc_ce_structure']);
231
		$donnees['_nom_alternatif_'] = $this->construireTxtTruck($donnees['cc_truk_nom_alternatif']);
267
		$donnees['_nom_alternatif_'] = $this->construireTxtTruck($donnees['cc_truk_nom_alternatif']);
232
		$donnees['_type_ncd_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type']);
268
		$donnees['_type_ncd_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type']);
233
		$donnees['_type_depot_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type_depot']);
269
		$donnees['_type_depot_'] = $this->construireTxtListeOntologie($donnees['cc_ce_type_depot']);
234
		$donnees['_identifiant_alternatif_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_identifiant_alternatif']);
270
		$donnees['_identifiant_alternatif_'] = $this->construireTxtTruckSansMajuscule($donnees['cc_truk_identifiant_alternatif']);
Line 242... Line 278...
242
		
278
		
243
		$donnees['_groupement_principe_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_principe']);
279
		$donnees['_groupement_principe_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_principe']);
244
		$donnees['_groupement_but_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_but']);
280
		$donnees['_groupement_but_'] = $this->construireTxtListeOntologie($donnees['cc_truk_groupement_but']);
245
		$donnees['_couverture_lieu_'] = $this->construireTxtTruck($donnees['cc_truk_couverture_lieu']);
281
		$donnees['_couverture_lieu_'] = $this->construireTxtTruck($donnees['cc_truk_couverture_lieu']);
-
 
282
	}
-
 
283
	
-
 
284
	private function parserValeurUniteBase($valeurTruk) {
-
 
285
		$unitesEnregistrees = array();
-
 
286
		if ($valeurTruk != '') {
-
 
287
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
-
 
288
			$unites_nbre = count($unites);
-
 
289
			for ($i = 0; $i < $unites_nbre; $i++) {
-
 
290
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
-
 
291
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
-
 
292
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
-
 
293
				$uniteDonneesNbre = count($uniteDonnees);
-
 
294
				
-
 
295
				$uniteBase = array();
-
 
296
				if ($uniteDonneesNbre > 0) {
-
 
297
					$uniteBase['nbre'] = $uniteDonnees[0];
-
 
298
				}
-
 
299
				
-
 
300
				if ($uniteBase['nbre'] > 0) {
-
 
301
					if ($uniteDonneesNbre > 1) {
-
 
302
						$uniteBase['precision'] = self::getPrecisionNom($uniteDonnees[1]);
-
 
303
					}
-
 
304
					if ($uniteDonneesNbre > 2) {
-
 
305
						$uniteBase['format'] = $uniteDonnees[2];
-
 
306
					}
-
 
307
					if ($uniteDonneesNbre > 3) {
-
 
308
						$uniteBase['part_nbre'] = $uniteDonnees[3];
-
 
309
					}
-
 
310
					if ($uniteDonneesNbre > 4) {
-
 
311
						$uniteBase['part_precision'] = self::getPrecisionNom($uniteDonnees[4]);
-
 
312
					}
-
 
313
					if ($uniteDonneesNbre > 5) {
-
 
314
						$uniteBase['sp_nbre'] = $uniteDonnees[5];
-
 
315
					}
-
 
316
					if ($uniteDonneesNbre > 6) {
-
 
317
						$uniteBase['sp_precision'] = self::getPrecisionNom($uniteDonnees[6]);
-
 
318
					}
-
 
319
					
-
 
320
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
-
 
321
						$uniteBase['id'] = $uniteTypeIdDonnees[0];
-
 
322
						$uniteBase['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
-
 
323
					} else {
-
 
324
						$uniteBase['type'] = $uniteTypeIdDonnees[0];
-
 
325
					}
-
 
326
					$unitesEnregistrees[] = $uniteBase;
-
 
327
				}
-
 
328
			}
-
 
329
		}
-
 
330
		return $unitesEnregistrees;
-
 
331
	}
-
 
332
	
-
 
333
	private function parserValeurUniteRangement($valeurTruk) {
-
 
334
		$unitesEnregistrees = array();
-
 
335
		if ($valeurTruk != '') {
-
 
336
			$unites = explode(self::SEPARATEUR_VALEURS, $valeurTruk);
-
 
337
			$unites_nbre = count($unites);
-
 
338
			for ($i = 0; $i < $unites_nbre; $i++) {
-
 
339
				$uniteTypeIdDonnees = explode(self::SEPARATEUR_TYPE_VALEUR, $unites[$i]);
-
 
340
				$uniteChaineDonnees = $uniteTypeIdDonnees[1];
-
 
341
				$uniteDonnees = explode(self::SEPARATEUR_DONNEES, $uniteChaineDonnees);
-
 
342
				$uniteDonneesNbre = count($uniteDonnees);
-
 
343
				
-
 
344
				$uniteRangement = array();
-
 
345
				if ($uniteDonneesNbre > 0) {
-
 
346
					$uniteRangement['nbre'] = $uniteDonnees[0];
-
 
347
				}
-
 
348
				
-
 
349
				if ($uniteRangement['nbre'] > 0) {
-
 
350
					if ($uniteDonneesNbre > 1) {
-
 
351
						$uniteRangement['precision'] = self::getPrecisionNom($uniteDonnees[1]);
-
 
352
					}
-
 
353
					if ($uniteDonneesNbre > 2) {
-
 
354
						$uniteRangement['format'] = $uniteDonnees[2];
-
 
355
					}
-
 
356
					
-
 
357
					if (preg_match('/^[0-9]+$/', $uniteTypeIdDonnees[0])) {
-
 
358
						$uniteRangement['id'] = $uniteTypeIdDonnees[0];
-
 
359
						$uniteRangement['type'] = Ontologie::getValeurNom($uniteTypeIdDonnees[0]);
-
 
360
					} else {
-
 
361
						$uniteRangement['type'] = $uniteTypeIdDonnees[0];
-
 
362
					}
-
 
363
					$unitesEnregistrees[] = $uniteRangement;
-
 
364
				}
-
 
365
			}
-
 
366
		}
-
 
367
		return $unitesEnregistrees;
-
 
368
	}
-
 
369
	
-
 
370
	private static function getPrecisionNom($precisionAbr) {
-
 
371
		$precision_nom = '';
-
 
372
		if ($precisionAbr != 'NULL') {
-
 
373
			// liste 79 : Liste exact/approximatif
-
 
374
			$precisions = Ontologie::getListeFormatee(1082);
-
 
375
			foreach ($precisions as $precision) {
-
 
376
				if ($precision['abreviation'] == $precisionAbr) {
-
 
377
					$precision_nom = $precision['nom'];
-
 
378
					break;
-
 
379
				}
-
 
380
			}
-
 
381
		}
-
 
382
		return $precision_nom;
246
	}
383
	}
247
}
384
}