Subversion Repositories Applications.referentiel

Rev

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

Rev Author Line No. Line
78 delphine 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Controleur du module Fiche Taxon.
5
 *
6
 * @category	Php 5.2
7
 * @package		Taxon
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: Fiche.php 96 2010-06-21 16:46:31Z jpm $
13
 */
14
class FicheTaxon extends AppliControleur {
15
 
16
	private $donnees = array();
17
	protected $taxonDao = null;
85 delphine 18
	private $tableau_manuel = null;
19
	private $num_taxon = array(0=>0,1=>0,2=>0);
78 delphine 20
 
21
	//+----------------------------------------------------------------------------------------------------------------+
22
	// Méthodes
23
	/**
24
	 * Fonction d'affichage par défaut
25
	 */
26
	public function executerActionParDefaut() {
27
		return $this->afficherTaxon();
28
	}
29
 
30
	// +---------------------------------------------------------------------------------------------------------------+
82 delphine 31
	// FICHE CONSULTATION TAXON
78 delphine 32
	public function afficherTaxon() {
33
		// Récupération du référentiel
34
		if (isset($_GET['ref'])) {
35
			$this->referentiel = strtolower($_GET['ref']);
36
		}
37
		// Gestion des actions par défaut
38
		$this->taxonDao = new TaxonDao();
39
		$this->definirCommeModulePrincipal(get_class($this));
40
		$this->construireMenu($this->referentiel);
41
		$this->construireFilAriane($this->referentiel);
42
		$this->executerActionReferentiel('Recherche', 'chargerMoteurRecherche', $this->referentiel);
43
 
44
		// Gestion des données de la requête
45
		if (!isset($_GET['num_nom'])) {
46
 
47
		} else {
48
			// Récupération des données
49
			$this->donnees['referentiel'] = $this->referentiel;
50
			$this->donnees['num_nom'] = $_GET['num_nom'];
82 delphine 51
			$this->donnees['info'] = $this->taxonDao->getTaxon($this->referentiel, $this->donnees['num_nom']);
103 jpm 52
			$this->donnees['num_nom_retenu'] = $this->donnees['info']['num_nom_retenu'];
53
			$this->donnees['nom'] = $this->donnees['info']['nom_complet'];
78 delphine 54
 
88 delphine 55
			if ($this->donnees['info'] != '') {
56
				// Chargement des données des onglets
57
				$this->chargerNomenclature();
58
				$this->chargerSynonymie();
59
				$this->chargerClassification();
60
				$this->chargerChorologie();
61
				$this->chargerComplements();
62
			}
78 delphine 63
 
64
			$this->setSortie(self::RENDU_CORPS, $this->getVue('fiche_taxon', $this->donnees));
65
		}
66
	}
67
 
82 delphine 68
	private function chargerNomenclature() {
69
		$this->donnees['selectionne'] = $this->taxonDao->getNomenclature($this->referentiel, $this->donnees['num_nom']);
70
		if (strpos($this->donnees['nom'], ' x ') ) {
85 delphine 71
			if ($this->donnees['num_nom'] != $this->donnees['num_nom_retenu'] && $this->donnees['num_nom_retenu'] != '') {
82 delphine 72
				$this->donnees['retenu'] = $this->taxonDao->getNomenclature($this->referentiel, $this->donnees['num_nom_retenu']);
73
				$this->donnees['parents'] = $this->taxonDao->getParentsHybride($this->referentiel, $this->donnees['num_nom_retenu']);
74
			} else {
75
				$this->donnees['parents'] = $this->taxonDao->getParentsHybride($this->referentiel, $this->donnees['num_nom']);
76
			}
77
		} else {
85 delphine 78
			if ($this->donnees['num_nom'] != $this->donnees['num_nom_retenu'] && $this->donnees['num_nom_retenu'] != '') {
82 delphine 79
				$this->donnees['retenu'] = $this->taxonDao->getNomenclature($this->referentiel, $this->donnees['num_nom_retenu']);
80
			}
81
		}
82
	}
83
 
84
	// recherche les synonymes (à compléter)
85
	private function chargerSynonymie() {
86
		$rechercheDao = new RechercheDao();
87
		// recherche des synonymes nomenclaturaux et taxonomiques
88
		$parametres = $this->parserChaineDeRecherche('nn:'.$this->donnees['num_nom'].' tax:1');
89
		$parametres['ref']= $this->referentiel;
85 delphine 90
		$synonymes = $rechercheDao->chercher('ParTaxon', $parametres);
91
		if ($synonymes != '') {
92
			foreach ($synonymes as $synonyme) {
104 delphine 93
				$this->trierSynonymesNomenclaturauxTaxonomiques($synonyme);
94
				$this->trierSynonymesMalAppliques($synonyme);
95
				$this->trierSynonymesOrthographiques($synonyme);
82 delphine 96
			}
104 delphine 97
		}
98
		// synonyme douteux
99
		if ($this->donnees['info']['synonyme_douteux'] == 1) {
100
			$this->donnees['fiche_synonymie']['douteux']['num_nom'] = $this->donnees['info'];
101
		}
102
		// synonyme proparte
103
		if ($this->donnees['info']['synonyme_proparte'] != ''){
104
			$propartes = preg_split('/;/', $this->donnees['info']['synonyme_proparte']);
105
			foreach ($propartes as $protarte) {
106
				$this->donnees['fiche_synonymie']['pro parte'] =
107
				$this->taxonDao->getTaxonAffichage($this->referentiel, $proparte);
85 delphine 108
			}
104 delphine 109
		}
110
		// homonymie
111
		$nom = $this->encodeChaine($this->donnees['info']['nom_complet']);
110 jpm 112
		$homonymes = $this->taxonDao->getHomonyme($this->referentiel, $nom);
113
		if (count($homonymes) > 1) {
114
			foreach ($homonymes as $id => &$homonyme) {
115
				$homonyme['statut'] = $homonyme['homonyme'];
116
			}
117
 
118
			$this->donnees['fiche_synonymie']['Homonymie (sensu)'] = $homonymes;
104 delphine 119
		}
120
		// Même basionyme
121
		if ($this->donnees['info']['basionyme'] != '') {
122
			$basionyme_commun = $this->taxonDao->getNomsBasionymeCommun($this->referentiel, $this->donnees['info']['basionyme']);
123
			foreach ($basionyme_commun as $nom) {
124
				if ($nom['num_nom_retenu'] != $this->donnees['num_nom_retenu']) {
125
					$this->donnees['fiche_synonymie']['Basionyme commun'][] = $nom;
88 delphine 126
				}
127
			}
104 delphine 128
		}
129
	}
110 jpm 130
 
104 delphine 131
	private function trierSynonymesNomenclaturauxTaxonomiques($synonyme) {
132
		if ($this->donnees['num_nom'] != $synonyme['num_nom'] && $synonyme['basionyme'] != null) {
133
			if (($this->donnees['num_nom'] != $synonyme['num_nom']) && ($synonyme['basionyme'] ==
134
					$this->donnees['num_nom'] || $this->donnees['info']['basionyme'] == $synonyme['num_nom'] ||
135
					$this->donnees['info']['basionyme'] == $synonyme['basionyme'])) {
136
				$this->donnees['fiche_synonymie']['nomenclaturale'][] = $synonyme;
137
			} elseif ($this->donnees['num_nom'] != $synonyme['num_nom'] && $synonyme['basionyme'] != null &&
138
					$this->donnees['info']['basionyme'] != null) {
139
				$this->donnees['fiche_synonymie']['taxonomique'][] = $synonyme;
140
			}
141
		} elseif ($this->donnees['num_nom'] != $synonyme['num_nom']) {
142
			$this->donnees['fiche_synonymie']['indéterminée (pas de basionyme)'][] = $synonyme;
143
		}
144
	}
110 jpm 145
 
104 delphine 146
	private function trierSynonymesMalAppliques($synonyme) {
147
		if ($synonyme['synonyme_mal_applique'] == 1) {
148
			if ($synonyme['num_nom'] == $synonyme['num_nom_retenu']) {
149
				$synonyme['statut'] = 'posséde des synonymes mal appliqués';
150
			} else {
151
				$synonyme['statut'] = 'est synonyme mal appliqué du num_nom '.$synonyme['num_nom_retenu'];
88 delphine 152
			}
104 delphine 153
			$this->donnees['fiche_synonymie']['mal appliquée'][] = $synonyme;
154
		}
82 delphine 155
	}
110 jpm 156
 
104 delphine 157
	private function trierSynonymesOrthographiques($synonyme) {
158
		if (isset($synonyme['synonyme_orthographique']) && $synonyme['synonyme_orthographique'] != '') {
159
			if ($synonyme['synonyme_orthographique'] == $synonyme['num_nom']) {
160
				$synonyme['statut'] = 'posséde des synonymes orthographiques';
161
			} else {
162
				$synonyme['statut'] = 'est synonyme orthographique du num_nom '.$synonyme['synonyme_orthographique'];
163
			}
164
			$this->donnees['fiche_synonymie']['orthographique'][] = $synonyme;
165
		}
166
	}
82 delphine 167
 
168
	private function chargerChorologie() {
85 delphine 169
		$this->chargerTableauManuel('presence');
170
		$this->chargerTableauManuel('statuts_origine');
171
		$this->chargerTableauManuel('statuts_introduction');
172
		$this->chargerTableauManuel('statuts_culture');
82 delphine 173
		foreach ($this->donnees['info'] as $param => $valeur) {
174
			if ($param == 'presence') {
175
				$this->donnees['chorologie']['Présence']['France']['code'] = $valeur;
85 delphine 176
				$this->donnees['chorologie']['Présence']['France']['valeur'] = $this->tableau_manuel['presence'][$valeur];
82 delphine 177
			} elseif (preg_match('/presence_(.*)/', $param, $lieu)) {
178
				$this->donnees['chorologie']['Présence'][$lieu['1']]['code'] = $valeur;
85 delphine 179
				$this->donnees['chorologie']['Présence'][$lieu['1']]['valeur'] = $this->tableau_manuel['presence'][$valeur];
82 delphine 180
			} elseif ($param == 'statut_origine') {
181
				$this->donnees['chorologie']['Statut d\'origine']['France']['code'] = $valeur;
85 delphine 182
				$this->donnees['chorologie']['Statut d\'origine']['France']['valeur'] =
183
					$this->tableau_manuel['statuts_origine'][$valeur];
82 delphine 184
			} elseif (preg_match('/statut_origine_(.*)/', $param, $lieu)) {
185
				$this->donnees['chorologie']['Statut d\'origine'][$lieu['1']]['code'] = $valeur;
85 delphine 186
				$this->donnees['chorologie']['Statut d\'origine'][$lieu['1']]['valeur'] =
187
					$this->tableau_manuel['statuts_origine'][$valeur];
82 delphine 188
			} elseif ($param == 'statut_introduction') {
189
				$this->donnees['chorologie']['Statut d\'introduction']['France']['code'] = $valeur;
85 delphine 190
				$this->donnees['chorologie']['Statut d\'introduction']['France']['valeur'] =
191
					$this->tableau_manuel['statuts_introduction'][$valeur];
82 delphine 192
			} elseif (preg_match('/statut_introduction_(.*)/', $param, $lieu)) {
193
				$this->donnees['chorologie']['Statut d\'introduction'][$lieu['1']]['code'] = $valeur;
85 delphine 194
				$this->donnees['chorologie']['Statut d\'introduction'][$lieu['1']]['valeur'] =
195
					$this->tableau_manuel['statuts_introduction'][$valeur];
82 delphine 196
			} elseif ($param == 'statut_culture') {
197
				$this->donnees['chorologie']['Statut de culture']['France']['code'] = $valeur;
85 delphine 198
				$this->donnees['chorologie']['Statut de culture']['France']['valeur'] =
199
					$this->tableau_manuel['statuts_culture'][$valeur];
82 delphine 200
			} elseif (preg_match('/statut_culture_(.*)/', $param, $lieu)) {
201
				$this->donnees['chorologie']['Statut de culture'][$lieu['1']]['code'] = $valeur;
85 delphine 202
				$this->donnees['chorologie']['Statut de culture'][$lieu['1']]['valeur'] =
203
					$this->tableau_manuel['statuts_culture'][$valeur];
82 delphine 204
			}
205
		}
110 jpm 206
		foreach ($this->donnees['chorologie']['Présence'] as $lieu => $valeur) {
82 delphine 207
			if (!isset($this->donnees['chorologie']['Statut d\'origine'][$lieu])) {
208
				$this->donnees['chorologie']['Statut d\'origine'][$lieu]['code'] = '';
85 delphine 209
				$this->donnees['chorologie']['Statut d\'origine'][$lieu]['valeur'] =
210
					$this->tableau_manuel['statuts_origine'][''];
82 delphine 211
			}
212
			if (!isset($this->donnees['chorologie']['Statut d\'introduction'][$lieu])) {
213
				$this->donnees['chorologie']['Statut d\'introduction'][$lieu]['code'] = '';
85 delphine 214
				$this->donnees['chorologie']['Statut d\'introduction'][$lieu]['valeur'] =
215
					$this->tableau_manuel['statuts_introduction'][''];
82 delphine 216
			}
217
			if (!isset($this->donnees['chorologie']['Statut de culture'][$lieu])) {
218
				$this->donnees['chorologie']['Statut de culture'][$lieu]['code'] = '';
85 delphine 219
				$this->donnees['chorologie']['Statut de culture'][$lieu]['valeur'] =
220
					$this->tableau_manuel['statuts_culture'][''];
82 delphine 221
			}
222
		}
223
	}
224
 
85 delphine 225
	private function chargerClassification() {
226
		if ($this->donnees['info']['num_tax_sup'] != '' || isset($this->donnees['retenu']['num_tax_sup'])) {
227
			if ($this->donnees['num_nom'] == $this->donnees['num_nom_retenu']) {
228
				$this->donnees['classification']['supérieurs'] = array_reverse($this->taxonDao->getClassification
229
					('Superieur', $this->referentiel, $this->donnees['info']['num_tax_sup']));
230
			} else {
231
				$this->donnees['classification']['supérieurs'] = array_reverse($this->taxonDao->getClassification
232
				('Superieur', $this->referentiel, $this->donnees['retenu']['num_tax_sup']));
233
			}
234
		}
235
		if ($this->donnees['num_nom_retenu'] != '') {
236
			$class_inf = $this->taxonDao->getClassification
237
				('Inferieur', $this->referentiel, $this->donnees['num_nom_retenu']);
88 delphine 238
			if ($class_inf != '') {
239
				$this->donnees['classification']['inférieurs'] = $class_inf['inf'];
240
				$this->donnees['niveau'] = $class_inf['niveau'];
241
			}
85 delphine 242
		}
243
	}
244
 
104 delphine 245
	private function chargerComplements() {
85 delphine 246
		$champs_manuel_technique = explode(',', $this->manuel['champs']);
247
		$champs_base_donnees = key($this->donnees['info']);
248
		$champs_supp_base = array_diff_key($this->donnees['info'], array_flip($champs_manuel_technique));
249
		foreach ($champs_supp_base as $champ=>$valeur) {
250
			if (!(preg_match('/presence_(.*)/',$champ) || preg_match('/statut_origine_(.*)/', $champ) ||
251
				 preg_match('/statut_introduction_(.*)/', $champ) || preg_match('/statut_culture_(.*)/', $champ))) {
252
				$this->donnees['complement'][$champ] = $valeur;
253
			}
254
		}
255
	}
256
 
82 delphine 257
	private function parserChaineDeRecherche($chaine) {
258
		$mots = preg_split('/ /i', $chaine, -1, PREG_SPLIT_NO_EMPTY);
259
		$parametres = array('mots' => '');
260
		$cle_precedente = null;
261
		foreach ($mots as $mot) {
262
			if (preg_match('/^(sg|gen|sp|ssp|au|an|nn|bib|nr|tax):(.*)$/', $mot, $match)) {
263
				$cle = $match[1];
264
				$cle_precedente = $cle;
265
				$valeur = $match[2];
266
				$parametres[$cle] = $valeur;
267
			} else if (!is_null($cle_precedente)) {
268
				$parametres[$cle_precedente] .= ' '.$mot;
269
			} else if (is_null($cle_precedente)) {
270
				if (empty($parametres['mots'])) {
271
					$parametres['mots'] = $mot;
272
				} else {
273
					$parametres['mots'] .= ' '.$mot;
274
				}
275
			}
276
		}
277
		return $parametres;
278
	}
279
 
88 delphine 280
	public function encodeChaine($chaine) {
281
		if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
282
			$chaine = mb_convert_encoding($chaine, Config::get('sortie_encodage'), Config::get('appli_encodage'));
283
		}
284
		$chaine = urlencode($chaine);
285
		return $chaine;
286
	}
287
 
82 delphine 288
	// retourne l'url de la fiche taxon pour les liens
78 delphine 289
	public static function getUrlFicheTaxon($params, $type) {
290
		$taxon = null;
291
		switch ($type) {
292
			case 'bas' :
293
				$taxon['num_nom'] = $params['bas_num'];
294
				break;
295
			case 'p1' :
296
				$taxon['num_nom'] = $params['p1_num'];
297
				break;
298
			case 'p2' :
299
				$taxon['num_nom'] = $params['p2_num'];
300
				break;
110 jpm 301
			default :
302
				break;
78 delphine 303
		}
304
		return Recherche::getUrlFicheTaxon($taxon);
305
	}
306
 
85 delphine 307
	// charger tableau de $this->manuel
308
	private function chargerTableauManuel($titreTableau) {
309
		$champs = explode(',', $this->manuel[$titreTableau]);
310
		foreach ($champs as $champ) {
311
			list($champ_nom, $type) = explode('=', trim($champ));
312
			$this->tableau_manuel[$titreTableau][$champ_nom] = $type;
313
		}
314
	}
315
 
78 delphine 316
 
317
}