Subversion Repositories eFlore/Applications.cel

Rev

Rev 2721 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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