Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 770 Rev 773
1
<?php
1
<?php
2
/**
2
/**
3
 * Classe gérant l'acceptation de la licence utilisateur  
3
 * Classe gérant l'acceptation de la licence utilisateur  
4
 * Encodage en entrée : utf8
4
 * Encodage en entrée : utf8
5
 * Encodage en sortie : utf8
5
 * Encodage en sortie : utf8
6
 *
6
 *
7
 * @author David Delon <david.delon@clapas.net>
7
 * @author David Delon <david.delon@clapas.net>
8
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
8
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
9
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
9
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
10
 * @version $Id$
10
 * @version $Id$
11
 * @copyright © 2010, David Delon
11
 * @copyright © 2010, David Delon
12
 */
12
 */
13
 
13
 
14
/**
14
/**
15
 * Cas d'utilisation :
15
 * Cas d'utilisation :
16
 * Service completion nom de commune
16
 * Service completion nom de commune
17
 *
17
 *
18
 * 1 : L'application recoit un debut de nom de commune
18
 * 1 : L'application recoit un debut de nom de commune
19
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres communes 
19
 * 2 : Si la longueur du prefixe est > 2, l'application retourne les 50 premieres communes 
20
 * commencant par ce prefixe
20
 * commencant par ce prefixe
21
 **/
21
 **/
22
class LocationSearch extends Cel {
22
class LocationSearch extends Cel {
23
 
23
 
24
	function getElement($uid){
24
	function getElement($uid){
25
 
25
 
26
		$retour = array();
26
		$retour = array();
27
	
27
	
28
		if (isset($uid[0])) {
28
		if (isset($uid[0])) {
29
			$retour = $this->executerRequeteLieu($uid[0]);
29
			$retour = $this->executerRequeteLieu($uid[0]);
30
		}
30
		}
31
	
31
	
32
		$output = json_encode($retour);
32
		$output = json_encode($retour);
33
		
33
		
34
		print($output);
34
		print($output);
35
	}
35
	}
36
 
36
 
37
	function getRessource(){
37
	function getRessource(){
38
			print "[]";
38
			print "[]";
39
            return;
39
            return;
40
	}
40
	}
41
	
41
	
42
	private function executerRequeteLieu($lieu) {
42
	private function executerRequeteLieu($lieu) {
43
		
43
		
44
		$lieu = $this->formaterChaineLieuPourRequete($lieu);
44
		$lieu = $this->formaterChaineLieuPourRequete($lieu);
45
		$retour = array();
45
		$retour = array();
46
				
46
				
47
        if ($this->estUneChaineRequeteValide($lieu)) {
47
        if ($this->estUneChaineRequeteValide($lieu)) {
48
		    $requete_information_lieu = 'SELECT DISTINCT name, code '.
48
		    $requete_information_lieu = 'SELECT DISTINCT name, code '.
49
					'FROM locations '.
49
					'FROM locations '.
50
					'WHERE '.
50
					'WHERE '.
51
		    			'maj_name LIKE '.$this->proteger($lieu.'%').' '.
51
		    			'maj_name LIKE '.$this->proteger($lieu.'%').' '.
52
		    			'OR name LIKE '.$this->proteger($lieu.'%').' '.
52
		    			'OR name LIKE '.$this->proteger($lieu.'%').' '.
53
		    		'ORDER BY name LIMIT 50';
53
		    		'ORDER BY name LIMIT 50';
54
		    		
54
		    		
55
    		$liste_lieux = $this->executerRequete($requete_information_lieu);
55
    		$liste_lieux = $this->executerRequete($requete_information_lieu);
56
    		
56
    		
57
    		if($liste_lieux) {
57
    		if($liste_lieux) {
58
    			foreach($liste_lieux as $lieu) {
58
    			foreach($liste_lieux as $lieu) {
59
    				$retour[] = $this->formaterLigneResultat($lieu);
59
    				$retour[] = $this->formaterLigneResultat($lieu);
60
    			}
60
    			}
61
    		}
61
    		}
62
        }
62
        }
63
        
63
        
64
        return $retour;
64
        return $retour;
65
	} 
65
	} 
66
	
66
	
67
	private function formaterChaineLieuPourRequete($params) {
67
	private function formaterChaineLieuPourRequete($params) {
68
		
68
		
69
		$lieu = '';
-
 
70
		
-
 
71
		foreach ($params as $element) {
-
 
72
			$lieu=$lieu." ".$element;
-
 
73
		}
69
		$lieu = $params;
74
		
70
		
75
		$lieu=ltrim($lieu);
71
		$lieu=ltrim($lieu);
76
		$lieu=ereg_replace('\*+','%',$lieu);
72
		$lieu=ereg_replace('\*+','%',$lieu);
77
		
73
		
78
		return $lieu;
74
		return $lieu;
79
	}
75
	}
80
	
76
	
81
	private function estUneChaineRequeteValide($lieu) {
77
	private function estUneChaineRequeteValide($lieu) {
82
		return (strlen($lieu) > 0) && ($lieu != '%');
78
		return (strlen($lieu) > 0) && ($lieu != '%');
83
	}
79
	}
84
	
80
	
85
	private function formaterLigneResultat($ligne) {
81
	private function formaterLigneResultat($ligne) {
86
		return array($ligne['name']." (".sprintf("%02s",$ligne['code']).")",$ligne['code']);
82
		return array($ligne['name']." (".sprintf("%02s",$ligne['code']).")",$ligne['code']);
87
	}
83
	}
88
}
84
}
89
 
85
 
90
/* +--Fin du code ---------------------------------------------------------------------------------------+
86
/* +--Fin du code ---------------------------------------------------------------------------------------+
91
* $Log$
87
* $Log$
92
* Revision 1.4  2008-01-30 08:57:28  ddelon
88
* Revision 1.4  2008-01-30 08:57:28  ddelon
93
* fin mise en place mygwt
89
* fin mise en place mygwt
94
*
90
*
95
* Revision 1.3  2007-05-21 18:13:03  ddelon
91
* Revision 1.3  2007-05-21 18:13:03  ddelon
96
* Correction bug recherche commune du type "la canourgue"
92
* Correction bug recherche commune du type "la canourgue"
97
*
93
*
98
*
94
*
99
*/
95
*/
100
 
96
 
101
 
97
 
102
 
98
 
103
?>
99
?>