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 |
}
|