Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 150 | Details | Compare with Previous | 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'];
113 jpm 75
		$donnees['_guid_'] = sprintf(Config::get('guid'), Config::get('guid_projet'), $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['_region_'] = Ontologie::getValeurNom($donnees['cs_ce_truk_region']);
83
		$donnees['_pays_'] = $this->construireTxtListeOntologie($donnees['cs_ce_truk_pays']);
84
		$donnees['_web_'] = $this->construireTxtTruckSansMajuscule($donnees['cs_truk_url']);
85
		$donnees['_courriel_'] = $this->formaterCourriels($donnees['cs_courriel']);
86
 
87
		$latitude = $donnees['cs_latitude'];
88
		$longitude = $donnees['cs_longitude'];
89
		$donnees['_latitude_longitude_'] = ($longitude != '' && $latitude != '') ? "$latitude / $longitude" : '';
90
		$donnees['_latitude_dcm_en_'] = ($latitude != '') ? str_replace(',', '.', $latitude) : '';
91
		$donnees['_longitude_dcm_en_'] = ($longitude != '') ? str_replace(',', '.', $longitude) : '';
92
		$donnees['_lien_carte_'] = sprintf(Config::get('lien_vers_carte'), $donnees['_latitude_dcm_en_'], $donnees['_longitude_dcm_en_']);
93
		$donnees['_url_img_carte_'] = sprintf(Config::get('url_img'), Config::get('img_carte'));
94
 
95
	}
96
 
97
	private function traiterDonneesStructureConservation(&$donnees) {
98
		// liste 15 : Liste des types de local de stockage de collections
99
		Ontologie::chargerListe(1018);
100
		// liste 16 : Liste des types de mobilier de stockage de collections
101
		Ontologie::chargerListe(1019);
102
		// liste 17 : Liste des paramètres de contrôle environnemental d'un local
103
		Ontologie::chargerListe(1020);
104
		// liste 18 : Liste des types de collection non botanique
105
		Ontologie::chargerListe(1021);
106
		// liste 19 : Liste des types d'opération de restauration pour les collections botaniques
107
		Ontologie::chargerListe(1022);
108
		// liste 20 : Liste oui/non/en partie
109
		Ontologie::chargerListe(1023);
110
		// liste 21 : Liste du matériel dit de nom conservation des parts d'herbier
111
		Ontologie::chargerListe(1024);
112
 
113
		$donnees['_formation_'] = $this->formaterOuiNon($donnees['csc_mark_formation']);
114
		$donnees['_formation_info_'] = $this->formaterParenthese($donnees['csc_formation']);
115
		$donnees['_formation_info_'] = $this->formaterSautDeLigne($donnees['_formation_info_']);
116
		$donnees['_formation_interet_'] = $this->formaterOuiNon($donnees['csc_mark_formation_interet']);
117
		$donnees['_stockage_local_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_local']);
118
		$donnees['_stockage_meuble_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_meuble']);
119
		$donnees['_stockage_parametre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_stockage_parametre']);
120
		$donnees['_collection_commune_'] = $this->formaterOuiNon($donnees['csc_mark_collection_commune']);
121
		$donnees['_collection_commune_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_collection_autre']);
122
		$donnees['_collection_commune_autre_'] = $this->formaterParenthese($donnees['_collection_commune_autre_']);
123
		$donnees['_acces_controle_'] = $this->formaterOuiNon($donnees['csc_mark_acces_controle']);
124
		$donnees['_restauration_'] = $this->formaterOuiNon($donnees['csc_mark_restauration']);
125
		$donnees['_restauration_operation_'] = $this->construireTxtListeOntologie($donnees['csc_truk_restauration_operation']);
126
		$donnees['_restauration_operation_'] = $this->formaterParenthese($donnees['_restauration_operation_']);
127
		$donnees['_materiel_conservation_'] = $this->construireTxtListeOntologie($donnees['csc_ce_materiel_conservation']);
128
		$donnees['_materiel_autre_'] = $this->construireTxtListeOntologie($donnees['csc_truk_materiel_autre']);
129
		$donnees['_materiel_autre_'] = $this->formaterParenthese($donnees['_materiel_autre_']);
130
		$donnees['_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_traitement']);
131
		$donnees['_traitement_liste_'] = $this->construireTxtListeOntologie($donnees['csc_truk_traitement']);
132
		$donnees['_traitement_liste_'] = $this->formaterParenthese($donnees['_traitement_liste_']);
133
		$donnees['_acquisition_collection_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_collection']);
134
		$donnees['_acquisition_echantillon_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_echantillon']);
135
		if ($donnees['csc_mark_acquisition_echantillon'] == '1') {
136
			$donnees['_acquisition_traitement_'] = $this->formaterOuiNon($donnees['csc_mark_acquisition_traitement']);
137
			if ($donnees['csc_mark_acquisition_traitement'] == '1') {
138
				$donnees['_acquisition_traitement_poison_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_poison']);
139
				$donnees['_acquisition_traitement_insecte_'] = $this->construireTxtListeOntologie($donnees['csc_truk_acquisition_traitement_insecte']);
140
			}
141
		}
142
	}
143
 
144
	private function traiterDonneesStructureValorisation(&$donnees) {
145
		// liste 24 : Liste des actions de valorisation des collections
146
		Ontologie::chargerListe(1027);
147
		// liste 25 : Liste des continents habités incluant aussi le pays France
148
		Ontologie::chargerListe(1028);
149
		// liste 26 : Liste des types de recherche nécessitant la consultation de collection botanique
150
		Ontologie::chargerListe(1029);
151
 
152
		$donnees['_action_'] = $this->formaterOuiNon($donnees['csv_mark_action']);
153
		$donnees['_action_info_'] = $this->construireTxtListeOntologie($donnees['csv_truk_action']);
154
		$donnees['_action_info_'] = $this->formaterParenthese($donnees['_action_info_']);
155
		$donnees['_collection_autre_'] = $this->construireTxtListeOntologie($donnees['csv_collection_autre']);
156
		$donnees['_action_future_'] = $this->formaterOuiNon($donnees['csv_mark_action_future']);
157
		$donnees['_action_future_info_'] = $this->formaterParenthese($donnees['csv_action_future']);
158
		$donnees['_recherche_'] = $this->formaterOuiNon($donnees['csv_mark_recherche']);
159
		if ($donnees['csv_mark_recherche'] == '1') {
160
			$donnees['_recherche_provenance_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_provenance']);
161
			$donnees['_recherche_type_'] = $this->construireTxtListeOntologie($donnees['csv_truk_recherche_type']);
162
		}
163
		$donnees['_acces_ss_motif_'] = $this->formaterOuiNon($donnees['csv_mark_acces_ss_motif']);
164
		$donnees['_acces_ss_motif_info_'] = $this->formaterParenthese($donnees['csv_acces_ss_motif']);
165
		$donnees['_visite_avec_motif_'] = $this->formaterOuiNon($donnees['csv_mark_visite_avec_motif']);
166
		$donnees['_visite_avec_motif_info_'] = $this->formaterParenthese($donnees['csv_visite_avec_motif']);
167
	}
168
 
150 jpm 169
	private function creerPaginationCollections($id_structure) {
170
		// Gestion du nombre de résultats
171
		$donnees_total = $this->collectionDao->getNbreParIdStructure($id_structure);
172
 
173
		// Gestion du fragmenteur
174
		$urlFiche = $this->obtenirObjetUrlFicheStructure($id_structure);
175
		$options = array(
176
			'url' => $urlFiche,
177
			'donnees_total' => $donnees_total,
178
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
179
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
180
		);
181
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
182
		$this->donnees['collectionsFrag'] = $fragmenteur->executer();
183
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
184
		$this->url->unsetVariablesRequete(array('page'));
185
 
186
		// Gestion de l'accès aux données
187
		$this->collectionDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
188
		$this->collectionDao->setDistinction(1);
189
		$this->donnees['collections'] = $this->collectionDao->getParIdStructure($id_structure);
190
		$this->traiterDonneesStructureCollections($this->donnees['collections']);
191
	}
192
 
113 jpm 193
	private function traiterDonneesStructureCollections(&$collections) {
194
		foreach ($collections as &$collection) {
195
			$collection['_url_'] = $this->obtenirUrlFicheCollection($collection['cc_id_collection']);
196
		}
197
	}
198
 
150 jpm 199
	private function creerPaginationPersonnel($id_structure) {
200
		// Gestion du nombre de résultats
201
		$donnees_total = $this->structureDao->getNbrePersonnel($id_structure);
202
 
203
		// Gestion du fragmenteur
204
		$urlFiche = $this->obtenirObjetUrlFicheStructure($id_structure);
205
		$options = array(
206
			'url' => $urlFiche,
207
			'donnees_total' => $donnees_total,
208
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
209
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
210
		);
211
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
212
		$this->donnees['personnelFrag'] = $fragmenteur->executer();
213
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
214
		$this->url->unsetVariablesRequete(array('page'));
215
 
216
		// Gestion de l'accès aux données
217
		$this->structureDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
218
		$this->structureDao->setDistinction(1);
219
		$this->donnees['personnel'] = $this->structureDao->getPersonnel($id_structure);
220
		$this->traiterPersonnel($this->donnees['personnel']);
221
	}
222
 
113 jpm 223
	private function traiterPersonnel(&$donnees) {
224
		// liste 09 : Liste des fonctions d'une personne au sein d'une structure
225
		Ontologie::chargerListe(1012);
226
		// liste 10 : Liste des statuts d'une personne au sein d'une structure
227
		Ontologie::chargerListe(1013);
228
 
229
		foreach ($donnees as &$personnel) {
230
			$personnel['_fonction_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_fonction']);
231
			$personnel['_statut_'] = $this->construireTxtListeOntologie($personnel['csap_ce_truk_statut']);
232
			$personnel['_tel_fax_'] = $this->construireTxtListeOntologie($personnel['cp_truk_telephone']);
233
			$personnel['_courriel_'] = $this->traiterTxtTruck($personnel['cp_truk_courriel']);
234
			$personnel['_courriel_'] = $this->formaterCourriels($personnel['_courriel_']);
235
			$personnel['_contact_'] = $this->formaterOuiNon($personnel['csap_mark_contact']);
236
			$personnel['_specialite_'] = $this->construireTxtListeOntologie($personnel['cp_ce_truk_specialite']);
118 jpm 237
			$personnel['_url_'] = $this->obtenirUrlFichePersonne($personnel['csap_id_personne']);
113 jpm 238
		}
239
	}
240
}