Rev 1093 | Rev 1108 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
//+---------------------------------------------------------------------------------------------------------+// GÉNÉRAL/*** Stope l'évènement courrant quand on clique sur un lien.* Utile pour Chrome, Safari...* @param evenement* @return*/function arreter(evenement) {if (evenement.stopPropagation) {evenement.stopPropagation();}return false;}// TODO : voir si cette fonction est bien utile. Résoud le pb d'un warning sous chrome.(function(){// remove layerX and layerYvar all = $.event.props,len = all.length,res = [];while (len--) {var el = all[len];if (el != 'layerX' && el != 'layerY') res.push(el);}$.event.props = res;}());//+----------------------------------------------------------------------------------------------------------+//UPLOAD PHOTO : Traitement de l'image$(document).ready(function() {$("#effacer-miniature").click(function () {supprimerMiniature();});$("#fichier").bind('change', function () {$("#form-upload").ajaxSubmit(options);return false;});//prepare the form when the DOM is ready//create service object(proxy) using SMD (generated by the json result)var options = {success: afficherMiniature, // post-submit callbackdataType: 'xml', // 'xml', 'script', or 'json' (expected server response type)resetForm: true // reset the form after successful submit};});function afficherMiniature(reponse) {// 'responseXML' is the XML document returned by the server; we use// jQuery to extract the content of the message node from the XML docvar miniatureUrl = $("miniature-url", reponse).text();var imgNom = $("image-nom", reponse).text();$("#miniature").empty();$("#miniature").append('<img id="miniature-img" class="miniature" alt="'+imgNom+'" src="'+miniatureUrl+'"/>');$("#effacer-miniature").show();console.log(imgNom);console.log(miniatureUrl);}function supprimerMiniature() {$("#miniature").empty();$("#effacer-miniature").hide();}//+----------------------------------------------------------------------------------------------------------+// GOOGLE MAPvar geocoder;var map;var marker;var latLng;function initialiserGoogleMap(){// Cartevar latLng = new google.maps.LatLng(43.29545, 5.37458);if (VILLE == 'Montpellier') {latLng = new google.maps.LatLng(43.61077, 3.87672);} else {console.log('Ville:'+VILLE);}// Tentative de geocalisationif (navigator.geolocation) {navigator.geolocation.getCurrentPosition(function(position) {var latitude = position.coords.latitude;var longitude = position.coords.longitude;latLng = new google.maps.LatLng(latitude, longitude);});}var options = {zoom: 16,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 Googlemap = new google.maps.Map(document.getElementById('map-canvas'), options); //affiche la google map dans la div map_canvasmap.mapTypes.set('OSM', osmMapType);// Geocodeurgeocoder = new google.maps.Geocoder();console.log(GOOGLE_MAP_MARQUEUR_URL);// Marqueur google draggablemarker = new google.maps.Marker({map: map,draggable: true,title: 'Ma station',icon: GOOGLE_MAP_MARQUEUR_URL,position: latLng});deplacerMarker(latLng);}$(document).ready(function() {initialiserGoogleMap();// Autocompletion du champ adresse$("#rue").autocomplete({//Cette partie utilise geocoder pour extraire des valeurs d'adressesource: function(request, response) {geocoder.geocode( {'address': request.term+', France', 'region' : 'fr' }, function(results, status) {if (status == google.maps.GeocoderStatus.OK) {response($.map(results, function(item) {var rue = "";$.each(item.address_components, function(){if (this.types[0] == "route" || this.types[0] == "street_address" ) {rue = this.short_name;}});var retour = {label: item.formatted_address,value: rue,latitude: item.geometry.location.lat(),longitude: item.geometry.location.lng()};return retour;}));} else {afficherErreurGoogleMap(status);}})},// Cette partie est executee a la selection d'une adresseselect: function(event, ui) {var latLng = new google.maps.LatLng(ui.item.latitude, ui.item.longitude);deplacerMarker(latLng);}});$("#geolocaliser").click(function() {var latitude = $('#latitude').val();var longitude = $('#longitude').val();latLng = new google.maps.LatLng(latitude, longitude);deplacerMarker(latLng);});google.maps.event.addListener(marker, 'dragend', function() {trouverCommune(marker.getPosition());mettreAJourMarkerPosition(marker.getPosition());});google.maps.event.addListener(map, 'click', function(event) {deplacerMarker(event.latLng);});});function afficherErreurGoogleMap(status) {if (DEBUG) {$("#dialogue-google-map").empty();$("#dialogue-google-map").append('<pre class="msg-erreur">'+"Le service de Géocodage de Google Map a échoué à cause de l'erreur : "+status+'</pre>');$("#dialogue-google-map").dialog();}}function deplacerMarker(latLng) {if (marker != undefined) {marker.setPosition(latLng);map.setCenter(latLng);//map.setZoom(18);mettreAJourMarkerPosition(latLng);trouverCommune(latLng);}}function mettreAJourMarkerPosition(latLng) {var lat = latLng.lat().toFixed(5);var lng = latLng.lng().toFixed(5);remplirChampLatitude(lat);remplirChampLongitude(lng);}function remplirChampLatitude(latDecimale) {var lat = Math.round(latDecimale*100000)/100000;$('#latitude').val(lat);}function remplirChampLongitude(lngDecimale) {var lng = Math.round(lngDecimale*100000)/100000;$('#longitude').val(lng);}function trouverCommune(pos) {$(function() {var urlNomCommuneFormatee = SERVICE_NOM_COMMUNE_URL.replace('{lat}', pos.lat()).replace('{lon}', pos.lng());$.ajax({url : urlNomCommuneFormatee,type : "GET",dataType : "jsonp",beforeSend : function() {$(".commune-info").empty();$("#dialogue-erreur").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 (DEBUG) {$("#dialogue-erreur").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").append('<p class="msg-erreur">Erreur 500 : '+errorThrown+"<br />"+erreurMsg+'</p>');}}},error : function(jqXHR, textStatus, errorThrown) {if (DEBUG) {$("#dialogue-erreur").append('<p class="msg">Une erreur Ajax est survenue lors de la transmission de vos observations.</p>');reponse = jQuery.parseJSON(jqXHR.responseText);var erreurMsg = "";if (reponse != null) {$.each(reponse, function (cle, valeur) {erreurMsg += valeur + "<br />";});}$("#dialogue-erreur").append('<p class="msg-erreur">Erreur Ajax : '+errorThrown+' (type : '+textStatus+') <br />'+erreurMsg+'</p>');}},complete : function(jqXHR, textStatus) {if (DEBUG && jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {var debugMsg = "";debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));if (debugInfos != null) {$.each(debugInfos, function (cle, valeur) {debugMsg += valeur + "<br />";});$("#dialogue-erreur").append('<pre class="msg-debug msg">Débogage : '+debugMsg+'</pre>');}}if ($("#dialogue-erreur .msg").length > 0) {$("#dialogue-erreur").dialog();}}});});}//+---------------------------------------------------------------------------------------------------------+// FORMULAIRE$(document).ready(function() {$("form#saisie-obs").validate({rules: {courriel : {required : true,email : true},courriel_confirmation : {required : true,equalTo: "#courriel"},rue : "required",rue_num_debut : {required : true,digits : true,min : 1},rue_num_fin : {required : true,digits : true,min : 1},rue_cote : "required",milieu : "required",latitude : {required: true,range: [-90, 90]},longitude : {required: true,range: [-180, 180]},date : {required: true,date: true},taxon : "required"}});$("#date").datepicker($.datepicker.regional['fr']);$("#courriel_confirmation").bind('paste', function(e) {$("#dialogue-bloquer-copier-coller").dialog();return false;});//bascule le texte d'afficher à masquer$("a.afficher-coord").click(function() {$("a.afficher-coord").toggle();$("#coordonnees-geo").toggle('slow');//valeur false pour que le lien ne soit pas suivireturn false});var obsNumero = 0;$("#ajouter-obs").bind('click', function(e) {if ($("#saisie-obs").valid() == false) {$("#dialogue-form-invalide").dialog();} else {//rassemble les obs dans un tableau htmlobsNumero = obsNumero + 1;$("#liste-obs tbody").append('<tr id="obs'+obsNumero+'" class="obs">'+'<td>'+obsNumero+'</td>'+'<td>'+$("#date").val()+'</td>'+'<td>'+$("#adresse").val()+'</td>'+'<td>'+$("#taxon option:selected").text()+'</td>'+'<td>'+$('input[name=milieu]:checked').val()+'</td>'+'<td>'+$("#latitude").val()+' / '+$("#longitude").val()+'</td>'+//Ajout du champ photo'<td class="obs-miniature">'+ajouterImgMiniature()+'</td>'+'<td>'+$("#notes").val()+'</td>'+'<td><button class="supprimer-obs" value="'+obsNumero+'" title="Supprimer l\'observation '+obsNumero+'">'+'<img src="'+SUPPRIMER_ICONE_URL+'"/></button></td>'+'</tr>');//rassemble les obs dans #liste-obsvar numNomSel = $("#taxon").val();$("#liste-obs").data('obsId'+obsNumero, {'date' : $("#date").val(),'num_nom_sel' : numNomSel,'nom_sel' : taxons[numNomSel]['nom_sel'],'nom_ret' : taxons[numNomSel]['nom_ret'],'num_nom_ret' : taxons[numNomSel]['num_nom_ret'],'num_taxon' : taxons[numNomSel]['num_taxon'],'famille' : taxons[numNomSel]['famille'],'nom_fr' : taxons[numNomSel]['nom_fr'],'milieu' : $('input[name=milieu]:checked').val(),'latitude' : $("#latitude").val(),'longitude' : $("#longitude").val(),'commune_nom' : $("#commune-nom").text(),'commune_code_insee' : $("#commune-code-insee").text(),'lieu_dit' : $("#rue").val(),'station' : $("#rue_num_debut").val()+'-'+$("#rue_num_fin").val()+'-'+$("#rue_cote").val(),'notes' : $("#notes").val(),//Ajout des champs images'image_nom' : $("#miniature-img").attr('alt'),'image_b64' : ''// TODO : ajoute le support HTML5});}});$(".supprimer-obs").live('click', function() {var obsId = $(this).val();// Problème avec IE 6 et 7if (obsId == "Supprimer") {obsId = $(this).attr("title");}$('#obs'+obsId).remove();$("#liste-obs").removeData('obsId'+obsId)});// TODO : remplacer par du jquery//document.getElementById('image_file').addEventListener('change', handleFileSelect, false);$("#transmettre-obs").click(function(e) {var observations = $("#liste-obs").data();if (observations == undefined || jQuery.isEmptyObject(observations)) {$("#dialogue-zero-obs").dialog();} else if ($("#saisie-obs").valid() == false) {$("#dialogue-form-invalide").dialog();} else {observations['projet'] = 'Sauvages';var utilisateur = new Object();utilisateur.prenom = $("#prenom").val();utilisateur.nom = $("#nom").val();utilisateur.courriel = $("#courriel").val();observations['utilisateur'] = utilisateur;var erreurMsg = "";$.ajax({url : SERVICE_SAISIE_URL,type : "POST",data : observations,dataType : "json",beforeSend : function() {$(".msg").remove();$(".msg-erreur").remove();$(".msg-debug").remove();},success : function(data, textStatus, jqXHR) {$("#dialogue-obs-transaction").append('<p class="msg">Vos observations ont bien été transmises.</p>');supprimerMiniature();},statusCode : {500 : function(jqXHR, textStatus, errorThrown) {erreurMsg += "Erreur 500 :\ntype : "+textStatus+' '+errorThrown+"\n";reponse = jQuery.parseJSON(jqXHR.responseText);if (reponse != null) {$.each(reponse, function (cle, valeur) {erreurMsg += valeur + "\n";});}if (DEBUG) {$("#dialogue-obs-transaction").append('<pre class="msg-erreur">'+erreurMsg+'</pre>');}}},error : function(jqXHR, textStatus, errorThrown) {erreurMsg += "Erreur Ajax :\ntype : "+textStatus+' '+errorThrown+"\n";reponse = jQuery.parseJSON(jqXHR.responseText);if (reponse != null) {$.each(reponse, function (cle, valeur) {erreurMsg += valeur + "\n";});}if (DEBUG) {$("#dialogue-obs-transaction").append('<pre class="msg-erreur">'+erreurMsg+'</pre>');}},complete : function(jqXHR, textStatus) {var debugMsg = '';if (jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));if (debugInfos != null) {$.each(debugInfos, function (cle, valeur) {debugMsg += valeur + "\n";});}}if (erreurMsg != '') {$("#dialogue-obs-transaction").append('<p class="msg">'+'Une erreur est survenue lors de la transmission de vos observations.'+'<br />'+'Vous pouvez signaler le disfonctionnement à <a href="'+'mailto:cel@tela-botanica.org'+'?'+'subject=Disfonctionnement du widget de saisie Biodiversite34'+"&body="+erreurMsg+"\nDébogage :\n"+debugMsg+'">cel@tela-botanica.org</a>.'+'</p>');}if (DEBUG) {$("#dialogue-obs-transaction").append('<pre class="msg-debug">Débogage : '+debugMsg+'</pre>');}$("#dialogue-obs-transaction").dialog();$("#liste-obs").removeData();$('.obs').remove();obsNumero = 0;}});}return false;});});function ajouterImgMiniature() {var miniature = '';if ($("#miniature img").length == 1) {var src = $("#miniature-img").attr("src");var alt = $("#miniature-img").attr("alt");miniature = '<img class="miniature" alt="'+alt+'"src="'+src+'" />';}return miniature;}function handleFileSelect(evt) {// Check for the various File API support.if (window.File && window.FileReader && window.FileList && window.Blob) {// Great success! All the File APIs are supported.var selectedfiles = evt.target.files; // FileList object// Loop through the FileList and render image files as thumbnails.for (var i = 0, f; f = selectedfiles[i]; i++) {// Only process image files.if (!f.type.match('image.*')) {continue;}var reader = new FileReader();// Read in the image file as a data URL.reader.readAsDataURL(f);// Closure to capture the file information.reader.onload = (function(theFile) {return function(e) {// Render thumbnail.document.getElementById('image').src = e.target.result;//document.getElementById('list').insertBefore(img, null);};})(f);}}else {alert('The File APIs are not fully supported in this browser.');}}