Subversion Repositories eFlore/Applications.coel-consultation

Rev

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

Rev 246 Rev 264
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 246 2015-03-03 09:13:36Z mathias $
12
 * @version		SVN: $Id: Recherche.php 264 2016-12-19 13:27:31Z mathias $
13
 */
13
 */
14
class Recherche extends aControleur {
14
class Recherche extends aControleur {
15
	
15
	
16
	//protected $chaine_recherche = null;
16
	//protected $chaine_recherche = null;
17
	protected $masque = null;
17
	protected $masque = null;
18
	protected static $url_exemple = null;
18
	protected 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
	protected function obtenirMasqueRecherche() {
55
	protected 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
 
68
 
69
	public static function getUrlExemple($chaine) {
69
	public static function getUrlExemple($chaine) {
70
		$url = '';
70
		$url = '';
71
		if (!is_null(self::$url_exemple)) {
71
		if (!is_null(self::$url_exemple)) {
72
			// 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
73
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
73
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
74
				$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'));
75
			}
75
			}
76
			$chaine = urlencode($chaine);
76
			$chaine = urlencode($chaine);
77
			$url = sprintf(self::$url_exemple, $chaine);
77
			$url = sprintf(self::$url_exemple, $chaine);
78
		}
78
		}
79
		return $url;
79
		return $url;
80
	}
80
	}
81
 
81
 
82
	// recherche des collections ou des personnes, dépendemment de la cible
82
	// recherche des collections ou des personnes, dépendemment de la cible
83
	public function rechercher() {
83
	public function rechercher() {
84
		// 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 !
85
		$masque = $this->obtenirMasqueRecherche();
85
		$masque = $this->obtenirMasqueRecherche();
86
 
86
 
87
		$donnees = array();
87
		$donnees = array();
88
		$donnees['masque'] = $masque;
88
		$donnees['masque'] = $masque;
89
		$rechercheDao =  new RechercheDao();
89
		$rechercheDao =  new RechercheDao();
90
		$parametres = array('mots' => '*');
90
		$parametres = array('mots' => '*');
91
 
91
 
92
		// Récupération des paramètres depuis le masque
92
		// Récupération des paramètres depuis le masque
93
		$parametres = $masque;
93
		$parametres = $masque;
94
 
94
 
95
		$this->remplacerAbreviationParId($parametres);
95
		$this->remplacerAbreviationParId($parametres);
96
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
96
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
97
		
97
		
98
		// Gestion du nombre de résultats
98
		// Gestion du nombre de résultats
99
		$donnees_total = null;
99
		$donnees_total = null;
100
		if (isset($masque['cible'])) {
100
		if (isset($masque['cible'])) {
101
			switch ($masque['cible']) {
101
			switch ($masque['cible']) {
102
				case 'collections':
102
				case 'collections':
103
					$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
103
					$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
104
					break;
104
					break;
105
				case 'personnes':
105
				case 'personnes':
106
					$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
106
					$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
107
					break;
107
					break;
108
				default:
108
				default:
109
					// @TODO qu'est-ce qui se passe ?
109
					// @TODO qu'est-ce qui se passe ?
110
			}
110
			}
111
		}
111
		}
112
 
112
 
113
		// Gestion du fragmenteur
113
		// Gestion du fragmenteur
114
		$options = array(
114
		$options = array(
115
			'url' => $this->url, 
115
			'url' => $this->url, 
116
			'donnees_total' => $donnees_total,
116
			'donnees_total' => $donnees_total,
117
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
117
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
118
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
118
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
119
		);
119
		);
120
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
120
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
121
		$donnees['fragmenteur'] = $fragmenteur->executer();
121
		$donnees['fragmenteur'] = $fragmenteur->executer();
122
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
122
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
123
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
123
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
124
 
124
 
125
		// Gestion de l'accès aux données
125
		// Gestion de l'accès aux données
126
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
126
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
127
		$rechercheDao->setDistinction(1);
127
		$rechercheDao->setDistinction(1);
128
		
128
		
129
		// Récupération des résultats
129
		// Récupération des résultats
130
		if (isset($masque['cible'])) {
130
		if (isset($masque['cible'])) {
131
			switch ($masque['cible']) {
131
			switch ($masque['cible']) {
132
				case 'collections':
132
				case 'collections':
133
					$resultats = $rechercheDao->chercherCollections($parametres);
133
					$resultats = $rechercheDao->chercherCollections($parametres);
134
					break;
134
					break;
135
				case 'personnes':
135
				case 'personnes':
136
					$resultats = $rechercheDao->chercherPersonnes($parametres);
136
					$resultats = $rechercheDao->chercherPersonnes($parametres);
137
					break;
137
					break;
138
				default:
138
				default:
139
			}
139
			}
140
		}
140
		}
141
 
141
 
142
		// Affichage de la liste de résultats
142
		// Affichage de la liste de résultats
143
		if (isset($masque['cible'])) {
143
		if (isset($masque['cible'])) {
144
			switch ($masque['cible']) {
144
			switch ($masque['cible']) {
145
				case 'collections':
145
				case 'collections':
-
 
146
					if (! empty($resultats)) {
146
					foreach ($resultats as $resultat) {
147
						foreach ($resultats as $resultat) {
147
						// Ajout des données concernant la structure si ce n'est pas déjà fait
148
							// Ajout des données concernant la structure si ce n'est pas déjà fait
148
						$structure_id = $resultat['cs_id_structure'];
149
							$structure_id = $resultat['cs_id_structure'];
149
						if (!isset($donnees['infos'][$structure_id])) {
150
							if (!isset($donnees['infos'][$structure_id])) {
150
							$structure = array(
151
								$structure = array(
151
								'nom' => $resultat['cs_nom'],
152
									'nom' => $resultat['cs_nom'],
152
								'ville' => $resultat['cs_ville'],
153
									'ville' => $resultat['cs_ville'],
153
								'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
154
									'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
154
							);
155
								);
155
							$donnees['infos'][$structure_id]['structure'] = $structure;
156
								$donnees['infos'][$structure_id]['structure'] = $structure;
156
						}
157
							}
157
						
158
 
158
						// Si la structure possède des collections
159
							// Si la structure possède des collections
159
						if (!empty($resultat['cc_id_collection'])) {
160
							if (!empty($resultat['cc_id_collection'])) {
160
							$collection = array(
161
								$collection = array(
161
								'nom' => $resultat['cc_nom'],
162
									'nom' => $resultat['cc_nom'],
162
								'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
163
									'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
163
							);
164
								);
164
							$donnees['infos'][$structure_id]['collections'][] = $collection;
165
								$donnees['infos'][$structure_id]['collections'][] = $collection;
-
 
166
							}
165
						}
167
						}
166
					}
168
					}
167
				break;
169
				break;
168
	
170
	
169
				case 'personnes':
171
				case 'personnes':
-
 
172
					if (! empty($resultats)) {
170
					foreach ($resultats as $resultat) {
173
						foreach ($resultats as $resultat) {
171
						//echo "<pre>".print_r($resultat,true)."</pre>";
174
							//echo "<pre>".print_r($resultat,true)."</pre>";
172
						if (!empty($resultat['cp_id_personne'])) {
175
							if (!empty($resultat['cp_id_personne'])) {
173
							$personne = array(
176
								$personne = array(
174
								'nomcomplet' => $resultat['cp_fmt_nom_complet'],
177
									'nomcomplet' => $resultat['cp_fmt_nom_complet'],
175
								'nom' => $resultat['cp_nom'],
178
									'nom' => $resultat['cp_nom'],
176
								'prenom' => $resultat['cp_prenom'],
179
									'prenom' => $resultat['cp_prenom'],
177
								'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
180
									'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
178
							);
181
								);
179
							$donnees['infos']['personnes'][] = $personne;
182
								$donnees['infos']['personnes'][] = $personne;
-
 
183
							}
180
						}
184
						}
181
					}
185
					}
182
				break;
186
				break;
183
	
187
	
184
				default:
188
				default:
185
			}
189
			}
186
		}
190
		}
187
 
191
 
188
		// Post-traitement des résultats pour l'affichage
192
		// Post-traitement des résultats pour l'affichage
189
		$this->postraiterDonnees($donnees['infos']);
193
		$this->postraiterDonnees($donnees['infos']);
190
		
194
		
191
		// Gestion des squelettes
195
		// Gestion des squelettes
192
		$this->chargerMoteurRecherche();
196
		$this->chargerMoteurRecherche();
193
		$resultat = $this->getVue('resultat', $donnees);
197
		$resultat = $this->getVue('resultat', $donnees);
194
		$this->setSortie(self::RENDU_CORPS, $resultat);
198
		$this->setSortie(self::RENDU_CORPS, $resultat);
195
		$this->chargerPiedDePage();
199
		$this->chargerPiedDePage();
196
	}
200
	}
197
	
201
	
198
	protected function initialiserMasquesVides($masque) {
202
	protected function initialiserMasquesVides($masque) {
199
		$masques_possibles = array('lieu-stockage',
203
		$masques_possibles = array('lieu-stockage',
200
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
204
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
201
		foreach($masques_possibles as $masque_possible) {
205
		foreach($masques_possibles as $masque_possible) {
202
			if(!isset($masque[$masque_possible])) {
206
			if(!isset($masque[$masque_possible])) {
203
				$masque[$masque_possible] = '';
207
				$masque[$masque_possible] = '';
204
			}
208
			}
205
		}
209
		}
206
		return $masque;
210
		return $masque;
207
	}
211
	}
208
 
212
 
209
	protected function remplacerAbreviationParId(&$parametres) {
213
	protected function remplacerAbreviationParId(&$parametres) {
210
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
214
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
211
		// liste 80 : Liste des types de collection botanique (id:1083)
215
		// liste 80 : Liste des types de collection botanique (id:1083)
212
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
216
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
213
		foreach ($params_a_remplacer as $param => $id_liste) {
217
		foreach ($params_a_remplacer as $param => $id_liste) {
214
			if (isset($parametres[$param])) {
218
			if (isset($parametres[$param])) {
215
				// Si plusieurs valeurs séparées par des virgules
219
				// Si plusieurs valeurs séparées par des virgules
216
				$valeurs = explode(',', $parametres[$param]);
220
				$valeurs = explode(',', $parametres[$param]);
217
				$valeurs_nbre = count($valeurs);
221
				$valeurs_nbre = count($valeurs);
218
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
222
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
219
				foreach ($valeurs as $valeur) {
223
				foreach ($valeurs as $valeur) {
220
					$cle = strtoupper($valeur);
224
					$cle = strtoupper($valeur);
221
					if (isset($liste[$cle])) {
225
					if (isset($liste[$cle])) {
222
						if ($valeurs_nbre == 1) {
226
						if ($valeurs_nbre == 1) {
223
							$parametres[$param] = $liste[$cle]['id'];
227
							$parametres[$param] = $liste[$cle]['id'];
224
						} else if ($valeurs_nbre > 1) {
228
						} else if ($valeurs_nbre > 1) {
225
							$valeur = preg_quote($valeur, '/');
229
							$valeur = preg_quote($valeur, '/');
226
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
230
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
227
						}
231
						}
228
					}
232
					}
229
				}
233
				}
230
			}
234
			}
231
		}
235
		}
232
	}
236
	}
233
}
237
}