Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
3228 delphine 1
 <?php
3120 delphine 2
// declare(encoding='UTF-8');
3
/**
4
 * Service affichant les dernières photo publiques du CEL ouvrable sous forme de diaporama.
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=AideCELWidgetPhoto
10
 *
11
 * Paramètres :
12
 * ===> extra = booléen (1 ou 0)  [par défaut : 1]
13
 * Affiche / Cache la vignette en taille plus importante au bas du widget.
14
 * ===> vignette = [0-9]+,[0-9]+  [par défaut : 4,3]
15
 * Indique le nombre de vignette par ligne et le nombre de ligne.
16
 *
3228 delphine 17
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
18
 * @license	GPL v3 <http://www.gnu.org/licenses/gpl.txt>
19
 * @license	CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
20
 * @version	$Id$
21
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
3120 delphine 22
 */
23
class Saisie2 extends WidgetCommun {
3239 idir 24
 
3228 delphine 25
	const DS = DIRECTORY_SEPARATOR;
26
	const SERVICE_DEFAUT = 'saisie';
3240 idir 27
	const WS_SAISIE = 'CelWidgetSaisie';
28
	const WS_UPLOAD = 'CelWidgetUploadImageTemp';
29
	const WS_OBS = 'CelObs';
3228 delphine 30
	const LANGUE_DEFAUT = 'fr';
31
	const PROJET_DEFAUT = 'base';
32
	const WS_NOM = 'noms';
33
	const EFLORE_API_VERSION = '0.1';
34
	private $cel_url_tpl = null;
35
	/** Si spécifié, on ajoute une barre de navigation inter-applications */
36
	private $bar;
37
	//private $parametres_autorises = array('projet', 'type', 'langue', 'order');
38
	private $parametres_autorises = array(
39
			'projet' => 'projet',
40
			'type' => 'type',
41
			'langue' => 'langue',
42
			'order' => 'order'
43
	);
44
	/**
45
	 * Méthode appelée par défaut pour charger ce widget.
46
	 */
47
	public function executer() {
48
		$retour = null;
49
		// Pour la création de l'id du cache nous ne tenons pas compte du paramètre de l'url callback
50
		unset($this->parametres['callback']);
51
		extract($this->parametres);
52
		$this->bar = (isset($bar)) ? $bar : false;
53
		/* Le fichier Framework.php du Framework de Tela Botanica doit être appelé avant tout autre chose dans l'application.
54
		 Sinon, rien ne sera chargé.
55
		 L'emplacement du Framework peut varier en fonction de l'environnement (test, prod...). Afin de faciliter la configuration
56
		 de l'emplacement du Framework, un fichier framework.defaut.php doit être renommé en framework.php et configuré pour chaque installation de
57
		 l'application.
58
		 Chemin du fichier chargeant le framework requis */
59
		$framework = dirname(__FILE__).'/framework.php';
60
		if (!file_exists($framework)) {
61
			$e = "Veuillez paramêtrer l'emplacement et la version du Framework dans le fichier $framework";
62
			trigger_error($e, E_USER_ERROR);
63
		} else {
64
			// Inclusion du Framework
65
			require_once $framework;
66
			// Ajout d'information concernant cette application
67
			Framework::setCheminAppli(__FILE__);// Obligatoire
68
			Framework::setInfoAppli(Config::get('info'));// Optionnel
3239 idir 69
 
3228 delphine 70
		}
71
		$langue = (isset($langue)) ? $langue : self::LANGUE_DEFAUT;
72
		$this->langue = I18n::setLangue($langue);
73
		$this->parametres['langue'] = $langue;
3120 delphine 74
 
3228 delphine 75
		if (!isset($mode)) {
76
			$mode = self::SERVICE_DEFAUT;
77
		}
78
		if (!isset($projet)) {
79
			$this->parametres['projet'] = self::PROJET_DEFAUT;
80
		}
3239 idir 81
 
3228 delphine 82
		$methode = $this->traiterNomMethodeExecuter($mode);
3239 idir 83
		if (method_exists($this, $methode)) {
84
			$retour = $this->$methode();
3228 delphine 85
		} else {
86
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
87
		}
3239 idir 88
 
3257 delphine 89
		$contenu = ''; //print_r($retour);exit;
3228 delphine 90
		if (is_null($retour)) {
91
			$this->messages[] = 'La ressource demandée a retourné une valeur nulle.';
92
		} else {
3239 idir 93
			if (isset($retour['donnees'])) {
3271 idir 94
				// ne pas afficher le projet dans l'url si on est dans saisie de base
3286 idir 95
				$projet_dans_url = ( $this->parametres['projet'] !== 'base') ? '?'. $this->parametres['projet'].'&'.'langue='.$this->parametres['langue'] : '';
3271 idir 96
 
3260 idir 97
				$retour['donnees']['conf_mode'] = $this->config['parametres']['modeServeur'];
3249 idir 98
				$retour['donnees']['prod'] = ($this->config['parametres']['modeServeur'] === 'prod');
3228 delphine 99
				$retour['donnees']['bar'] = $this->bar;
3268 idir 100
				$retour['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], $this->config['manager']['cheminDos']);
3228 delphine 101
				$retour['donnees']['url_ws_annuaire'] = sprintf($this->config['chemins']['baseURLServicesAnnuaireTpl'], 'utilisateur/identite-par-courriel/');
3240 idir 102
				$retour['donnees']['url_ws_saisie'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_SAISIE);
103
				$retour['donnees']['url_ws_obs'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_OBS);
104
				$retour['donnees']['url_ws_upload'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_UPLOAD);
3286 idir 105
				$retour['donnees']['authTpl'] = $this->config['manager']['authTpl']. $projet_dans_url;
3228 delphine 106
				$retour['donnees']['mode'] = $mode;
3260 idir 107
				if( isset( $this->parametres['squelette'] ) ) {
108
					$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS. $this->parametres['squelette'].'.tpl.html';
109
				} else {
110
					$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$retour['squelette'].'.tpl.html';
111
				}
3228 delphine 112
				$contenu = $this->traiterSquelettePhp($squelette, $retour['donnees']);
113
			} else {
114
				$this->messages[] = 'Les données à transmettre au squelette sont nulles.';
115
			}
116
		}
117
		$this->envoyer($contenu);
118
	}
3120 delphine 119
 
3239 idir 120
 
3228 delphine 121
	private function executerSaisie() {
122
		$retour = array();
123
		$retour['squelette'] = 'saisie';
3248 idir 124
		$retour['donnees']['general'] = I18n::get('General');
125
		$retour['donnees']['aide'] = I18n::get('Aide');
3228 delphine 126
		$retour['donnees']['observateur'] = I18n::get('Observateur');
3248 idir 127
		$retour['donnees']['observation'] = I18n::get('Observation');
128
		$retour['donnees']['image'] = I18n::get('Image');
129
 		$retour['donnees']['chpsupp'] = I18n::get('Chpsupp');
130
 		$retour['donnees']['resume'] = I18n::get('Resume');
3228 delphine 131
		$retour['donnees']['widget'] = $this->rechercherProjet();
132
		return $retour;
133
	}
3239 idir 134
 
3228 delphine 135
	/* Recherche si le projet existe sinon va chercher les infos de base */
136
	private function rechercherProjet() {
137
		// projet avec un squelette défini (et non juste un mot-clé d'observation)
3239 idir 138
		$estProjetDefini = true;
139
		$tab = array();
3228 delphine 140
		$url = $this->config['manager']['celUrlTpl'].'?projet='.$this->parametres['projet'].'&langue='.$this->parametres['langue'];
3239 idir 141
		$json = $this->getDao()->consulter($url);
142
 
3257 delphine 143
		if ( $json !== "[]" ) {
3239 idir 144
			$tab = $this->rechercherChampsSupp();
145
		} else {
146
			$url = $this->config['manager']['celUrlTpl'].'?projet=base&langue='.$this->parametres['langue'];
147
			$json = $this->getDao()->consulter($url);
3228 delphine 148
			$estProjetDefini = false;
149
		}
3239 idir 150
		$tableau = json_decode($json, true);
3228 delphine 151
		$tableau = $this->traiterParametres($estProjetDefini, $tableau[0]);
152
		$tableau['especes'] = $this->rechercherInfosEspeces($tableau);
3249 idir 153
		if ($tableau['milieux'] != '') {
154
			$tableau['milieux'] = explode(';', $tableau['milieux']);
3228 delphine 155
		} else {
156
			$tableau['milieux'] = array();
157
		}
3278 delphine 158
		if (isset($tableau['motscles'])) {
159
		    $tableau['tag-obs'] = $tableau['tag-img'] = $tableau['motscles'];
160
		}
3239 idir 161
		$tableau['chpSupp'] = $tab;
3240 idir 162
		$langue_projet_url = ( isset ( $this->parametres['langue'] ) && $this->parametres['langue'] !== 'fr' ) ? '_' . $this->parametres['langue'] : '';
3330 idir 163
		$tableau['chemin_fichiers'] = sprintf( $this->config['chemins']['baseURLAbsoluDyn'], $this->config['manager']['imgProjet'] . $tableau['projet'] . $langue_projet_url . '/' );
3228 delphine 164
		return $tableau;
165
	}
3239 idir 166
 
3228 delphine 167
	/* Recherche si un projet a des champs de saisie supplémentaire */
168
	private function rechercherChampsSupp() {
169
		$retour = array();
3239 idir 170
		$projet = $this->parametres['projet'];
171
		$url = $this->config['manager']['celChpSupTpl'] .'?projet=' . $projet . '&langue=' . $this->parametres['langue'];
3228 delphine 172
		$json = $this->getDao()->consulter($url);
173
		$retour = (array) json_decode($json, true);
3249 idir 174
 
3239 idir 175
		foreach ( $retour[$projet]['champs-supp'] as $key => $chsup ) {
176
 
3249 idir 177
			$retour[$projet]['champs-supp'][$key]['name'] = $this->clean_string( $chsup['name'] );
178
			$retour[$projet]['champs-supp'][$key]['description'] = $this->clean_string( $chsup['description']);
179
			$retour[$projet]['champs-supp'][$key]['unit'] = $this->clean_string( $chsup['unit'] );
3239 idir 180
 
181
			if ( isset( $chsup['fieldValues'] ) ) {
3350 idir 182
				$retour[$projet]['champs-supp'][$key]['fieldValues'] = json_decode( $this->clean_string( $chsup['fieldValues'] ), true );
3239 idir 183
 
184
				if ( isset( $retour[$projet]['champs-supp'][$key]['fieldValues']['listValue'] ) ) {
3347 idir 185
					foreach( $retour[$projet]['champs-supp'][$key]['fieldValues']['listValue'] as $list_key => $list_value_array ) {
3228 delphine 186
						// Obtenir une liste de valeurs utilisables dans les attributs for id ou name par exemple
3350 idir 187
						$retour[$projet]['champs-supp'][$key]['fieldValues']['cleanListValue'][] = ($list_value_array !== 'other') ? 'val-' . preg_replace( '/[^A-Za-z0-9_\-]/', '', $this->remove_accents( strtolower($list_value_array[0] ) ) ) : '';
3228 delphine 188
					}
189
				}
190
			}
3239 idir 191
			$retour[$projet]['champs-supp'][$key]['mandatory'] = intval( $chsup['mandatory'] );
3228 delphine 192
		}
193
		return $retour;
194
	}
3239 idir 195
 
3249 idir 196
	private function clean_string( $string ) {
197
		// les fonctions de base de php ne parviennent pas à une conversion satisfaisante des codes ascii
198
		// qui ont été générés automatiquement lors de la transmission des chaines en json
199
		// dans le widget cel manager vers la base
200
		// Pour les mêmes raisons, @apos@ et @quot@ est une autre astuces utilisée dans ce même widget
201
		// pour permettre la transmission des apostrophes et guillements sans erreur
202
		$patterns = array( '/\@apos\@/', '/\@quot\@/', '/u00c0/', '/u00c1/', '/u00c2/', '/u00c3/', '/u00c4/', '/u00c5/', '/u00c6/', '/u00c7/', '/u00c8/', '/u00c9/', '/u00ca/', '/u00cb/', '/u00cc/', '/u00cd/', '/u00ce/', '/u00cf/', '/u00d1/', '/u00d2/', '/u00d3/', '/u00d4/', '/u00d5/', '/u00d6/', '/u00d8/', '/u00d9/', '/u00da/', '/u00db/', '/u00dc/', '/u00dd/', '/u00df/', '/u00e0/', '/u00e1/', '/u00e2/', '/u00e3/', '/u00e4/', '/u00e5/', '/u00e6/', '/u00e7/', '/u00e8/', '/u00e9/', '/u00ea/', '/u00eb/', '/u00ec/', '/u00ed/', '/u00ee/', '/u00ef/', '/u00f0/', '/u00f1/', '/u00f2/', '/u00f3/', '/u00f4/', '/u00f5/', '/u00f6/', '/u00f8/', '/u00f9/', '/u00fa/', '/u00fb/', '/u00fc/', '/u00fd/', '/u00ff/' );
203
		$replacements = array( '&apos;', '&quot;', 'À', 'Á', 'Â', 'Ã', 'Ä', 'Å', 'Æ', 'Ç', 'È', 'É', 'Ê', 'Ë', 'Ì', 'Í', 'Î', 'Ï', 'Ñ', 'Ò', 'Ó', 'Ô', 'Õ', 'Ö', 'Ø', 'Ù', 'Ú', 'Û', 'Ü', 'Ý', 'ß', 'à', 'á', 'â', 'ã', 'ä', 'å', 'æ', 'ç', 'è', 'é', 'ê', 'ë', 'ì', 'í', 'î', 'ï', 'ð', 'ñ', 'ò', 'ó', 'ô', 'õ', 'ö', 'ø', 'ù', 'ú', 'û', 'ü', 'ý','ÿ' );
204
 
205
		$clean_string = preg_replace( $patterns, $replacements, $string );
206
 
207
		return $clean_string;
208
	}
209
 
3228 delphine 210
	// remplace certains parametres définis en bd par les parametres définis dans l'url
211
	private function traiterParametres($estProjetDefini, $tableau) {
3278 delphine 212
		$criteres = array('tag-obs', 'tag-img', 'projet', 'titre', 'logo');
3228 delphine 213
		$criteresProjetNonDefini = array('commune', 'num_nom', 'referentiel');
214
		foreach($this->parametres as $nom_critere => $valeur_critere) {
3249 idir 215
			if (($estProjetDefini == false || $tableau['projet'] == 'base') && in_array($nom_critere, $criteresProjetNonDefini)) {
3228 delphine 216
				$tableau[$nom_critere] = $valeur_critere;
217
			} else if (in_array($nom_critere, $criteres)) {
218
				$tableau[$nom_critere] = $valeur_critere;
219
			}
220
		}
221
		return $tableau;
222
	}
3239 idir 223
 
224
	private function rechercherInfosEspeces( $infos_projets ) { //print_r($infos_projets);exit;
225
		$retour = array();
226
		$referentiel = $infos_projets['referentiel'];
3228 delphine 227
		$urlWsNsTpl = $this->config['chemins']['baseURLServicesEfloreTpl'];
3260 idir 228
		$retour['url_ws_autocompletion_ns'] = sprintf( $urlWsNsTpl, self::EFLORE_API_VERSION, $referentiel, self::WS_NOM );;
229
		$retour['url_ws_autocompletion_ns_tpl'] = sprintf( $urlWsNsTpl, self::EFLORE_API_VERSION, '{referentiel}', self::WS_NOM );
3228 delphine 230
		$retour['ns_referentiel'] = $referentiel;
3239 idir 231
 
232
		if ( isset( $infos_projets['type_especes'] ) ) {
233
 
234
			switch ( $infos_projets['type_especes'] ) {
3249 idir 235
				case 'fixe' :
3257 delphine 236
					$retour = $this->chargerInfosTaxon( $infos_projets['referentiel'], $infos_projets['especes'] );
3228 delphine 237
					break;
3257 delphine 238
				case 'referentiel' : break;
3249 idir 239
				case 'liste' :
3239 idir 240
					$referentiel = $infos_projets['referentiel'];
3256 idir 241
////////////////////// temporaire test transmission liste taxons
242
					$retour['taxons'] = $this->recupererListeNomsSci();
3239 idir 243
					break;
3228 delphine 244
			}
3239 idir 245
		} else if ( isset( $infos_projets['referentiel'] ) ) {
3228 delphine 246
			$referentiel = $infos_projets['referentiel'];
3239 idir 247
			if ( isset($infos_projets['num_nom'] ) ) {
3257 delphine 248
				$retour = $this->chargerInfosTaxon( $infos_projets['referentiel'], $infos_projets['num_nom'] );
3228 delphine 249
			}
250
		}
251
		return $retour;
252
	}
3239 idir 253
 
3228 delphine 254
	/**
255
	 * Consulte un webservice pour obtenir des informations sur le taxon dont le
256
	 * numéro nomenclatural est $num_nom (ce sont donc plutôt des infos sur le nom
257
	 * et non le taxon?)
258
	 * @param string|int $num_nom
259
	 * @return array
260
	 */
3239 idir 261
	protected function chargerInfosTaxon( $referentiel, $num_nom ) {
262
		$url_service_infos = sprintf( $this->config['chemins']['infosTaxonUrl'], $referentiel, $num_nom );
263
		$infos = json_decode( file_get_contents( $url_service_infos ) );
3228 delphine 264
		// trop de champs injectés dans les infos espèces peuvent
265
		// faire planter javascript
3330 idir 266
		$champs_a_garder = array( 'id', 'nom_sci','nom_sci_complet', 'nom_complet', 'famille','nom_retenu.id', 'nom_retenu_complet', 'num_taxonomique' );
3228 delphine 267
		$resultat = array();
268
		$retour = array();
3239 idir 269
		if ( isset( $infos ) && !empty( $infos ) ) {
270
			$infos = (array) $infos;
3249 idir 271
			if ( isset( $infos['nom_sci'] ) && $infos['nom_sci'] !== '' ) {
3239 idir 272
				$resultat = array_intersect_key( $infos, array_flip($champs_a_garder ) );
3249 idir 273
				$resultat['retenu'] = ( $infos['id'] == $infos['nom_retenu.id'] ) ? 'true' : 'false';
3228 delphine 274
				$retour['espece_imposee'] = true;
275
				$retour['nn_espece_defaut'] = $nnEspeceImposee;
276
				$retour['nom_sci_espece_defaut'] = $resultat['nom_complet'];
3239 idir 277
				$retour['infos_espece'] = $this->array2js( $resultat, true );
3228 delphine 278
			}
279
		}
280
		return $retour;
281
	}
3120 delphine 282
 
3239 idir 283
	protected function getReferentielImpose() {
284
		$referentiel_impose = true;
3249 idir 285
		if (!empty($_GET['referentiel']) && $_GET['referentiel'] !== 'autre') {
3239 idir 286
			$this->ns_referentiel = $_GET['referentiel'];
287
		} else if (isset($this->configProjet['referentiel'])) {
288
			$this->ns_referentiel = $this->configProjet['referentiel'];
289
		} else if (isset($this->configMission['referentiel'])) {
290
			$this->ns_referentiel = $this->configMission['referentiel'];
291
		} else {
292
			$referentiel_impose = false;
293
		}
294
		return $referentiel_impose;
295
	}
3231 delphine 296
 
3228 delphine 297
	/**
3256 idir 298
	 * Trie par nom français les taxons lus dans le fichier csv
3228 delphine 299
	 */
300
	protected function recupererListeNomsSci() {
301
		$taxons = $this->recupererListeTaxon();
302
		if (is_array($taxons)) {
303
			$taxons = self::trierTableauMd($taxons, array('nom_fr' => SORT_ASC));
304
		}
305
		return $taxons;
306
	}
3239 idir 307
 
3228 delphine 308
	/**
309
	 * @TODO documenter
310
	 * @return array
311
	 */
312
	protected function recupererListeNoms() {
313
		$taxons = $this->recupererListeTaxon();
314
		$nomsAAfficher = array();
315
		$nomsSpeciaux = array();
316
		if (is_array($taxons)) {
317
			foreach ($taxons as $taxon) {
318
				$nomSciTitle = $taxon['nom_ret'].
319
				($taxon['nom_fr'] != '' ? ' - '.$taxon['nom_fr'] : '' ).
320
				($taxon['nom_fr_autre'] != '' ? ' - '.$taxon['nom_fr_autre'] : '' );
321
				$nomFrTitle = $taxon['nom_sel'].
322
				($taxon['nom_ret'] != $taxon['nom_sel']? ' - '.$taxon['nom_ret'] : '' ).
323
				($taxon['nom_fr_autre'] != '' ? ' - '.$taxon['nom_fr_autre'] : '' );
3239 idir 324
 
3228 delphine 325
				if ($taxon['groupe'] == 'special') {
326
					$nomsSpeciaux[] = array(
327
							'num_nom' => $taxon['num_nom_sel'],
328
							'nom_a_afficher' => $taxon['nom_fr'],
329
							'nom_a_sauver' => $taxon['nom_sel'],
330
							'nom_title' => $nomSciTitle,
331
							'nom_type' => 'nom-special');
332
				} else {
333
					$nomsAAfficher[] = array(
334
							'num_nom' => $taxon['num_nom_sel'],
335
							'nom_a_afficher' => $taxon['nom_sel'],
336
							'nom_a_sauver' => $taxon['nom_sel'],
337
							'nom_title' => $nomSciTitle,
338
							'nom_type' => 'nom-sci');
339
					$nomsAAfficher[] = array(
340
							'num_nom' => $taxon['num_nom_sel'],
341
							'nom_a_afficher' => $taxon['nom_fr'],
342
							'nom_a_sauver' => $taxon['nom_fr'],
343
							'nom_title' => $nomFrTitle,
344
							'nom_type' => 'nom-fr');
345
				}
346
			}
347
			$nomsAAfficher = self::trierTableauMd($nomsAAfficher, array('nom_a_afficher' => SORT_ASC));
348
			$nomsSpeciaux = self::trierTableauMd($nomsSpeciaux, array('nom_a_afficher' => SORT_ASC));
349
		}
350
		return array('speciaux' => $nomsSpeciaux, 'sci-et-fr' => $nomsAAfficher);
351
	}
3239 idir 352
 
3228 delphine 353
	/**
3256 idir 354
	 * Lit une liste de taxons depuis un fichier csv fourni
3228 delphine 355
	 */
356
	protected function recupererListeTaxon() {
357
		$taxons = array();
3256 idir 358
		$langue_projet_url = ( isset ( $this->parametres['langue'] ) && $this->parametres['langue'] !== 'fr' ) ? '_' . $this->parametres['langue'] : '';
359
		$chemin_images = dirname(__FILE__) . self::DS . '..' . self::DS . 'manager' . self::DS . 'squelettes' . self::DS . 'img' . self::DS . 'images_projets' . self::DS;
3260 idir 360
		$fichier_csv = $chemin_images . $this->parametres['projet'] . $langue_projet_url . self::DS . 'especes.csv';
3257 delphine 361
 
3256 idir 362
		if ( file_exists( $fichier_csv ) && is_readable( $fichier_csv ) ) {
363
			$taxons = $this->decomposerFichierCsv( $fichier_csv );
3228 delphine 364
		} else {
3256 idir 365
			$this->debug[] = "Impossible d'ouvrir le fichier '$fichier_csv'.";
3228 delphine 366
		}
367
		return $taxons;
368
	}
3239 idir 369
 
3228 delphine 370
	/**
3256 idir 371
	 * Découpe un fihcier csv
3228 delphine 372
	 */
3256 idir 373
	protected function decomposerFichierCsv($fichier, $delimiter = "\t"){
3228 delphine 374
		$header = null;
375
		$data = array();
3256 idir 376
		if (($handle = fopen($fichier, "r")) !== FALSE) {
3228 delphine 377
			while (($row = fgetcsv($handle, 1000, $delimiter)) !== FALSE) {
378
				if (!$header) {
379
					$header = $row;
380
				} else {
381
					$data[] = array_combine($header, $row);
382
				}
383
			}
384
			fclose($handle);
385
		}
386
		return $data;
387
	}
3239 idir 388
 
3228 delphine 389
	/**
390
	 * Convertit un tableau PHP en Javascript - @WTF pourquoi ne pas faire un json_encode ?
391
	 * @param array $array
392
	 * @param boolean $show_keys
393
	 * @return une portion de JSON représentant le tableau
394
	 */
395
	protected function array2js($array,$show_keys) {
396
		$tableauJs = '{}';
397
		if (!empty($array)) {
398
			$total = count($array) - 1;
399
			$i = 0;
400
			$dimensions = array();
401
			foreach ($array as $key => $value) {
402
				if (is_array($value)) {
403
					$dimensions[$i] = array2js($value,$show_keys);
404
					if ($show_keys) {
3260 idir 405
						$dimensions[$i] = '\"'.$key.'\":'.$dimensions[$i];
3228 delphine 406
					}
407
				} else {
3260 idir 408
					$dimensions[$i] = '\"'.addslashes($value).'\"';
3228 delphine 409
					if ($show_keys) {
3260 idir 410
						$dimensions[$i] = '\"'.$key.'\":'.$dimensions[$i];
3228 delphine 411
					}
412
				}
413
				if ($i == 0) {
414
					$dimensions[$i] = '{'.$dimensions[$i];
415
				}
416
				if ($i == $total) {
417
					$dimensions[$i].= '}';
418
				}
419
				$i++;
420
			}
421
			$tableauJs = implode(',', $dimensions);
422
		}
423
		return $tableauJs;
424
	}
3120 delphine 425
 
3257 delphine 426
	private function remove_accents($string) {
427
	    if ( !preg_match('/[\x80-\xff]/', $string) )
428
	        return $string;
3260 idir 429
 
3257 delphine 430
	        $chars = array(
431
	            // Decompositions for Latin-1 Supplement
432
	            chr(195).chr(128) => 'A', chr(195).chr(129) => 'A',
433
	            chr(195).chr(130) => 'A', chr(195).chr(131) => 'A',
434
	            chr(195).chr(132) => 'A', chr(195).chr(133) => 'A',
435
	            chr(195).chr(135) => 'C', chr(195).chr(136) => 'E',
436
	            chr(195).chr(137) => 'E', chr(195).chr(138) => 'E',
437
	            chr(195).chr(139) => 'E', chr(195).chr(140) => 'I',
438
	            chr(195).chr(141) => 'I', chr(195).chr(142) => 'I',
439
	            chr(195).chr(143) => 'I', chr(195).chr(145) => 'N',
440
	            chr(195).chr(146) => 'O', chr(195).chr(147) => 'O',
441
	            chr(195).chr(148) => 'O', chr(195).chr(149) => 'O',
442
	            chr(195).chr(150) => 'O', chr(195).chr(153) => 'U',
443
	            chr(195).chr(154) => 'U', chr(195).chr(155) => 'U',
444
	            chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y',
445
	            chr(195).chr(159) => 's', chr(195).chr(160) => 'a',
446
	            chr(195).chr(161) => 'a', chr(195).chr(162) => 'a',
447
	            chr(195).chr(163) => 'a', chr(195).chr(164) => 'a',
448
	            chr(195).chr(165) => 'a', chr(195).chr(167) => 'c',
449
	            chr(195).chr(168) => 'e', chr(195).chr(169) => 'e',
450
	            chr(195).chr(170) => 'e', chr(195).chr(171) => 'e',
451
	            chr(195).chr(172) => 'i', chr(195).chr(173) => 'i',
452
	            chr(195).chr(174) => 'i', chr(195).chr(175) => 'i',
453
	            chr(195).chr(177) => 'n', chr(195).chr(178) => 'o',
454
	            chr(195).chr(179) => 'o', chr(195).chr(180) => 'o',
455
	            chr(195).chr(181) => 'o', chr(195).chr(182) => 'o',
456
	            chr(195).chr(182) => 'o', chr(195).chr(185) => 'u',
457
	            chr(195).chr(186) => 'u', chr(195).chr(187) => 'u',
458
	            chr(195).chr(188) => 'u', chr(195).chr(189) => 'y',
459
	            chr(195).chr(191) => 'y',
460
	            // Decompositions for Latin Extended-A
461
	            chr(196).chr(128) => 'A', chr(196).chr(129) => 'a',
462
	            chr(196).chr(130) => 'A', chr(196).chr(131) => 'a',
463
	            chr(196).chr(132) => 'A', chr(196).chr(133) => 'a',
464
	            chr(196).chr(134) => 'C', chr(196).chr(135) => 'c',
465
	            chr(196).chr(136) => 'C', chr(196).chr(137) => 'c',
466
	            chr(196).chr(138) => 'C', chr(196).chr(139) => 'c',
467
	            chr(196).chr(140) => 'C', chr(196).chr(141) => 'c',
468
	            chr(196).chr(142) => 'D', chr(196).chr(143) => 'd',
469
	            chr(196).chr(144) => 'D', chr(196).chr(145) => 'd',
470
	            chr(196).chr(146) => 'E', chr(196).chr(147) => 'e',
471
	            chr(196).chr(148) => 'E', chr(196).chr(149) => 'e',
472
	            chr(196).chr(150) => 'E', chr(196).chr(151) => 'e',
473
	            chr(196).chr(152) => 'E', chr(196).chr(153) => 'e',
474
	            chr(196).chr(154) => 'E', chr(196).chr(155) => 'e',
475
	            chr(196).chr(156) => 'G', chr(196).chr(157) => 'g',
476
	            chr(196).chr(158) => 'G', chr(196).chr(159) => 'g',
477
	            chr(196).chr(160) => 'G', chr(196).chr(161) => 'g',
478
	            chr(196).chr(162) => 'G', chr(196).chr(163) => 'g',
479
	            chr(196).chr(164) => 'H', chr(196).chr(165) => 'h',
480
	            chr(196).chr(166) => 'H', chr(196).chr(167) => 'h',
481
	            chr(196).chr(168) => 'I', chr(196).chr(169) => 'i',
482
	            chr(196).chr(170) => 'I', chr(196).chr(171) => 'i',
483
	            chr(196).chr(172) => 'I', chr(196).chr(173) => 'i',
484
	            chr(196).chr(174) => 'I', chr(196).chr(175) => 'i',
485
	            chr(196).chr(176) => 'I', chr(196).chr(177) => 'i',
486
	            chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij',
487
	            chr(196).chr(180) => 'J', chr(196).chr(181) => 'j',
488
	            chr(196).chr(182) => 'K', chr(196).chr(183) => 'k',
489
	            chr(196).chr(184) => 'k', chr(196).chr(185) => 'L',
490
	            chr(196).chr(186) => 'l', chr(196).chr(187) => 'L',
491
	            chr(196).chr(188) => 'l', chr(196).chr(189) => 'L',
492
	            chr(196).chr(190) => 'l', chr(196).chr(191) => 'L',
493
	            chr(197).chr(128) => 'l', chr(197).chr(129) => 'L',
494
	            chr(197).chr(130) => 'l', chr(197).chr(131) => 'N',
495
	            chr(197).chr(132) => 'n', chr(197).chr(133) => 'N',
496
	            chr(197).chr(134) => 'n', chr(197).chr(135) => 'N',
497
	            chr(197).chr(136) => 'n', chr(197).chr(137) => 'N',
498
	            chr(197).chr(138) => 'n', chr(197).chr(139) => 'N',
499
	            chr(197).chr(140) => 'O', chr(197).chr(141) => 'o',
500
	            chr(197).chr(142) => 'O', chr(197).chr(143) => 'o',
501
	            chr(197).chr(144) => 'O', chr(197).chr(145) => 'o',
502
	            chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe',
503
	            chr(197).chr(148) => 'R',chr(197).chr(149) => 'r',
504
	            chr(197).chr(150) => 'R',chr(197).chr(151) => 'r',
505
	            chr(197).chr(152) => 'R',chr(197).chr(153) => 'r',
506
	            chr(197).chr(154) => 'S',chr(197).chr(155) => 's',
507
	            chr(197).chr(156) => 'S',chr(197).chr(157) => 's',
508
	            chr(197).chr(158) => 'S',chr(197).chr(159) => 's',
509
	            chr(197).chr(160) => 'S', chr(197).chr(161) => 's',
510
	            chr(197).chr(162) => 'T', chr(197).chr(163) => 't',
511
	            chr(197).chr(164) => 'T', chr(197).chr(165) => 't',
512
	            chr(197).chr(166) => 'T', chr(197).chr(167) => 't',
513
	            chr(197).chr(168) => 'U', chr(197).chr(169) => 'u',
514
	            chr(197).chr(170) => 'U', chr(197).chr(171) => 'u',
515
	            chr(197).chr(172) => 'U', chr(197).chr(173) => 'u',
516
	            chr(197).chr(174) => 'U', chr(197).chr(175) => 'u',
517
	            chr(197).chr(176) => 'U', chr(197).chr(177) => 'u',
518
	            chr(197).chr(178) => 'U', chr(197).chr(179) => 'u',
519
	            chr(197).chr(180) => 'W', chr(197).chr(181) => 'w',
520
	            chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y',
521
	            chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z',
522
	            chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z',
523
	            chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z',
524
	            chr(197).chr(190) => 'z', chr(197).chr(191) => 's'
525
	        );
526
 
527
	        $string = strtr($string, $chars);
528
 
529
	        return $string;
530
	}
3120 delphine 531
}
3239 idir 532
?>