Subversion Repositories eFlore/Applications.cel

Rev

Rev 1056 | Rev 1209 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
712 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Widget fournissant des interfaces de saisies simplifiée pour différent projets.
5
 * Encodage en entrée : utf8
6
 * Encodage en sortie : utf8
7
 *
8
 * Cas d'utilisation et documentation :
9
 * @link http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=AideCELWidgetSaisie
10
 *
11
 * Paramètres :
12
 * ===> projet = chaine  [par défaut : Biodiversite34]
13
 * Indique quel projet nous voulons charger
14
 *
15
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
16
 * @license		GPL v3 <http://www.gnu.org/licenses/gpl.txt>
17
 * @license		CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
18
 * @version		$Id$
19
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
20
 */
21
class Saisie extends WidgetCommun {
1056 jpm 22
 
712 jpm 23
	const DS = DIRECTORY_SEPARATOR;
24
	const PROJET_DEFAUT = 'biodiversite34';
1056 jpm 25
	const WS_SAISIE = "CelWidgetSaisie";
26
 
719 jpm 27
	private $projet = null;
28
	private $configProjet = null;
1056 jpm 29
 
712 jpm 30
	/**
31
	 * Méthode appelée par défaut pour charger ce widget.
32
	 */
33
	public function executer() {
34
		$retour = null;
35
		extract($this->parametres);
36
 
37
		if (!isset($projet)) {
719 jpm 38
			$this->projet = self::PROJET_DEFAUT;
39
		} else {
40
			$this->projet = $projet;
712 jpm 41
		}
719 jpm 42
		$this->chargerConfigProjet();
1056 jpm 43
 
719 jpm 44
		$service = (isset($service)) ? $service : $this->projet;
45
		$methode = $this->traiterNomMethodeExecuter($service);
712 jpm 46
		if (method_exists($this, $methode)) {
47
			$retour = $this->$methode();
48
		} else {
49
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
50
		}
51
 
1056 jpm 52
		$contenu = null;
53
		$mime = null;
54
		if (is_array($retour) && array_key_exists('squelette', $retour)) {
719 jpm 55
			$ext = (isset($retour['squelette_ext'])) ? $retour['squelette_ext'] : '.tpl.html';
56
			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$this->projet.self::DS.$retour['squelette'].$ext;
712 jpm 57
			$contenu = $this->traiterSquelettePhp($squelette, $retour['donnees']);
1056 jpm 58
			$mime = isset($retour['mime']) ? $retour['mime'] : null;
59
		} else {
60
			if (count($this->messages) == 0) {
61
				$this->messages[] = "La méthode du sous-service ne renvoie pas les données dans le bon format.";
62
			}
63
			$contenu = 'Un problème est survenu : '.print_r($this->messages, true);
712 jpm 64
		}
1056 jpm 65
 
66
		$this->envoyer($contenu, $mime);
712 jpm 67
	}
1056 jpm 68
 
719 jpm 69
	private function chargerConfigProjet() {
70
		$fichier_config = dirname(__FILE__).self::DS.'configurations'.self::DS.$this->projet.'.ini';
71
		if (file_exists($fichier_config)) {
72
			if (!$this->configProjet	= parse_ini_file($fichier_config)) {
73
				$this->messages[] = "Le fichier ini '$fichier_config' du projet n'a pu être chargé.";
1056 jpm 74
			}
719 jpm 75
		} else {
76
			$this->messages[] = "Le fichier ini '$fichier_config' du projet n'existe pas.";
77
		}
78
	}
1056 jpm 79
 
719 jpm 80
	public function executerTaxons() {
81
		$widget['squelette'] = $this->projet.'_taxons';
82
		$widget['squelette_ext'] = '.tpl.js';
83
		$widget['donnees'] = array();
84
		$methode = 'recupererListeTaxon'.str_replace(' ', '', ucwords(str_replace('-', ' ', strtolower($this->projet))));
85
		$taxons = $this->$methode();
86
		$taxons_tries = array();
87
		foreach ($taxons as $taxon) {
88
			$taxons_tries[$taxon['num_nom_sel']] = $taxon;
89
		}
90
		$widget['donnees']['taxons'] = json_encode($taxons_tries);
91
		return  $widget;
92
	}
1056 jpm 93
 
94
	public function executerUploadImage() {
1123 jpm 95
		$retour = array(
96
			'squelette' => $this->projet.'_image',
97
			'squelette_ext' => '.tpl.xml',
98
			'mime' => 'text/xml',
99
			'donnees' => array(
100
				'urlMiniature' => '',
101
				'imageNom' => '',
102
				'message' => '',
103
				'debogage' => ''));
104
		$message = '';
105
		$debogage = '';
106
		if ($_FILES['fichier']['error'] == UPLOAD_ERR_OK) {
1056 jpm 107
			if (is_uploaded_file($_FILES['fichier']['tmp_name'])) {
108
				if ($_FILES['fichier']['type'] == 'image/jpeg') {
109
					$dossierStockage = $this->config['chemins']['imagesTempDossier'];
110
 
111
					$nomFichierOriginal = preg_replace('/[.](jpeg|jpg)$/i', '.jpg', strtolower($_FILES['fichier']['name']));
112
					$originalChemin = $dossierStockage.$nomFichierOriginal;
113
					$deplacementOk = move_uploaded_file($_FILES['fichier']['tmp_name'], $originalChemin);
114
 
115
					if ($deplacementOk === true) {
116
						$miniatureFichier = str_replace('.jpg', '_min.jpg', $nomFichierOriginal);
117
						$miniatureChemin = $dossierStockage.$miniatureFichier;
118
 
119
						// Parametres
120
						$largeurIdeale = 100;
121
						$hauteurIdeale = 100;
122
						$qualite = 85;
123
 
124
						// Calcul de la hauteur et de la largeur optimale de la miniature
125
						$taillesImgOriginale = getimagesize($originalChemin);
126
						$largeurOrigine = $taillesImgOriginale[0];
127
						$hauteurOrigine = $taillesImgOriginale[1];
128
 
129
						$largeurMin = $largeurIdeale;
130
						$hauteurMin = (int) ($hauteurOrigine * ($largeurIdeale / $largeurOrigine));
131
						if ($hauteurMin > $hauteurIdeale) {
132
							$hauteurMin = $hauteurIdeale;
133
							$largeurMin = (int)($largeurOrigine * ($hauteurMin / $hauteurOrigine));
134
						}
135
 
136
						// Création de la miniature
137
						$imageOriginale = imagecreatefromjpeg($originalChemin);
138
						$imageMiniature = imagecreatetruecolor($largeurMin, $hauteurMin);
139
						$couleurFond = imagecolorallocate($imageMiniature, 255, 255, 255);
140
						imagefill($imageMiniature, 0, 0, $couleurFond);
141
						imagecopyresized($imageMiniature, $imageOriginale, 0, 0, 0, 0, $largeurMin, $hauteurMin, $largeurOrigine, $hauteurOrigine);
142
						imagejpeg($imageMiniature, $miniatureChemin, $qualite);
143
						imagedestroy($imageMiniature);
144
						imagedestroy($imageOriginale);
145
 
146
						// Retour des infos
147
						$retour['donnees']['urlMiniature'] = sprintf($this->config['chemins']['imagesTempUrlTpl'], $miniatureFichier);
148
						$retour['donnees']['imageNom'] = $nomFichierOriginal;
149
					} else {
1123 jpm 150
						$message = "L'image n'a pu être déplacé sur le serveur.";
1056 jpm 151
					}
152
				} else {
1123 jpm 153
					$message = "L'image n'est pas au format JPEG.";
1056 jpm 154
				}
155
			} else {
1123 jpm 156
				$message = "L'image n'a pu être téléversée.";
157
				$debogage = $message.print_r($_FILES, true);
1056 jpm 158
			}
159
		} else {
1123 jpm 160
			if ($_FILES['fichier']['error'] == UPLOAD_ERR_FORM_SIZE) {
161
				$message = "L'image téléversée excède la taille maximum autorisée.".
162
					"Veuillez modifier votre image avant de la téléverser à nouveau.";
163
			} else {
164
				$message = "Une erreur de transfert a eu lieu (téléversement interrompu).";
165
			}
166
			$debogage = "Code erreur : {$_FILES['fichier']['error']}. ".
1056 jpm 167
				"Voir : http://php.net/manual/fr/features.file-upload.errors.php";
168
		}
1123 jpm 169
		// Retour des infos
170
		$retour['donnees']['message'] = $message;
171
		$retour['donnees']['debogage'] = $debogage;
1056 jpm 172
		return $retour;
173
	}
174
 
175
	public function executerBiodiversite34() {
176
		$widget['squelette'] = $this->projet;
177
		$widget['donnees'] = array();
178
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
179
		$widget['donnees']['url_ws_saisie'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_SAISIE);
180
 
181
		$widget['donnees']['taxons'] = $this->recupererListeTaxonBiodiversite34();
182
		$widget['donnees']['milieux'] = $this->parserMilieuxBiodiversite34();
183
		return  $widget;
184
	}
185
 
719 jpm 186
	private function parserMilieuxBiodiversite34() {
187
		$infosMilieux = array();
188
		$milieux = explode('|', $this->configProjet['milieux']);
189
		foreach ($milieux as $milieu) {
190
			$details = explode(';', $milieu);
191
			if (isset($details[1])) {
192
				$infosMilieux[$details[0]] = $details[1];
193
			} else {
194
				$infosMilieux[$details[0]] = '';
195
			}
196
		}
1056 jpm 197
		ksort($infosMilieux);
719 jpm 198
		return $infosMilieux;
199
	}
1056 jpm 200
 
712 jpm 201
	private function recupererListeTaxonBiodiversite34() {
202
		$taxons = null;
203
		$fichier_tsv = dirname(__FILE__).self::DS.'configurations'.self::DS.'biodiversite34_taxons.tsv';
204
		if (file_exists($fichier_tsv) && is_readable($fichier_tsv)) {
205
			$taxons = $this->decomposerFichierTsv($fichier_tsv);
206
		} else {
207
			$this->debug[] = "Impossible d'ouvrir le fichier '$fichier_tsv'.";
208
		}
1056 jpm 209
 
210
		$taxons_tries = self::trierTableauMd($taxons, array('nom_fr' => SORT_ASC));
211
 
212
		return $taxons_tries;
213
	}
214
 
215
	public function executerSauvages() {
216
		$widget['squelette'] = $this->projet;
217
		$widget['donnees'] = array();
218
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
219
		$widget['donnees']['url_ws_saisie'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_SAISIE);
220
 
221
		$widget['donnees']['taxons'] = $this->recupererListeTaxonSauvages();
222
		$widget['donnees']['milieux'] = $this->parserMilieuxSauvages();
223
		return  $widget;
224
	}
225
 
226
	private function parserMilieuxSauvages() {
227
		$infosMilieux = array();
228
		$milieux = explode('|', $this->configProjet['milieux']);
229
		foreach ($milieux as $milieu) {
230
			$details = explode(';', $milieu);
231
			if (isset($details[1])) {
232
				$infosMilieux[$details[0]] = $details[1];
233
			} else {
234
				$infosMilieux[$details[0]] = '';
235
			}
236
		}
237
		return $infosMilieux;
238
	}
239
 
240
	private function recupererListeTaxonSauvages() {
241
		$taxons = null;
242
		$fichier_tsv = dirname(__FILE__).self::DS.'configurations'.self::DS.'sauvages_taxons.tsv';
243
		if (file_exists($fichier_tsv) && is_readable($fichier_tsv)) {
244
			$taxons = $this->decomposerFichierTsv($fichier_tsv);
245
		} else {
246
			$this->debug[] = "Impossible d'ouvrir le fichier '$fichier_tsv'.";
247
		}
712 jpm 248
		return $taxons;
249
	}
1056 jpm 250
 
712 jpm 251
	private function decomposerFichierTsv($fichier, $delimiter = "\t"){
252
		$header = NULL;
253
	    $data = array();
254
	    if (($handle = fopen($fichier, 'r')) !== FALSE) {
255
	        while (($row = fgetcsv($handle, 1000, $delimiter)) !== FALSE) {
256
	            if (!$header) {
257
	                $header = $row;
1056 jpm 258
	            } else {
712 jpm 259
	                $data[] = array_combine($header, $row);
260
	            }
261
	        }
262
	        fclose($handle);
263
	    }
1056 jpm 264
	    return $data;
712 jpm 265
	}
266
}