Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 1273 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
146 jpm 1
<?php
2
class DeterminationFormateur implements Formateur {
3
 
159 jpm 4
	const TPL_VUE = 'determination';
146 jpm 5
 
6
	private $parametres = null;
7
	private $surligneur = null;
8
	private $trieur = null;
9
	private $urls = null;
10
	private $fusioneur = null;
11
	private $manipulateurDeChaine = null;
12
	private $imagesService = null;
13
 
14
	private $motsASurligner = array();
15
	private $noms = array();
16
	private $infosPourTpl = array();
617 mathilde 17
 
146 jpm 18
	public function __construct(ParametresResultats $parametres, Array $resultats,
19
		Surligneur $surligneur = null, Trieur $trieur = null, AppUrls $urls = null,
20
		ChaineManipulateur $manipulateurDeChaine = null, Images $imagesService = null) {
21
 
22
		$this->parametres = $parametres;
23
		$this->noms = $resultats['resultat'];
24
		$this->surligneur = (is_null($surligneur)) ? new Surligneur() : $surligneur;
25
		$this->trieur = (is_null($trieur)) ? new Trieur() : $trieur;
26
		$this->urls = (is_null($urls)) ? new AppUrls() : $urls;
27
		$this->manipulateurDeChaine = is_null($manipulateurDeChaine) ? new ChaineManipulateur() : $manipulateurDeChaine;
28
		$this->imagesService = is_null($imagesService) ? new Images($this->parametres->projetImg) : $imagesService;
29
	}
30
 
31
	public function getTplInfos() {
32
		return $this->infosPourTpl;
33
	}
34
 
35
	public function getTplNom() {
36
		return self::TPL_VUE;
37
	}
38
 
39
	public function formater() {
931 delphine 40
		$this->obtenirUrlsDessins();
146 jpm 41
		$this->obtenirUrlsPhotos();
279 gduche 42
		$this->chargerRepartition();
146 jpm 43
		$this->extraireInfosNomsPourTplDetermination();
1273 aurelien 44
		$this->infosPourTpl['urlWidget'] = Config::get('base_url_widget_saisie')."?referentiel=".Registre::get('parametres.referentiel');
146 jpm 45
	}
617 mathilde 46
 
931 delphine 47
	private function obtenirUrlsDessins() {
48
		if (Config::get(Registre::get('parametres.referentiel').'.baseDessins') != "") {
49
			$this->extraireInfosTaxons();
50
			$this->imagesService->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseDessins'));
51
			$tax = implode(',', $this->infosPourTpl['taxons']);
52
			$this->imagesService->setNnTaxon($tax);
1115 mathias 53
			$costeImg = $this->imagesService->setApi(Eflore::API_EFLORE)->getInfosImagesTaxons();
931 delphine 54
			if (!empty($costeImg)) {
55
				foreach ($costeImg as  $infos) {
56
					$num_taxon = $infos['num_taxonomique'];
57
					$images[$num_taxon][] = $infos['binaire.href'];
58
					$this->infosPourTpl['dessins'] = $images;
59
				}
617 mathilde 60
			}
61
		}
62
	}
997 aurelien 63
 
617 mathilde 64
	private function extraireInfosTaxons() {
65
		foreach ($this->noms as $id => $nom ) {
66
			if (array_key_exists('num_taxonomique', $nom)) {
67
				$this->infosPourTpl['taxons'][$id] = $nom['num_taxonomique'];
68
			}
69
		}
70
	}
71
 
872 delphine 72
	private function obtenirUrlsPhotos() {
1060 aurelien 73
		if (Config::get(Registre::get('parametres.referentiel').'.baseImages') != "") {
74
			$this->imagesService->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseImages'));
75
			$ids = $this->extraireIdDesNoms();
1115 mathias 76
			$urls = $this->imagesService->setApi(Eflore::API_EFLORE)->getUrlsImagesParIdsNoms($ids);
1060 aurelien 77
			$this->infosPourTpl['imagesUrls'] = $this->supprimerCodeReferentielDesIds($urls);
78
		}
279 gduche 79
	}
997 aurelien 80
 
146 jpm 81
	private function extraireIdDesNoms() {
82
		$ids = array();
83
		foreach ($this->noms as $id => $nom) {
84
			$idAAjouter = $id;
85
			if (is_numeric($idAAjouter)) {
86
				$ids[] = $idAAjouter;
87
			}
88
			if (array_key_exists('nom_retenu.id', $nom)) {
89
				if (in_array($nom['nom_retenu.id'], $ids) == false) {
90
					$idAAjouter = $nom['nom_retenu.id'];
91
					if (is_numeric($idAAjouter)) {
92
						$ids[] = $idAAjouter;
93
					}
94
				}
95
			}
96
		}
97
		return $ids;
98
	}
1004 aurelien 99
 
100
	private function extraireNumerosNomSynonymes() {
101
		$numNomsASynonyme = array();
102
		foreach ($this->noms as $id => $nom) {
1133 raphael 103
			// certains taxons requêtés via /bdtfx/noms?masque= n'ont pas de num_tax ni de num_nom_retenu
104
			if(!isset($nom['nom_retenu.id'])) continue;
1004 aurelien 105
			$num_nom_retenu = $nom['nom_retenu.id'];
106
			if(!isset($numNomsASynonyme[$num_nom_retenu])) {
107
				$numNomsASynonyme[$num_nom_retenu] = array();
108
			}
109
			$numNomsASynonyme[$num_nom_retenu][] = $id;
110
			if($num_nom_retenu != $id) {
111
				$numNomsASynonyme[$id] = $numNomsASynonyme[$num_nom_retenu];
112
			}
113
		}
114
		return $numNomsASynonyme;
115
	}
116
 
931 delphine 117
	private function supprimerCodeReferentielDesIds($urls) {
146 jpm 118
		$urlsNettoyees = array();
119
		foreach ($urls as $id => $url) {
931 delphine 120
			$id = $this->supprimerCodeReferentiel($id);
146 jpm 121
			$urlsNettoyees[$id] = $url;
122
		}
123
		return $urlsNettoyees;
124
	}
1004 aurelien 125
 
931 delphine 126
	private function supprimerCodeReferentiel($chaine) {
997 aurelien 127
		$codeReferentiel = Registre::get('parametres.referentiel').'.';
931 delphine 128
		$chaine = str_replace($codeReferentiel, '', $chaine);
311 jpm 129
		return $chaine;
130
	}
872 delphine 131
 
132
	// TODO : utiliser le conteneur pour charger tous les objets de cette classe
133
	private function chargerRepartition() {
931 delphine 134
		if (Config::get(Registre::get('parametres.referentiel').'.baseRepartition') != "") {
135
			$conteneur = new Conteneur();
136
			$cartesWs = $conteneur->getApiCartes();
137
			$cartesWs->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseRepartition'));
138
			$cartesWs->setLargeur('108x101');
139
			$urls = array();
1004 aurelien 140
			$numsNomsASynonymes = $this->extraireNumerosNomSynonymes();
931 delphine 141
			foreach ($this->noms as $id => $nom) {
142
				if (array_key_exists('nom_retenu.id', $nom)) {
143
					$id = $nom['nom_retenu.id'];
1004 aurelien 144
					$idsNoms = $numsNomsASynonymes[$id];
145
					$cartesWs->setId("nn:".implode(',',$idsNoms)."");
931 delphine 146
					if (array_key_exists($id, $urls) == false) {
147
						$urls[$id] = $cartesWs->getUrlPng();
148
					}
872 delphine 149
				}
150
			}
931 delphine 151
			$this->infosPourTpl['repartition']['urls'] = $urls;
872 delphine 152
		}
153
	}
311 jpm 154
 
872 delphine 155
	private function extraireInfosNomsPourTplDetermination() {
156
		$tri = $this->diviserResultats();
157
		$this->infosPourTpl['nomsSansCorrespondance'] = isset($tri['sansCorres']) ? $tri['sansCorres'] : false;
158
		$this->infosPourTpl['noms'] = isset($tri['retenus'])  ? $tri['retenus'] : false;
159
		$this->infosPourTpl['synonymes'] = isset($tri['synonymes'] ) ?  $tri['synonymes']  : false;
160
	}
1004 aurelien 161
 
792 mathilde 162
	/**
163
	 * division ordonnée par
164
	 * 1 - noms retenus qui commencent par la requete
165
	 * 2 - requete contenue dans un synonyme dont le nom retenu ne contient pas la requete
166
	 * 3 - requete contenue dans un hybride  retenu
167
	 * 4 - requete contenue dans un nom retenu mais pas au début
168
	 * 5 - requete contenue dans un nom sans correspondance
169
	 *
170
	 */
171
	private function diviserResultats() {
172
		$tri = array();
173
		$sansCorres = array();
174
		$synonymes = array();
175
		$retenus = array();
176
		foreach ($this->noms as $cle => $valeurs) {
177
			if ($valeurs['nom_retenu.libelle'] == null) {//sans correspondances
915 delphine 178
				$sansCorres[$cle] = $valeurs['nom_sci_complet'];
792 mathilde 179
			} elseif ($valeurs['retenu'] == 'true') { // retenus
923 delphine 180
				if (preg_match('/ x |^x /',$valeurs['nom_sci'] )  ) {
792 mathilde 181
					//hybrides
880 aurelien 182
					$retenus[2][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
923 delphine 183
				} elseif (strripos($valeurs['nom_sci_complet'], $this->parametres->masqueRecherche) === 0) {//preg_match('/^'.strtolower($this->parametres->masqueRecherche).' |^'.strtolower($this->parametres->masqueRecherche).'$/', strtolower($valeurs['nom_sci']) ) ) {
792 mathilde 184
					//commence par
880 aurelien 185
					$retenus[0][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
968 delphine 186
				} else {
792 mathilde 187
					//contient
880 aurelien 188
					$retenus[3][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
146 jpm 189
				}
792 mathilde 190
			} else {//synonymes
191
				$idNomRetenu = $valeurs['nom_retenu.id'];
923 delphine 192
				if (in_array($valeurs['nom_retenu.id'], array_keys($this->noms)) == false) {
193
					//synonymes dont le nom retenu n'est pas un résultat de recherche
1189 mathias 194
					$retenus[1][$idNomRetenu] = $this->retournerInfosNomRetenu($idNomRetenu,$valeurs['nom_retenu.libelle'], $valeurs['rang.libelle']);
792 mathilde 195
					$this->infosPourTpl['taxons'][$idNomRetenu] = $valeurs['num_taxonomique']; //num taxon pour images coste
196
				}
197
				$synonymes[$idNomRetenu][] = $this->retournerInfosSynonyme($cle, $valeurs);
146 jpm 198
			}
199
		}
792 mathilde 200
		ksort($retenus);
201
		$tri['retenus'] = $retenus;
202
		$tri['synonymes'] = $synonymes;
203
		$tri['sansCorres'] = $sansCorres;
204
		return $tri;
146 jpm 205
	}
1004 aurelien 206
 
792 mathilde 207
	private  function retournerInfosNomRetenu($cle, $nom_sci, $rang) {
208
		$infos = array();
209
		$infos['nomSciRetenu'] = $nom_sci;
210
		$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom,  strtolower($this->parametres->masqueRecherche), $nom_sci);
211
		$infos['rang'] = $rang;
212
		return $infos;
213
	}
1004 aurelien 214
 
792 mathilde 215
	private  function retournerInfosSynonyme($cle, $valeurs) {
216
		$infos = array();
217
		$infos['nn'] = $cle;
902 delphine 218
		$infos['nomSci'] = $valeurs['nom_sci_complet'];
792 mathilde 219
		$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom, $this->parametres->masqueRecherche, $valeurs['nom_retenu.libelle']);
220
		return $infos;
221
	}
1004 aurelien 222
 
792 mathilde 223
	public function trier() {
1004 aurelien 224
		$nomsRetenus = array();
225
		foreach ($this->infosPourTpl['noms'] as $categorie => $valeurs ) { //classement alpha par groupes
226
			$nomsRetenus += $this->classerAlphabetiquement('nomSciRetenu', $valeurs);
227
		}
228
		$this->infosPourTpl['noms'] = $nomsRetenus;
229
		$this->infosPourTpl['nomsSansCorrespondance'] =
230
		$this->classerAlphabetiquement('nomSciRetenu', $this->infosPourTpl['nomsSansCorrespondance'] );
146 jpm 231
	}
792 mathilde 232
 
146 jpm 233
	private function ajouterAuxNomsScoreSimilariteAvec($masque) {
234
		$nom_demande_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($masque));
235
		foreach ($this->infosPourTpl['noms'] as $id => $nom) {
236
			$nom_flou_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($nom['nomSciRetenu']));
237
			$stat = array();
238
			// Prime pour la ressemblance globale :
239
			$score = 500 - levenshtein($nom_flou_ss, $nom_demande_ss);
240
			// On affine
241
			$score = $score + (similar_text($nom_demande_ss, $nom_flou_ss) * 3);
242
			$nom['score'] = $score;
243
			$this->infosPourTpl['noms'][$id] = $nom;
244
		}
245
	}
1004 aurelien 246
 
872 delphine 247
	private function classerAlphabetiquement($champs, $valeurs) {
248
		$this->trieur->setTableau($valeurs);
931 delphine 249
		$this->trieur->setChampsEtOrdres(array($champs => 'nat'));
872 delphine 250
		return $this->trieur->trier();
251
	}
146 jpm 252
 
253
	public function surligner() {
254
		$this->definirMotsASurligner();
255
		foreach ($this->infosPourTpl['noms'] as $idNom => $nom) {
252 delphine 256
			$this->infosPourTpl['noms'][$idNom]['nomSciRetenu'] = $this->surlignerMotsMasqueRecherche($nom['nomSciRetenu']);
257
			if (isset($this->infosPourTpl['synonymes'][$idNom])) {
258
				foreach ($this->infosPourTpl['synonymes'][$idNom] as $idSyn => $synonyme) {
259
					$this->infosPourTpl['synonymes'][$idNom][$idSyn]['nomSci'] = $this->surlignerMotsMasqueRecherche($synonyme['nomSci']);
146 jpm 260
				}
261
			}
262
		}
263
	}
1004 aurelien 264
 
146 jpm 265
	private function definirMotsASurligner() {
266
		$this->motsASurligner = explode(' ', $this->parametres->masqueRecherche);
267
	}
268
	private function surlignerMotsMasqueRecherche($nom) {
269
		$this->surligneur->setTexte($nom);
270
		$nom = $this->surligneur->surlignerMots($this->motsASurligner);
271
		return $nom;
272
	}
273
}
274
?>