Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
424 jpm 1
<?php
575 jpm 2
// declare(encoding='UTF-8');
424 jpm 3
/**
4
 * Service fournissant une carte dynamique des obsertions publiques du CEL.
5
 * Encodage en entrée : utf8
6
 * Encodage en sortie : utf8
7
 *
575 jpm 8
 * Cas d'utilisation et documentation :
9
 * @link http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=AideCELWidgetCarto
424 jpm 10
 *
575 jpm 11
 * Paramètres :
12
 * ===> utilisateur = identifiant
13
 * Affiche seulement les observations d'un utilisateur donné. L'identifiant correspond au courriel de
14
 * l'utilisateur avec lequel il s'est inscrit sur Tela Botanica.
15
 * ===> dept = code_du_département
16
 * Affiche seulement les observations pour le département français métropolitain indiqué. Les codes de département utilisables
17
 * sont : 01 à 19, 2A, 2B et 21 à 95.
18
 * ===> projet = mot-clé
19
 * Affiche seulement les observations pour le projet d'observations indiqué. Dans l'interface du CEL, vous pouvez taguer vos
20
 * observations avec un mot-clé de projet. Si vous voulez regrouper des observations de plusieurs utilisateurs, communiquez un
21
 * mot-clé de projet à vos amis et visualisez les informations ainsi regroupées.
22
 * ===> num_taxon = num_taxon
23
 * Affiche seulement les observations pour la plante indiquée. Le num_taxon correspond au numéro taxonomique de la plante.
24
 * Ce numéro est disponible dans les fiches d'eFlore. Par exemple, pour "Poa bulbosa L." le numéro taxonomique vaut 7080.
25
 *
26
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
27
 * @license	GPL v3 <http://www.gnu.org/licenses/gpl.txt>
28
 * @license	CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
29
 * @version	$Id$
30
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
424 jpm 31
 */
32
class Carto extends WidgetCommun {
464 delphine 33
	const DS = DIRECTORY_SEPARATOR;
471 jpm 34
	const SERVICE_DEFAUT = 'carte-defaut';
424 jpm 35
 
36
	/**
575 jpm 37
	 * Méthode appelée par défaut pour charger ce widget.
424 jpm 38
	 */
39
	public function executer() {
40
		$retour = null;
41
		extract($this->parametres);
42
 
503 jpm 43
		if (!isset($carte)) {
44
			$carte = self::SERVICE_DEFAUT;
471 jpm 45
		}
46
 
47
		$methode = $this->traiterNomMethodeExecuter($carte);
48
		if (method_exists($this, $methode)) {
49
			$retour = $this->$methode();
424 jpm 50
		} else {
471 jpm 51
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
424 jpm 52
		}
53
 
54
		if (is_null($retour)) {
55
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
56
			$this->envoyer($info);
57
		} else {
543 jpm 58
			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$retour['squelette'].'.tpl.html';
424 jpm 59
			$html = $this->traiterSquelettePhp($squelette, $retour['donnees']);
60
			$this->envoyer($html);
61
		}
62
	}
63
 
64
	/**
65
	 * Carte par défaut
66
	 */
67
	public function executerCarteDefaut() {
68
		$widget = null;
69
		extract($this->parametres);
479 jpm 70
		$utilisateur = (isset($utilisateur) ? $utilisateur : '*');
490 jpm 71
		$projet = (isset($projet) ? $projet : '*');
72
		$dept = (isset($dept) ? $dept : '*');
73
		$num_taxon = (isset($num_taxon) ? $num_taxon : '*');
479 jpm 74
 
424 jpm 75
		// Création url données json
490 jpm 76
		$url_cel_carto = sprintf($this->config['chemins']['baseURLServicesCelTpl'], 'CelWidgetMap');
77
		$url_json = "$url_cel_carto/carte-defaut-json/$utilisateur/$projet/$dept/$num_taxon";
484 delphine 78
 
424 jpm 79
		$url_base = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
80
 
81
		// Création des infos du widget
490 jpm 82
		$widget['donnees']['url_cel_carto'] = $url_cel_carto;
424 jpm 83
		$widget['donnees']['url_json'] = $url_json;
84
		$widget['donnees']['url_base'] = $url_base;
543 jpm 85
		$widget['donnees']['jquery_version'] = '1.4.4';
479 jpm 86
		$widget['donnees']['utilisateur'] = $utilisateur;
490 jpm 87
		$widget['donnees']['projet'] = $projet;
88
		$widget['donnees']['dept'] = $dept;
89
		$widget['donnees']['num_taxon'] = $num_taxon;
90
		$widget['donnees']['taxons'] = $this->chargerTaxons();
559 jpm 91
		if ($num_taxon != '*') {
92
			$taxon_courrant = current($widget['donnees']['taxons']);
93
			$widget['donnees']['taxon_nom'] = $taxon_courrant['nom'];
94
		}
424 jpm 95
		$widget['squelette'] = 'carte_defaut';
464 delphine 96
 
97
		if (isset($dept)) {
98
			// si on veut afficher les limites départemmentales on va compter et chercher les noms de fichiers
99
			$fichiersKml = $this->chercherFichierKml($dept);
574 jpm 100
			foreach ($fichiersKml as $dossier => $kml){
101
				$url_limites_communales = sprintf($this->config['carto']['limitesCommunaleUrlTpl'], $dossier, $kml);
464 delphine 102
				$widget['donnees']['url_limites_communales'][] = $url_limites_communales;
103
			}
104
		}
465 delphine 105
 
424 jpm 106
		return $widget;
107
	}
464 delphine 108
 
490 jpm 109
	private function chargerTaxons() {
110
		extract($this->parametres);
111
		$utilisateur = (isset($utilisateur) ? $utilisateur : '*');
112
		$projet = (isset($projet) ? $projet : '*');
113
		$dept = (isset($dept) ? $dept : '*');
114
		$num_taxon = (isset($num_taxon) ? $num_taxon : '*');
115
 
116
		// Récupération des données au format Json
117
		$service = "CelWidgetMap/taxons/$utilisateur/$projet/$dept/$num_taxon";
118
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], $service);
119
		$json = $this->getDao()->envoyerRequeteConsultation($url);
120
		$donnees = json_decode($json);
121
 
122
		// Post-traitement des données
123
		$taxons = $this->traiterTaxons($donnees);
124
 
125
		return $taxons;
126
	}
127
 
128
	private function traiterTaxons($donnees) {
129
		$taxons = array();
130
		if (is_array($donnees) && count($donnees) > 0) {
131
			foreach ($donnees as $donnee) {
534 jpm 132
				if (!isset($taxons[$donnee->num_taxon]) && ! $this->etreVide($donnee->nom_ret)) {
490 jpm 133
					$taxon = array();
134
					$taxon['nn'] = $donnee->num_nom_ret;
135
					$taxon['nt'] = $donnee->num_taxon;
136
					$taxon['nom'] = $this->nettoyerTexte($donnee->nom_ret);
137
					$taxon['famille'] = $this->nettoyerTexte($donnee->famille);
138
					$taxons[$donnee->num_taxon] = $taxon;
139
				}
140
			}
141
		}
142
		return $taxons;
143
	}
144
 
543 jpm 145
	private function chercherFichierKml($dept){
574 jpm 146
		$chemins = explode(',', $this->config['carto']['communesKmzChemin']);
147
		$fichiers = array();
148
		foreach ($chemins as $dossier_chemin) {
149
			if ($dossier_ressource = opendir($dossier_chemin)) {
150
				while ($element = readdir($dossier_ressource)) {
151
					if ($element != '.' && $element != '..') {
152
						$dept_protege = preg_quote($dept);
153
						if ((!is_dir($dossier_chemin.'/'.$element)) && (preg_match("/^$dept_protege(?:_[0-9]+|)\.km[lz]$/", $element))) {
154
							$fichiers[basename($dossier_chemin)] = $element;
155
						}
543 jpm 156
					}
464 delphine 157
				}
574 jpm 158
				closedir($dossier_ressource);
159
				if (count($fichiers) > 0) {
160
					break;
161
				}
464 delphine 162
			}
163
		}
574 jpm 164
		return $fichiers;
471 jpm 165
	}
166
 
167
	/**
168
	 * Tableau des observations d'une station
169
	 */
170
	public function executerObservations() {
171
		$widget = null;
172
		extract($this->parametres);
464 delphine 173
 
490 jpm 174
		$observations = $this->chargerObservation($station);
475 jpm 175
 
471 jpm 176
		// Création des infos du widget
475 jpm 177
		if (isset($observations['commune'])) {
178
			$commune = $observations['commune'];
179
			unset($observations['commune']);
180
			$widget['donnees']['commune'] = $commune;
181
		}
547 jpm 182
 
183
		$obs_ids = null;
184
		if (isset($observations['ids'])) {
185
			$obs_ids = $observations['ids'];
186
			unset($observations['ids']);
187
		}
188
		$widget['squelette'] = $this->choisirFormatSortie(count($observations));
189
 
190
		if ($widget['squelette'] == 'obs_liste' && $obs_ids != null && count($obs_ids) > 0) {
191
			$widget['donnees']['images'] = $this->chargerImages($obs_ids);
192
		}
193
 
471 jpm 194
		$widget['donnees']['observations'] = $observations;
195
		$widget['donnees']['station_id'] = $station;
196
 
197
		return $widget;
464 delphine 198
	}
471 jpm 199
 
490 jpm 200
	private function chargerObservation($station) {
201
		extract($this->parametres);
202
		$utilisateur = (isset($utilisateur) ? $utilisateur : '*');
203
		$projet = (isset($projet) ? $projet : '*');
204
		$dept = (isset($dept) ? $dept : '*');
205
		$num_taxon = (isset($num_taxon) ? $num_taxon : '*');
206
 
471 jpm 207
		// Récupération des données au format Json
490 jpm 208
		$service = "CelWidgetMap/observations/$station/$utilisateur/$projet/$dept/$num_taxon";
209
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], $service);
471 jpm 210
		$json = $this->getDao()->envoyerRequeteConsultation($url);
211
		$donnees = json_decode($json);
212
 
213
		// Post-traitement des données
214
		$observations = $this->traiterObservations($donnees);
215
 
216
		return $observations;
217
	}
218
 
219
	private function traiterObservations($donnees) {
220
		$observations = array();
221
		if (is_array($donnees) && count($donnees) > 0) {
222
			foreach ($donnees as $donnee) {
223
				$observation = array();
547 jpm 224
				$observation['id'] = $donnee->id;
507 jpm 225
				$observation['nn'] = $this->etreVide($donnee->num_nom_sel) ? null : $donnee->num_nom_sel;
471 jpm 226
				$observation['nom'] = $this->nettoyerTexte($donnee->nom_sel);
545 jpm 227
				$observation['date'] = $this->formaterDate($donnee->date_observation, '%d/%m/%Y');
471 jpm 228
				$observation['lieu'] = $this->traiterLieu($donnee);
229
				$observation['observateur'] = $this->tronquerCourriel($donnee->identifiant);
230
 
231
				$observations[] = $observation;
232
				$observations['commune'] = $this->nettoyerTexte($donnee->location);
547 jpm 233
				$observations['ids'][] = $donnee->id;
471 jpm 234
			}
235
		}
236
		return $observations;
237
	}
238
 
239
	private function traiterLieu($donnee) {
240
		$lieu = array();
241
		if (isset($donnee->lieudit) && ! empty($donnee->lieudit)) {
242
			$lieu[] = $donnee->lieudit;
243
		}
244
		if (isset($donnee->milieu) && ! empty($donnee->milieu)) {
245
			$lieu[] = $donnee->milieu;
246
		}
247
		return implode(', ', $lieu);
248
	}
249
 
250
	private function choisirFormatSortie($observations_nbre) {
251
		extract($this->parametres);
252
		$sortie = 'obs_tableau';
490 jpm 253
		if (isset($format) && $format != '*') {
471 jpm 254
			$sortie = ($format == 'tableau' ) ? 'obs_tableau' : 'obs_liste';
255
		} else {
256
			$sortie = ($observations_nbre > 4) ? 'obs_tableau' : 'obs_liste';
257
		}
258
		return $sortie;
259
	}
260
 
547 jpm 261
	private function chargerImages($obs_ids) {
262
		// Récupération des données au format Json
263
		$service = 'CelImage/liste-ids?obsId='.implode(',', $obs_ids);
264
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], $service);
265
		$json = $this->getDao()->envoyerRequeteConsultation($url);
266
		$donnees = json_decode($json);
267
 
268
		// Post-traitement des données
269
		$images = $this->traiterImages($donnees);
270
 
271
		return $images;
272
	}
273
 
274
	private function traiterImages($donnees) {
275
		$images = array();
276
		//echo '<br/><pre>'.print_r($donnees,true).'</pre>';
277
		if (count($donnees) > 0) {
278
			foreach ($donnees as $id_obs => $id_images) {
279
				foreach ($id_images as $id_img) {
280
					$urls['id'] = $id_img;
281
					$urls['S'] = $this->getUrlImage($id_img, 'S');
282
					$urls['L'] = $this->getUrlImage($id_img, 'L');
283
					$images[$id_obs][] = $urls;
284
				}
285
			}
286
		}
287
		return $images;
288
	}
289
 
501 jpm 290
	/**
291
	 * Afficher message d'avertissement.
292
	 */
293
	public function executerAvertissement() {
294
		$widget = null;
295
 
296
		// Création des infos du widget
297
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
298
		$widget['squelette'] = 'avertissement';
299
 
300
		return $widget;
301
	}
424 jpm 302
}