Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 1340 Rev 1765
1
<?php
1
<?php
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
3
 
3
 
4
/**
4
/**
5
 * Classe gérant la completion des noms de lieux
5
 * Classe gérant la completion des noms de lieux
6
 * Encodage en entrée : utf8
6
 * Encodage en entrée : utf8
7
 * Encodage en sortie : utf8
7
 * Encodage en sortie : utf8
8
 *
8
 *
9
 * @author David Delon <david.delon@clapas.net>
9
 * @author David Delon <david.delon@clapas.net>
10
 * @author Aurélien Peronnet <aurelien@tela-botanica.org>
10
 * @author Aurélien Peronnet <aurelien@tela-botanica.org>
11
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
11
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
12
 * @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>
13
 * @version $Id$
13
 * @version $Id$
14
 * @copyright © 2010, David Delon
14
 * @copyright © 2010, David Delon
15
 */
15
 */
16
 
16
 
17
/**
17
/**
18
 * Cas d'utilisation :
18
 * Cas d'utilisation :
19
 * Service completion nom de commune (plus tard de lieu en général)
19
 * Service completion nom de commune (plus tard de lieu en général)
20
 *
20
 *
21
 * 1 : L'application recoit un debut de nom de lieu
21
 * 1 : L'application recoit un debut de nom de lieu
22
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres lieux 
22
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres lieux 
23
 * commencant par ce prefixe
23
 * commencant par ce prefixe
24
 **/
24
 **/
25
class LocationSearch extends Cel {
25
class LocationSearch extends Cel {
26
 
26
 
27
	function getElement($uid){
27
	function getElement($uid){
28
 
28
 
29
		$retour = array();
29
		$retour = array();
30
	
30
	
31
		if (isset($uid[0])) {
31
		if (isset($uid[0])) {
32
			$retour = $this->executerRequeteLieu($uid[0]);
32
			$retour = $this->executerRequeteLieu($uid[0]);
33
		}
33
		}
34
	
34
	
35
		$this->envoyerJson($retour);			
35
		$this->envoyerJson($retour);			
36
		return true;	
36
		return true;	
37
	}
37
	}
38
 
38
 
39
	function getRessource(){
39
	function getRessource(){
40
			print "[]";
40
			print "[]";
41
            return;
41
            return;
42
	}
42
	}
43
	
43
	
44
	private function executerRequeteLieu($lieu) {
44
	private function executerRequeteLieu($lieu) {
45
		
45
		
46
		$lieu_formate = $this->formaterChaineLieuPourRequete($lieu);
46
		$lieu_formate = $this->formaterChaineLieuPourRequete($lieu);
47
		$retour = array();
47
		$retour = array();
48
						
48
						
49
        if ($this->estUneChaineRequeteValide($lieu_formate)) {
49
        if ($this->estUneChaineRequeteValide($lieu_formate)) {
50
		    $requete_information_lieu = 'SELECT DISTINCT nom, code '.
50
		    $requete_information_lieu = 'SELECT DISTINCT nom, code '.
51
					'FROM cel_zones_geo '.
51
					'FROM cel_zones_geo '.
52
					'WHERE '.
52
					'WHERE '.
53
		    			'nom LIKE '.$this->proteger($lieu_formate.'%').' '.
53
		    			'nom LIKE '.Cel::db()->proteger($lieu_formate.'%').' '.
54
		    		'ORDER BY nom LIMIT 50';
54
		    		'ORDER BY nom LIMIT 50';
55
 
55
 
56
    		$liste_lieux = $this->requeter($requete_information_lieu);
56
    		$liste_lieux = Cel::db()->requeter($requete_information_lieu);
57
    		
57
    		
58
    		if($liste_lieux) {
58
    		if($liste_lieux) {
59
    			foreach($liste_lieux as $lieu_trouve) {
59
    			foreach($liste_lieux as $lieu_trouve) {
60
    				$retour[] = $this->formaterLigneResultat($lieu_trouve);
60
    				$retour[] = $this->formaterLigneResultat($lieu_trouve);
61
    			}
61
    			}
62
    		}
62
    		}
63
        }
63
        }
64
        
64
        
65
        return $retour;
65
        return $retour;
66
	} 
66
	} 
67
	
67
	
68
	private function formaterChaineLieuPourRequete($params) {
68
	private function formaterChaineLieuPourRequete($params) {
69
		
69
		
70
		$lieu = $params;
70
		$lieu = $params;
71
		
71
		
72
		$lieu=ltrim($lieu);
72
		$lieu=ltrim($lieu);
73
		$lieu=preg_replace('/\*+/','%',$lieu);
73
		$lieu=preg_replace('/\*+/','%',$lieu);
74
		
74
		
75
		$lieu = str_replace(' ','_',$lieu);
75
		$lieu = str_replace(' ','_',$lieu);
76
		$lieu = str_replace('-','_',$lieu);
76
		$lieu = str_replace('-','_',$lieu);
77
		
77
		
78
		return $lieu;
78
		return $lieu;
79
	}
79
	}
80
	
80
	
81
	private function estUneChaineRequeteValide($lieu) {
81
	private function estUneChaineRequeteValide($lieu) {
82
		return (strlen($lieu) > 0) && ($lieu != '%');
82
		return (strlen($lieu) > 0) && ($lieu != '%');
83
	}
83
	}
84
	
84
	
85
	private function formaterLigneResultat($ligne) {
85
	private function formaterLigneResultat($ligne) {
86
		return array($ligne['nom']." (".substr(sprintf("%02s",$ligne['code']),0,2).")",$ligne['code']);
86
		return array($ligne['nom']." (".substr(sprintf("%02s",$ligne['code']),0,2).")",$ligne['code']);
87
	}
87
	}
88
}
88
}
89
/* +--Fin du code ---------------------------------------------------------------------------------------+
89
/* +--Fin du code ---------------------------------------------------------------------------------------+
90
* $Log$
90
* $Log$
91
* Revision 1.4  2008-01-30 08:57:28  ddelon
91
* Revision 1.4  2008-01-30 08:57:28  ddelon
92
* fin mise en place mygwt
92
* fin mise en place mygwt
93
*
93
*
94
* Revision 1.3  2007-05-21 18:13:03  ddelon
94
* Revision 1.3  2007-05-21 18:13:03  ddelon
95
* Correction bug recherche commune du type "la canourgue"
95
* Correction bug recherche commune du type "la canourgue"
96
*
96
*
97
*
97
*
98
*/
98
*/
99
?>
99
?>