Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 448 | Rev 959 | 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);
422 delphine 54
		$donnees['nomsVerna'] = (isset($nomsVerna['resultat']) && is_array($nomsVerna['resultat'])) ? array_slice($nomsVerna['resultat'], 0, 3) : array();
55
		$donnees['autresNomsVerna'] = count($nomsVerna['resultat']) - 3;
56
		$donnees['wikini'] = $this->getWikini();
329 aurelien 57
		return $donnees;
58
	}
59
 
321 aurelien 60
	private function getChorologie() {
448 delphine 61
		$infos_choro = $this->nomCourant->getNomRetenu()->getInfos();
329 aurelien 62
		$donnees = $this->traiterTableauChorologie($infos_choro);
63
		$this->meta->setProjet('bdtfx');
64
		$meta = $this->meta->getMetaDonnees();
65
		$titreMeta = $meta[0]['titre'];
66
		$donnees['meta']['titre'] = $titreMeta;
67
		$donnees['meta']['url'] = $this->appUrls->obtenirUrlMetaDonnees('bdtfx');
68
		return $donnees;
69
	}
70
 
71
	private function traiterTableauChorologie($infos_choro) {
321 aurelien 72
		$donnees_choro = array();
73
		$colonnes = array();
74
		foreach ($infos_choro as $param => $valeur) {
329 aurelien 75
			if(substr($param, 0, 8) == 'presence') {
76
				$lieu = $this->obtenirLieuPourCodePresence($param);
77
				if($lieu != '') {
321 aurelien 78
					$donnees_choro['Présence'][$lieu] = $valeur;
329 aurelien 79
					if(!in_array($lieu, $colonnes)) {
80
						$colonnes[] = $lieu;
81
					}
321 aurelien 82
				}
329 aurelien 83
			} else {
84
				$donnees_choro = $this->traiterChampsStatuts($donnees_choro, $param, $valeur);
321 aurelien 85
			}
86
		}
329 aurelien 87
 
88
		ksort($donnees_choro);
89
		$donnees = array('colonnes' => $colonnes, 'donnees' => $donnees_choro);
321 aurelien 90
 
91
		return $donnees;
92
	}
329 aurelien 93
 
94
	private function traiterChampsStatuts($tableau_donnees, $code, $valeur) {
455 delphine 95
		if ($code == 'statut_origine.libelle') {
329 aurelien 96
			$tableau_donnees['Statut d\'origine']['France'] = $valeur;
455 delphine 97
		} elseif ($code == 'statut_introduction.libelle') {
329 aurelien 98
			$tableau_donnees['Statut d\'introduction']['France'] = $valeur;
455 delphine 99
		} elseif ($code == 'statut_culture.libelle') {
329 aurelien 100
			$tableau_donnees['Statut de culture']['France'] = $valeur;
101
		}
102
 
103
		return $tableau_donnees;
306 jpm 104
	}
329 aurelien 105
 
106
	private function obtenirLieuPourCodePresence($code) {
107
		$tableau_presence = explode('_', $code, 2);
108
		$prefixe = (count($tableau_presence) == 2) ? $tableau_presence[0] : '';
109
		$lieu = (count($tableau_presence) == 2) ? $tableau_presence[1] : '';
110
 
455 delphine 111
		if($code == 'presence.libelle') {
329 aurelien 112
			$lieu = 'France';
113
		} elseif (($lieu != '') && strpos($lieu , '.') === false) {
114
			$lieu = 'France ('.$this->getCorrespondanceLieu($lieu).')';
115
		} else {
116
			$lieu = '';
117
		}
118
		return $lieu;
119
	}
120
 
121
	private function getCorrespondanceLieu($lieu) {
122
		switch(strtolower($lieu)) {
123
			case 'ga':
124
				$lieu = 'Hors Corse';
125
				break;
126
			case 'co':
127
				$lieu = 'Corse';
128
				break;
129
		}
130
 
131
		return $lieu;
132
	}
408 aurelien 133
 
134
	private function getWikini() {
135
		$wikini = array();
136
		$wikini['titre'] = 'Wikini';
137
		$referentiel = $this->conteneur->getParametre('referentiel');
138
		$num_tax = $this->nomCourant->getNomSelectionne()->get('num_taxonomique');
139
		$page_wiki = $this->wikini->getPageWikiPourRefEtNumTax($referentiel, $num_tax);
419 aurelien 140
		$wikini['noms_communs'] = $this->wikini->getTexteFormate($page_wiki, 'noms communs');
141
		$wikini['culture_et_arts'] = $this->wikini->getTexteFormate($page_wiki, 'culture et arts');
142
		$wikini['usage'] = $this->wikini->getTexteFormate($page_wiki, 'usage');
408 aurelien 143
		return $wikini;
144
	}
272 delphine 145
}
146
?>