Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
719 jpm 1
//+---------------------------------------------------------------------------------------------------------+
2
// GÉNÉRAL
3
/**
4
 * Stope l'évènement courrant quand on clique sur un lien.
5
 * Utile pour Chrome, Safari...
6
 * @param evenement
7
 * @return
8
 */
9
function arreter(evenement) {
10
	if (evenement.stopPropagation) {
11
		evenement.stopPropagation();
12
	}
13
	return false;
14
}
15
 
1925 mathias 16
// Permet de valider des dates sans utiliser le validateur "date", qui dépend du navigateur et fout la merde (locale, etc.)
17
// Attention, on peut rentrer 99/99/9999 ça marche ...
18
// merci http://stackoverflow.com/questions/280759/jquery-validate-how-to-add-a-rule-for-regular-expression-validation
19
$.validator.addMethod(
20
    "regex",
21
    function(value, element, regexp) {
22
        var re = new RegExp(regexp);
23
        return this.optional(element) || re.test(value);
24
    },
25
    "La valeur ne correspond pas au format demandé."
26
);
27
 
719 jpm 28
//+---------------------------------------------------------------------------------------------------------+
29
// FORMULAIRE
30
 
712 jpm 31
$(function() {
719 jpm 32
	$("#saisie-obs").validate({
33
		rules: {
34
			prenom : "required",
35
			nom : "required",
36
			courriel : {
37
				required : true,
1925 mathias 38
				email : true
39
			},
719 jpm 40
			courriel_confirmation : {
41
				required : true,
42
				equalTo: "#courriel"
43
			},
44
			milieu : "required",
744 jpm 45
			latitude : {
46
				required: true,
1925 mathias 47
				range: [-90, 90]
48
			},
744 jpm 49
			longitude : {
50
				required: true,
1925 mathias 51
				range: [-180, 180]
52
			},
744 jpm 53
			date : {
54
				required: true,
1925 mathias 55
				regex: "^[0-9]{2}/[0-9]{2}/[0-9]{4}$"
56
			},
744 jpm 57
			taxon : "required"
719 jpm 58
		}
59
	});
60
 
833 jpm 61
	$("#date").datepicker({
1990 jpm 62
		maxDate: new Date,
63
		onClose: function(dateText, inst) {$("#saisie-obs").valid();}
833 jpm 64
	});
712 jpm 65
 
744 jpm 66
	$("#courriel_confirmation").bind('paste', function(e) {
712 jpm 67
		$("#dialogue-bloquer-copier-coller").dialog();
68
		return false;
69
	});
70
 
719 jpm 71
	$("#localiser-gg-map").fancybox({
72
		'modal'			: true,
73
		'autoDimensions' : true,
74
		'titleShow'		: false,
75
		'onClosed'		: function() {
76
		    $("#gg-map").hide();
77
		},
78
		'onStart'		: function(e) {
79
			arreter(e);
80
			$("#gg-map-localisation").height($(window).height() - 100);
744 jpm 81
			$("#gg-map-carte").height($(window).height() - 200);
719 jpm 82
			$("#gg-map-localisation").width($(window).width() - 100);
83
		},
84
		'onComplete'	: function() {
85
			initialiserCarte();
86
		}
87
	});
88
 
89
	$("#valider-coordonnees").click(function(e) {
90
		var coordonnees = $("#marqueur-coordonnees").data('latLon');
91
		if (coordonnees != undefined) {
92
			$("#latitude").val(coordonnees.lat);
93
			$("#longitude").val(coordonnees.lon);
94
		}
833 jpm 95
		var commune = $("#marqueur-commune").data('commune');
96
		if (commune != undefined) {
97
			$("#commune_nom").val(commune.nom);
98
			$("#commune_code_insee").val(commune.codeInsee);
99
		}
719 jpm 100
		$.fancybox.close();
833 jpm 101
		$("#saisie-obs").valid();
719 jpm 102
	});
103
	$("#annuler-coordonnees").bind('click', function(e) {
104
		$.fancybox.close();
833 jpm 105
		$("#saisie-obs").valid()
719 jpm 106
	});
107
 
712 jpm 108
	var obsNumero = 0;
719 jpm 109
	$("#ajouter-obs").bind('click', function(e) {
110
		if ($("#saisie-obs").valid() == false) {
111
			$("#dialogue-form-invalide").dialog();
112
		} else {
113
			obsNumero = obsNumero + 1;
114
			$("#liste-obs tbody").append(
115
				'<tr id="obs'+obsNumero+'" class="obs">'+
116
					'<td>'+obsNumero+'</td>'+
117
					'<td>'+$("#date").val()+'</td>'+
118
					'<td>'+$("#taxon option:selected").text()+'</td>'+
119
					'<td>'+$("#milieu option:selected").text()+'</td>'+
120
					'<td>'+$("#latitude").val()+'</td>'+
121
					'<td>'+$("#longitude").val()+'</td>'+
122
					'<td>'+$("#notes").val()+'</td>'+
123
					'<td><button class="supprimer-obs" value="'+obsNumero+'" title="'+obsNumero+'">Supprimer</button></td>'+
124
				'</tr>');
125
			var numNomSel = $("#taxon").val();
126
			$("#liste-obs").data('obsId'+obsNumero, {
127
				'date' : $("#date").val(),
128
				'num_nom_sel' : numNomSel,
129
				'nom_sel' : taxons[numNomSel]['nom_sel'],
130
				'nom_ret' : taxons[numNomSel]['nom_ret'],
131
				'num_nom_ret' : taxons[numNomSel]['num_nom_ret'],
132
				'num_taxon' : taxons[numNomSel]['num_taxon'],
133
				'famille' : taxons[numNomSel]['famille'],
1848 aurelien 134
				'nom_referentiel' : 'bdtfx',
719 jpm 135
				'nom_fr' : taxons[numNomSel]['nom_fr'],
136
				'milieu' : $("#milieu option:selected").val(),
137
				'latitude' : $("#latitude").val(),
138
				'longitude' : $("#longitude").val(),
833 jpm 139
				'commune_nom' : $("#commune_nom").val(),
140
				'commune_code_insee' : $("#commune_code_insee").val(),
719 jpm 141
				'notes' : $("#notes").val()});
142
		}
712 jpm 143
	});
144
 
145
	$(".supprimer-obs").live('click', function() {
146
		var obsId = $(this).val();
719 jpm 147
		// Problème avec IE 6 et 7
148
		if (obsId == "Supprimer") {
149
			obsId = $(this).attr("title");
150
		}
151
 
152
		$('#obs'+obsId).remove();
153
		$("#liste-obs").removeData('obsId'+obsId)
712 jpm 154
	});
155
 
719 jpm 156
	$("#tramsmettre-obs").click(function(e) {
712 jpm 157
		var observations = $("#liste-obs").data();
719 jpm 158
 
159
		if (observations == undefined || jQuery.isEmptyObject(observations)) {
712 jpm 160
			$("#dialogue-zero-obs").dialog();
719 jpm 161
		} else if ($("#saisie-obs").valid() == false) {
162
			$("#dialogue-form-invalide").dialog();
712 jpm 163
		} else {
833 jpm 164
			observations['projet'] = 'Biodiversite34';
165
 
719 jpm 166
			var utilisateur = new Object();
1352 aurelien 167
			utilisateur.id_utilisateur = $("#id_utilisateur").val();
719 jpm 168
			utilisateur.prenom = $("#prenom").val();
169
			utilisateur.nom = $("#nom").val();
170
			utilisateur.courriel = $("#courriel").val();
171
			observations['utilisateur'] = utilisateur;
172
 
833 jpm 173
			var erreurMsg = "";
719 jpm 174
			$.ajax({
1348 aurelien 175
				url : SERVICE_SAISIE_URL,
719 jpm 176
				type : "POST",
177
				data : observations,
833 jpm 178
				dataType : "json",
719 jpm 179
				beforeSend : function() {
833 jpm 180
					$(".msg").remove();
181
					$(".msg-erreur").remove();
182
					$(".msg-debug").remove();
719 jpm 183
				},
833 jpm 184
				success : function(data, textStatus, jqXHR) {
185
					$("#dialogue-obs-transaction").append('<p class="msg">Vos observations ont bien été transmises.</p>');
186
				},
719 jpm 187
				statusCode : {
188
				    500 : function(jqXHR, textStatus, errorThrown) {
833 jpm 189
						erreurMsg += "Erreur 500 :\ntype : "+textStatus+' '+errorThrown+"\n";
719 jpm 190
						reponse = jQuery.parseJSON(jqXHR.responseText);
191
						if (reponse != null) {
192
							$.each(reponse, function (cle, valeur) {
833 jpm 193
								erreurMsg += valeur + "\n";
719 jpm 194
							});
195
						}
833 jpm 196
						if (DEBUG) {
197
							$("#dialogue-obs-transaction").append('<pre class="msg-erreur">'+erreurMsg+'</pre>');
198
						}
719 jpm 199
				    }
200
				},
833 jpm 201
				error : function(jqXHR, textStatus, errorThrown) {
202
					erreurMsg += "Erreur Ajax :\ntype : "+textStatus+' '+errorThrown+"\n";
203
					reponse = jQuery.parseJSON(jqXHR.responseText);
204
					if (reponse != null) {
205
						$.each(reponse, function (cle, valeur) {
206
							erreurMsg += valeur + "\n";
207
						});
208
					}
209
 
210
					if (DEBUG) {
211
						$("#dialogue-obs-transaction").append('<pre class="msg-erreur">'+erreurMsg+'</pre>');
212
					}
719 jpm 213
				},
214
				complete : function(jqXHR, textStatus) {
833 jpm 215
					var debugMsg = '';
216
					if (jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {
719 jpm 217
						debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));
218
						if (debugInfos != null) {
219
							$.each(debugInfos, function (cle, valeur) {
833 jpm 220
								debugMsg += valeur + "\n";
719 jpm 221
							});
222
						}
223
					}
833 jpm 224
					if (erreurMsg != '') {
225
						$("#dialogue-obs-transaction").append('<p class="msg">'+
226
								'Une erreur est survenue lors de la transmission de vos observations.'+'<br />'+
227
								'Vous pouvez signaler le disfonctionnement à <a href="'+
228
								'mailto:cel@tela-botanica.org'+'?'+
229
								'subject=Disfonctionnement du widget de saisie Biodiversite34'+
230
								"&body="+erreurMsg+"\nDébogage :\n"+debugMsg+
231
								'">cel@tela-botanica.org</a>.'+
232
								'</p>');
233
					}
234
					if (DEBUG) {
235
						$("#dialogue-obs-transaction").append('<pre class="msg-debug">Débogage : '+debugMsg+'</pre>');
236
					}
719 jpm 237
 
238
					$("#dialogue-obs-transaction").dialog();
239
					$("#liste-obs").removeData();
240
					$('.obs').remove();
241
					obsNumero = 0;
833 jpm 242
				}
712 jpm 243
			});
244
		}
719 jpm 245
		return false;
246
	});
247
});
712 jpm 248
 
719 jpm 249
//+---------------------------------------------------------------------------------------------------------+
250
// GOOGLE MAP
251
 
252
var geocoder;
253
var latLng;
254
var map;
255
var marker;
256
var osmMapType;
257
function initialiserCarte() {
258
	geocoder = new google.maps.Geocoder();
259
	latLng = new google.maps.LatLng(43.577, 3.455);
747 jpm 260
	map = new google.maps.Map(document.getElementById('gg-map-carte'), {
261
		zoom: 9,
262
		mapTypeId: google.maps.MapTypeId.HYBRID,
263
		mapTypeControlOptions: {
264
			mapTypeIds: ['OSM', google.maps.MapTypeId.ROADMAP, google.maps.MapTypeId.HYBRID, google.maps.MapTypeId.SATELLITE, google.maps.MapTypeId.TERRAIN]}
265
	});
266
 
267
	// Ajout de la couche OSM à la carte
719 jpm 268
	osmMapType = new google.maps.ImageMapType({
269
		getTileUrl: function(coord, zoom) {
270
			return "http://tile.openstreetmap.org/" +
271
			zoom + "/" + coord.x + "/" + coord.y + ".png";
272
		},
273
		tileSize: new google.maps.Size(256, 256),
274
		isPng: true,
275
		alt: "OpenStreetMap",
276
		name: "OSM",
277
		maxZoom: 19
712 jpm 278
	});
719 jpm 279
	map.mapTypes.set('OSM', osmMapType);
280
 
747 jpm 281
	// Ajout des limites de communes
3016 mathias 282
	ctaLayer = new google.maps.KmlLayer('https://www.tela-botanica.org/commun/google/map/3/kmz/communes/34.kmz', {preserveViewport: true});
747 jpm 283
	ctaLayer.setMap(map);
284
 
285
	// Définition du marqueur
719 jpm 286
	marker = new google.maps.Marker({
287
		position: latLng,
288
		title: 'Ma station',
289
		map: map,
290
		draggable: true
291
	});
747 jpm 292
	deplacerMarker(latLng);
719 jpm 293
 
747 jpm 294
	// Tentative de géolocalisation
295
	if(navigator.geolocation) {	// Try W3C Geolocation (Preferred)
296
		navigator.geolocation.getCurrentPosition(function(position) {
297
			(DEBUG) ? console.log("Géolocalisation OK.") : '';
298
			latLng = new google.maps.LatLng(position.coords.latitude,position.coords.longitude);
299
			deplacerMarker(latLng);
300
			map.setCenter(latLng);
833 jpm 301
		}, function(erreur) {
302
			(DEBUG) ? console.log("Géolocalisation échouée : "+erreur.code+" = "+erreur.message) : '';
747 jpm 303
		});
304
	} else { //Browser doesn't support Geolocation
305
		(DEBUG) ? console.log("Navigateur ne supportant pas la géolocalisation. Localisation par défaut.") : '';
306
	}
833 jpm 307
	deplacerMarker(latLng);
308
	map.setCenter(latLng);
719 jpm 309
 
747 jpm 310
	// Add des évènements concernant le marqueur
719 jpm 311
	google.maps.event.addListener(marker, 'dragstart', function() {
312
		mettreAJourMarkerAdresse('Marqueur de station début du déplacement...');
313
	});
314
 
315
	google.maps.event.addListener(marker, 'drag', function() {
316
		mettreAJourMarkerStatut('Marqueur de station en cours de déplacement...');
317
		mettreAJourMarkerPosition(marker.getPosition());
318
	});
319
 
320
	google.maps.event.addListener(marker, 'dragend', function() {
321
		mettreAJourMarkerStatut('Marqueur de station déplacé (glisser/déposer).');
322
		mettreAJourMarkerPosition(marker.getPosition());
323
		geocoderPosition(marker.getPosition());
833 jpm 324
		trouverCommune(marker.getPosition());
719 jpm 325
	});
326
 
327
	google.maps.event.addListener(map, 'click', function(event) {
328
		deplacerMarker(event.latLng);
329
	});
330
}
331
 
747 jpm 332
function deplacerMarker(latLon) {
333
	if (marker != undefined) {
334
		marker.setPosition(latLon);
335
		mettreAJourMarkerStatut('Marqueur de station déplacé (clic).');
336
		mettreAJourMarkerPosition(marker.getPosition());
337
		geocoderPosition(marker.getPosition());
833 jpm 338
		trouverCommune(marker.getPosition());
747 jpm 339
	}
340
}
341
 
719 jpm 342
function geocoderPosition(pos) {
343
	if (geocoder != undefined) {
344
		geocoder.geocode({
345
			latLng: pos
346
		}, function(responses, status) {
347
			if (status == google.maps.GeocoderStatus.OK) {
348
				if (responses && responses.length > 0) {
349
					mettreAJourMarkerAdresse(responses[0].formatted_address);
350
				} else {
351
					mettreAJourMarkerAdresse("Impossible de trouver d'adresse pour cette position.");
352
				}
353
			} else {
354
				mettreAJourMarkerAdresse("Un problème de géolocalisation est survenu : "+status+".");
355
			}
356
		});
357
	}
358
}
359
 
833 jpm 360
function trouverCommune(pos) {
2736 mathias 361
	if (this.latLng == null) { // tentative de protection contre le démon de Prémilhat
362
		return;
363
	}
833 jpm 364
	$(function() {
1348 aurelien 365
		var urlNomCommuneFormatee = SERVICE_NOM_COMMUNE_URL.replace('{lat}', pos.lat()).replace('{lon}', pos.lng());
833 jpm 366
		$.ajax({
367
			url : urlNomCommuneFormatee,
368
			type : "GET",
369
			dataType : "json",
370
			beforeSend : function() {
371
				$(".commune-info").empty();
372
				$("#dialogue-erreur").empty();
373
			},
374
			success : function(data, textStatus, jqXHR) {
375
				$(".commune-info").empty();
376
				$("#commune-nom").append(data.nom);
377
				$("#commune-code-insee").append(data.codeINSEE);
378
				$("#marqueur-commune").data('commune', {'nom' : data.nom, 'codeInsee' : data.codeINSEE});
379
			},
380
			statusCode : {
381
			    500 : function(jqXHR, textStatus, errorThrown) {
382
					if (DEBUG) {
383
						$("#dialogue-erreur").append('<p id="msg">Un problème est survenu lors de l\'appel au service fournissante le nom des communes.</p>');
384
						reponse = jQuery.parseJSON(jqXHR.responseText);
385
						var erreurMsg = "";
386
						if (reponse != null) {
387
							$.each(reponse, function (cle, valeur) {
388
								erreurMsg += valeur + "<br />";
389
							});
390
						}
391
 
392
						$("#dialogue-erreur").append('<p class="msg-erreur">Erreur 500 : '+errorThrown+"<br />"+erreurMsg+'</p>');
393
					}
394
			    }
395
			},
396
			error : function(jqXHR, textStatus, errorThrown) {
397
				if (DEBUG) {
398
					$("#dialogue-erreur").append('<p class="msg">Une erreur Ajax est survenue lors de la transmission de vos observations.</p>');
399
					reponse = jQuery.parseJSON(jqXHR.responseText);
400
					var erreurMsg = "";
401
					if (reponse != null) {
402
						$.each(reponse, function (cle, valeur) {
403
							erreurMsg += valeur + "<br />";
404
						});
405
					}
406
 
407
					$("#dialogue-erreur").append('<p class="msg-erreur">Erreur Ajax : '+errorThrown+' (type : '+textStatus+') <br />'+erreurMsg+'</p>');
408
				}
409
			},
410
			complete : function(jqXHR, textStatus) {
411
				if (DEBUG && jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {
412
					var debugMsg = "";
413
					debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));
414
					if (debugInfos != null) {
415
						$.each(debugInfos, function (cle, valeur) {
416
							debugMsg += valeur + "<br />";
417
						});
418
						$("#dialogue-erreur").append('<pre class="msg-debug msg">Débogage : '+debugMsg+'</pre>');
419
					}
420
				}
421
				if ($("#dialogue-erreur .msg").length > 0) {
422
					$("#dialogue-erreur").dialog();
423
				}
424
			}
425
		});
426
	});
427
}
428
 
719 jpm 429
function mettreAJourMarkerStatut(str) {
430
	document.getElementById('marqueur-statut').innerHTML = str;
431
}
432
 
433
function mettreAJourMarkerPosition(latLng) {
744 jpm 434
	var lat = latLng.lat().toFixed(5);
435
	var lon = latLng.lng().toFixed(5);
436
	document.getElementById('marqueur-wgs84').innerHTML = [lat, lon].join(', ');
437
	$("#marqueur-coordonnees").data('latLon', {'lat' : lat, 'lon' : lon});
438
 
439
	Proj4js.defs["EPSG:4326"] = "+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs";
440
	Proj4js.defs["EPSG:2154"]="+title=RGF93 / Lambert-93 +proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs ";
441
	var source = new Proj4js.Proj('EPSG:4326');// Coordonnées source : WGS 84
442
	var dest = new Proj4js.Proj('EPSG:2154');// Coordonnées destination  : Lambert 93
443
	var p = new Proj4js.Point(lon+','+lat);//lon+','+lat any object will do as long as it has 'x' and 'y' properties
444
	Proj4js.transform(source, dest, p);
445
	//Proj4js.reportError = function(msg) {alert(msg);}
446
	//console.log(p.toString());
447
	document.getElementById('marqueur-lambert93').innerHTML = [p.x.toFixed(0)+' '+dest.units, p.y.toFixed(0)+' '+dest.units].join(', ');
719 jpm 448
}
449
 
450
function mettreAJourMarkerAdresse(str) {
451
	document.getElementById('marqueur-adresse').innerHTML = str;
452
}
453