Subversion Repositories eFlore/Applications.coel-consultation

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
9 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Controleur générale de l'application Collection.
5
 *
6
 * @category	php5.2
7
 * @package		Collection
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id: ColControleur.php 91 2010-06-21 10:12:41Z jpm $
13
 */
11 jpm 14
abstract class ColControleur extends Controleur {
55 jpm 15
 
89 jpm 16
	const FMT_DATE = '%d/%m/%Y';// Supporte les formats de dates non valides (1989-00-00)
69 jpm 17
	const FMT_DATE_TXT = '%A %d %B %Y';
89 jpm 18
	const FMT_DATE_HEURE = '%d/%m/%Y %H:%i:%s';// Supporte les formats de dates non valides (1989-00-00 00:00:00)
55 jpm 19
	const FMT_DATE_HEURE_TXT = '%A %d %B %Y à %H:%M';
20
 
82 jpm 21
	const META_TITRE = 'titre';
22
	const META_DESCRIPTION = 'description';
23
	const META_TAGS = 'tags';
9 jpm 24
	const RENDU_TETE = 'tete';
25
	const RENDU_CORPS = 'corps';
26
	const RENDU_PIED = 'pied';
82 jpm 27
 
15 jpm 28
	const TYPE_AUTRE = 'AUTRE';
29
	const TYPE_TOTAL = 'TOTAL';
30
	const SEPARATEUR_TYPE_VALEUR = '##';
31
	const SEPARATEUR_VALEURS = ';;';
32
	const SEPARATEUR_DONNEES = '||';
33
	const VALEUR_NULL = 'NC';
9 jpm 34
 
35
	private $sortie = array();
36
	private $parametres = array();
11 jpm 37
	// FIXME : voir s'il est plus intéressant d'utiliser une méthode dans les classes filles
38
	protected $url = null;
9 jpm 39
 
40
	public function __construct()  {
41
		$registre = Registre::getInstance();
42
		$this->parametres = $registre->get('parametres');
43
		$this->url = $this->parametres['url'];
44
		parent::__construct();
45
	}
46
 
47
	/**
82 jpm 48
	 * Attribue une position de sortie à un contenu.
9 jpm 49
	 */
50
	protected function setSortie($position, $contenu, $fusionner = false) {
82 jpm 51
		if ($this->verifierExistenceTypeSortie($position)) {
9 jpm 52
			if ($fusionner) {
53
				$this->sortie[$position] .= $contenu;
54
			} else {
55
				$this->sortie[$position] = $contenu;
56
			}
57
		}
58
	}
11 jpm 59
 
60
	/**
82 jpm 61
	 * Vérifie l'existence du type de sortie indiqué pour son utilisation dans le tableau de sortie.
62
	 * @param string le type de sortie à tester.
63
	 * @return bool true si le type de sortie est valide, sinon false.
11 jpm 64
	 */
82 jpm 65
	private function verifierExistenceTypeSortie($type) {
11 jpm 66
		$existe = true;
82 jpm 67
		if ($type != self::RENDU_TETE &&
68
			$type != self::RENDU_CORPS &&
69
			$type != self::RENDU_PIED &&
70
			$type != self::META_TITRE &&
71
			$type != self::META_DESCRIPTION &&
72
			$type != self::META_TAGS) {
73
			trigger_error("Le type de sortie '$type' n'est pas une valeur prédéfinie.", E_USER_WARNING);
11 jpm 74
			$existe = false;
75
		}
76
		return $existe;
77
	}
78
 
79
	/**
80
	 * Retourne le tableau de sortie à utiliser dans le controleur principal de l'application.
81
	 */
9 jpm 82
	public function getSortie() {
83
		return $this->sortie;
84
	}
85
 
11 jpm 86
	/**
87
	 * Execute l'action d'un module donnée et fusionne le résultat avec le tableau de sortie.
88
	 */
89
	protected function executerAction($ClasseModule, $action) {
90
		$module = new $ClasseModule();
91
		$module->$action();
92
		$this->fusionnerSortie($module->getSortie());
93
 
94
	}
9 jpm 95
 
11 jpm 96
	/**
97
	 * Fusionne un tableau de sortie par défaut avec le tableau passé en paramêtre.
98
	 * @param array le tableau à fusionner
99
	 */
100
	private function fusionnerSortie($sortie) {
101
		$this->sortie = array_merge($this->sortie, $sortie);
102
	}
103
 
16 jpm 104
	protected function construireTxtTruckSimple($chaine_a_analyser) {
105
		return $this->construireTxtTruck($chaine_a_analyser, false, false);
106
	}
107
 
15 jpm 108
	protected function construireTxtTruckSansMajuscule($chaine_a_analyser) {
109
		return $this->construireTxtTruck($chaine_a_analyser, false);
110
	}
111
 
16 jpm 112
	protected function construireTxtTruckSansPointFinal($chaine_a_analyser) {
113
		return $this->construireTxtTruck($chaine_a_analyser, true, false);
114
	}
115
 
116
	protected function construireTxtTruck($chaine_a_analyser, $majuscule = true, $point_final = true) {
15 jpm 117
		$termes = array();
118
		if ((!is_null($chaine_a_analyser)) && (trim($chaine_a_analyser) != ''))	{
119
			$valeurs = explode(self::SEPARATEUR_VALEURS, $chaine_a_analyser);
120
			$nbre_valeurs = count($valeurs);
121
			if ($nbre_valeurs > 0) {
122
				for ($i = 0; $i < $nbre_valeurs; $i++)	{
123
					$valeur = trim($valeurs[$i]);
124
					if ($valeur != '') {
125
						$valeur_formatee = $this->formaterValeurTruck($valeur);
126
						$termes[] = $valeur_formatee;
127
					}
128
				}
129
			}
130
		}
131
 
16 jpm 132
		$chaine_a_retourner = $this->formaterTableauDeTxt($termes, $majuscule, $point_final);
15 jpm 133
		return $chaine_a_retourner;
134
	}
135
 
55 jpm 136
	protected function getTxtTruckParPosition($chaine_a_analyser, $position = 1) {
137
		$retour = '';
138
		if ((!is_null($chaine_a_analyser)) && (trim($chaine_a_analyser) != ''))	{
139
			$valeurs = explode(self::SEPARATEUR_VALEURS, $chaine_a_analyser);
140
			$nbre_valeurs = count($valeurs);
141
			if ($nbre_valeurs > 0) {
142
				$position = $position - 1;
143
				$valeur = trim($valeurs[$position]);
144
				if ($valeur != '') {
145
					$retour = $this->formaterValeurTruck($valeur);
146
				}
147
			}
148
		}
149
		return $retour;
150
	}
151
 
152
	protected function getTableauTruck($chaine_a_analyser) {
153
		$tableau_retour = array();
154
		if ((!is_null($chaine_a_analyser)) && (trim($chaine_a_analyser) != ''))	{
155
			$valeurs = explode(self::SEPARATEUR_VALEURS, $chaine_a_analyser);
156
			$nbre_valeurs = count($valeurs);
157
			if ($nbre_valeurs > 0) {
158
				for ($i = 0; $i < $nbre_valeurs; $i++)	{
159
					$valeur = trim($valeurs[$i]);
160
					if ($valeur != '') {
161
						$tableau_retour[] = $valeur;
162
					}
163
				}
164
			}
165
		}
166
		return $tableau_retour;
167
	}
168
 
15 jpm 169
	private function formaterValeurTruck($valeur) {
170
		$chaine_a_retourner = '';
171
 
172
		if (preg_match('/^[^#]+##[^$]+$/', $valeur))	{
173
			$cle_valeur = explode(self::SEPARATEUR_TYPE_VALEUR, $valeur);
174
			$chaine_a_retourner = (($cle_valeur[1] == '' || $cle_valeur[1] == 'null') ? self::VALEUR_NULL : $cle_valeur[1]);
175
			$chaine_a_retourner .= ' '.$this->formaterParenthese($cle_valeur[0]);
176
		} else if ($valeur != '')	{
177
			$chaine_a_retourner = $valeur;
178
		} else {
179
			trigger_error("Valeur truck posant problème :$valeur", E_USER_NOTICE);
180
		}
181
 
182
		return $chaine_a_retourner;
183
	}
184
 
185
	protected function formaterParenthese($chaine_a_afficher) {
186
		if ($chaine_a_afficher != '') {
187
			$chaine_a_afficher = '('.$chaine_a_afficher.')';
188
		}
189
		return $chaine_a_afficher;
190
	}
191
 
192
	protected function formaterSautDeLigne($chaine_a_formater) {
193
		$txt_a_retourner = preg_replace('/\n/', '<br />', $chaine_a_formater);
194
		return $txt_a_retourner;
195
	}
196
 
16 jpm 197
	protected function formaterTableauDeTxt($tableau_de_txt, $majuscule = true, $point_final = true) {
15 jpm 198
		$chaine_a_afficher = '';
199
		$taille_du_tableau = count($tableau_de_txt);
200
		if ($taille_du_tableau > 0) {
201
			$index_avt_dernier = $taille_du_tableau - 1;
202
			for ($i = 0; $i < $taille_du_tableau; $i++)	{
203
				$mot = $tableau_de_txt[$i];
204
				if ($i != $index_avt_dernier) {
205
					$chaine_a_afficher .= $mot.', ';
206
				} else {
16 jpm 207
					$chaine_a_afficher .= $this->nettoyerPointFinal($mot);
208
					if ($point_final) {
209
						$chaine_a_afficher .= '.';
210
					}
15 jpm 211
				}
212
			}
213
		}
214
		if ($majuscule) {
215
			$chaine_a_afficher = ucfirst($chaine_a_afficher);
216
		}
217
		return $chaine_a_afficher;
218
	}
219
 
220
	protected function formaterAutre($chaine_a_afficher) {
221
		if ($chaine_a_afficher != '') {
222
			$chaine_a_afficher = ' [Autre : '.$chaine_a_afficher.']';
223
		}
224
		return $chaine_a_afficher;
225
	}
226
 
227
	protected function formaterOuiNon($chaine_a_formater) {
228
		$txt_a_retourner = '';
229
		if ($chaine_a_formater == '0') {
230
			$txt_a_retourner = 'non';
231
		} else if ($chaine_a_formater == '1') {
232
			$txt_a_retourner = 'oui';
233
		}
234
		return $txt_a_retourner;
235
	}
236
 
55 jpm 237
	protected function formaterDate($date, $format = self::FMT_DATE_HEURE) {
17 jpm 238
		if ($date == '' || $date == '0000-00-00' || $date == '0000-00-00 00:00:00') {
239
			$date = 'Inconnue';
55 jpm 240
		} else {
89 jpm 241
			if (preg_match('/^([0-9]{4})-([0-9]{2})-([0-9]{2})(?: ([0-9]{2}):([0-9]{2}):([0-9]{2})|)$/', $date, $match)) {// Date Heure
242
				$annee = $match[1];
243
				$mois = $match[2];
244
				$jour = $match[3];
245
				$heure = (isset($match[4])) ? $match[4] : '00';
246
				$minute = (isset($match[5])) ? $match[5] : '00';
247
				$seconde = (isset($match[6])) ? $match[6] : '00';
248
				if ($format == self::FMT_DATE && $jour == '00' && $mois == '00') {
249
					$date = $annee;
250
				} else if ($format == self::FMT_DATE && $jour == '00') {
251
					$date = strftime('%b', mktime(0, 0, 0, $mois, 1)).' '.$annee;
252
				} else {
253
					$timestamp = strtotime($date);
254
					if ($timestamp !== false) {
255
						$date = strftime($format, $timestamp);
256
					}
257
				}
258
			} else {
259
				$e = "La chaine '$date' n'est pas reconnue.";
260
				trigger_error($e, E_USER_WARNING);
261
			}
17 jpm 262
		}
263
		return $date;
264
	}
265
 
15 jpm 266
	protected function nettoyerPointFinal($mot) {
267
		$mot = preg_replace('/[.]$/', '', $mot);
268
		return $mot;
269
	}
270
 
271
	public function construireTxtListeOntologie($chaineAAnalyser, $valeurEstOntologie = true, $typeEstOntologie = true, $donneeEstOntologie = false) {
272
		$termes = array();
273
		$autres = array();
274
		$chaineAAnalyser = trim($chaineAAnalyser);
275
		if ($chaineAAnalyser != '') {
276
			$valeurs = explode(self::SEPARATEUR_VALEURS, $chaineAAnalyser);
277
			$nbreValeurs = count($valeurs);
278
			if ($nbreValeurs > 0)	{
279
				for ($i = 0; $i < $nbreValeurs; $i++)	{
280
					$valeur = $valeurs[$i];
281
 
282
					// VALEUR SANS TYPE
283
					// La valeur sans type est une entrée de l'ontologie
80 jpm 284
					if ($valeurEstOntologie && preg_match('/^[0-9]+$/u', $valeur)) {
15 jpm 285
						if ($valeur == '0') {
286
							$valeur = '';
287
						} else {
288
							$valeurOntologie = Ontologie::getValeur($valeur);
289
							if ($valeurOntologie != '') {
290
								$valeur = $valeurOntologie['nom'];
291
							}
292
						}
293
					}
294
 
295
					// VALEUR AVEC TYPE
296
					// Type : AUTRE
297
					$valeurTypeAutre = self::TYPE_AUTRE.self::SEPARATEUR_TYPE_VALEUR;
80 jpm 298
					if (preg_match('/^'.$valeurTypeAutre.'.+$/u', $valeur)) {
299
						$txtAutre = preg_replace('/^'.$valeurTypeAutre.'/u', '', $valeur);
15 jpm 300
						if ($txtAutre != '') {
301
							$autres[] = $txtAutre;
302
						}
303
						$valeur = '';
304
					}
305
					// Type correspondant à une entrée de l'ontologie
306
					if ($typeEstOntologie) {
19 jpm 307
						$valeurTypeOntologie = '([0-9]+)'.self::SEPARATEUR_TYPE_VALEUR;
80 jpm 308
						$valeurTypeAutre = '([[:alnum:]]+)'.self::SEPARATEUR_TYPE_VALEUR;
309
						if (preg_match('/^'.$valeurTypeOntologie.'.*$/u', $valeur, $match)) {// Cas type : réf. numérique
19 jpm 310
							$type = $match[1];
311
							$valeurOntologieNom = Ontologie::getValeurNom($type);
312
							if ($valeurOntologieNom !== false) {
80 jpm 313
								$valeurOntologieNom .= ' : ';
314
								$valeur = preg_replace('/^'.$type.'/u', $valeurOntologieNom, $valeur);
15 jpm 315
							}
80 jpm 316
						} else if (preg_match('/^'.$valeurTypeAutre.'.*$/u', $valeur, $match)) {// Cas type : AUTRE
317
							$type = $match[1];
318
							$valeur = preg_replace('/^'.$type.'/u', $type.' : ', $valeur);
15 jpm 319
						}
320
					}
321
					// Donnée correspondant à une entrée de l'ontologie
322
					if ($donneeEstOntologie) {
323
						$donneeOntologie = self::SEPARATEUR_TYPE_VALEUR.'([0-9]+)';
80 jpm 324
						if (preg_match('/^.+'.$donneeOntologie.'$/u', $valeur, $match)) {
15 jpm 325
							$donnee = $match[1];
326
							$donnee = str_replace(self::SEPARATEUR_TYPE_VALEUR, '', $donnee);
19 jpm 327
							$valeurOntologieNom = Ontologie::getValeurNom($donnee);
328
							if ($valeurOntologieNom !== false) {
80 jpm 329
								$valeur = preg_replace('/'.$donnee.'$/u', $valeurOntologieNom, $valeur);
15 jpm 330
							}
331
						}
332
					}
333
 
334
					// Nettoyage final
335
					$valeur = preg_replace('/'.self::SEPARATEUR_TYPE_VALEUR.'/', '', $valeur);
336
 
337
					if ($valeur != '') {
338
						$termes[] = $valeur;
339
					}
340
				}
341
			}
342
		}
343
 
344
		$chaineTermes = $this->formaterTableauDeTxt($termes);
345
		$chaineAutres = $this->formaterTableauDeTxt($autres);
346
		$chaineARetourner = $chaineTermes.$this->formaterAutre($chaineAutres);
347
 
348
		return $chaineARetourner;
349
	}
350
 
18 jpm 351
	protected function obtenirUrlFicheStructure($id_structure) {
352
		$this->url->setVariableRequete('module', 'Fiche');
353
		$this->url->setVariableRequete('action', 'afficherStructure');
354
		$this->url->setVariableRequete('id', $id_structure);
355
		$url = $this->url->getURL();
356
		$this->url->unsetVariablesRequete(array('module', 'action', 'id'));
357
		return $url;
358
	}
359
 
55 jpm 360
	protected function obtenirUrlFicheCollection($id_collection) {
18 jpm 361
		$this->url->setVariableRequete('module', 'Fiche');
362
		$this->url->setVariableRequete('action', 'afficherCollection');
363
		$this->url->setVariableRequete('id', $id_collection);
364
		$url = $this->url->getURL();
365
		$this->url->unsetVariablesRequete(array('module', 'action', 'id'));
366
		return $url;
367
	}
19 jpm 368
 
55 jpm 369
	protected function obtenirUrlFichePersonne($id_personne) {
370
		$this->url->setVariableRequete('module', 'Fiche');
371
		$this->url->setVariableRequete('action', 'afficherPersonne');
372
		$this->url->setVariableRequete('id', $id_personne);
373
		$url = $this->url->getURL();
374
		$this->url->unsetVariablesRequete(array('module', 'action', 'id'));
375
		return $url;
376
	}
377
 
19 jpm 378
	protected function postraiterDonnees(&$tableau) {
379
		if (count($tableau) > 0) {
380
			foreach ($tableau as $cle => &$valeur) {
381
				if ($valeur == '') {
382
					$valeur = '&nbsp;';
383
				} else if (is_string($valeur)) {
384
					$valeur = preg_replace('/&(?!amp;)/i', '&amp;', $valeur, -1);
385
				} else if (is_array($valeur)) {
386
					$this->postraiterDonnees($valeur);
387
				}
388
			}
389
		}
390
	}
85 jpm 391
 
392
	protected function chargerPiedDePage() {
91 jpm 393
		$donnees['appli'] = Application::getInfo();
394
		$this->setSortie(self::RENDU_PIED, $this->getVue('pied', $donnees));
85 jpm 395
	}
9 jpm 396
}