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();
|
931 |
delphine |
44 |
$this->infosPourTpl['urlWidget'] = Config::get('base_url_widget')."?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) {
|
|
|
103 |
$num_nom_retenu = $nom['nom_retenu.id'];
|
|
|
104 |
if(!isset($numNomsASynonyme[$num_nom_retenu])) {
|
|
|
105 |
$numNomsASynonyme[$num_nom_retenu] = array();
|
|
|
106 |
}
|
|
|
107 |
$numNomsASynonyme[$num_nom_retenu][] = $id;
|
|
|
108 |
if($num_nom_retenu != $id) {
|
|
|
109 |
$numNomsASynonyme[$id] = $numNomsASynonyme[$num_nom_retenu];
|
|
|
110 |
}
|
|
|
111 |
}
|
|
|
112 |
return $numNomsASynonyme;
|
|
|
113 |
}
|
|
|
114 |
|
931 |
delphine |
115 |
private function supprimerCodeReferentielDesIds($urls) {
|
146 |
jpm |
116 |
$urlsNettoyees = array();
|
|
|
117 |
foreach ($urls as $id => $url) {
|
931 |
delphine |
118 |
$id = $this->supprimerCodeReferentiel($id);
|
146 |
jpm |
119 |
$urlsNettoyees[$id] = $url;
|
|
|
120 |
}
|
|
|
121 |
return $urlsNettoyees;
|
|
|
122 |
}
|
1004 |
aurelien |
123 |
|
931 |
delphine |
124 |
private function supprimerCodeReferentiel($chaine) {
|
997 |
aurelien |
125 |
$codeReferentiel = Registre::get('parametres.referentiel').'.';
|
931 |
delphine |
126 |
$chaine = str_replace($codeReferentiel, '', $chaine);
|
311 |
jpm |
127 |
return $chaine;
|
|
|
128 |
}
|
872 |
delphine |
129 |
|
|
|
130 |
// TODO : utiliser le conteneur pour charger tous les objets de cette classe
|
|
|
131 |
private function chargerRepartition() {
|
931 |
delphine |
132 |
if (Config::get(Registre::get('parametres.referentiel').'.baseRepartition') != "") {
|
|
|
133 |
$conteneur = new Conteneur();
|
|
|
134 |
$cartesWs = $conteneur->getApiCartes();
|
|
|
135 |
$cartesWs->setProjet(Config::get(Registre::get('parametres.referentiel').'.baseRepartition'));
|
|
|
136 |
$cartesWs->setLargeur('108x101');
|
|
|
137 |
$urls = array();
|
1004 |
aurelien |
138 |
$numsNomsASynonymes = $this->extraireNumerosNomSynonymes();
|
931 |
delphine |
139 |
foreach ($this->noms as $id => $nom) {
|
|
|
140 |
if (array_key_exists('nom_retenu.id', $nom)) {
|
|
|
141 |
$id = $nom['nom_retenu.id'];
|
1004 |
aurelien |
142 |
$idsNoms = $numsNomsASynonymes[$id];
|
|
|
143 |
$cartesWs->setId("nn:".implode(',',$idsNoms)."");
|
931 |
delphine |
144 |
if (array_key_exists($id, $urls) == false) {
|
|
|
145 |
$urls[$id] = $cartesWs->getUrlPng();
|
|
|
146 |
}
|
872 |
delphine |
147 |
}
|
|
|
148 |
}
|
931 |
delphine |
149 |
$this->infosPourTpl['repartition']['urls'] = $urls;
|
872 |
delphine |
150 |
}
|
|
|
151 |
}
|
311 |
jpm |
152 |
|
872 |
delphine |
153 |
private function extraireInfosNomsPourTplDetermination() {
|
|
|
154 |
$tri = $this->diviserResultats();
|
|
|
155 |
$this->infosPourTpl['nomsSansCorrespondance'] = isset($tri['sansCorres']) ? $tri['sansCorres'] : false;
|
|
|
156 |
$this->infosPourTpl['noms'] = isset($tri['retenus']) ? $tri['retenus'] : false;
|
|
|
157 |
$this->infosPourTpl['synonymes'] = isset($tri['synonymes'] ) ? $tri['synonymes'] : false;
|
|
|
158 |
}
|
1004 |
aurelien |
159 |
|
792 |
mathilde |
160 |
/**
|
|
|
161 |
* division ordonnée par
|
|
|
162 |
* 1 - noms retenus qui commencent par la requete
|
|
|
163 |
* 2 - requete contenue dans un synonyme dont le nom retenu ne contient pas la requete
|
|
|
164 |
* 3 - requete contenue dans un hybride retenu
|
|
|
165 |
* 4 - requete contenue dans un nom retenu mais pas au début
|
|
|
166 |
* 5 - requete contenue dans un nom sans correspondance
|
|
|
167 |
*
|
|
|
168 |
*/
|
|
|
169 |
private function diviserResultats() {
|
|
|
170 |
$tri = array();
|
|
|
171 |
$sansCorres = array();
|
|
|
172 |
$synonymes = array();
|
|
|
173 |
$retenus = array();
|
|
|
174 |
foreach ($this->noms as $cle => $valeurs) {
|
|
|
175 |
if ($valeurs['nom_retenu.libelle'] == null) {//sans correspondances
|
915 |
delphine |
176 |
$sansCorres[$cle] = $valeurs['nom_sci_complet'];
|
792 |
mathilde |
177 |
} elseif ($valeurs['retenu'] == 'true') { // retenus
|
923 |
delphine |
178 |
if (preg_match('/ x |^x /',$valeurs['nom_sci'] ) ) {
|
792 |
mathilde |
179 |
//hybrides
|
880 |
aurelien |
180 |
$retenus[2][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
|
923 |
delphine |
181 |
} 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 |
182 |
//commence par
|
880 |
aurelien |
183 |
$retenus[0][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
|
968 |
delphine |
184 |
} else {
|
792 |
mathilde |
185 |
//contient
|
880 |
aurelien |
186 |
$retenus[3][$cle] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_sci_complet'], $valeurs['rang.libelle']);
|
146 |
jpm |
187 |
}
|
792 |
mathilde |
188 |
} else {//synonymes
|
|
|
189 |
$idNomRetenu = $valeurs['nom_retenu.id'];
|
923 |
delphine |
190 |
if (in_array($valeurs['nom_retenu.id'], array_keys($this->noms)) == false) {
|
|
|
191 |
//synonymes dont le nom retenu n'est pas un résultat de recherche
|
968 |
delphine |
192 |
$retenus[1][$idNomRetenu] = $this->retournerInfosNomRetenu($cle,$valeurs['nom_retenu.libelle'], $valeurs['rang.libelle']);
|
792 |
mathilde |
193 |
$this->infosPourTpl['taxons'][$idNomRetenu] = $valeurs['num_taxonomique']; //num taxon pour images coste
|
|
|
194 |
}
|
|
|
195 |
$synonymes[$idNomRetenu][] = $this->retournerInfosSynonyme($cle, $valeurs);
|
146 |
jpm |
196 |
}
|
|
|
197 |
}
|
792 |
mathilde |
198 |
ksort($retenus);
|
|
|
199 |
$tri['retenus'] = $retenus;
|
|
|
200 |
$tri['synonymes'] = $synonymes;
|
|
|
201 |
$tri['sansCorres'] = $sansCorres;
|
|
|
202 |
return $tri;
|
146 |
jpm |
203 |
}
|
1004 |
aurelien |
204 |
|
792 |
mathilde |
205 |
private function retournerInfosNomRetenu($cle, $nom_sci, $rang) {
|
|
|
206 |
$infos = array();
|
|
|
207 |
$infos['nomSciRetenu'] = $nom_sci;
|
|
|
208 |
$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom, strtolower($this->parametres->masqueRecherche), $nom_sci);
|
|
|
209 |
$infos['rang'] = $rang;
|
|
|
210 |
return $infos;
|
|
|
211 |
}
|
1004 |
aurelien |
212 |
|
792 |
mathilde |
213 |
private function retournerInfosSynonyme($cle, $valeurs) {
|
|
|
214 |
$infos = array();
|
|
|
215 |
$infos['nn'] = $cle;
|
902 |
delphine |
216 |
$infos['nomSci'] = $valeurs['nom_sci_complet'];
|
792 |
mathilde |
217 |
$infos['urlFiche'] = $this->urls->obtenirUrlFiche($cle, $this->parametres->typeNom, $this->parametres->masqueRecherche, $valeurs['nom_retenu.libelle']);
|
|
|
218 |
return $infos;
|
|
|
219 |
}
|
1004 |
aurelien |
220 |
|
792 |
mathilde |
221 |
public function trier() {
|
1004 |
aurelien |
222 |
$nomsRetenus = array();
|
|
|
223 |
foreach ($this->infosPourTpl['noms'] as $categorie => $valeurs ) { //classement alpha par groupes
|
|
|
224 |
$nomsRetenus += $this->classerAlphabetiquement('nomSciRetenu', $valeurs);
|
|
|
225 |
}
|
|
|
226 |
$this->infosPourTpl['noms'] = $nomsRetenus;
|
|
|
227 |
$this->infosPourTpl['nomsSansCorrespondance'] =
|
|
|
228 |
$this->classerAlphabetiquement('nomSciRetenu', $this->infosPourTpl['nomsSansCorrespondance'] );
|
146 |
jpm |
229 |
}
|
792 |
mathilde |
230 |
|
146 |
jpm |
231 |
private function ajouterAuxNomsScoreSimilariteAvec($masque) {
|
|
|
232 |
$nom_demande_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($masque));
|
|
|
233 |
foreach ($this->infosPourTpl['noms'] as $id => $nom) {
|
|
|
234 |
$nom_flou_ss = strtolower($this->manipulateurDeChaine->supprimerAccents($nom['nomSciRetenu']));
|
|
|
235 |
$stat = array();
|
|
|
236 |
// Prime pour la ressemblance globale :
|
|
|
237 |
$score = 500 - levenshtein($nom_flou_ss, $nom_demande_ss);
|
|
|
238 |
// On affine
|
|
|
239 |
$score = $score + (similar_text($nom_demande_ss, $nom_flou_ss) * 3);
|
|
|
240 |
$nom['score'] = $score;
|
|
|
241 |
$this->infosPourTpl['noms'][$id] = $nom;
|
|
|
242 |
}
|
|
|
243 |
}
|
1004 |
aurelien |
244 |
|
872 |
delphine |
245 |
private function classerAlphabetiquement($champs, $valeurs) {
|
|
|
246 |
$this->trieur->setTableau($valeurs);
|
931 |
delphine |
247 |
$this->trieur->setChampsEtOrdres(array($champs => 'nat'));
|
872 |
delphine |
248 |
return $this->trieur->trier();
|
|
|
249 |
}
|
146 |
jpm |
250 |
|
|
|
251 |
public function surligner() {
|
|
|
252 |
$this->definirMotsASurligner();
|
|
|
253 |
foreach ($this->infosPourTpl['noms'] as $idNom => $nom) {
|
252 |
delphine |
254 |
$this->infosPourTpl['noms'][$idNom]['nomSciRetenu'] = $this->surlignerMotsMasqueRecherche($nom['nomSciRetenu']);
|
|
|
255 |
if (isset($this->infosPourTpl['synonymes'][$idNom])) {
|
|
|
256 |
foreach ($this->infosPourTpl['synonymes'][$idNom] as $idSyn => $synonyme) {
|
|
|
257 |
$this->infosPourTpl['synonymes'][$idNom][$idSyn]['nomSci'] = $this->surlignerMotsMasqueRecherche($synonyme['nomSci']);
|
146 |
jpm |
258 |
}
|
|
|
259 |
}
|
|
|
260 |
}
|
|
|
261 |
}
|
1004 |
aurelien |
262 |
|
146 |
jpm |
263 |
private function definirMotsASurligner() {
|
|
|
264 |
$this->motsASurligner = explode(' ', $this->parametres->masqueRecherche);
|
|
|
265 |
}
|
|
|
266 |
private function surlignerMotsMasqueRecherche($nom) {
|
|
|
267 |
$this->surligneur->setTexte($nom);
|
|
|
268 |
$nom = $this->surligneur->surlignerMots($this->motsASurligner);
|
|
|
269 |
return $nom;
|
|
|
270 |
}
|
|
|
271 |
}
|
|
|
272 |
?>
|