Subversion Repositories eFlore/Applications.cel

Rev

Rev 2131 | Details | Compare with Previous | Last modification | View Log | RSS feed

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