Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 195 | Rev 246 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 195 Rev 213
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * classe Controleur du module Recherche.
4
 * classe Controleur du module Recherche.
5
 *
5
 *
6
 * @package		Collection
6
 * @package		Collection
7
 * @category	Php5
7
 * @category	Php5
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
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
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id: Recherche.php 195 2014-01-22 13:29:20Z aurelien $
12
 * @version		SVN: $Id: Recherche.php 213 2014-04-25 13:12:08Z aurelien $
13
 */
13
 */
14
class Recherche extends aControleur {
14
class Recherche extends aControleur {
15
	
15
	
16
	//private $chaine_recherche = null;
16
	//private $chaine_recherche = null;
17
	private $masque = null;
17
	private $masque = null;
18
	private static $url_exemple = null;
18
	private static $url_exemple = null;
19
	
19
	
20
	//+----------------------------------------------------------------------------------------------------------------+
20
	//+----------------------------------------------------------------------------------------------------------------+
21
	// Méthodes
21
	// Méthodes
22
	/**
22
	/**
23
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
23
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
24
	 */
24
	 */
25
	public function executerActionParDefaut() {
25
	public function executerActionParDefaut() {
26
		return $this->rechercher();
26
		return $this->rechercher();
27
	}
27
	}
28
	
28
	
29
	/**
29
	/**
30
	 * Charge le moteur de recherche et l'envoie à la vue.
30
	 * Charge le moteur de recherche et l'envoie à la vue.
31
	 */
31
	 */
32
	public function chargerMoteurRecherche() {
32
	public function chargerMoteurRecherche() {
33
		$donnees = array();
33
		$donnees = array();
34
 
34
 
35
		// Gestion des données de la requête
35
		// Gestion des données de la requête
36
		//$donnees['recherche'] = htmlspecialchars($this->obtenirChaineRecherche());
36
		//$donnees['recherche'] = htmlspecialchars($this->obtenirChaineRecherche());
37
		// masque multi-critères
37
		// masque multi-critères
38
		$donnees['masque'] = $this->obtenirMasqueRecherche();
38
		$donnees['masque'] = $this->obtenirMasqueRecherche();
39
 
39
 
40
		// Gestion des urls
40
		// Gestion des urls
41
		$donnees['url_form'] = $this->obtenirUrlRecherche();
41
		$donnees['url_form'] = $this->obtenirUrlRecherche();
42
		$donnees['url_module'] = 'Recherche';
42
		$donnees['url_module'] = 'Recherche';
43
		$donnees['url_action'] = 'rechercher';
43
		$donnees['url_action'] = 'rechercher';
44
		$donnees['url_contexte'] = $this->registre->get('contexte');
44
		$donnees['url_contexte'] = $this->registre->get('contexte');
45
		self::$url_exemple = $this->obtenirUrlRecherche('%s');
45
		self::$url_exemple = $this->obtenirUrlRecherche('%s');
46
			
46
			
47
		// remplissage de case de tableaux vides pour éviter des warnings
47
		// remplissage de case de tableaux vides pour éviter des warnings
48
		$donnees['masque'] = $this->initialiserMasquesVides($donnees['masque']);
48
		$donnees['masque'] = $this->initialiserMasquesVides($donnees['masque']);
49
		//echo '<pre>'.print_r($donnees['masque'],true).'</pre>';exit;
49
		//echo '<pre>'.print_r($donnees['masque'],true).'</pre>';exit;
50
		
50
		
51
		// Gestion du squelette et de la sortie
51
		// Gestion du squelette et de la sortie
52
		$this->setSortie(self::RENDU_TETE, $this->getVue('moteur', $donnees));
52
		$this->setSortie(self::RENDU_TETE, $this->getVue('moteur', $donnees));
53
	}
53
	}
54
 
54
 
55
	private function obtenirMasqueRecherche() {
55
	private function obtenirMasqueRecherche() {
56
		$masque = array();
56
		$masque = array();
57
		if (!is_null($this->masque)) {
57
		if (!is_null($this->masque)) {
58
			$masque = $this->masque;
58
			$masque = $this->masque;
59
		} else if (isset($_GET['masque'])) {
59
		} else if (isset($_GET['masque'])) {
60
			$masque = $_GET['masque'];
60
			$masque = $_GET['masque'];
61
			$_SESSION['col']['masque'] = $masque;
61
			$_SESSION['col']['masque'] = $masque;
62
		} else if (isset($_SESSION['col']['masque'])) {
62
		} else if (isset($_SESSION['col']['masque'])) {
63
			$masque = $_SESSION['col']['masque'];
63
			$masque = $_SESSION['col']['masque'];
64
		}
64
		}
65
		$this->masque = $masque;
65
		$this->masque = $masque;
66
		return $masque;
66
		return $masque;
67
	}
67
	}
68
 
-
 
69
	/*private function obtenirChaineRecherche() {
-
 
70
		$chaine = '';
-
 
71
		if (!is_null($this->chaine_recherche)) {
-
 
72
			$chaine = $this->chaine_recherche;
-
 
73
		} else if (isset($_GET['recherche'])) {
-
 
74
			// Pré-traitement de la chaine de recherche
-
 
75
			$chaine = $_GET['recherche'];
-
 
76
			// Suppression des slash ajouté automatiquement par PHP devant les guillemets
-
 
77
			$chaine = stripslashes($chaine);
-
 
78
			// Mémorisation de la chaine
-
 
79
			$this->memoriserChaineRecherche($chaine);
-
 
80
			// Stockage dans la classe pour éviter d'effectuer à nouveau le traitement ci-dessus
-
 
81
			$this->chaine_recherche = $chaine;
-
 
82
		} else if (isset($_SESSION['col']['recherche'])) {
-
 
83
			$chaine = $_SESSION['col']['recherche'];
-
 
84
		}
-
 
85
		return $chaine;
-
 
86
	}*/
-
 
87
 
-
 
88
	/*private function memoriserChaineRecherche($chaine) {
-
 
89
		$_SESSION['col']['recherche'] = $chaine;
-
 
90
	}*/
-
 
91
 
68
 
92
	public static function getUrlExemple($chaine) {
69
	public static function getUrlExemple($chaine) {
93
		$url = '';
70
		$url = '';
94
		if (!is_null(self::$url_exemple)) {
71
		if (!is_null(self::$url_exemple)) {
95
			// L'utilisation d'urlencode nécessiate de pré-encodé la chaine dans le format de sortie si nécessaire
72
			// L'utilisation d'urlencode nécessiate de pré-encodé la chaine dans le format de sortie si nécessaire
96
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
73
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
97
				$chaine = mb_convert_encoding($chaine, Config::get('sortie_encodage'), Config::get('appli_encodage'));
74
				$chaine = mb_convert_encoding($chaine, Config::get('sortie_encodage'), Config::get('appli_encodage'));
98
			}
75
			}
99
			$chaine = urlencode($chaine);
76
			$chaine = urlencode($chaine);
100
			$url = sprintf(self::$url_exemple, $chaine);
77
			$url = sprintf(self::$url_exemple, $chaine);
101
		}
78
		}
102
		return $url;
79
		return $url;
103
	}
80
	}
104
 
81
 
105
	// recherche des collections ou des personnes, dépendemment de la cible
82
	// recherche des collections ou des personnes, dépendemment de la cible
106
	public function rechercher() {
83
	public function rechercher() {
107
		// un seul pour les collections ou les personnes, on ne cherche pas 2 choses à la fois !
84
		// un seul pour les collections ou les personnes, on ne cherche pas 2 choses à la fois !
108
		$masque = $this->obtenirMasqueRecherche();
85
		$masque = $this->obtenirMasqueRecherche();
109
 
86
 
110
		$donnees = array();
87
		$donnees = array();
111
		$donnees['masque'] = $masque;
88
		$donnees['masque'] = $masque;
112
		$rechercheDao =  new RechercheDao();
89
		$rechercheDao =  new RechercheDao();
113
		$parametres = array('mots' => '*');
90
		$parametres = array('mots' => '*');
114
		
-
 
115
		// Récupération des paramêtres de l'url
-
 
116
		/*$chaine_de_recherche = $this->obtenirChaineRecherche();
-
 
117
		echo "CH RECH: $chaine_de_recherche<br/>"; 
-
 
118
		if (!empty($chaine_de_recherche)) {
-
 
119
			$this->url->setVariableRequete('recherche', $chaine_de_recherche);
-
 
120
		}
-
 
121
		$parametres = $this->parserChaineDeRecherche($chaine_de_recherche);*/
-
 
122
 
91
 
123
		// Récupération des paramètres depuis le masque
92
		// Récupération des paramètres depuis le masque
124
		$parametres = $masque;
93
		$parametres = $masque;
125
 
94
 
126
		$this->remplacerAbreviationParId($parametres);
95
		$this->remplacerAbreviationParId($parametres);
127
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
96
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
128
		
97
		
129
		// Gestion du nombre de résultats
98
		// Gestion du nombre de résultats
130
		switch ($masque['cible']) {
99
		switch ($masque['cible']) {
131
			case 'collections':
100
			case 'collections':
132
				$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
101
				$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
133
				break;
102
				break;
134
			case 'personnes':
103
			case 'personnes':
135
				$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
104
				$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
136
				break;
105
				break;
137
			default:
106
			default:
138
				// @TODO qu'est-ce qui se passe ?
107
				// @TODO qu'est-ce qui se passe ?
139
		}
108
		}
140
 
109
 
141
		// Gestion du fragmenteur
110
		// Gestion du fragmenteur
142
		$options = array(
111
		$options = array(
143
			'url' => $this->url, 
112
			'url' => $this->url, 
144
			'donnees_total' => $donnees_total,
113
			'donnees_total' => $donnees_total,
145
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
114
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
146
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
115
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
147
		);
116
		);
148
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
117
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
149
		$donnees['fragmenteur'] = $fragmenteur->executer();
118
		$donnees['fragmenteur'] = $fragmenteur->executer();
150
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
119
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
151
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
120
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
152
 
121
 
153
		// Gestion de l'accès aux données
122
		// Gestion de l'accès aux données
154
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
123
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
155
		$rechercheDao->setDistinction(1);
124
		$rechercheDao->setDistinction(1);
156
		
125
		
157
		// Récupération des résultats
126
		// Récupération des résultats
158
		switch ($masque['cible']) {
127
		switch ($masque['cible']) {
159
			case 'collections':
128
			case 'collections':
160
				$resultats = $rechercheDao->chercherCollections($parametres);
129
				$resultats = $rechercheDao->chercherCollections($parametres);
161
				break;
130
				break;
162
			case 'personnes':
131
			case 'personnes':
163
				$resultats = $rechercheDao->chercherPersonnes($parametres);
132
				$resultats = $rechercheDao->chercherPersonnes($parametres);
164
				break;
133
				break;
165
			default:
134
			default:
166
		}
135
		}
167
 
136
 
168
		// Affichage de la liste de résultats
137
		// Affichage de la liste de résultats
169
		switch ($masque['cible']) {
138
		switch ($masque['cible']) {
170
			case 'collections':
139
			case 'collections':
171
				foreach ($resultats as $resultat) {
140
				foreach ($resultats as $resultat) {
172
					// Ajout des données concernant la structure si ce n'est pas déjà fait
141
					// Ajout des données concernant la structure si ce n'est pas déjà fait
173
					$structure_id = $resultat['cs_id_structure'];
142
					$structure_id = $resultat['cs_id_structure'];
174
					if (!isset($donnees['infos'][$structure_id])) {
143
					if (!isset($donnees['infos'][$structure_id])) {
175
						$structure = array(
144
						$structure = array(
176
							'nom' => $resultat['cs_nom'],
145
							'nom' => $resultat['cs_nom'],
177
							'ville' => $resultat['cs_ville'],
146
							'ville' => $resultat['cs_ville'],
178
							'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
147
							'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
179
						);
148
						);
180
						$donnees['infos'][$structure_id]['structure'] = $structure;
149
						$donnees['infos'][$structure_id]['structure'] = $structure;
181
					}
150
					}
182
					
151
					
183
					// Si la structure possède des collections
152
					// Si la structure possède des collections
184
					if (!empty($resultat['cc_id_collection'])) {
153
					if (!empty($resultat['cc_id_collection'])) {
185
						$collection = array(
154
						$collection = array(
186
							'nom' => $resultat['cc_nom'],
155
							'nom' => $resultat['cc_nom'],
187
							'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
156
							'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
188
						);
157
						);
189
						$donnees['infos'][$structure_id]['collections'][] = $collection;
158
						$donnees['infos'][$structure_id]['collections'][] = $collection;
190
					}
159
					}
191
				}
160
				}
192
			break;
161
			break;
193
 
162
 
194
			case 'personnes':
163
			case 'personnes':
195
				foreach ($resultats as $resultat) {
164
				foreach ($resultats as $resultat) {
196
					//echo "<pre>".print_r($resultat,true)."</pre>";
165
					//echo "<pre>".print_r($resultat,true)."</pre>";
197
					if (!empty($resultat['cp_id_personne'])) {
166
					if (!empty($resultat['cp_id_personne'])) {
198
						$personne = array(
167
						$personne = array(
199
							'nomcomplet' => $resultat['cp_fmt_nom_complet'],
168
							'nomcomplet' => $resultat['cp_fmt_nom_complet'],
200
							'nom' => $resultat['cp_nom'],
169
							'nom' => $resultat['cp_nom'],
201
							'prenom' => $resultat['cp_prenom'],
170
							'prenom' => $resultat['cp_prenom'],
202
							'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
171
							'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
203
						);
172
						);
204
						$donnees['infos']['personnes'][] = $personne;
173
						$donnees['infos']['personnes'][] = $personne;
205
					}
174
					}
206
				}
175
				}
207
			break;
176
			break;
208
 
177
 
209
			default:
178
			default:
210
		}
179
		}
211
 
180
 
212
		// Post-traitement des résultats pour l'affichage
181
		// Post-traitement des résultats pour l'affichage
213
		$this->postraiterDonnees($donnees['infos']);
182
		$this->postraiterDonnees($donnees['infos']);
214
		
183
		
215
		// Gestion des squelettes
184
		// Gestion des squelettes
216
		$this->chargerMoteurRecherche();
185
		$this->chargerMoteurRecherche();
217
		$resultat = $this->getVue('resultat', $donnees);
186
		$resultat = $this->getVue('resultat', $donnees);
218
		$this->setSortie(self::RENDU_CORPS, $resultat);
187
		$this->setSortie(self::RENDU_CORPS, $resultat);
219
		$this->chargerPiedDePage();
188
		$this->chargerPiedDePage();
220
	}
189
	}
221
	
190
	
222
	private function initialiserMasquesVides($masque) {
191
	private function initialiserMasquesVides($masque) {
223
		$masques_possibles = array('lieu-stockage',
192
		$masques_possibles = array('lieu-stockage',
224
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
193
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
225
		foreach($masques_possibles as $masque_possible) {
194
		foreach($masques_possibles as $masque_possible) {
226
			if(!isset($masque[$masque_possible])) {
195
			if(!isset($masque[$masque_possible])) {
227
				$masque[$masque_possible] = '';
196
				$masque[$masque_possible] = '';
228
			}
197
			}
229
		}
198
		}
230
		return $masque;
199
		return $masque;
231
	}
200
	}
232
	
-
 
233
	/*private function parserChaineDeRecherche($chaine) {		
-
 
234
		$mots = preg_split('/ /i', $chaine, -1, PREG_SPLIT_NO_EMPTY);
-
 
235
		$parametres = array('mots' => '');
-
 
236
		$cle_precedente = null;
-
 
237
		foreach ($mots as $mot) {
-
 
238
			if (preg_match('/^(sci|veg|bot|zg|p|pr|str-d):(.*)$/', $mot, $match)) {
-
 
239
				$cle = $match[1];
-
 
240
				$cle_precedente = $cle;
-
 
241
				$valeur = $match[2];
-
 
242
				$parametres[$cle] = $valeur;
-
 
243
			} else if (!is_null($cle_precedente)) {
-
 
244
				$parametres[$cle_precedente] .= ' '.$mot;
-
 
245
			} else if (is_null($cle_precedente)) {
-
 
246
				if (empty($parametres['mots'])) {
-
 
247
					$parametres['mots'] = $mot;
-
 
248
				} else {
-
 
249
					$parametres['mots'] .= ' '.$mot;
-
 
250
				}
-
 
251
			}
-
 
252
		}
-
 
253
		$this->remplacerAbreviationParId($parametres);
-
 
254
		
-
 
255
		return $parametres;
-
 
256
	}*/
-
 
257
 
201
 
258
	private function remplacerAbreviationParId(&$parametres) {
202
	private function remplacerAbreviationParId(&$parametres) {
259
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
203
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
260
		// liste 80 : Liste des types de collection botanique (id:1083)
204
		// liste 80 : Liste des types de collection botanique (id:1083)
261
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
205
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
262
		foreach ($params_a_remplacer as $param => $id_liste) {
206
		foreach ($params_a_remplacer as $param => $id_liste) {
263
			if (isset($parametres[$param])) {
207
			if (isset($parametres[$param])) {
264
				// Si plusieurs valeurs séparées par des virgules
208
				// Si plusieurs valeurs séparées par des virgules
265
				$valeurs = explode(',', $parametres[$param]);
209
				$valeurs = explode(',', $parametres[$param]);
266
				$valeurs_nbre = count($valeurs);
210
				$valeurs_nbre = count($valeurs);
267
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
211
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
268
				foreach ($valeurs as $valeur) {
212
				foreach ($valeurs as $valeur) {
269
					$cle = strtoupper($valeur);
213
					$cle = strtoupper($valeur);
270
					if (isset($liste[$cle])) {
214
					if (isset($liste[$cle])) {
271
						if ($valeurs_nbre == 1) {
215
						if ($valeurs_nbre == 1) {
272
							$parametres[$param] = $liste[$cle]['id'];
216
							$parametres[$param] = $liste[$cle]['id'];
273
						} else if ($valeurs_nbre > 1) {
217
						} else if ($valeurs_nbre > 1) {
274
							$valeur = preg_quote($valeur, '/');
218
							$valeur = preg_quote($valeur, '/');
275
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
219
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
276
						}
220
						}
277
					}
221
					}
278
				}
222
				}
279
			}
223
			}
280
		}
224
		}
281
	}
225
	}
282
}
226
}