Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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

Rev Author Line No. Line
272 delphine 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe mère du module Liste.
5
 *
6
 * @category	PHP 5.2
7
 * @package		eflore-consultation
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @author		Delphine CAUQUIL <delphine@tela-botanica.org>
10
 * @copyright	2011 Tela-Botanica
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
12
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
13
 * @version		$Id$
14
 */
15
class Ethnobotanique extends aControleur {
302 jpm 16
 
17
	private $conteneur = null;
18
	private $nomCourant = null;
19
	private $nomsVernaculaires = null;
408 aurelien 20
	private $wikini;
302 jpm 21
 
22
	public function __construct(Conteneur $conteneur) {
23
		$this->conteneur = $conteneur;
24
		$this->nomCourant = $this->conteneur->getNomCourant();
25
		$this->nomsVernaculaires = $this->conteneur->getApiNomsVernaculaires();
408 aurelien 26
		$this->wikini = $this->conteneur->getApiWikini();
307 jpm 27
		$this->meta = $this->conteneur->getApiMetaDonnees();
28
		$this->appUrls = $this->conteneur->getAppUrls();
284 aurelien 29
	}
302 jpm 30
 
31
	public function obtenirDonnees() {
306 jpm 32
		$donnees['nvjfl'] = $this->getNvjfl();
321 aurelien 33
		$donnees['chorologie'] = $this->getChorologie();
408 aurelien 34
		$donnees['wikini'] = $this->getWikini();
306 jpm 35
		return $donnees;
36
	}
37
 
38
	private function getNvjfl() {
307 jpm 39
		$nvjfl = array();
302 jpm 40
		$nt = $this->nomCourant->getNomRetenu()->get('num_taxonomique');
306 jpm 41
		$nomsVerna = $this->nomsVernaculaires->getRechercheComplete($nt);
307 jpm 42
		$nvjfl['noms'] = $nomsVerna['resultat'];
43
		$this->meta->setProjet('nvjfl');
44
		$meta = $this->meta->getMetaDonnees();
45
		$titreMeta = $meta[0]['titre'];
46
		$nvjfl['meta']['titre'] = $titreMeta;
47
		$nvjfl['meta']['url'] = $this->appUrls->obtenirUrlMetaDonnees('nvjfl');
48
		return $nvjfl;
272 delphine 49
	}
321 aurelien 50
 
329 aurelien 51
	public function getBloc() {
52
		$nt = $this->nomCourant->getNomRetenu()->get('num_taxonomique');
53
		$nomsVerna = $this->nomsVernaculaires->getRechercheLimitee($nt);
332 aurelien 54
		$donnees['nomsVerna'] = (isset($nomsVerna['resultat']) && is_array($nomsVerna['resultat'])) ? array_slice($nomsVerna['resultat'], 0, 5) : array();
329 aurelien 55
		return $donnees;
56
	}
57
 
321 aurelien 58
	private function getChorologie() {
59
		$infos_choro = $this->nomCourant->getNomSelectionne()->getInfos();
329 aurelien 60
		$donnees = $this->traiterTableauChorologie($infos_choro);
61
		$this->meta->setProjet('bdtfx');
62
		$meta = $this->meta->getMetaDonnees();
63
		$titreMeta = $meta[0]['titre'];
64
		$donnees['meta']['titre'] = $titreMeta;
65
		$donnees['meta']['url'] = $this->appUrls->obtenirUrlMetaDonnees('bdtfx');
66
		return $donnees;
67
	}
68
 
69
	private function traiterTableauChorologie($infos_choro) {
321 aurelien 70
		$donnees_choro = array();
71
		$colonnes = array();
72
		foreach ($infos_choro as $param => $valeur) {
329 aurelien 73
			if(substr($param, 0, 8) == 'presence') {
74
				$lieu = $this->obtenirLieuPourCodePresence($param);
75
				if($lieu != '') {
321 aurelien 76
					$donnees_choro['Présence'][$lieu] = $valeur;
329 aurelien 77
					if(!in_array($lieu, $colonnes)) {
78
						$colonnes[] = $lieu;
79
					}
321 aurelien 80
				}
329 aurelien 81
			} else {
82
				$donnees_choro = $this->traiterChampsStatuts($donnees_choro, $param, $valeur);
321 aurelien 83
			}
84
		}
329 aurelien 85
 
86
		ksort($donnees_choro);
87
		$donnees = array('colonnes' => $colonnes, 'donnees' => $donnees_choro);
321 aurelien 88
 
89
		return $donnees;
90
	}
329 aurelien 91
 
92
	private function traiterChampsStatuts($tableau_donnees, $code, $valeur) {
93
		if ($code == 'statut_origine') {
94
			$tableau_donnees['Statut d\'origine']['France'] = $valeur;
95
		} elseif ($code == 'statut_introduction') {
96
			$tableau_donnees['Statut d\'introduction']['France'] = $valeur;
97
		} elseif ($code == 'statut_culture') {
98
			$tableau_donnees['Statut de culture']['France'] = $valeur;
99
		}
100
 
101
		return $tableau_donnees;
306 jpm 102
	}
329 aurelien 103
 
104
	private function obtenirLieuPourCodePresence($code) {
105
		$tableau_presence = explode('_', $code, 2);
106
		$prefixe = (count($tableau_presence) == 2) ? $tableau_presence[0] : '';
107
		$lieu = (count($tableau_presence) == 2) ? $tableau_presence[1] : '';
108
 
109
		if($code == 'presence') {
110
			$lieu = 'France';
111
		} elseif (($lieu != '') && strpos($lieu , '.') === false) {
112
			$lieu = 'France ('.$this->getCorrespondanceLieu($lieu).')';
113
		} else {
114
			$lieu = '';
115
		}
116
		return $lieu;
117
	}
118
 
119
	private function getCorrespondanceLieu($lieu) {
120
		switch(strtolower($lieu)) {
121
			case 'ga':
122
				$lieu = 'Hors Corse';
123
				break;
124
			case 'co':
125
				$lieu = 'Corse';
126
				break;
127
		}
128
 
129
		return $lieu;
130
	}
408 aurelien 131
 
132
	private function getWikini() {
133
		$wikini = array();
134
		$wikini['titre'] = 'Wikini';
135
		$referentiel = $this->conteneur->getParametre('referentiel');
136
		$num_tax = $this->nomCourant->getNomSelectionne()->get('num_taxonomique');
137
		$page_wiki = $this->wikini->getPageWikiPourRefEtNumTax($referentiel, $num_tax);
419 aurelien 138
		$wikini['noms_communs'] = $this->wikini->getTexteFormate($page_wiki, 'noms communs');
139
		$wikini['culture_et_arts'] = $this->wikini->getTexteFormate($page_wiki, 'culture et arts');
140
		$wikini['usage'] = $this->wikini->getTexteFormate($page_wiki, 'usage');
408 aurelien 141
		return $wikini;
142
	}
272 delphine 143
}
144
?>