Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 923 | 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() {
931 delphine 41
		$this->obtenirUrlsDessins();
146 jpm 42
		$this->obtenirUrlsPhotos();
279 gduche 43
		$this->chargerRepartition();
146 jpm 44
		$this->extraireInfosNomsPourTplDetermination();
931 delphine 45
		$this->infosPourTpl['urlWidget'] = Config::get('base_url_widget')."?referentiel=".Registre::get('parametres.referentiel');
146 jpm 46
	}
617 mathilde 47
 
872 delphine 48
 
931 delphine 49
	private function obtenirUrlsDessins() {
50
		if (Config::get(Registre::get('parametres.referentiel').'.baseDessins') != "") {
51
			$this->extraireInfosTaxons();
52
			$this->imagesService->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseDessins'));
53
			$tax = implode(',', $this->infosPourTpl['taxons']);
54
			$this->imagesService->setNnTaxon($tax);
55
			$costeImg = $this->imagesService->getInfosImagesTaxons();
56
			if (!empty($costeImg)) {
57
				foreach ($costeImg as  $infos) {
58
					$num_taxon = $infos['num_taxonomique'];
59
					$images[$num_taxon][] = $infos['binaire.href'];
60
					$this->infosPourTpl['dessins'] = $images;
61
				}
617 mathilde 62
			}
63
		}
64
	}
65
	private function extraireInfosTaxons() {
66
		foreach ($this->noms as $id => $nom ) {
67
			if (array_key_exists('num_taxonomique', $nom)) {
68
				$this->infosPourTpl['taxons'][$id] = $nom['num_taxonomique'];
69
			}
70
		}
71
	}
72
 
872 delphine 73
	private function obtenirUrlsPhotos() {
74
		$this->imagesService->setProjet('cel');
75
		$ids = $this->extraireIdDesNoms();
76
		$urls = $this->imagesService->getUrlsImagesParIdsNoms($ids);
931 delphine 77
		$this->infosPourTpl['imagesUrls'] = $this->supprimerCodeReferentielDesIds($urls);
279 gduche 78
	}
146 jpm 79
	private function extraireIdDesNoms() {
80
		$ids = array();
81
		foreach ($this->noms as $id => $nom) {
82
			$idAAjouter = $id;
83
			if (is_numeric($idAAjouter)) {
84
				$ids[] = $idAAjouter;
85
			}
86
			if (array_key_exists('nom_retenu.id', $nom)) {
87
				if (in_array($nom['nom_retenu.id'], $ids) == false) {
88
					$idAAjouter = $nom['nom_retenu.id'];
89
					if (is_numeric($idAAjouter)) {
90
						$ids[] = $idAAjouter;
91
					}
92
				}
93
			}
94
		}
95
		return $ids;
96
	}
931 delphine 97
	private function supprimerCodeReferentielDesIds($urls) {
146 jpm 98
		$urlsNettoyees = array();
99
		foreach ($urls as $id => $url) {
931 delphine 100
			$id = $this->supprimerCodeReferentiel($id);
146 jpm 101
			$urlsNettoyees[$id] = $url;
102
		}
103
		return $urlsNettoyees;
104
	}
931 delphine 105
	private function supprimerCodeReferentiel($chaine) {
106
		$codeReferentiel = $this->parametres->referentielCourant.'.';
107
		$chaine = str_replace($codeReferentiel, '', $chaine);
311 jpm 108
		return $chaine;
109
	}
872 delphine 110
 
111
	// TODO : utiliser le conteneur pour charger tous les objets de cette classe
112
	private function chargerRepartition() {
931 delphine 113
		if (Config::get(Registre::get('parametres.referentiel').'.baseRepartition') != "") {
114
			$conteneur = new Conteneur();
115
			$cartesWs = $conteneur->getApiCartes();
116
			$cartesWs->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseRepartition'));
117
			$cartesWs->setLargeur('108x101');
118
			$urls = array();
119
			foreach ($this->noms as $id => $nom) {
120
				if (array_key_exists('nom_retenu.id', $nom)) {
121
					$id = $nom['nom_retenu.id'];
122
					$cartesWs->setId("nn:$id");
123
					if (array_key_exists($id, $urls) == false) {
124
						$urls[$id] = $cartesWs->getUrlPng();
125
					}
872 delphine 126
				}
127
			}
931 delphine 128
			$this->infosPourTpl['repartition']['urls'] = $urls;
872 delphine 129
		}
130
	}
311 jpm 131
 
872 delphine 132
	private function extraireInfosNomsPourTplDetermination() {
133
		$tri = $this->diviserResultats();
134
		$this->infosPourTpl['nomsSansCorrespondance'] = isset($tri['sansCorres']) ? $tri['sansCorres'] : false;
135
		$this->infosPourTpl['noms'] = isset($tri['retenus'])  ? $tri['retenus'] : false;
136
		$this->infosPourTpl['synonymes'] = isset($tri['synonymes'] ) ?  $tri['synonymes']  : false;
137
	}
792 mathilde 138
	/**
139
	 * division ordonnée par
140
	 * 1 - noms retenus qui commencent par la requete
141
	 * 2 - requete contenue dans un synonyme dont le nom retenu ne contient pas la requete
142
	 * 3 - requete contenue dans un hybride  retenu
143
	 * 4 - requete contenue dans un nom retenu mais pas au début
144
	 * 5 - requete contenue dans un nom sans correspondance
145
	 *
146
	 */
147
	private function diviserResultats() {
148
		$tri = array();
149
		$sansCorres = array();
150
		$synonymes = array();
151
		$retenus = array();
152
		foreach ($this->noms as $cle => $valeurs) {
153
			if ($valeurs['nom_retenu.libelle'] == null) {//sans correspondances
915 delphine 154
				$sansCorres[$cle] = $valeurs['nom_sci_complet'];
792 mathilde 155
			} elseif ($valeurs['retenu'] == 'true') { // retenus
923 delphine 156
				if (preg_match('/ x |^x /',$valeurs['nom_sci'] )  ) {
792 mathilde 157
					//hybrides
880 aurelien 158
					$retenus[2][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
923 delphine 159
				} 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 160
					//commence par
880 aurelien 161
					$retenus[0][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
146 jpm 162
				} else {
792 mathilde 163
					//contient
880 aurelien 164
					$retenus[3][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
146 jpm 165
				}
792 mathilde 166
			} else {//synonymes
167
				$idNomRetenu = $valeurs['nom_retenu.id'];
923 delphine 168
				if (in_array($valeurs['nom_retenu.id'], array_keys($this->noms)) == false) {
169
					//synonymes dont le nom retenu n'est pas un résultat de recherche
880 aurelien 170
					$retenus[1][$idNomRetenu] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_retenu_complet'], $valeurs['rang.libelle']);
792 mathilde 171
					$this->infosPourTpl['taxons'][$idNomRetenu] = $valeurs['num_taxonomique']; //num taxon pour images coste
172
				}
173
				$synonymes[$idNomRetenu][] = $this->retournerInfosSynonyme($cle, $valeurs);
146 jpm 174
			}
175
		}
792 mathilde 176
		ksort($retenus);
177
		$tri['retenus'] = $retenus;
178
		$tri['synonymes'] = $synonymes;
179
		$tri['sansCorres'] = $sansCorres;
180
		return $tri;
146 jpm 181
	}
792 mathilde 182
	private  function retournerInfosNomRetenu($cle, $nom_sci, $rang) {
183
		$infos = array();
184
		$infos['nomSciRetenu'] = $nom_sci;
185
		$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom,  strtolower($this->parametres->masqueRecherche), $nom_sci);
186
		$infos['rang'] = $rang;
187
		return $infos;
188
	}
189
	private  function retournerInfosSynonyme($cle, $valeurs) {
190
		$infos = array();
191
		$infos['nn'] = $cle;
902 delphine 192
		$infos['nomSci'] = $valeurs['nom_sci_complet'];
792 mathilde 193
		$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom, $this->parametres->masqueRecherche, $valeurs['nom_retenu.libelle']);
194
		return $infos;
195
	}
196
	public function trier() {
923 delphine 197
		/*if (count($this->infosPourTpl['noms']) <= 1) { // classement par score
792 mathilde 198
			$nomsRetenus = array();
199
			foreach ($this->infosPourTpl['noms'] as $categorie) { //ote la division des retenus
200
				$nomsRetenus += $categorie;
201
			}
202
			$this->ajouterAuxNomsScoreSimilariteAvec($this->parametres->masqueRecherche);
203
			$this->trieur->setTableau($nomsRetenus);
204
			$this->trieur->setChampsEtOrdres(array('score' => SORT_DESC));
205
			$this->infosPourTpl['noms'] = $this->trieur->trier();
206
			$this->infosPourTpl['nomsSansCorrespondance'] =
207
						$this->classerAlphabetiquement('nomSciRetenu', $this->infosPourTpl['nomsSansCorrespondance'] );
208
		} else { // classement alphabétique
923 delphine 209
		*/
792 mathilde 210
			$nomsRetenus = array();
211
			foreach ($this->infosPourTpl['noms'] as $categorie => $valeurs ) { //classement alpha par groupes
212
				$nomsRetenus += $this->classerAlphabetiquement('nomSciRetenu', $valeurs);
213
			}
214
			$this->infosPourTpl['noms'] = $nomsRetenus;
215
			$this->infosPourTpl['nomsSansCorrespondance'] =
923 delphine 216
				$this->classerAlphabetiquement('nomSciRetenu', $this->infosPourTpl['nomsSansCorrespondance'] );
217
		//}
146 jpm 218
	}
792 mathilde 219
 
146 jpm 220
	private function ajouterAuxNomsScoreSimilariteAvec($masque) {
221
		$nom_demande_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($masque));
222
		foreach ($this->infosPourTpl['noms'] as $id => $nom) {
223
			$nom_flou_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($nom['nomSciRetenu']));
224
			$stat = array();
225
			// Prime pour la ressemblance globale :
226
			$score = 500 - levenshtein($nom_flou_ss, $nom_demande_ss);
227
			// On affine
228
			$score = $score + (similar_text($nom_demande_ss, $nom_flou_ss) * 3);
229
			$nom['score'] = $score;
230
			$this->infosPourTpl['noms'][$id] = $nom;
231
		}
232
	}
872 delphine 233
	private function classerAlphabetiquement($champs, $valeurs) {
234
		$this->trieur->setTableau($valeurs);
931 delphine 235
		$this->trieur->setChampsEtOrdres(array($champs => 'nat'));
872 delphine 236
		return $this->trieur->trier();
237
	}
146 jpm 238
 
872 delphine 239
 
240
 
146 jpm 241
	public function surligner() {
242
		$this->definirMotsASurligner();
243
		foreach ($this->infosPourTpl['noms'] as $idNom => $nom) {
252 delphine 244
			$this->infosPourTpl['noms'][$idNom]['nomSciRetenu'] = $this->surlignerMotsMasqueRecherche($nom['nomSciRetenu']);
245
			if (isset($this->infosPourTpl['synonymes'][$idNom])) {
246
				foreach ($this->infosPourTpl['synonymes'][$idNom] as $idSyn => $synonyme) {
247
					$this->infosPourTpl['synonymes'][$idNom][$idSyn]['nomSci'] = $this->surlignerMotsMasqueRecherche($synonyme['nomSci']);
146 jpm 248
				}
249
			}
250
		}
251
	}
252
	private function definirMotsASurligner() {
253
		$this->motsASurligner = explode(' ', $this->parametres->masqueRecherche);
254
	}
255
	private function surlignerMotsMasqueRecherche($nom) {
256
		$this->surligneur->setTexte($nom);
257
		$nom = $this->surligneur->surlignerMots($this->motsASurligner);
258
		return $nom;
259
	}
260
}
261
?>