Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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