Subversion Repositories eFlore/Applications.cel

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2697 mathias 1
// Héritage !!
2
function WidgetSaisieSauvages() {
3
	this.markerDeb = undefined;
4
	this.latLngDeb = undefined;
5
	this.markerFin = undefined;
6
	this.latLngCentre = undefined;
7
	this.latLngFin = undefined;
8
	this.ligneRue = undefined;
9
	this.premierDeplacement = true;
10
	this.valeurChamp = "";
11
	this.avertissementDeuxPhotosAffiche = false;
2700 mathias 12
	this.googleMapMarqueurDebutUrl = null;
13
	this.googleMapMarqueurFinUrl = null;
14
	this.ville = null;
15
	this.supprimerIconeUrl = null;
2744 aurelien 16
	this.serviceTraceRueUrl = null;
2709 mathias 17
	this.taxons = {};
2744 aurelien 18
	this.listeRues = {};
19
	this.indexRueSelectionnee = 0;
2748 aurelien 20
	this.requeteRechercheRue = null;
21
	this.aucuneRueSelectionnee = "Aucune rue sélectionnée";
22
	this.nomDeRueInconnue = "Nom de rue inconnu";
2905 aurel 23
	this.zoneGeo = null;
2701 mathias 24
}
2697 mathias 25
WidgetSaisieSauvages.prototype = new WidgetSaisie();
1346 aurelien 26
 
2697 mathias 27
// surcharge
28
WidgetSaisieSauvages.prototype.initCarto = function() {
29
	this.initialiserGoogleMap();
30
	this.afficherEtapeGeolocalisation(1);
2736 mathias 31
	this.latLng = true; // patch cracra pour éviter de surcharger trouvercommune()
2707 mathias 32
 
2708 mathias 33
	var lthis = this;
2707 mathias 34
	$('#carte-recherche').autocomplete({
35
		//Cette partie utilise geocoder pour extraire des valeurs d'adresse
36
		source: function(request, response) {
37
			lthis.geocoder.geocode( {'address': request.term+', France', 'region' : 'fr' }, function(results, status) {
38
				if (status == google.maps.GeocoderStatus.OK) {
39
					response($.map(results, function(item) {
40
						var rue = "";
41
						$.each(item.address_components, function(){
42
							if (this.types[0] == "route" || this.types[0] == "street_address" ) {
43
								rue = this.short_name;
44
							}
45
						});
46
						var retour = {
47
							label: item.formatted_address,
48
							value: rue,
49
							latitude: item.geometry.location.lat(),
50
							longitude: item.geometry.location.lng()
51
						};
52
						return retour;
53
					}));
54
				} else {
55
					lthis.afficherErreurGoogleMap(status);
56
				}
57
			});
58
		},
59
		// Cette partie est executee a la selection d'une adresse
60
		select: function(event, ui) {
61
			var nouvellePosition = new google.maps.LatLng(ui.item.latitude, ui.item.longitude);
62
			lthis.initialiserMarkerDeb();
63
			lthis.deplacerMarkerDeb(nouvellePosition);
64
			lthis.map.setZoom(16);
65
			lthis.afficherEtapeGeolocalisation(2);
66
		}
67
	});
2701 mathias 68
};
1054 jpm 69
 
2697 mathias 70
//surcharge
71
WidgetSaisieSauvages.prototype.initForm = function() {
2708 mathias 72
	// super() à la main - toute autre manière de faire est über-komplex
73
	WidgetSaisie.prototype.initForm.call(this);
1916 jpm 74
 
2697 mathias 75
	this.surChangementTaxonListe();
76
	$('#taxon-liste').on('change', this.surChangementTaxonListe);
2700 mathias 77
	if (this.debug) {
2697 mathias 78
		console.log('Selected taxon:'+$('#taxon-liste option:selected').val());
1916 jpm 79
	}
2697 mathias 80
	$('#taxon-liste').on('blur', this.surChangementValeurTaxon);
81
	$('#taxon').on('blur', this.surChangementValeurTaxon);
2701 mathias 82
};
1916 jpm 83
 
2697 mathias 84
//surcharge
85
WidgetSaisieSauvages.prototype.initEvts = function() {
86
	var lthis = this;
2700 mathias 87
	// super() à la main - toute autre manière de faire est über-komplex
88
	WidgetSaisie.prototype.initEvts.call(this);
89
 
90
	$('.dropdown-menu input, .dropdown-menu label').on('click', function(event) {
91
		event.stopPropagation();
2697 mathias 92
	});
2700 mathias 93
	$('#fichier').off(); // elever l'écouteur d'événements de base
2697 mathias 94
	$('#fichier').on('click change', function(event) {
95
 
96
		if($("#photos-conteneur #miniatures .miniature").length == 1 && ! lthis.avertissementDeuxPhotosAffiche) {
97
			messageAvertissement = "Attention: \n"+
98
			"Sélectionnez uniquement les photos correspondantes à une seule plante \n"+
99
			"(c'est à dire correspondant à un seul individu d'une espèce donnée) \n"+
100
			"vue dans le tronçon de rue inventoriée ";
101
			if(window.confirm(messageAvertissement)) {
102
				lthis.avertissementDeuxPhotosAffiche = true;
103
				return true;
104
			} else {
105
				return false;
1916 jpm 106
			}
2697 mathias 107
		}
108
		if ($(this).val().length > 0) {
109
			arreter(event);
110
			var options = {
111
				success: lthis.afficherMiniature.bind(lthis), // post-submit callback
112
				dataType: 'xml', // 'xml', 'script', or 'json' (expected server response type)
113
				resetForm: true // reset the form after successful submit
114
			};
115
			$('#miniature').append(
2700 mathias 116
				'<img id="miniature-chargement" class="miniature" alt="chargement" src="'+ this.chargementImageIconeUrl +'"/>');
2697 mathias 117
			$('#ajouter-obs').attr('disabled', 'disabled');
118
			if (lthis.verifierFormat($(this).val())) {
119
				$('#form-upload').ajaxSubmit(options);
120
			} else {
121
				$('#form-upload')[0].reset();
122
				window.alert("Le format de fichier n'est pas supporté, les formats acceptés sont "+	$('#fichier').attr('accept'));
123
			}
124
			return false;
125
		}
1916 jpm 126
	});
127
 
2697 mathias 128
	$('.cb-milieux').on('click', function(event) {
129
		$(this).valid();
130
		event.stopPropagation();
131
	});
1956 jpm 132
 
2697 mathias 133
	// Défilement des photos
134
	$('body').on('click', '.defilement-control-zone', function(event) {
135
		lthis.defilerMiniatures($(this));
136
	});
137
	$('body').on('mouseover', '.defilement-control-zone', function(event) {
138
		$('.defilement-control', this).removeClass('hidden');
139
	});
140
	$('body').on('mouseout', '.defilement-control-zone', function(event) {
141
		$('.defilement-control', this).addClass('hidden');
142
	});
1916 jpm 143
 
2697 mathias 144
	$('#photo-placeholder').click(function(event) {
145
		$('#fichier').click();
146
	});
147
	$('#geolocaliser').on('click', this.geolocaliser.bind(this));
2744 aurelien 148
 
2745 aurelien 149
	$('.navigation-rue').on('click', this.surClicRueSuivantPrecedent.bind(this));
2701 mathias 150
};
2408 jpm 151
 
2697 mathias 152
WidgetSaisieSauvages.prototype.montrerFormIdentite = function() {
153
	$('#zone-courriel-confirmation, #zone-prenom-nom').css('display', 'block');
2701 mathias 154
};
2697 mathias 155
 
156
// surcharge
157
WidgetSaisieSauvages.prototype.initialiserGoogleMap = function() {
158
	var lthis = this;
2905 aurel 159
	this.latLngDeb = new google.maps.LatLng(48.8543, 2.3483);// Paris par défaut
160
 
161
	// si param "zone_geo"
162
	if (this.zoneGeo != "") {
163
		var url = "http://api.tela-botanica.org/service:cel:coordSearch?zone=" + this.zoneGeo;
164
		$.getJSON(url, function(data) {
165
			lthis.latLngDeb = new google.maps.LatLng(data.lat, data.lng);
166
			lthis.suiteInitialiserGoogleMap();
167
		});
168
 
169
	}
170
 
171
	// si param "ville"
2907 aurel 172
	else {
173
		if (this.ville == 'Marseille') {
174
			this.latLngDeb = new google.maps.LatLng(43.29545, 5.37458);
175
		}
176
		if (this.ville == 'Montpellier') {
177
			this.latLngDeb = new google.maps.LatLng(43.61077, 3.87672);
178
		}
2905 aurel 179
		this.suiteInitialiserGoogleMap();
1946 jpm 180
	}
2905 aurel 181
 
2907 aurel 182
 
2905 aurel 183
}
184
 
185
 
186
WidgetSaisieSauvages.prototype.suiteInitialiserGoogleMap = function() {
1922 jpm 187
	var options = {
2905 aurel 188
			zoom: 14, // avant : 16
2697 mathias 189
			center: this.latLngDeb,
1922 jpm 190
			mapTypeId: google.maps.MapTypeId.HYBRID,
191
			mapTypeControlOptions: {
2408 jpm 192
				mapTypeIds: ['OSM',
193
					google.maps.MapTypeId.ROADMAP,
194
					google.maps.MapTypeId.HYBRID,
195
					google.maps.MapTypeId.SATELLITE,
1922 jpm 196
					google.maps.MapTypeId.TERRAIN]}
197
		};
2408 jpm 198
 
1922 jpm 199
	// Ajout de la couche OSM à la carte
200
	osmMapType = new google.maps.ImageMapType({
201
		getTileUrl: function(coord, zoom) {
202
			return 'http://tile.openstreetmap.org/' + zoom + '/' + coord.x + '/' + coord.y + '.png';
203
		},
204
		tileSize: new google.maps.Size(256, 256),
205
		isPng: true,
206
		alt: 'OpenStreetMap',
207
		name: 'OSM',
208
		maxZoom: 19
1346 aurelien 209
	});
2408 jpm 210
 
1922 jpm 211
	// Création de la carte Google
2697 mathias 212
	this.map = new google.maps.Map(document.getElementById('map-canvas'), options); //affiche la google map dans la div map_canvas
213
	this.map.mapTypes.set('OSM', osmMapType);
2408 jpm 214
 
1922 jpm 215
	// Ajout de l'évènment sur click dans Carte
2697 mathias 216
	google.maps.event.addListener(this.map, 'click', this.surClickDansCarte.bind(this));
2408 jpm 217
 
1922 jpm 218
	// Lorsque la carte est chargée, on vérifie si on peut précharger des données
2907 aurel 219
	var lthis = this;
220
	google.maps.event.addListenerOnce(this.map, 'idle', function(){
221
		// Initialisation du marker de début de rue
222
		if (!lthis.obsId) {
223
			// Tentative de geolocalisation si aucune obs à précharger
224
			lthis.initialiserMarkerDeb();
225
			if (this.zoneGeo == "" && this.ville == "") {
2905 aurel 226
				lthis.tenterGeolocalisation();
227
			}
2907 aurel 228
		}
229
	});
2408 jpm 230
 
1922 jpm 231
	// Création du Geocoder
2697 mathias 232
	this.geocoder = new google.maps.Geocoder();
2701 mathias 233
};
1054 jpm 234
 
2708 mathias 235
WidgetSaisieSauvages.prototype.surClickDansCarte = function(event) {
2736 mathias 236
	this.latLngDeb = event.latLng;
237
	this.deplacerMarkerDeb(this.latLngDeb);
2708 mathias 238
};
239
 
2697 mathias 240
// surcharge
241
WidgetSaisieSauvages.prototype.prechargerForm = function(data) {
2256 aurelien 242
 
243
    $('#carte-recherche').val(data.zoneGeo);
244
	$('#commune-nom').text(data.zoneGeo);
2408 jpm 245
 
2257 aurelien 246
	if(data.hasOwnProperty("codeZoneGeo")) {
247
		$('#commune-code-insee').text(data.codeZoneGeo.replace('INSEE-C:', ''));
248
	}
2408 jpm 249
 
2697 mathias 250
    var pos = new google.maps.LatLng(data.latitude, data.longitude);
2408 jpm 251
 
2256 aurelien 252
    if(data.hasOwnProperty("extension")) {
253
    	// cas des obs florilèges qui apparaissent aussi comme des obs sauvages
254
    	// mais qui n'ont pas de coté de rue
255
    	if(data.extension.hasOwnProperty("coteRue")) {
256
    		$('#rue_cote option[value='+data.extension.coteRue.valeur+']').attr("selected", "selected");
257
    	}
2408 jpm 258
 
2697 mathias 259
    	var deb = new google.maps.LatLng(data.extension.latitudeDebutRue.valeur, data.extension.longitudeDebutRue.valeur);
260
	    var fin = new google.maps.LatLng(data.extension.latitudeFinRue.valeur, data.extension.longitudeFinRue.valeur);
2758 aurelien 261
 
2708 mathias 262
	    this.mettreAJourMarkerPosition(pos);
2408 jpm 263
 
2758 aurelien 264
	    this.latLngDeb = deb;
265
		this.initialiserMarkerDebSimple();
266
 
267
		this.latLngFin = fin;
268
	    this.initialiserMarkerFin(fin);
269
 
270
	    this.rechercherRue();
2408 jpm 271
 
2256 aurelien 272
	    var latlngbounds = new google.maps.LatLngBounds();
273
	    latlngbounds.extend(deb);
274
	    latlngbounds.extend(fin);
2697 mathias 275
	    this.map.setCenter(latlngbounds.getCenter());
276
	    this.map.fitBounds(latlngbounds);
2256 aurelien 277
    } else if(data.hasOwnProperty("latitude") && data.hasOwnProperty("longitude")) {
2697 mathias 278
    	this.deplacerMarkerDeb(pos);
2256 aurelien 279
    }
2701 mathias 280
};
2256 aurelien 281
 
2758 aurelien 282
WidgetSaisieSauvages.prototype.initialiserMarkerDebSimple = function() {
283
	this.premierDeplacement = true;
284
	if (this.markerDeb == undefined) {
285
		// Marqueur de début de Rue
286
		this.markerDeb = new google.maps.Marker({
287
			map: this.map,
288
			draggable: true,
289
			title: 'Début de la portion de rue étudiée',
290
			icon: this.googleMapMarqueurDebutUrl,
291
			position: this.latLngDeb
292
		});
293
		google.maps.event.addListener(this.markerDeb, 'dragend', this.surDeplacementMarkerDeb.bind(this));
294
	}
295
}
296
 
297
 
2697 mathias 298
WidgetSaisieSauvages.prototype.initialiserMarkerDeb = function() {
299
	this.premierDeplacement = true;
300
	if (this.markerDeb == undefined) {
1922 jpm 301
		// Marqueur de début de Rue
2697 mathias 302
		this.markerDeb = new google.maps.Marker({
303
			map: this.map,
1922 jpm 304
			draggable: true,
305
			title: 'Début de la portion de rue étudiée',
2700 mathias 306
			icon: this.googleMapMarqueurDebutUrl,
2697 mathias 307
			position: this.latLngDeb
1922 jpm 308
		});
2697 mathias 309
		google.maps.event.addListener(this.markerDeb, 'dragend', this.surDeplacementMarkerDeb.bind(this));
1922 jpm 310
	}
2408 jpm 311
 
2697 mathias 312
	this.latLngFin = this.latLngDeb;
313
	if (this.markerFin != undefined) {
314
		this.markerFin.setMap(null);
1922 jpm 315
	}
2697 mathias 316
	this.latLngCentre = this.latLngDeb;
317
	if (this.ligneRue != undefined) {
318
		this.ligneRue.setMap(null);
1922 jpm 319
	}
2701 mathias 320
};
1346 aurelien 321
 
2697 mathias 322
WidgetSaisieSauvages.prototype.surDeplacementMarkerDeb = function() {
2758 aurelien 323
	// Annulation d'une éventuelle recherche de rue déjà en cours
324
	this.annulerRechercherRue();
2736 mathias 325
	this.latLngDeb = this.markerDeb.getPosition();
326
	this.deplacerMarkerDeb(this.latLngDeb);
2701 mathias 327
};
1346 aurelien 328
 
2697 mathias 329
WidgetSaisieSauvages.prototype.deplacerMarkerDeb = function(nouvellePosition) {
2748 aurelien 330
 
2697 mathias 331
	this.latLngDeb = nouvellePosition;
2758 aurelien 332
	if (this.markerDeb == undefined) {
333
		// Marqueur de début de Rue
334
		this.markerDeb = new google.maps.Marker({
335
			map: this.map,
336
			draggable: true,
337
			title: 'Début de la portion de rue étudiée',
338
			icon: this.googleMapMarqueurDebutUrl,
339
			position: this.latLngDeb
340
		});
341
		google.maps.event.addListener(this.markerDeb, 'dragend', this.surDeplacementMarkerDeb.bind(this));
342
	}
2697 mathias 343
	this.markerDeb.setPosition(this.latLngDeb);
344
	this.map.setCenter(this.latLngDeb);
2708 mathias 345
	this.mettreAJourMarkerPosition(this.latLngDeb);
2697 mathias 346
	this.trouverCommune(this.latLngDeb);
1922 jpm 347
 
2744 aurelien 348
	var nouvellePositionFin = new google.maps.LatLng(this.latLngDeb.lat(), this.latLngDeb.lng() + 0.0010);
349
	this.initialiserMarkerFin();
2758 aurelien 350
	this.deplacerMarkerFin(nouvellePositionFin);
2744 aurelien 351
	this.afficherEtapeGeolocalisation(3);
2701 mathias 352
};
1346 aurelien 353
 
2697 mathias 354
WidgetSaisieSauvages.prototype.initialiserMarkerFin = function() {
355
	if (this.markerFin == undefined) {
356
		this.markerFin = new google.maps.Marker({
357
			map: this.map,
1922 jpm 358
			draggable: true,
359
			title: 'Fin de la portion de rue étudiée',
2700 mathias 360
			icon: this.googleMapMarqueurFinUrl,
2697 mathias 361
			position: this.latLngFin
1922 jpm 362
		});
2697 mathias 363
		google.maps.event.addListener(this.markerFin, 'dragend', this.surDeplacementMarkerFin.bind(this));
1346 aurelien 364
	}
2701 mathias 365
};
1346 aurelien 366
 
2697 mathias 367
WidgetSaisieSauvages.prototype.deplacerMarkerFin = function(nouvellePosition) {
368
	this.latLngFin = nouvellePosition;
369
	this.markerFin.setMap(this.map);
370
	this.markerFin.setPosition(this.latLngFin);
371
	this.dessinerLigneRue(this.latLngDeb, this.latLngFin);
2701 mathias 372
};
1922 jpm 373
 
2697 mathias 374
WidgetSaisieSauvages.prototype.surDeplacementMarkerFin = function() {
2748 aurelien 375
	// Annulation d'une éventuelle recherche déjà en cours
376
	this.annulerRechercherRue();
2744 aurelien 377
	this.rechercherRue();
378
};
379
 
380
WidgetSaisieSauvages.prototype.surClicRueSuivantPrecedent = function(event) {
381
	event.preventDefault();
382
	if($(event.target).hasClass("navigation-rue-suivant")) {
383
		this.indexRueSelectionnee = this.indexRueSelectionnee < this.listeRues.length - 1 ? this.indexRueSelectionnee + 1 : 0;
384
	} else {
385
		this.indexRueSelectionnee = this.indexRueSelectionnee > 0 ? this.indexRueSelectionnee - 1 : this.listeRues.length - 1;
386
	}
387
	this.mettreRueEnValeur(this.listeRues[this.indexRueSelectionnee]);
388
}
389
 
390
WidgetSaisieSauvages.prototype.afficherChargementRechercheRue = function() {
2758 aurelien 391
	if(!!this.ligneRue) {
392
		this.ligneRue.setMap(null);
393
	}
2744 aurelien 394
	var img = '<img src="'+this.chargementImageIconeUrl+'" />';
395
	$('#indication-nom-rue-nom').html(img+" Recherche de la rue en cours");
396
	$('#indication-nom-rue').css('visibility','visible');
397
	$('#indication-nom-rue').effect("highlight", {}, 500);
398
	$(".navigation-rue").toggle(false);
399
}
400
 
401
WidgetSaisieSauvages.prototype.rechercherRue = function() {
402
	this.afficherChargementRechercheRue();
403
 
404
	var params = "latitude_debut="+this.markerDeb.getPosition().lat()+"&longitude_debut="+this.markerDeb.getPosition().lng()+
405
	"&latitude_fin="+this.markerFin.getPosition().lat()+"&longitude_fin="+this.markerFin.getPosition().lng();
406
	var lthis = this;
407
 
2748 aurelien 408
	this.requeteRechercheRue = $.getJSON(this.serviceTraceRueUrl+'?'+params, function(data) {
2744 aurelien 409
		$('#indication-nom-rue-nom').html("");
410
		lthis.listeRues = data.elements;
411
		var coordDeb = {"lat" : lthis.markerDeb.getPosition().lat(), "lon" : lthis.markerDeb.getPosition().lng()};
412
		var coordFin = {"lat" : lthis.markerFin.getPosition().lat(), "lon" : lthis.markerFin.getPosition().lng()};
2748 aurelien 413
		var tags = {"name" : lthis.aucuneRueSelectionnee};
2744 aurelien 414
		var pasDeRue = {"geometry" : [coordDeb, coordFin], "tags" : tags};
415
		lthis.listeRues.push(pasDeRue);
416
		lthis.indexRueSelectionnee = 0;
417
		lthis.mettreRueEnValeur(lthis.listeRues[0]);
418
	});
419
}
420
 
2748 aurelien 421
WidgetSaisieSauvages.prototype.annulerRechercherRue = function() {
422
	if(this.requeteRechercheRue != null) {
423
		this.requeteRechercheRue.abort();
424
		this.requeteRechercheRue = null;
425
		$('#indication-nom-rue').css('visibility','hidden');
426
	}
427
}
428
 
429
 
2744 aurelien 430
WidgetSaisieSauvages.prototype.mettreRueEnValeur = function(rue) {
431
	this.afficherIndicationRue(rue['tags']['name']);
432
	this.afficherTraceRue(rue['geometry']);
2697 mathias 433
	this.afficherEtapeGeolocalisation(4);
2744 aurelien 434
}
435
 
436
WidgetSaisieSauvages.prototype.afficherIndicationRue = function(indication) {
2748 aurelien 437
	indication = !!indication ? indication : this.nomDeRueInconnue;
2744 aurelien 438
	$('#indication-nom-rue-nom').html(indication);
439
	$('#indication-nom-rue').css('visibility','visible');
440
	$('#indication-nom-rue').effect("highlight", {}, 500);
441
	$(".navigation-rue").toggle(this.listeRues.length > 1);
442
}
443
 
444
WidgetSaisieSauvages.prototype.afficherTraceRue = function(rue) {
445
 
446
	if (this.ligneRue != undefined) {
447
		this.ligneRue.setMap(null);
448
	}
449
 
450
	var cheminRue = new Array();
451
	if(rue.length > 0) {
452
		$.each(rue, function(index, value) {
453
			cheminRue.push(new google.maps.LatLng(value['lat'], value['lon']));
454
		});
455
 
456
		this.ligneRue = new google.maps.Polyline({
457
			path: cheminRue,
458
			strokeColor: "#FF0000",
459
			strokeOpacity: 1.0,
460
			strokeWeight: 2
461
		});
462
 
463
		this.ligneRue.setMap(this.map);
464
	}
2701 mathias 465
};
1922 jpm 466
 
2697 mathias 467
WidgetSaisieSauvages.prototype.dessinerLigneRue = function(pointDebut, pointFin) {
468
	if (this.ligneRue != undefined) {
469
		this.ligneRue.setMap(null);
1346 aurelien 470
	}
2408 jpm 471
 
2697 mathias 472
	this.ligneRue = new google.maps.Polyline({
1922 jpm 473
		path: [pointDebut, pointFin],
474
		strokeColor: "#FF0000",
475
		strokeOpacity: 1.0,
476
		strokeWeight: 2
477
	});
1346 aurelien 478
 
2697 mathias 479
	this.ligneRue.setMap(this.map);
2701 mathias 480
};
1346 aurelien 481
 
2697 mathias 482
WidgetSaisieSauvages.prototype.afficherCentreRue = function() {
483
	this.latLngDeb = this.markerDeb.getPosition();
484
	this.latLngFin = this.markerFin.getPosition();
485
	this.latLngCentre = new google.maps.LatLng((this.latLngFin.lat() + this.latLngDeb.lat())/2, (this.latLngFin.lng() + this.latLngDeb.lng())/2);
2708 mathias 486
	this.mettreAJourMarkerPosition(this.latLngCentre);
2701 mathias 487
};
1922 jpm 488
 
2697 mathias 489
WidgetSaisieSauvages.prototype.afficherEtapeGeolocalisation = function(numEtape) {
1922 jpm 490
	$('.liste_indication_geolocalisation').children().hide();
491
	$('.liste_indication_geolocalisation :nth-child('+numEtape+')').show();
2701 mathias 492
};
1922 jpm 493
 
2697 mathias 494
// surcharge
495
WidgetSaisieSauvages.prototype.geolocaliser = function(event) {
1922 jpm 496
	var latitude = $('#latitude').val(),
497
		longitude = $('#longitude').val(),
498
		nouvellePosition = new google.maps.LatLng(latitude, longitude);
2697 mathias 499
	this.initialiserMarkerDeb();
500
	this.deplacerMarkerDeb(nouvellePosition);
501
	this.afficherEtapeGeolocalisation(2);
502
	this.map.setZoom(16);
1922 jpm 503
	arreter(event);
2701 mathias 504
};
1922 jpm 505
 
2697 mathias 506
WidgetSaisieSauvages.prototype.tenterGeolocalisation = function() {
2715 mathias 507
	var lthis = this;
1922 jpm 508
	if (navigator.geolocation) {
509
		navigator.geolocation.getCurrentPosition(function(position) {
510
			var latitude = position.coords.latitude,
511
				longitude = position.coords.longitude,
512
				nouvellePosition = new google.maps.LatLng(latitude, longitude);
2715 mathias 513
			lthis.initialiserMarkerDeb();
514
			lthis.deplacerMarkerDeb(nouvellePosition);
515
			lthis.map.setZoom(16);
1922 jpm 516
		});
2758 aurelien 517
	} else {
518
		lthis.initialiserMarkerDeb();
1922 jpm 519
	}
2701 mathias 520
};
1922 jpm 521
 
2697 mathias 522
/**
523
 * AUTO-COMPLÉTION Noms Scientifiques => OK
524
 * sélectionne un nom et puis qu'on le remplacer par un nom non valide
525
 * Garder la trace de la valeur permet de vider le nn lorsqu'on
526
 */
527
WidgetSaisieSauvages.prototype.ajouterAutocompletionNoms = function() {
528
	var lthis = this;
1922 jpm 529
	$('#taxon').autocomplete({
2408 jpm 530
		source: function(requete, add){
1922 jpm 531
			// la variable de requête doit être vidée car sinon le parametre "term" est ajouté
2408 jpm 532
 
2697 mathias 533
			var url = lthis.getUrlAutocompletionNomsSci();
1922 jpm 534
			$.getJSON(url, function(data) {
2697 mathias 535
				var suggestions = lthis.traiterRetourNomsSci(data);
2408 jpm 536
				add(suggestions);
1922 jpm 537
			});
538
		},
539
		html: true
540
	});
2408 jpm 541
 
1922 jpm 542
	$('#taxon').bind('autocompleteselect', function(event, ui) {
543
		$('#taxon').data(ui.item);
2697 mathias 544
		lthis.valeurChamp = $('#taxon').val();
1922 jpm 545
		if (ui.item.retenu == true) {
546
			$('#taxon').addClass('ns-retenu');
547
		} else {
548
			$('#taxon').removeClass('ns-retenu');
549
		}
550
	});
2529 aurelien 551
 
552
	$('#taxon').bind('keypress', function() {
2697 mathias 553
		if(lthis.valeurChamp != $('#taxon').val()) {
2529 aurelien 554
			$('#taxon').data('numNomSel', '');
555
		}
2697 mathias 556
		lthis.valeurChamp = $('#taxon').val();
2529 aurelien 557
	});
2701 mathias 558
};
1922 jpm 559
 
2697 mathias 560
WidgetSaisieSauvages.prototype.getUrlAutocompletionNomsSci = function() {
1922 jpm 561
	var mots = $('#taxon').val(),
2700 mathias 562
		url = this.serviceAutocompletionNomSciUrlTpl.replace('{referentiel}', this.nomSciReferentiel);
1922 jpm 563
	url = url.replace('{masque}', mots);
564
	return url;
2701 mathias 565
};
1922 jpm 566
 
2697 mathias 567
WidgetSaisieSauvages.prototype.traiterRetourNomsSci = function(data) {
1922 jpm 568
	var suggestions = [];
569
	if (data.resultat != undefined) {
570
		$.each(data.resultat, function(i, val) {
571
			val.nn = i;
572
			var nom = {label: '', value: '', nt: '', nomSel: '', nomSelComplet: '', numNomSel: '',
573
				nomRet: '', numNomRet: '', famille: '', retenu: false
574
			};
2700 mathias 575
			if (suggestions.length >= this.autocompletionElementsNbre) {
1922 jpm 576
				nom.label = '...';
577
				nom.value = $('#taxon').val();
578
				suggestions.push(nom);
579
				return false;
580
			} else {
581
				nom.label = val.nom_sci_complet;
582
				nom.value = val.nom_sci_complet;
583
				nom.nt = val.num_taxonomique;
584
				nom.nomSel = val.nom_sci;
585
				nom.nomSelComplet = val.nom_sci_complet;
586
				nom.numNomSel = val.nn;
587
				nom.nomRet = val.nom_retenu_complet;
588
				nom.numNomRet = val['nom_retenu.id'];
589
				nom.famille = val.famille;
590
				nom.retenu = (val.retenu == 'false') ? false : true;
2408 jpm 591
 
1922 jpm 592
				suggestions.push(nom);
593
			}
594
		});
595
	}
596
	return suggestions;
2701 mathias 597
};
1922 jpm 598
 
2697 mathias 599
// surcharge
600
WidgetSaisieSauvages.prototype.configurerFormValidator = function() {
1916 jpm 601
	$.validator.addMethod(
2408 jpm 602
		'dateCel',
603
		function (value, element) {
604
			return value == '' || (/^[0-9]{2}[-\/][0-9]{2}[-\/][0-9]{4}$/.test(value));
605
		},
1916 jpm 606
		'Format : jj/mm/aaaa. Date incomplète, utiliser 0, exemple : 00/12/2011.');
2408 jpm 607
 
1916 jpm 608
	$.extend($.validator.defaults, {
609
		ignore: [],// Forcer Jquery Validate à examiner les éléments avec en display:none;
610
		highlight: function(element) {
611
			$(element).closest('.control-group').removeClass('success').addClass('error');
612
		},
613
		success: function(element) {
614
			element.text('OK!').addClass('valid');
615
			element.closest('.control-group').removeClass('error').addClass('success');
2408 jpm 616
 
1916 jpm 617
			if (element.attr('id') == 'taxon' && $('#taxon').val() != '') {
618
				// Si le taxon n'est pas lié au référentiel, on vide le data associé
619
				if ($('#taxon').data('value') != $('#taxon').val()) {
620
					$('#taxon').data('numNomSel', '');
621
					$('#taxon').data('nomRet', '');
622
					$('#taxon').data('numNomRet', '');
623
					$('#taxon').data('nt', '');
624
					$('#taxon').data('famille', '');
625
				}
626
			}
627
		}
628
	});
2701 mathias 629
};
1916 jpm 630
 
2697 mathias 631
// surcharge
632
WidgetSaisieSauvages.prototype.definirReglesFormValidator = function() {
1916 jpm 633
	$('#form-observateur').validate({
634
		rules: {
635
			courriel: {
636
				required: true,
637
				email: true},
638
			courriel_confirmation: {
639
				required: true,
640
				equalTo: '#courriel'},
641
			prenom: {
642
				required: true},
643
			nom: {
644
				required: true}
645
		}
646
	});
647
	$('#form-obs').validate({
648
		rules: {
649
			station: {
650
				required: true},
651
			latitude : {
652
				required: true,
653
				range: [-90, 90]},
654
			longitude: {
655
				required: true,
656
				range: [-180, 180]},
657
			date: {
658
				required: true,
659
				'dateCel' : true},
1956 jpm 660
			coteRue: {
1916 jpm 661
				required: true},
662
			'taxon-liste': {
663
				required: true},
664
			'milieux[]': {
665
				required: true,
666
				minlength: 1}
667
		},
668
		errorPlacement: function(error, element) {
669
			if (element.attr('name') == 'date') {
670
				element.parent('.input-prepend').after(error);
671
			} else if (element.attr('name') == 'milieux[]') {
672
				error.insertAfter('#milieux-controls');
673
			} else {
674
				error.insertAfter(element);
675
			}
676
		},
677
		messages: {
678
			'milieu[]': 'Vous devez sélectionner au moins un milieu'
679
		}
680
	});
2701 mathias 681
};
1916 jpm 682
 
2697 mathias 683
WidgetSaisieSauvages.prototype.validerFormulaire = function() {
1946 jpm 684
	var observateur = $('#form-observateur').valid(),
685
		obs = $('#form-obs').valid(),
2697 mathias 686
		debRue = (this.latLngDeb == undefined || this.latLngDeb == this.latLngFin) ? false : true,
687
		finRue = (this.latLngFin == undefined || this.latLngDeb == this.latLngFin) ? false : true;
1946 jpm 688
	var ok = (observateur && obs && debRue && finRue) ? true : false;
1964 jpm 689
	//console.log('observateur:'+observateur+'-obs:'+obs+'-debRue:'+debRue+'('+latLngDeb+')-finRue:'+finRue+'('+latLngDeb+')');
1946 jpm 690
	return ok;
2701 mathias 691
};
1946 jpm 692
 
2697 mathias 693
WidgetSaisieSauvages.prototype.surChangementTaxonListe = function() {
1916 jpm 694
	if ($('#taxon-liste').val() === '?') {
695
		$('#taxon-input-groupe').removeClass('hidden');
696
	} else {
697
		$('#taxon-input-groupe').addClass('hidden');
698
	}
2701 mathias 699
};
1916 jpm 700
 
2697 mathias 701
WidgetSaisieSauvages.prototype.surChangementValeurTaxon = function() {
2529 aurelien 702
	var nomHorsListe = $('#taxon-liste').val() == '?' ? true : false;
2697 mathias 703
	var nomSpecial = $('#taxon-liste option:selected').hasClass('nom-special');
704
	var numNomSel = nomHorsListe ? $('#taxon').data('numNomSel') : $('#taxon-liste').val();
2529 aurelien 705
 
706
	// Un nom non valide entraine automatiquement une certitude "à déterminer"
707
	if(nomSpecial || !numNomSel) {
708
		$('#certitude-adeterminer').attr('checked', 'checked');
709
	} else {
710
		$('#certitude-adeterminer').removeAttr('checked');
711
	}
2701 mathias 712
};
2529 aurelien 713
 
2697 mathias 714
// surcharge
715
WidgetSaisieSauvages.prototype.ajouterObs = function() {
716
	if (this.validerFormulaire() == true) {
717
		this.obsNbre = this.obsNbre + 1;
718
		$('.obs-nbre').text(this.obsNbre);
1922 jpm 719
		$('.obs-nbre').triggerHandler('changement');
2697 mathias 720
		this.afficherObs();
721
		this.stockerObsData();
722
		this.supprimerMiniatures();
1922 jpm 723
	} else {
1956 jpm 724
		// Affichage de tous les panneau cachés avec champ obligatoire
2697 mathias 725
		var debRue = (this.latLngDeb == undefined || this.latLngDeb == this.latLngFin) ? false : true,
726
			finRue = (this.latLngFin == undefined || this.latLngDeb == this.latLngFin) ? false : true;
1922 jpm 727
		if (debRue == false || finRue == false) {
2700 mathias 728
			this.afficherPanneau('#dialogue-form-invalide-rue');
1922 jpm 729
		} else {
2700 mathias 730
			this.afficherPanneau('#dialogue-form-invalide');
1922 jpm 731
		}
2697 mathias 732
		this.montrerFormIdentite();
1922 jpm 733
	}
2697 mathias 734
};
1922 jpm 735
 
2697 mathias 736
// surcharge
737
WidgetSaisieSauvages.prototype.afficherObs = function() {
1922 jpm 738
	var numNomSel = ($('#taxon-liste').val() == '?') ? $('#taxon').data('numNomSel') : $('#taxon-liste').val(),
739
		nomSpecial = $('#taxon-liste option:selected').hasClass('nom-special'),
740
		taxon = ($('#taxon-liste').val() == '?') ? $('#taxon').val() : $('#taxon-liste option:selected').data('nom-a-sauver'),
2700 mathias 741
		referentiel = (numNomSel == undefined) ? '' : '['+ this.nomSciReferentiel +']',
1922 jpm 742
		commune = $('#commune-nom').text(),
743
		codeInsee = $('#commune-code-insee').text(),
2748 aurelien 744
		station = this.getValeurStation(),
1922 jpm 745
		lat = $('input[name="latitude"]').val(),
746
		lng = $('input[name="longitude"]').val(),
747
		date = $('#date').val(),
2697 mathias 748
		milieux = this.getMilieux(),
749
		notes = (nomSpecial ? this.taxons[numNomSel]['nom_fr'] + ".<br />" : '') + $('#notes').val();
2408 jpm 750
 
1922 jpm 751
	$('#liste-obs').prepend(
2697 mathias 752
		'<div id="obs'+this.obsNbre+'" class="row-fluid obs obs'+this.obsNbre+'">' +
1946 jpm 753
			'<div class="span12">' +
754
				'<div class="well">' +
755
					'<div class="obs-action pull-right has-tooltip" data-placement="bottom" ' +
756
						'title="Supprimer cette observation de la liste à transmettre">' +
2697 mathias 757
						'<button class="btn btn-danger supprimer-obs" value="'+this.obsNbre+'" title="'+this.obsNbre+'">' +
1946 jpm 758
							'<i class="icon-trash icon-white"></i>' +
759
						'</button>' +
2408 jpm 760
					'</div> ' +
761
					'<div class="row-fluid">' +
1946 jpm 762
						'<div class="span2 obs-miniatures">' +
2697 mathias 763
						this.ajouterImgMiniatureAuTransfert() +
1922 jpm 764
						'</div>'+
1946 jpm 765
						'<div class="span7">' +
766
							'<ul class="unstyled">' +
1922 jpm 767
								'<li>'+
768
									'<span class="nom-sci">' + taxon + '</span> ' +
2697 mathias 769
									this.formaterNumNomSel(numNomSel) +
1946 jpm 770
									' observé à <br />' +
1993 jpm 771
									'<span class="commune">' + commune + '</span> ' +
772
									'(' + codeInsee + '), ' +
1946 jpm 773
									'<span class="station">' + station + '</span><br /> ' +
1922 jpm 774
									' le ' +
775
									'<span class="date">' + date + '</span>' +
776
								'</li>' +
777
								'<li>' +
1946 jpm 778
									'Milieux : ' + milieux + ' ' + ' ; ' +
1922 jpm 779
								'</li>' +
780
								'<li>' +
2408 jpm 781
									'Notes : ' + notes +
1946 jpm 782
								'</li>' +
783
							'</ul>' +
784
						'</div>' +
785
					'</div>' +
786
				'</div>' +
1922 jpm 787
			'</div>'+
788
		'</div>');
2697 mathias 789
	$('#zone-liste-obs').removeClass("hidden");
790
};
1922 jpm 791
 
2748 aurelien 792
WidgetSaisieSauvages.prototype.getValeurStation = function() {
793
	var station = "";
794
	var valeurSelectionnee = $("#indication-nom-rue-nom").text().trim();
795
	if(valeurSelectionnee == this.aucuneRueSelectionnee || valeurSelectionnee == this.nomDeRueInconnue) {
796
		station = $('input[name="adresse"]').val().trim()
797
	} else {
798
		station = $("#indication-nom-rue-nom").text().trim();
799
	}
800
 
801
	return station;
802
}
803
 
2697 mathias 804
WidgetSaisieSauvages.prototype.getMilieux = function() {
1922 jpm 805
	var milieuxStr = '',
806
		milieux = [];
807
	$('.cb-milieux:checked').each(function() {
808
		milieux.push($(this).val());
809
	});
2408 jpm 810
 
1922 jpm 811
	milieuxStr = Array.prototype.slice.call(milieux).join(', ');
812
	return milieuxStr;
2697 mathias 813
};
1922 jpm 814
 
2697 mathias 815
WidgetSaisieSauvages.prototype.ajouterImgMiniatureAuTransfert = function() {
1922 jpm 816
	var html = '',
817
		miniatures = '',
818
		indicateurs = '',
819
		premiere = true,
820
		numero = 1;
821
	if ($('#miniatures img').length == 0) {
2700 mathias 822
		html = '<img class="miniature" alt="Aucune photo"src="'+ this.pasDePhotoIconeUrl +'" />';
1922 jpm 823
	} else if ($('#miniatures img').length >= 1) {
824
		$('#miniatures img').each(function() {
825
			var visible = premiere ? 'miniature-selectionnee' : 'miniature-cachee',
826
				css = $(this).hasClass('b64') ? 'miniature b64' : 'miniature',
827
				src = $(this).attr('src'),
828
				alt = $(this).attr('alt');
2408 jpm 829
 
1922 jpm 830
			var miniature = '<img class="'+css+' '+visible+'"  alt="'+alt+'"src="'+src+'" />';
831
			miniatures += miniature;
2408 jpm 832
 
1922 jpm 833
			var indicateurActif = premiere ? 'active' : '';
834
			var indicateur = '<li class="' + indicateurActif + '" data-numero="' + numero++ + '"></li>';
835
			indicateurs += indicateur;
2408 jpm 836
 
1922 jpm 837
			premiere = false;
838
		});
2408 jpm 839
 
1922 jpm 840
		if ($('#miniatures img').length == 1) {
841
			html = miniatures;
842
		} else {
2408 jpm 843
			html =
1922 jpm 844
				'<div class="defilement">' +
845
					miniatures +
846
					'<a class="defilement-control-zone gauche">' +
847
					'	<span class="defilement-control gauche hidden">&#60;</span>' +
848
					'</a>' +
849
					'<a class="defilement-control-zone droite">' +
850
					'	<span class="defilement-control droite hidden">&#62;</span>' +
851
					'</a>' +
852
					'<ol class="defilement-indicateurs">' + indicateurs + '</ol>' +
853
				'</div>';
854
		}
855
	}
856
	return html;
2697 mathias 857
};
1922 jpm 858
 
2697 mathias 859
WidgetSaisieSauvages.prototype.defilerMiniatures = function(element) {
1922 jpm 860
	var miniatureSelectionne = element.siblings('img.miniature-selectionnee');
861
	miniatureSelectionne.removeClass('miniature-selectionnee').addClass('miniature-cachee');
862
	var miniatureAffichee = miniatureSelectionne;
2408 jpm 863
 
1922 jpm 864
	var indicateurActif = element.parent().find('.defilement-indicateurs .active');
865
	indicateurActif.removeClass('active');
2408 jpm 866
 
1922 jpm 867
	if (element.hasClass('defilement-control-zone') && element.hasClass('gauche')) {
868
		if (miniatureSelectionne.prev('.miniature').length != 0) {
869
			miniatureAffichee = miniatureSelectionne.prev('.miniature');
870
			indicateurActif.prev().addClass('active');
871
		} else {
872
			miniatureAffichee = miniatureSelectionne.siblings('.miniature').last();
873
			indicateurActif.siblings().last().addClass('active');
874
		}
875
	} else {
876
		if (miniatureSelectionne.next('.miniature').length != 0) {
877
			miniatureAffichee = miniatureSelectionne.next('.miniature');
878
			indicateurActif.next().addClass('active');
879
		} else {
880
			miniatureAffichee = miniatureSelectionne.siblings('.miniature').first();
881
			indicateurActif.siblings().first().addClass('active');
882
		}
883
	}
884
	miniatureAffichee.addClass('miniature-selectionnee').removeClass('miniature-cachee');
2701 mathias 885
};
1922 jpm 886
 
2697 mathias 887
WidgetSaisieSauvages.prototype.formaterNumNomSel = function(numNomSel) {
1922 jpm 888
	var nn = '';
889
	if (numNomSel == undefined) {
890
		nn = '<span class="alert-error">[non lié au référentiel]</span>';
891
	} else {
892
		nn = '<span class="nn">[nn'+numNomSel+']</span>';
893
	}
894
	return nn;
2701 mathias 895
};
1922 jpm 896
 
2697 mathias 897
// surcharge
898
WidgetSaisieSauvages.prototype.surChangementReferentiel = function() {
2700 mathias 899
	this.nomSciReferentiel = $('#referentiel').val();
1922 jpm 900
	$('#taxon').val('');
2701 mathias 901
};
1922 jpm 902
 
2697 mathias 903
// surcharge
904
WidgetSaisieSauvages.prototype.stockerObsData = function() {
905
	var lthis = this;
1922 jpm 906
	var nomHorsListe = $('#taxon-liste').val() == '?' ? true : false;
907
		nomSpecial = $('#taxon-liste option:selected').hasClass('nom-special'),
2709 mathias 908
		numNomSel = nomHorsListe ? $('#taxon').data('numNomSel') : $('#taxon-liste').val();
909
	var nomSel = nomHorsListe ? $('#taxon').val() : $('#taxon-liste option:selected').data('nom-a-sauver'),
2708 mathias 910
		nomRet = nomHorsListe ? $('#taxon').data('nomRet') : this.taxons[numNomSel]['nom_ret'],
911
		numNomRet = nomHorsListe ? $('#taxon').data('numNomRet') : this.taxons[numNomSel]['num_nom_ret'],
912
		numTaxon = nomHorsListe ? $('#taxon').data('nt') : this.taxons[numNomSel]['num_taxon'],
913
		famille = nomHorsListe ? $('#taxon').data('famille') : this.taxons[numNomSel]['famille'],
2700 mathias 914
		referentiel = (numNomSel == undefined) ? '' : this.nomSciReferentiel,
2708 mathias 915
		notes = (nomSpecial ? this.taxons[numNomSel]['nom_fr'] + '. ' : '') + $('#notes').val();
2521 aurelien 916
 
917
		certitude = $('input[name=certitude]:checked').val();
918
		certitude = (certitude == undefined) ? '' : certitude;
2408 jpm 919
 
2697 mathias 920
	$('#liste-obs').data('obsId'+this.obsNbre, {
2408 jpm 921
		'date': $('#date').val(),
1922 jpm 922
		'notes': notes,
2408 jpm 923
 
2748 aurelien 924
		'station': this.getValeurStation(),
1922 jpm 925
		'latitude': $('#latitude').val(),
926
		'longitude': $('#longitude').val(),
927
		'commune_nom': $('#commune-nom').text(),
928
		'commune_code_insee': $('#commune-code-insee').text(),
2408 jpm 929
 
1922 jpm 930
		'nom_sel': nomSel,
931
		'num_nom_sel': numNomSel,
932
		'nom_ret': nomRet,
933
		'num_nom_ret': numNomRet,
934
		'num_taxon': numTaxon,
935
		'famille': famille,
936
		'referentiel': referentiel,
2521 aurelien 937
		'certitude': certitude,
2697 mathias 938
		'milieu': lthis.getMilieux(),
2408 jpm 939
 
1922 jpm 940
		// Ajout des champs images
2697 mathias 941
		'image_nom': lthis.getNomsImgsOriginales(),
2408 jpm 942
 
1922 jpm 943
		// Ajout des champs étendus de l'obs
2697 mathias 944
		'obs_etendue': lthis.getObsChpEtendus()
1922 jpm 945
	});
2700 mathias 946
	if (this.debug) {
2697 mathias 947
		console.log($('#liste-obs').data('obsId'+this.obsNbre));
1964 jpm 948
	}
2701 mathias 949
};
1922 jpm 950
 
2697 mathias 951
WidgetSaisieSauvages.prototype.getObsChpEtendus = function() {
1946 jpm 952
	var champs = [];
2697 mathias 953
	if (this.latLngDeb != undefined) {
954
		var latitudeDebutRue = {cle: 'latitudeDebutRue', label: 'Latitude du début de la rue', valeur: this.latLngDeb.lat().toFixed(5)};
1922 jpm 955
		champs.push(latitudeDebutRue);
2697 mathias 956
		var longitudeDebutRue = {cle: 'longitudeDebutRue', label: 'Longitude du début de la rue', valeur: this.latLngDeb.lng().toFixed(5)};
1922 jpm 957
		champs.push(longitudeDebutRue);
958
	}
2697 mathias 959
	if (this.latLngFin != undefined) {
960
		var latitudeFinRue = {cle: 'latitudeFinRue', label: 'Latitude de fin de la rue', valeur: this.latLngFin.lat().toFixed(5)};
1922 jpm 961
		champs.push(latitudeFinRue);
2697 mathias 962
		var longitudeFinRue = {cle: 'longitudeFinRue', label: 'Longitude de fin de la rue', valeur: this.latLngFin.lng().toFixed(5)};
1922 jpm 963
		champs.push(longitudeFinRue);
964
	}
2408 jpm 965
 
1922 jpm 966
	$('.obs-chp-etendu').each(function() {
967
		var valeur = $(this).val(),
968
			cle = $(this).attr('name'),
969
			label = $(this).data('label');
970
		if (valeur != '') {
971
			var chpEtendu = {cle: cle, label: label, valeur: valeur};
972
			champs.push(chpEtendu);
973
		}
974
	});
975
	return champs;
2892 aurel 976
};