Subversion Repositories eFlore/Applications.coel-consultation

Rev

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

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