Subversion Repositories eFlore/Applications.cel

Rev

Rev 773 | Rev 895 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 773 Rev 860
Line 1... Line 1...
1
<?php
1
<?php
-
 
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
-
 
3
 
2
/**
4
/**
3
 * Classe gérant l'acceptation de la licence utilisateur  
5
 * Classe gérant la completion des noms de lieux
4
 * Encodage en entrée : utf8
6
 * Encodage en entrée : utf8
5
 * Encodage en sortie : utf8
7
 * Encodage en sortie : utf8
6
 *
8
 *
7
 * @author David Delon <david.delon@clapas.net>
9
 * @author David Delon <david.delon@clapas.net>
-
 
10
 * @author Aurélien Peronnet <aurelien@tela-botanica.org>
8
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
11
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
9
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
12
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
10
 * @version $Id$
13
 * @version $Id$
11
 * @copyright © 2010, David Delon
14
 * @copyright © 2010, David Delon
12
 */
15
 */
Line 13... Line 16...
13
 
16
 
14
/**
17
/**
15
 * Cas d'utilisation :
18
 * Cas d'utilisation :
16
 * Service completion nom de commune
19
 * Service completion nom de commune (plus tard de lieu en général)
17
 *
20
 *
18
 * 1 : L'application recoit un debut de nom de commune
21
 * 1 : L'application recoit un debut de nom de lieu
19
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres communes 
22
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres lieux 
20
 * commencant par ce prefixe
23
 * commencant par ce prefixe
21
 **/
24
 **/
Line 22... Line 25...
22
class LocationSearch extends Cel {
25
class LocationSearch extends Cel {
Line 43... Line 46...
43
		
46
		
44
		$lieu = $this->formaterChaineLieuPourRequete($lieu);
47
		$lieu = $this->formaterChaineLieuPourRequete($lieu);
Line 45... Line 48...
45
		$retour = array();
48
		$retour = array();
46
				
49
				
47
        if ($this->estUneChaineRequeteValide($lieu)) {
50
        if ($this->estUneChaineRequeteValide($lieu)) {
48
		    $requete_information_lieu = 'SELECT DISTINCT name, code '.
51
		    $requete_information_lieu = 'SELECT DISTINCT nom, code '.
49
					'FROM locations '.
-
 
50
					'WHERE '.
52
					'FROM cel_zones_geo '.
51
		    			'maj_name LIKE '.$this->proteger($lieu.'%').' '.
53
					'WHERE '.
Line 52... Line 54...
52
		    			'OR name LIKE '.$this->proteger($lieu.'%').' '.
54
		    			'nom LIKE '.$this->proteger($lieu.'%').' '.
Line 53... Line 55...
53
		    		'ORDER BY name LIMIT 50';
55
		    		'ORDER BY nom LIMIT 50';
54
		    		
56
		    		
55
    		$liste_lieux = $this->executerRequete($requete_information_lieu);
57
    		$liste_lieux = $this->requeter($requete_information_lieu);
56
    		
58
    		
Line 77... Line 79...
77
	private function estUneChaineRequeteValide($lieu) {
79
	private function estUneChaineRequeteValide($lieu) {
78
		return (strlen($lieu) > 0) && ($lieu != '%');
80
		return (strlen($lieu) > 0) && ($lieu != '%');
79
	}
81
	}
Line 80... Line 82...
80
	
82
	
81
	private function formaterLigneResultat($ligne) {
83
	private function formaterLigneResultat($ligne) {
82
		return array($ligne['name']." (".sprintf("%02s",$ligne['code']).")",$ligne['code']);
84
		return array($ligne['nom']." (".sprintf("%02s",$ligne['code']).")",$ligne['code']);
83
	}
85
	}
Line 84... Line 86...
84
}
86
}
85
 
87