Rev 3120 | Blame | Compare with Previous | Last modification | View Log | RSS feed
/*** Constructeur WidgetSaisie par défaut*/function WidgetSaisie() {this.map = null;this.marker = null;this.latLng = null; // position en coursthis.geocoder = null;this.serviceNomCommuneUrl = null;this.serviceNomCommuneUrlAlt = null;this.googleMapMarqueurUrl = null;this.chargementIconeUrl = null;this.chargementImageIconeUrl = null;}/*** Initialisation du widget*/WidgetSaisie.prototype.init = function() {this.initCarto();this.initEvts();};/*** Initialise la cartographie*/WidgetSaisie.prototype.initCarto = function() {this.initialiserGoogleMap();this.initialiserAutocompleteCommune();};/*** Initialise les écouteurs d'événements*/WidgetSaisie.prototype.initEvts = function() {// Autocompletion du champ adresse$("#carte-recherche").on('focus', function() {$(this).select();});$("#carte-recherche").on('mouseup', function(event) {// Pour Safari...event.preventDefault();});$("#carte-recherche").keypress(function(e) {if (e.which == 13) {e.preventDefault();}});};/*** Initialise l'autocomplétion de la commune, en fonction du référentiel*/WidgetSaisie.prototype.initialiserAutocompleteCommune = function() {var geocoderOptions = {},addressSuffix = '',lthis = this;switch(this.nomSciReferentiel) {case 'isfan':// Si des résultats se trouvent dans ce rectangle, ils apparaîtront en premier.// Ça marche moyen...geocoderOptions.bounds = new google.maps.LatLngBounds(new google.maps.LatLng(20.756114, -22.023927),new google.maps.LatLng(38.065392, 33.78662));break;case 'apd':geocoderOptions.bounds = new google.maps.LatLngBounds(new google.maps.LatLng(-6.708254, -26.154786),new google.maps.LatLng(27.488781, 30.490722));break;case 'bdtfx':case 'bdtxa':geocoderOptions.region = 'fr';addressSuffix = ', France';}$("#carte-recherche").autocomplete({//Cette partie utilise geocoder pour extraire des valeurs d'adressesource: function(request, response) {geocoderOptions.address = request.term + addressSuffix;lthis.geocoder.geocode( geocoderOptions, function(results, status) {if (status == google.maps.GeocoderStatus.OK) {response($.map(results, function(item) {var retour = {label: item.formatted_address,value: item.formatted_address,latitude: item.geometry.location.lat(),longitude: item.geometry.location.lng()};return retour;}));} else {lthis.afficherErreurGoogleMap(status);}});},// Cette partie est executee a la selection d'une adresseselect: function(event, ui) {lthis.latLng = new google.maps.LatLng(ui.item.latitude, ui.item.longitude);lthis.deplacerMarker(lthis.latLng);}});};WidgetSaisie.prototype.afficherErreurGoogleMap = function(status) {if (this.debug) {$('#dialogue-google-map .contenu').empty().append('<pre class="msg-erreur">'+"Le service de Géocodage de Google Map a échoué à cause de l'erreur : "+status+'</pre>');this.afficherPanneau('#dialogue-google-map');}};WidgetSaisie.prototype.surDeplacementMarker = function() {this.latLng = this.marker.getPosition();this.trouverCommune(this.latLng);this.mettreAJourMarkerPosition(this.marker.getPosition());};WidgetSaisie.prototype.surClickDansCarte = function(event) {this.latLng = event.latLng;this.deplacerMarker(this.latLng);};/*** Place le marqueur aux coordonnées indiquées dans les champs "latitude" et "longitude"*/WidgetSaisie.prototype.geolocaliser = function() {var latitude = $('#latitude').val();var longitude = $('#longitude').val();this.latLng = new google.maps.LatLng(latitude, longitude);this.deplacerMarker(this.latLng);};WidgetSaisie.prototype.initialiserGoogleMap = function(localisationNavigateur) {// par défaut on tente de localiser le navigateur (avec son sextant)if (localisationNavigateur === undefined) {localisationNavigateur = true;}var lthis = this;var latLng,zoomDefaut;// Carte @TODO mettre ça dans la configif(this.nomSciReferentiel == 'bdtre') {latLng = new google.maps.LatLng(-21.10, 55.30);// RéunionzoomDefaut = 7;} else if(this.nomSciReferentiel == 'lbf') {latLng = new google.maps.LatLng(33.72211, 35.8603);// LibanzoomDefaut = 7;} else if(this.nomSciReferentiel == 'bdtxa') {latLng = new google.maps.LatLng(14.6, -61.08334);// Fort-De-FrancezoomDefaut = 8;} else if(this.nomSciReferentiel == 'isfan') {latLng = new google.maps.LatLng(29.28358, 10.21884);// Afrique du NordzoomDefaut = 4;} else if(this.nomSciReferentiel == 'apd') {latLng = new google.maps.LatLng(8.75624, 1.80176);// Afrique de l'Ouest et du CentrezoomDefaut = 4;} else if(this.nomSciReferentiel == 'florical') {latLng = new google.maps.LatLng(-21.40722, 165.4541);// Nouvelle-CalédoniezoomDefaut = 7;} else if(this.nomSciReferentiel == 'aublet') {latLng = new google.maps.LatLng(3.80287, -53.09692);// GuyanezoomDefaut = 7;} else {latLng = new google.maps.LatLng(46.30871, 2.54395);// Centre de la France - @WARNING Prémilhat !! :)zoomDefaut = 5;}var options = {zoom: zoomDefaut,center: latLng,mapTypeId: google.maps.MapTypeId.HYBRID,mapTypeControlOptions: {mapTypeIds: ['OSM', google.maps.MapTypeId.ROADMAP, google.maps.MapTypeId.HYBRID, google.maps.MapTypeId.SATELLITE, google.maps.MapTypeId.TERRAIN]}};// Ajout de la couche OSM à la carteosmMapType = new google.maps.ImageMapType({getTileUrl: function(coord, zoom) {return "http://tile.openstreetmap.org/" +zoom + "/" + coord.x + "/" + coord.y + ".png";},tileSize: new google.maps.Size(256, 256),isPng: true,alt: 'OpenStreetMap',name: 'OSM',maxZoom: 19});// Création de la carte Googlethis.map = new google.maps.Map(document.getElementById('map-canvas'), options); //affiche la google map dans la div map_canvasthis.map.mapTypes.set('OSM', osmMapType);// Création du Geocoderthis.geocoder = new google.maps.Geocoder();// Marqueur google draggablethis.marker = new google.maps.Marker({map: this.map,draggable: true,title: 'Ma station',icon: this.googleMapMarqueurUrl,position: latLng});this.initialiserMarker(latLng);// Tentative de geocalisation depuis le navigateurif (localisationNavigateur && navigator.geolocation) {navigator.geolocation.getCurrentPosition(function(position) {var latitude = position.coords.latitude;var longitude = position.coords.longitude;lthis.latLng = new google.maps.LatLng(latitude, longitude);lthis.deplacerMarker(lthis.latLng);});}// intéraction carte$("#geolocaliser").on('click', this.geolocaliser.bind(this));google.maps.event.addListener(this.marker, 'dragend', this.surDeplacementMarker.bind(this));google.maps.event.addListener(this.map, 'click', this.surClickDansCarte.bind(this));};WidgetSaisie.prototype.initialiserMarker = function(latLng) {if (this.marker != undefined) {this.marker.setPosition(latLng);this.map.setCenter(latLng);// au chargement de la carte, la position est nullethis.viderMarkerPosition();}};WidgetSaisie.prototype.deplacerMarker = function(latLng) {if (this.marker != undefined) {this.marker.setPosition(latLng);this.map.setCenter(latLng);this.mettreAJourMarkerPosition(latLng);this.trouverCommune(latLng);}};WidgetSaisie.prototype.viderMarkerPosition = function() {this.remplirChampLatitude(null);this.remplirChampLongitude(null);};WidgetSaisie.prototype.mettreAJourMarkerPosition = function(latLng) {var lat = latLng.lat().toFixed(5);var lng = latLng.lng().toFixed(5);this.remplirChampLatitude(lat);this.remplirChampLongitude(lng);};/*** Définit la valeur de latitude, à travers la "value" du champ "#latitude";* pour définir une valeur vraiment vide (et non 0), passer null en argument*/WidgetSaisie.prototype.remplirChampLatitude = function(latDecimale) {var lat = '';if (latDecimale !== null) {lat = Math.round(latDecimale * 100000) / 100000;}$('#latitude').val(lat);};/*** Définit la valeur de longitude, à travers la "value" du champ "#longitude";* pour définir une valeur vraiment vide (et non 0), passer null en argument*/WidgetSaisie.prototype.remplirChampLongitude = function(lngDecimale) {var lng = '';if (lngDecimale !== null) {lng = Math.round(lngDecimale * 100000) / 100000;}$('#longitude').val(lng);};WidgetSaisie.prototype.trouverCommune = function(pos) {if (this.latLng == null) { // tentative de protection contre le démon de Prémilhatreturn;}var lthis = this;$(function() {var url_service = lthis.serviceNomCommuneUrl;var urlNomCommuneFormatee = url_service.replace('{lat}', pos.lat()).replace('{lon}', pos.lng());$.ajax({url : urlNomCommuneFormatee,type : "GET",dataType : "jsonp",beforeSend : function() {$(".commune-info").empty();$("#dialogue-erreur .alert-txt").empty();},success : function(data, textStatus, jqXHR) {$(".commune-info").empty();$("#commune-nom").append(data.nom);$("#commune-code-insee").append(data.codeINSEE);$("#marqueur-commune").data('commune', {'nom' : data.nom, 'codeInsee' : data.codeINSEE});},statusCode : {500 : function(jqXHR, textStatus, errorThrown) {if (this.debug) {$("#dialogue-erreur .alert-txt").append('<p id="msg">Un problème est survenu lors de l\'appel au service fournissante le nom des communes.</p>');reponse = jQuery.parseJSON(jqXHR.responseText);var erreurMsg = "";if (reponse != null) {$.each(reponse, function (cle, valeur) {erreurMsg += valeur + "<br />";});}$("#dialogue-erreur .alert-txt").append('<p class="msg-erreur">Erreur 500 : '+errorThrown+"<br />"+erreurMsg+'</p>');}}},error : function(jqXHR, textStatus, errorThrown) {if (this.debug) {$("#dialogue-erreur .alert-txt").append('<p class="msg">Une erreur Ajax est survenue lors de la recherche de la commune.</p>');reponse = jQuery.parseJSON(jqXHR.responseText);var erreurMsg = "";if (reponse != null) {$.each(reponse, function (cle, valeur) {erreurMsg += valeur + "<br />";});}$("#dialogue-erreur .alert-txt").append('<p class="msg-erreur">Erreur Ajax : '+errorThrown+' (type : '+textStatus+') <br />'+erreurMsg+'</p>');}},complete : function(jqXHR, textStatus) {var debugMsg = extraireEnteteDebug(jqXHR);if (debugMsg != '') {if (this.debug) {$("#dialogue-erreur .alert-txt").append('<pre class="msg-debug msg">Débogage : '+debugMsg+'</pre>');}}if ($("#dialogue-erreur .msg").length > 0) {$("#dialogue-erreur").show();}}});});};