Subversion Repositories eFlore/Applications.cel

Rev

Rev 3667 | 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;
3589 delphine 38
	private $num_taxon = false;
836 jpm 39
	private $utilisateur = null;
40
	private $projet = null;
41
	private $dept = null;
3589 delphine 42
	private $num_nom_ret = null;
836 jpm 43
	private $station = null;
44
	private $format = null;// Format des obs pour les stations (tableau/liste)
1438 aurelien 45
	private $photos = null; // Seulement les obs avec photos ou bien toutes
46
	private $titre = null; // Indication s'il faut le titre par défaut, personnalisé ou bien sans titre
47
	private $logo = null; // url du logo à ajouter si nécessaire
48
	private $url_site = null; // url du site auquel le logo est lié
1448 aurelien 49
	private $image = null; // url d'une image à ajouter dans l'interface
1494 aurelien 50
	private $nbjours = null; // nombre de jour à partir de la date courate pour lesquels on affiche les points
2291 mathias 51
	private $annee = null; // filtre par année
2681 aurelien 52
	private $referentiel = null;
53
	private $groupe_zones_geo = null; // Groupe de zones géographiques personnalisé
3038 mathias 54
	/** langue (traduction), charge un template de la forme "defaut_en.tpl.html" */
55
	protected $langue = null;
1586 jpm 56
 
424 jpm 57
	/**
575 jpm 58
	 * Méthode appelée par défaut pour charger ce widget.
424 jpm 59
	 */
60
	public function executer() {
61
		$retour = null;
836 jpm 62
		$this->extraireParametres();
3589 delphine 63
		if ($this->num_taxon == false) {
64
    		$methode = $this->traiterNomMethodeExecuter($this->carte);
65
    		if (method_exists($this, $methode)) {
66
    			$retour = $this->$methode();
67
    		} else {
68
    			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
69
    		}
70
    		if (is_null($retour)) {
71
    			$info = 'Un problème est survenu : '.print_r($this->messages, true);
72
    			$this->envoyer($info);
73
    		} else {
74
    			// Suffixe de template pour la langue - fr par défaut @TODO configurer ça un jour
75
    			$suffixeLangue = "";
76
    			if ($this->langue != null && $this->langue != "fr") {
77
    				$suffixeLangue = "_" . $this->langue;
78
    			}
79
    			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$retour['squelette'].$suffixeLangue.'.tpl.html';
80
    			$html = $this->traiterSquelettePhp($squelette, $retour['donnees']);
81
    			$this->envoyer($html);
82
    		}
424 jpm 83
		} else {
3593 delphine 84
		    $this->envoyer("Cette carto utilise le paramètre num_taxon pour afficher les observations liées à un taxon particulier.
3590 delphine 85
		        Ce paramètre n'est plus maintenu. Vous pouvez utiliser le paramètre num_nom_retenu pour réaliser
3593 delphine 86
		        un filtre sur le numéro nomenclatural du nom. En cas de problème, vous pouvez nous contacter via l'outil suivant : <br />
3592 delphine 87
		        <iframe style=\"width:650px;height:600px;\" src=\"https://www.tela-botanica.org/widget:reseau:remarques?lang=fr&service=cel&pageSource=tela-botanica.org/widget:cel:cartoPoint\"></iframe>");
424 jpm 88
		}
89
	}
1586 jpm 90
 
836 jpm 91
	public function extraireParametres() {
92
		extract($this->parametres);
3589 delphine 93
		$this->num_taxon  = (isset($num_taxon) ? true : false);
3594 delphine 94
		unset($this->parametres['num_taxon']);
836 jpm 95
		$this->carte = (isset($carte) ? $carte : self::SERVICE_CARTO_ACTION_DEFAUT);
96
		$this->utilisateur = (isset($utilisateur) ? $utilisateur : '*');
97
		$this->projet = (isset($projet) ? $projet : '*');
939 jpm 98
		$this->tag = (isset($tag) ? $tag : '*');
1475 aurelien 99
		$this->tag = (isset($motcle) ? $motcle : $this->tag);
3841 delphine 100
		if (isset($standard)) {
101
		    $this->standard = $standard;
102
		} elseif (isset($projet) && in_array($projet, array("sauvages", "messicoles",
103
		    "arbres-tetards", "arbres-remarquables","missions-flore", "tb_lichensgo", "tb_streets", "bellesdemarue"))) {
104
		    $this->standard = '0';
105
		} else {
106
		    $this->standard = '1';
107
		}
836 jpm 108
		$this->dept = (isset($dept) ? $dept : '*');
837 jpm 109
		$this->commune = (isset($commune) ? $commune : '*');
2561 aurelien 110
		$this->pays = (isset($pays) ? $pays : '*');
3589 delphine 111
		$this->num_nom_ret = (isset($num_nom_ret) ? $num_nom_ret : '*');
939 jpm 112
		$this->date = (isset($date) ? $date : '*');
113
		$this->taxon = (isset($taxon) ? $taxon : '*');
940 jpm 114
		$this->commentaire = (isset($commentaire) ? $commentaire : null);
836 jpm 115
		$this->station = (isset($station) ? $station : null);
116
		$this->format = (isset($format) ? $format : null);
1438 aurelien 117
		$this->photos = (isset($photos) ? $photos : null);
118
		$this->titre = (isset($titre) ? urldecode($titre) : null);
119
		$this->logo = (isset($logo) ? urldecode($logo) : null);
120
		$this->url_site = (isset($url_site) ? urldecode($url_site) : null);
1448 aurelien 121
		$this->image = (isset($image) ? urldecode($image) : null);
1494 aurelien 122
		$this->nbjours = (isset($nbjours) ? urldecode($nbjours) : null);
2291 mathias 123
		$this->annee = (isset($annee) ? urldecode($annee) : null);
1494 aurelien 124
		$this->referentiel = (isset($referentiel) ? urldecode($referentiel) : null);
2681 aurelien 125
		$this->groupe_zones_geo = (isset($groupe_zones_geo) ? urldecode($groupe_zones_geo) : null);
841 jpm 126
		$this->start = (isset($start) ? $start : null);
127
		$this->limit = (isset($limit) ? $limit : null);
3038 mathias 128
		// définition de la langue, en mode souple
129
		if (isset($this->parametres['lang'])) {
130
			$this->langue = $this->parametres['lang'];
131
		}
836 jpm 132
	}
424 jpm 133
 
134
	/**
135
	 * Carte par défaut
136
	 */
137
	public function executerCarteDefaut() {
138
		$widget = null;
939 jpm 139
		$url_stations = $this->contruireUrlServiceCarto('stations');
424 jpm 140
		$url_base = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
141
 
142
		// Création des infos du widget
836 jpm 143
		$widget['donnees']['url_cel_carto'] = $this->contruireUrlServiceCarto();
939 jpm 144
		$widget['donnees']['url_stations'] = $url_stations;
424 jpm 145
		$widget['donnees']['url_base'] = $url_base;
836 jpm 146
		$widget['donnees']['utilisateur'] = $this->utilisateur;
147
		$widget['donnees']['projet'] = $this->projet;
3601 delphine 148
		$widget['donnees']['standard'] = $this->standard;
939 jpm 149
		$widget['donnees']['tag'] = $this->tag;
836 jpm 150
		$widget['donnees']['dept'] = $this->dept;
837 jpm 151
		$widget['donnees']['commune'] = $this->commune;
2561 aurelien 152
		$widget['donnees']['pays'] = $this->pays;
3589 delphine 153
		$widget['donnees']['num_nom_ret'] = $this->num_nom_ret;
939 jpm 154
		$widget['donnees']['date'] = $this->date;
155
		$widget['donnees']['taxon'] = $this->taxon;
940 jpm 156
		$widget['donnees']['commentaire'] = $this->commentaire;
1438 aurelien 157
		$widget['donnees']['photos'] = $this->photos;
158
		$widget['donnees']['titre'] = $this->titre;
159
		$widget['donnees']['logo'] = $this->logo;
160
		$widget['donnees']['url_site'] = $this->url_site;
1448 aurelien 161
		$widget['donnees']['image'] = $this->image;
1494 aurelien 162
		$widget['donnees']['nbjours'] = $this->nbjours;
2291 mathias 163
		$widget['donnees']['annee'] = $this->annee;
1494 aurelien 164
		$widget['donnees']['referentiel'] = $this->referentiel;
2681 aurelien 165
		$widget['donnees']['groupe_zones_geo'] = $this->groupe_zones_geo;
939 jpm 166
		$widget['donnees']['url_limites_communales'] = $this->obtenirUrlsLimitesCommunales();
1091 aurelien 167
		$widget['donnees']['communeImageUrl'] = $this->config['carto']['communeImageUrl'];
168
		$widget['donnees']['pointImageUrl'] = $this->config['carto']['pointImageUrl'];
169
		$widget['donnees']['groupeImageUrlTpl'] = $this->config['carto']['groupeImageUrlTpl'];
1586 jpm 170
		$widget['donnees']['url_widget_saisie'] = $this->config['urls']['widgetSaisie'];
2848 mathias 171
		$widget['donnees']['prod'] = ($this->config['parametres']['modeServeur'] == "prod");
3198 killian 172
		$widget['donnees']['cleGoogleMaps'] = $this->config['api']['cleGoogleMapsCartoPoint'];
3085 mathias 173
		$widget['donnees']['baseURLServicesAnnuaireTpl'] = $this->config['chemins']['baseURLServicesAnnuaireTpl'];
174
		$widget['donnees']['baseURLServicesCelTpl'] = $this->config['chemins']['baseURLServicesCelTpl'];
1586 jpm 175
 
424 jpm 176
		$widget['squelette'] = 'carte_defaut';
1586 jpm 177
 
424 jpm 178
		return $widget;
179
	}
1586 jpm 180
 
836 jpm 181
	private function contruireUrlServiceCarto($action = null) {
182
		// Création url données json
183
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::SERVICE_CARTO_NOM);
184
		if ($action) {
185
			$url .= "/$action";
1586 jpm 186
 
836 jpm 187
			$parametres_retenus = array();
3601 delphine 188
			$parametres_a_tester = array('station', 'standard', 'utilisateur', 'projet', 'tag', 'dept', 'commune',
3589 delphine 189
				'num_nom_ret', 'taxon', 'date', 'commentaire', 'nbjours', 'referentiel','pays', 'groupe_zones_geo',
939 jpm 190
				'start', 'limit');
836 jpm 191
			foreach ($parametres_a_tester as $param) {
841 jpm 192
				if (isset($this->$param) && $this->$param != '*') {
836 jpm 193
					$parametres_retenus[$param] = $this->$param;
194
				}
195
			}
196
			if (count($parametres_retenus) > 0) {
197
				$parametres_url = array();
198
				foreach ($parametres_retenus as $cle => $valeur) {
199
					$parametres_url[] = $cle.'='.$valeur;
200
				}
201
				$url .= '?'.implode('&', $parametres_url);
202
			}
203
		}
1586 jpm 204
		return $url;
836 jpm 205
	}
1586 jpm 206
 
939 jpm 207
	private function obtenirUrlsLimitesCommunales() {
208
		$urls = null;
209
		if (isset($this->dept)) {
1096 aurelien 210
			// si on veut afficher les limites départementales on va compter et chercher les noms de fichiers
939 jpm 211
			$fichiersKml = $this->chercherFichierKml();
212
			if (count($fichiersKml) > 0) {
213
				foreach ($fichiersKml as $kml => $dossier){
214
					$url_limites_communales = sprintf($this->config['carto']['limitesCommunaleUrlTpl'], $dossier, $kml);
215
					$urls[] = $url_limites_communales;
490 jpm 216
				}
217
			}
218
		}
939 jpm 219
		$urls = json_encode($urls);
220
		return $urls;
490 jpm 221
	}
1586 jpm 222
 
836 jpm 223
	private function chercherFichierKml(){
939 jpm 224
		$fichiers = array();
1586 jpm 225
		if (isset($this->config['carto']['communesKmzChemin'])) {
226
			$chemins = explode(',', $this->config['carto']['communesKmzChemin']);
227
			$departements = explode(',', $this->dept);// plrs code de départements peuvent être demandés séparés par des virgules
228
			$departements_trouves = array();
229
			foreach ($chemins as $dossier_chemin) {
230
				if ($dossier_ressource = opendir($dossier_chemin)) {
231
					while ($element = readdir($dossier_ressource)) {
232
						if ($element != '.' && $element != '..') {
233
							foreach ($departements as $departement) {
234
								$nom_dossier = basename($dossier_chemin);
235
								if (!isset($departements_trouves[$departement]) || $departements_trouves[$departement] == $nom_dossier) {
236
									$dept_protege = preg_quote($departement);
237
									if (!is_dir($dossier_chemin.'/'.$element) && preg_match("/^$dept_protege(?:_[0-9]+|)\.km[lz]$/", $element)) {
238
										$fichiers[$element] = $nom_dossier;
239
										$departements_trouves[$departement] = $nom_dossier;
240
									}
599 jpm 241
								}
242
							}
574 jpm 243
						}
543 jpm 244
					}
1586 jpm 245
					closedir($dossier_ressource);
464 delphine 246
				}
247
			}
1586 jpm 248
		} else {
249
			$this->messages[] = 'Veuillez configurer le paramètres carto.communesKmzChemin.';
464 delphine 250
		}
574 jpm 251
		return $fichiers;
471 jpm 252
	}
1586 jpm 253
 
471 jpm 254
	/**
501 jpm 255
	 * Afficher message d'avertissement.
256
	 */
257
	public function executerAvertissement() {
258
		$widget = null;
259
 
260
		// Création des infos du widget
1452 aurelien 261
		$widget['donnees']['contenu_aide'] = $this->chargerAideWiki();
501 jpm 262
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
263
		$widget['squelette'] = 'avertissement';
1586 jpm 264
 
501 jpm 265
		return $widget;
266
	}
1586 jpm 267
 
1452 aurelien 268
	/**
269
	 * Charge le contenu du wikini demandé
270
	 */
271
	function chargerAideWiki() {
2007 mathias 272
		$url = str_replace('{page}','AideCarto',$this->config['carto']['aideWikiniUrlCartoPoint']);
1452 aurelien 273
		$infos_aide = file_get_contents($url);
1586 jpm 274
 
1452 aurelien 275
		$aide = '';
1586 jpm 276
 
1452 aurelien 277
		if($infos_aide != null && $infos_aide != '') {
278
			$infos_aide = json_decode($infos_aide);
279
			$infos_aide = (is_a($infos_aide, 'StdClass') && $infos_aide->texte != null) ? $infos_aide->texte : '';
280
		}
1586 jpm 281
 
1452 aurelien 282
		return $infos_aide;
283
	}
1091 aurelien 284
}
3085 mathias 285
?>