Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 264 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 264 Rev 270
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 264 2016-12-19 13:27:31Z mathias $
12
 * @version		SVN: $Id: Recherche.php 270 2016-12-19 14:53:09Z 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
			'url_var' => Config::get('parametre_url_page'),
116
			'donnees_total' => $donnees_total,
117
			'donnees_total' => $donnees_total,
117
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
118
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
118
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
119
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
119
		);
120
		);
120
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
121
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
121
		$donnees['fragmenteur'] = $fragmenteur->executer();
122
		$donnees['fragmenteur'] = $fragmenteur->executer();
122
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
123
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
123
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
124
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
124
 
125
 
125
		// Gestion de l'accès aux données
126
		// Gestion de l'accès aux données
126
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
127
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
127
		$rechercheDao->setDistinction(1);
128
		$rechercheDao->setDistinction(1);
128
		
129
		
129
		// Récupération des résultats
130
		// Récupération des résultats
130
		if (isset($masque['cible'])) {
131
		if (isset($masque['cible'])) {
131
			switch ($masque['cible']) {
132
			switch ($masque['cible']) {
132
				case 'collections':
133
				case 'collections':
133
					$resultats = $rechercheDao->chercherCollections($parametres);
134
					$resultats = $rechercheDao->chercherCollections($parametres);
134
					break;
135
					break;
135
				case 'personnes':
136
				case 'personnes':
136
					$resultats = $rechercheDao->chercherPersonnes($parametres);
137
					$resultats = $rechercheDao->chercherPersonnes($parametres);
137
					break;
138
					break;
138
				default:
139
				default:
139
			}
140
			}
140
		}
141
		}
141
 
142
 
142
		// Affichage de la liste de résultats
143
		// Affichage de la liste de résultats
143
		if (isset($masque['cible'])) {
144
		if (isset($masque['cible'])) {
144
			switch ($masque['cible']) {
145
			switch ($masque['cible']) {
145
				case 'collections':
146
				case 'collections':
146
					if (! empty($resultats)) {
147
					if (! empty($resultats)) {
147
						foreach ($resultats as $resultat) {
148
						foreach ($resultats as $resultat) {
148
							// Ajout des données concernant la structure si ce n'est pas déjà fait
149
							// Ajout des données concernant la structure si ce n'est pas déjà fait
149
							$structure_id = $resultat['cs_id_structure'];
150
							$structure_id = $resultat['cs_id_structure'];
150
							if (!isset($donnees['infos'][$structure_id])) {
151
							if (!isset($donnees['infos'][$structure_id])) {
151
								$structure = array(
152
								$structure = array(
152
									'nom' => $resultat['cs_nom'],
153
									'nom' => $resultat['cs_nom'],
153
									'ville' => $resultat['cs_ville'],
154
									'ville' => $resultat['cs_ville'],
154
									'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
155
									'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
155
								);
156
								);
156
								$donnees['infos'][$structure_id]['structure'] = $structure;
157
								$donnees['infos'][$structure_id]['structure'] = $structure;
157
							}
158
							}
158
 
159
 
159
							// Si la structure possède des collections
160
							// Si la structure possède des collections
160
							if (!empty($resultat['cc_id_collection'])) {
161
							if (!empty($resultat['cc_id_collection'])) {
161
								$collection = array(
162
								$collection = array(
162
									'nom' => $resultat['cc_nom'],
163
									'nom' => $resultat['cc_nom'],
163
									'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
164
									'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
164
								);
165
								);
165
								$donnees['infos'][$structure_id]['collections'][] = $collection;
166
								$donnees['infos'][$structure_id]['collections'][] = $collection;
166
							}
167
							}
167
						}
168
						}
168
					}
169
					}
169
				break;
170
				break;
170
	
171
	
171
				case 'personnes':
172
				case 'personnes':
172
					if (! empty($resultats)) {
173
					if (! empty($resultats)) {
173
						foreach ($resultats as $resultat) {
174
						foreach ($resultats as $resultat) {
174
							//echo "<pre>".print_r($resultat,true)."</pre>";
175
							//echo "<pre>".print_r($resultat,true)."</pre>";
175
							if (!empty($resultat['cp_id_personne'])) {
176
							if (!empty($resultat['cp_id_personne'])) {
176
								$personne = array(
177
								$personne = array(
177
									'nomcomplet' => $resultat['cp_fmt_nom_complet'],
178
									'nomcomplet' => $resultat['cp_fmt_nom_complet'],
178
									'nom' => $resultat['cp_nom'],
179
									'nom' => $resultat['cp_nom'],
179
									'prenom' => $resultat['cp_prenom'],
180
									'prenom' => $resultat['cp_prenom'],
180
									'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
181
									'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
181
								);
182
								);
182
								$donnees['infos']['personnes'][] = $personne;
183
								$donnees['infos']['personnes'][] = $personne;
183
							}
184
							}
184
						}
185
						}
185
					}
186
					}
186
				break;
187
				break;
187
	
188
	
188
				default:
189
				default:
189
			}
190
			}
190
		}
191
		}
191
 
192
 
192
		// Post-traitement des résultats pour l'affichage
193
		// Post-traitement des résultats pour l'affichage
193
		$this->postraiterDonnees($donnees['infos']);
194
		$this->postraiterDonnees($donnees['infos']);
194
		
195
		
195
		// Gestion des squelettes
196
		// Gestion des squelettes
196
		$this->chargerMoteurRecherche();
197
		$this->chargerMoteurRecherche();
197
		$resultat = $this->getVue('resultat', $donnees);
198
		$resultat = $this->getVue('resultat', $donnees);
198
		$this->setSortie(self::RENDU_CORPS, $resultat);
199
		$this->setSortie(self::RENDU_CORPS, $resultat);
199
		$this->chargerPiedDePage();
200
		$this->chargerPiedDePage();
200
	}
201
	}
201
	
202
	
202
	protected function initialiserMasquesVides($masque) {
203
	protected function initialiserMasquesVides($masque) {
203
		$masques_possibles = array('lieu-stockage',
204
		$masques_possibles = array('lieu-stockage',
204
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
205
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
205
		foreach($masques_possibles as $masque_possible) {
206
		foreach($masques_possibles as $masque_possible) {
206
			if(!isset($masque[$masque_possible])) {
207
			if(!isset($masque[$masque_possible])) {
207
				$masque[$masque_possible] = '';
208
				$masque[$masque_possible] = '';
208
			}
209
			}
209
		}
210
		}
210
		return $masque;
211
		return $masque;
211
	}
212
	}
212
 
213
 
213
	protected function remplacerAbreviationParId(&$parametres) {
214
	protected function remplacerAbreviationParId(&$parametres) {
214
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
215
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
215
		// liste 80 : Liste des types de collection botanique (id:1083)
216
		// liste 80 : Liste des types de collection botanique (id:1083)
216
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
217
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
217
		foreach ($params_a_remplacer as $param => $id_liste) {
218
		foreach ($params_a_remplacer as $param => $id_liste) {
218
			if (isset($parametres[$param])) {
219
			if (isset($parametres[$param])) {
219
				// Si plusieurs valeurs séparées par des virgules
220
				// Si plusieurs valeurs séparées par des virgules
220
				$valeurs = explode(',', $parametres[$param]);
221
				$valeurs = explode(',', $parametres[$param]);
221
				$valeurs_nbre = count($valeurs);
222
				$valeurs_nbre = count($valeurs);
222
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
223
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
223
				foreach ($valeurs as $valeur) {
224
				foreach ($valeurs as $valeur) {
224
					$cle = strtoupper($valeur);
225
					$cle = strtoupper($valeur);
225
					if (isset($liste[$cle])) {
226
					if (isset($liste[$cle])) {
226
						if ($valeurs_nbre == 1) {
227
						if ($valeurs_nbre == 1) {
227
							$parametres[$param] = $liste[$cle]['id'];
228
							$parametres[$param] = $liste[$cle]['id'];
228
						} else if ($valeurs_nbre > 1) {
229
						} else if ($valeurs_nbre > 1) {
229
							$valeur = preg_quote($valeur, '/');
230
							$valeur = preg_quote($valeur, '/');
230
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
231
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
231
						}
232
						}
232
					}
233
					}
233
				}
234
				}
234
			}
235
			}
235
		}
236
		}
236
	}
237
	}
237
}
238
}