Subversion Repositories eFlore/Applications.coel-consultation

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
113 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Controleur du module Fiche Structure.
5
 *
6
 * @category	Php 5.2
7
 * @package		Collection
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id: Fiche.php 96 2010-06-21 16:46:31Z jpm $
13
 */
14
class FicheStructure extends Fiche {
15
 
150 jpm 16
	private $donnees = array();
17
 
113 jpm 18
	//+----------------------------------------------------------------------------------------------------------------+
19
	// Méthodes
20
	/**
21
	 * Fonction d'affichage par défaut
22
	 */
23
	public function executerActionParDefaut() {
24
		return $this->afficherStructure();
25
	}
26
 
27
	// +---------------------------------------------------------------------------------------------------------------+
28
	// FICHE STRUCTURE
29
	public function afficherStructure() {
30
		// Gestion des actions par défaut
31
		$this->executerAction('Recherche', 'chargerMoteurRecherche');
32
 
33
		// Gestion des données de la requête
34
		if (!isset($_GET['id'])) {
35
 
36
		} else {
37
			// Gestion des données
150 jpm 38
			$this->donnees['id'] = $_GET['id'];
39
			$this->donnees['info'] = $this->structureDao->getStructure($this->donnees['id']);
40
 
41
			$this->traiterDonneesStructure($this->donnees['info']);
42
			$this->creerPaginationPersonnel($this->donnees['id']);
43
			$this->traiterDonneesStructureConservation($this->donnees['info']);
44
			$this->traiterDonneesStructureValorisation($this->donnees['info']);
45
			$this->creerPaginationCollections($this->donnees['id']);
46
			$this->postraiterDonnees($this->donnees);
47
			$this->donnees['metadonnees'] = $this->traiterMetaDonnees($this->donnees['info']);
113 jpm 48
 
49
			// Création des méta-données de la page
150 jpm 50
			$titre = $this->donnees['info']['cs_nom'];
51
			$description = $this->donnees['info']['cs_description'];
52
			$tags = "Structure, id:{$this->donnees['id']}, {$this->donnees['info']['_guid_']}";
113 jpm 53
 
54
			// Envoie à la sortie
55
			//Debug::printr($donnees);
56
			$this->setSortie(self::META_TITRE, $titre);
57
			$this->setSortie(self::META_DESCRIPTION, $description);
58
			$this->setSortie(self::META_TAGS, $tags);
150 jpm 59
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_structure', $this->donnees));
113 jpm 60
			$this->chargerPiedDePage();
61
		}
62
	}
63
 
64
	private function traiterDonneesStructure(&$donnees) {
65
		// liste 01 : Liste des états des enregistrements de la base de données
66
		Ontologie::chargerListe(1001);
67
		// liste 12 : Liste des types de structure privé
68
		Ontologie::chargerListe(1015);
69
		// liste 13 : Liste des types de structure public
70
		Ontologie::chargerListe(1016);
71
		// liste 71 : Liste des pays du standard ISO-3166-1
72
		Ontologie::chargerListe(1074);
73
 
130 jpm 74
		$guid_id_valeur = Config::get('guid_id_structure').$donnees['cs_id_structure'];
195 aurelien 75
		$donnees['_guid_'] = sprintf(Config::get('guid'), $guid_id_valeur);
114 jpm 76
		$donnees['_date_fondation_'] = $this->formaterDate($donnees['cs_date_fondation'], aControleur::FMT_DATE);
113 jpm 77
		$donnees['_nbre_personne_'] = (empty($donnees['cs_nbre_personne'])) ? '' : $donnees['cs_nbre_personne'];
78
		$donnees['_acronyme_'] = $this->construireTxtTruck($donnees['cs_truk_identifiant_alternatif']);
79
		$donnees['_telephone_fax_'] = $this->construireTxtTruck($donnees['cs_truk_telephone']);
80
		$donnees['_type_prive_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_prive']);
81
		$donnees['_type_public_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_type_public']);
82
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_pays']);
83
		$donnees['_web_'] = $this->construireTxtTruckSansMajuscule($donnees['cs_truk_url']);
84
		$donnees['_courriel_'] = $this->formaterCourriels($donnees['cs_courriel']);
85
 
86
		$latitude = $donnees['cs_latitude'];
87
		$longitude = $donnees['cs_longitude'];
88
		$donnees['_latitude_longitude_'] = ($longitude != '' && $latitude != '') ? "$latitude / $longitude" : '';
89
		$donnees['_latitude_dcm_en_'] = ($latitude != '') ? str_replace(',', '.', $latitude) : '';
90
		$donnees['_longitude_dcm_en_'] = ($longitude != '') ? str_replace(',', '.', $longitude) : '';
91
		$donnees['_lien_carte_'] = sprintf(Config::get('lien_vers_carte'), $donnees['_latitude_dcm_en_'], $donnees['_longitude_dcm_en_']);
92
		$donnees['_url_img_carte_'] = sprintf(Config::get('url_img'), Config::get('img_carte'));
93
 
94
	}
95
 
96
	private function traiterDonneesStructureConservation(&$donnees) {
97
		// liste 15 : Liste des types de local de stockage de collections
98
		Ontologie::chargerListe(1018);
99
		// liste 16 : Liste des types de mobilier de stockage de collections
100
		Ontologie::chargerListe(1019);
101
		// liste 17 : Liste des paramètres de contrôle environnemental d'un local
102
		Ontologie::chargerListe(1020);
103
		// liste 18 : Liste des types de collection non botanique
104
		Ontologie::chargerListe(1021);
105
		// liste 19 : Liste des types d'opération de restauration pour les collections botaniques
106
		Ontologie::chargerListe(1022);
107
		// liste 20 : Liste oui/non/en partie
108
		Ontologie::chargerListe(1023);
109
		// liste 21 : Liste du matériel dit de nom conservation des parts d'herbier
110
		Ontologie::chargerListe(1024);
111
 
112
		$donnees['_formation_'] = $this->formaterOuiNon($donnees['csc_mark_formation']);
113
		$donnees['_formation_info_'] = $this->formaterParenthese($donnees['csc_formation']);
114
		$donnees['_formation_info_'] = $this->formaterSautDeLigne($donnees['_formation_info_']);
115
		$donnees['_formation_interet_'] = $this->formaterOuiNon($donnees['csc_mark_formation_interet']);
116
		$donnees['_stockage_local_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_local']);
117
		$donnees['_stockage_meuble_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_meuble']);
118
		$donnees['_stockage_parametre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_parametre']);
119
		$donnees['_collection_commune_'] = $this->formaterOuiNon($donnees['csc_mark_collection_commune']);
120
		$donnees['_collection_commune_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_collection_autre']);
121
		$donnees['_collection_commune_autre_'] = $this->formaterParenthese($donnees['_collection_commune_autre_']);
122
		$donnees['_acces_controle_'] = $this->formaterOuiNon($donnees['csc_mark_acces_controle']);
123
		$donnees['_restauration_'] = $this->formaterOuiNon($donnees['csc_mark_restauration']);
124
		$donnees['_restauration_operation_'] = $this->construireTxtListeOntologie($donnees['csc_truk_restauration_operation']);
125
		$donnees['_restauration_operation_'] = $this->formaterParenthese($donnees['_restauration_operation_']);
126
		$donnees['_materiel_conservation_'] = $this->construireTxtListeOntologie($donnees['csc_ce_materiel_conservation']);
127
		$donnees['_materiel_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_materiel_autre']);
128
		$donnees['_materiel_autre_'] = $this->formaterParenthese($donnees['_materiel_autre_']);
129
		$donnees['_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_traitement']);
130
		$donnees['_traitement_liste_'] = $this->construireTxtListeOntologie($donnees['csc_truk_traitement']);
131
		$donnees['_traitement_liste_'] = $this->formaterParenthese($donnees['_traitement_liste_']);
132
		$donnees['_acquisition_collection_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_collection']);
133
		$donnees['_acquisition_echantillon_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_echantillon']);
134
		if ($donnees['csc_mark_acquisition_echantillon'] == '1') {
135
			$donnees['_acquisition_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_traitement']);
136
			if ($donnees['csc_mark_acquisition_traitement'] == '1') {
137
				$donnees['_acquisition_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_poison']);
138
				$donnees['_acquisition_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_insecte']);
139
			}
140
		}
141
	}
142
 
143
	private function traiterDonneesStructureValorisation(&$donnees) {
144
		// liste 24 : Liste des actions de valorisation des collections
145
		Ontologie::chargerListe(1027);
146
		// liste 25 : Liste des continents habités incluant aussi le pays France
147
		Ontologie::chargerListe(1028);
148
		// liste 26 : Liste des types de recherche nécessitant la consultation de collection botanique
149
		Ontologie::chargerListe(1029);
150
 
151
		$donnees['_action_'] = $this->formaterOuiNon($donnees['csv_mark_action']);
152
		$donnees['_action_info_'] = $this->construireTxtListeOntologie($donnees['csv_truk_action']);
153
		$donnees['_action_info_'] = $this->formaterParenthese($donnees['_action_info_']);
154
		$donnees['_collection_autre_'] = $this->construireTxtListeOntologie($donnees['csv_collection_autre']);
155
		$donnees['_action_future_'] = $this->formaterOuiNon($donnees['csv_mark_action_future']);
156
		$donnees['_action_future_info_'] = $this->formaterParenthese($donnees['csv_action_future']);
157
		$donnees['_recherche_'] = $this->formaterOuiNon($donnees['csv_mark_recherche']);
158
		if ($donnees['csv_mark_recherche'] == '1') {
159
			$donnees['_recherche_provenance_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_provenance']);
160
			$donnees['_recherche_type_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_type']);
161
		}
162
		$donnees['_acces_ss_motif_'] = $this->formaterOuiNon($donnees['csv_mark_acces_ss_motif']);
163
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
164
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
165
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
166
	}
167
 
150 jpm 168
	private function creerPaginationCollections($id_structure) {
169
		// Gestion du nombre de résultats
170
		$donnees_total = $this->collectionDao->getNbreParIdStructure($id_structure);
171
 
172
		// Gestion du fragmenteur
173
		$urlFiche = $this->obtenirObjetUrlFicheStructure($id_structure);
174
		$options = array(
175
			'url' => $urlFiche,
176
			'donnees_total' => $donnees_total,
177
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
178
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
179
		);
180
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
181
		$this->donnees['collectionsFrag'] = $fragmenteur->executer();
182
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
183
		$this->url->unsetVariablesRequete(array('page'));
184
 
185
		// Gestion de l'accès aux données
186
		$this->collectionDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
187
		$this->collectionDao->setDistinction(1);
188
		$this->donnees['collections'] = $this->collectionDao->getParIdStructure($id_structure);
189
		$this->traiterDonneesStructureCollections($this->donnees['collections']);
190
	}
191
 
113 jpm 192
	private function traiterDonneesStructureCollections(&$collections) {
193
		foreach ($collections as &$collection) {
194
			$collection['_url_'] = $this->obtenirUrlFicheCollection($collection['cc_id_collection']);
195
		}
196
	}
197
 
150 jpm 198
	private function creerPaginationPersonnel($id_structure) {
199
		// Gestion du nombre de résultats
200
		$donnees_total = $this->structureDao->getNbrePersonnel($id_structure);
201
 
202
		// Gestion du fragmenteur
203
		$urlFiche = $this->obtenirObjetUrlFicheStructure($id_structure);
204
		$options = array(
205
			'url' => $urlFiche,
206
			'donnees_total' => $donnees_total,
207
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
208
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
209
		);
210
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
211
		$this->donnees['personnelFrag'] = $fragmenteur->executer();
212
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
213
		$this->url->unsetVariablesRequete(array('page'));
214
 
215
		// Gestion de l'accès aux données
216
		$this->structureDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
217
		$this->structureDao->setDistinction(1);
218
		$this->donnees['personnel'] = $this->structureDao->getPersonnel($id_structure);
219
		$this->traiterPersonnel($this->donnees['personnel']);
220
	}
221
 
113 jpm 222
	private function traiterPersonnel(&$donnees) {
223
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
224
		Ontologie::chargerListe(1012);
225
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
226
		Ontologie::chargerListe(1013);
227
 
228
		foreach ($donnees as &$personnel) {
229
			$personnel['_fonction_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_fonction']);
230
			$personnel['_statut_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_statut']);
231
			$personnel['_tel_fax_'] = $this->construireTxtListeOntologie($personnel['cp_truk_telephone']);
232
			$personnel['_courriel_'] = $this->traiterTxtTruck($personnel['cp_truk_courriel']);
233
			$personnel['_courriel_'] = $this->formaterCourriels($personnel['_courriel_']);
234
			$personnel['_contact_'] = $this->formaterOuiNon($personnel['csap_mark_contact']);
235
			$personnel['_specialite_'] = $this->construireTxtListeOntologie($personnel['cp_ce_truk_specialite']);
118 jpm 236
			$personnel['_url_'] = $this->obtenirUrlFichePersonne($personnel['csap_id_personne']);
113 jpm 237
		}
238
	}
239
}