Subversion Repositories eFlore/Applications.cel

Rev

Rev 2572 | Details | Compare with Previous | 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
1586 jpm 13
 * Affiche seulement les observations d'un utilisateur donné. L'identifiant correspond au courriel de
575 jpm 14
 * l'utilisateur avec lequel il s'est inscrit sur Tela Botanica.
15
 * ===> dept = code_du_département
1586 jpm 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.
575 jpm 18
 * ===> projet = mot-clé
1586 jpm 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
575 jpm 21
 * mot-clé de projet à vos amis et visualisez les informations ainsi regroupées.
22
 * ===> num_taxon = num_taxon
1586 jpm 23
 * Affiche seulement les observations pour la plante indiquée. Le num_taxon correspond au numéro taxonomique de la plante.
575 jpm 24
 * Ce numéro est disponible dans les fiches d'eFlore. Par exemple, pour "Poa bulbosa L." le numéro taxonomique vaut 7080.
1586 jpm 25
 *
575 jpm 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
 */
1091 aurelien 32
class Cartopoint extends WidgetCommun {
464 delphine 33
	const DS = DIRECTORY_SEPARATOR;
1091 aurelien 34
	const SERVICE_CARTO_NOM = 'CelWidgetMapPoint';
836 jpm 35
	const SERVICE_CARTO_ACTION_DEFAUT = 'carte-defaut';
1586 jpm 36
 
836 jpm 37
	private $carte = null;
38
	private $utilisateur = null;
39
	private $projet = null;
40
	private $dept = null;
41
	private $num_taxon = null;
42
	private $station = null;
43
	private $format = null;// Format des obs pour les stations (tableau/liste)
1438 aurelien 44
	private $photos = null; // Seulement les obs avec photos ou bien toutes
45
	private $titre = null; // Indication s'il faut le titre par défaut, personnalisé ou bien sans titre
46
	private $logo = null; // url du logo à ajouter si nécessaire
47
	private $url_site = null; // url du site auquel le logo est lié
1448 aurelien 48
	private $image = null; // url d'une image à ajouter dans l'interface
2605 mathias 49
	private $nbjours = null; // nombre de jours à partir de la date courante pour lesquels on affiche les points
2291 mathias 50
	private $annee = null; // filtre par année
2605 mathias 51
	private $referentiel = null; // référentiel
52
	/** boîte englobante (bounding box), représentée par deux paires de coordonnées : gauche-bas / droite-haut
53
	 * http://wiki.openstreetmap.org/wiki/Bounding_Box
54
	 * (chaque bibliothèque donne les 4 coins dans un ordre différent... autant choisir celui-là)
55
	 * Exemple de paramètre: 43.6650177|3.8706364,43.7410594|4.0111413 (latS, lonO, latN, lonE)
56
	 */
57
	private $bbox = null;
1586 jpm 58
 
424 jpm 59
	/**
575 jpm 60
	 * Méthode appelée par défaut pour charger ce widget.
424 jpm 61
	 */
62
	public function executer() {
63
		$retour = null;
836 jpm 64
		$this->extraireParametres();
65
		$methode = $this->traiterNomMethodeExecuter($this->carte);
471 jpm 66
		if (method_exists($this, $methode)) {
67
			$retour = $this->$methode();
424 jpm 68
		} else {
471 jpm 69
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
424 jpm 70
		}
71
		if (is_null($retour)) {
72
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
73
			$this->envoyer($info);
74
		} else {
543 jpm 75
			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$retour['squelette'].'.tpl.html';
424 jpm 76
			$html = $this->traiterSquelettePhp($squelette, $retour['donnees']);
77
			$this->envoyer($html);
78
		}
79
	}
1586 jpm 80
 
836 jpm 81
	public function extraireParametres() {
82
		extract($this->parametres);
83
		$this->carte = (isset($carte) ? $carte : self::SERVICE_CARTO_ACTION_DEFAUT);
84
		$this->utilisateur = (isset($utilisateur) ? $utilisateur : '*');
85
		$this->projet = (isset($projet) ? $projet : '*');
939 jpm 86
		$this->tag = (isset($tag) ? $tag : '*');
1475 aurelien 87
		$this->tag = (isset($motcle) ? $motcle : $this->tag);
836 jpm 88
		$this->dept = (isset($dept) ? $dept : '*');
837 jpm 89
		$this->commune = (isset($commune) ? $commune : '*');
2561 aurelien 90
		$this->pays = (isset($pays) ? $pays : '*');
836 jpm 91
		$this->num_taxon = (isset($num_taxon) ? $num_taxon : '*');
939 jpm 92
		$this->date = (isset($date) ? $date : '*');
93
		$this->taxon = (isset($taxon) ? $taxon : '*');
940 jpm 94
		$this->commentaire = (isset($commentaire) ? $commentaire : null);
836 jpm 95
		$this->station = (isset($station) ? $station : null);
96
		$this->format = (isset($format) ? $format : null);
1438 aurelien 97
		$this->photos = (isset($photos) ? $photos : null);
98
		$this->titre = (isset($titre) ? urldecode($titre) : null);
99
		$this->logo = (isset($logo) ? urldecode($logo) : null);
100
		$this->url_site = (isset($url_site) ? urldecode($url_site) : null);
1448 aurelien 101
		$this->image = (isset($image) ? urldecode($image) : null);
1494 aurelien 102
		$this->nbjours = (isset($nbjours) ? urldecode($nbjours) : null);
2291 mathias 103
		$this->annee = (isset($annee) ? urldecode($annee) : null);
1494 aurelien 104
		$this->referentiel = (isset($referentiel) ? urldecode($referentiel) : null);
2605 mathias 105
		$this->bbox = (isset($bbox) ? urldecode($bbox) : null); // on s'emmerde pas à faire un tableau
841 jpm 106
		$this->start = (isset($start) ? $start : null);
107
		$this->limit = (isset($limit) ? $limit : null);
836 jpm 108
	}
424 jpm 109
 
110
	/**
111
	 * Carte par défaut
112
	 */
113
	public function executerCarteDefaut() {
114
		$widget = null;
939 jpm 115
		$url_stations = $this->contruireUrlServiceCarto('stations');
424 jpm 116
		$url_base = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
117
 
118
		// Création des infos du widget
836 jpm 119
		$widget['donnees']['url_cel_carto'] = $this->contruireUrlServiceCarto();
939 jpm 120
		$widget['donnees']['url_stations'] = $url_stations;
424 jpm 121
		$widget['donnees']['url_base'] = $url_base;
836 jpm 122
		$widget['donnees']['utilisateur'] = $this->utilisateur;
123
		$widget['donnees']['projet'] = $this->projet;
939 jpm 124
		$widget['donnees']['tag'] = $this->tag;
836 jpm 125
		$widget['donnees']['dept'] = $this->dept;
837 jpm 126
		$widget['donnees']['commune'] = $this->commune;
2561 aurelien 127
		$widget['donnees']['pays'] = $this->pays;
836 jpm 128
		$widget['donnees']['num_taxon'] = $this->num_taxon;
939 jpm 129
		$widget['donnees']['date'] = $this->date;
130
		$widget['donnees']['taxon'] = $this->taxon;
940 jpm 131
		$widget['donnees']['commentaire'] = $this->commentaire;
1438 aurelien 132
		$widget['donnees']['photos'] = $this->photos;
133
		$widget['donnees']['titre'] = $this->titre;
134
		$widget['donnees']['logo'] = $this->logo;
135
		$widget['donnees']['url_site'] = $this->url_site;
1448 aurelien 136
		$widget['donnees']['image'] = $this->image;
1494 aurelien 137
		$widget['donnees']['nbjours'] = $this->nbjours;
2291 mathias 138
		$widget['donnees']['annee'] = $this->annee;
1494 aurelien 139
		$widget['donnees']['referentiel'] = $this->referentiel;
2605 mathias 140
		$widget['donnees']['bbox'] = $this->bbox;
939 jpm 141
		$widget['donnees']['url_limites_communales'] = $this->obtenirUrlsLimitesCommunales();
1091 aurelien 142
		$widget['donnees']['communeImageUrl'] = $this->config['carto']['communeImageUrl'];
143
		$widget['donnees']['pointImageUrl'] = $this->config['carto']['pointImageUrl'];
144
		$widget['donnees']['groupeImageUrlTpl'] = $this->config['carto']['groupeImageUrlTpl'];
1586 jpm 145
		$widget['donnees']['url_widget_saisie'] = $this->config['urls']['widgetSaisie'];
146
 
424 jpm 147
		$widget['squelette'] = 'carte_defaut';
1586 jpm 148
 
424 jpm 149
		return $widget;
150
	}
1586 jpm 151
 
836 jpm 152
	private function contruireUrlServiceCarto($action = null) {
153
		// Création url données json
154
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::SERVICE_CARTO_NOM);
155
		if ($action) {
156
			$url .= "/$action";
1586 jpm 157
 
836 jpm 158
			$parametres_retenus = array();
1586 jpm 159
			$parametres_a_tester = array('station', 'utilisateur', 'projet', 'tag', 'dept', 'commune',
2561 aurelien 160
				'num_taxon', 'taxon', 'date', 'commentaire', 'nbjours', 'referentiel','pays',
939 jpm 161
				'start', 'limit');
836 jpm 162
			foreach ($parametres_a_tester as $param) {
841 jpm 163
				if (isset($this->$param) && $this->$param != '*') {
836 jpm 164
					$parametres_retenus[$param] = $this->$param;
165
				}
166
			}
167
			if (count($parametres_retenus) > 0) {
168
				$parametres_url = array();
169
				foreach ($parametres_retenus as $cle => $valeur) {
170
					$parametres_url[] = $cle.'='.$valeur;
171
				}
172
				$url .= '?'.implode('&', $parametres_url);
173
			}
174
		}
1586 jpm 175
		return $url;
836 jpm 176
	}
1586 jpm 177
 
939 jpm 178
	private function obtenirUrlsLimitesCommunales() {
179
		$urls = null;
180
		if (isset($this->dept)) {
1096 aurelien 181
			// si on veut afficher les limites départementales on va compter et chercher les noms de fichiers
939 jpm 182
			$fichiersKml = $this->chercherFichierKml();
183
			if (count($fichiersKml) > 0) {
184
				foreach ($fichiersKml as $kml => $dossier){
185
					$url_limites_communales = sprintf($this->config['carto']['limitesCommunaleUrlTpl'], $dossier, $kml);
186
					$urls[] = $url_limites_communales;
490 jpm 187
				}
188
			}
189
		}
939 jpm 190
		$urls = json_encode($urls);
191
		return $urls;
490 jpm 192
	}
1586 jpm 193
 
836 jpm 194
	private function chercherFichierKml(){
939 jpm 195
		$fichiers = array();
1586 jpm 196
		if (isset($this->config['carto']['communesKmzChemin'])) {
197
			$chemins = explode(',', $this->config['carto']['communesKmzChemin']);
198
			$departements = explode(',', $this->dept);// plrs code de départements peuvent être demandés séparés par des virgules
199
			$departements_trouves = array();
200
			foreach ($chemins as $dossier_chemin) {
201
				if ($dossier_ressource = opendir($dossier_chemin)) {
202
					while ($element = readdir($dossier_ressource)) {
203
						if ($element != '.' && $element != '..') {
204
							foreach ($departements as $departement) {
205
								$nom_dossier = basename($dossier_chemin);
206
								if (!isset($departements_trouves[$departement]) || $departements_trouves[$departement] == $nom_dossier) {
207
									$dept_protege = preg_quote($departement);
208
									if (!is_dir($dossier_chemin.'/'.$element) && preg_match("/^$dept_protege(?:_[0-9]+|)\.km[lz]$/", $element)) {
209
										$fichiers[$element] = $nom_dossier;
210
										$departements_trouves[$departement] = $nom_dossier;
211
									}
599 jpm 212
								}
213
							}
574 jpm 214
						}
543 jpm 215
					}
1586 jpm 216
					closedir($dossier_ressource);
464 delphine 217
				}
218
			}
1586 jpm 219
		} else {
220
			$this->messages[] = 'Veuillez configurer le paramètres carto.communesKmzChemin.';
464 delphine 221
		}
574 jpm 222
		return $fichiers;
471 jpm 223
	}
1586 jpm 224
 
471 jpm 225
	/**
501 jpm 226
	 * Afficher message d'avertissement.
227
	 */
228
	public function executerAvertissement() {
229
		$widget = null;
230
 
231
		// Création des infos du widget
1452 aurelien 232
		$widget['donnees']['contenu_aide'] = $this->chargerAideWiki();
501 jpm 233
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
234
		$widget['squelette'] = 'avertissement';
1586 jpm 235
 
501 jpm 236
		return $widget;
237
	}
1586 jpm 238
 
1452 aurelien 239
	/**
240
	 * Charge le contenu du wikini demandé
241
	 */
242
	function chargerAideWiki() {
2007 mathias 243
		$url = str_replace('{page}','AideCarto',$this->config['carto']['aideWikiniUrlCartoPoint']);
1452 aurelien 244
		$infos_aide = file_get_contents($url);
1586 jpm 245
 
1452 aurelien 246
		$aide = '';
1586 jpm 247
 
1452 aurelien 248
		if($infos_aide != null && $infos_aide != '') {
249
			$infos_aide = json_decode($infos_aide);
250
			$infos_aide = (is_a($infos_aide, 'StdClass') && $infos_aide->texte != null) ? $infos_aide->texte : '';
251
		}
1586 jpm 252
 
1452 aurelien 253
		return $infos_aide;
254
	}
1091 aurelien 255
}
256
?>