Subversion Repositories eFlore/Applications.cel

Rev

Rev 2710 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2710 Rev 2841
1
// Héritage
1
// Héritage
2
function WidgetSaisieMissionsFlore() {
2
function WidgetSaisieMissionsFlore() {
3
	this.serviceAltitudeUrl = null;
3
	this.serviceAltitudeUrl = null;
4
}
4
}
5
WidgetSaisieMissionsFlore.prototype = new WidgetSaisie();
5
WidgetSaisieMissionsFlore.prototype = new WidgetSaisie();
6
 
6
 
7
 
7
 
8
WidgetSaisieMissionsFlore.prototype.initForm = function() {
8
WidgetSaisieMissionsFlore.prototype.initForm = function() {
9
	// super()
9
	// super()
10
	WidgetSaisie.prototype.initForm.call(this);
10
	WidgetSaisie.prototype.initForm.call(this);
11
 
11
 
12
	this.surChangementAbondance();// Vérif lors du chargement de la page
12
	this.surChangementAbondance();// Vérif lors du chargement de la page
13
	$('#abondance').on('change', this.surChangementAbondance.bind(this));
13
	$('#abondance').on('change', this.surChangementAbondance.bind(this));
14
};
14
};
15
 
15
 
16
WidgetSaisieMissionsFlore.prototype.initEvts = function() {
16
WidgetSaisieMissionsFlore.prototype.initEvts = function() {
17
	// super()
17
	// super()
18
	WidgetSaisie.prototype.initEvts.call(this);
18
	WidgetSaisie.prototype.initEvts.call(this);
19
 
19
 
20
	var lthis = this;
20
	var lthis = this;
21
	$('body').on('click', '.fermer', function(event) {
21
	$('body').on('click', '.fermer', function(event) {
22
			event.preventDefault();
22
			event.preventDefault();
23
			lthis.basculerOuvertureFermetureCadre($(this).find('.icone'));
23
			lthis.basculerOuvertureFermetureCadre($(this).find('.icone'));
24
	});
24
	});
25
	$('.btn-coord ').on('click', this.basculerAffichageCoord);
25
	$('.btn-coord ').on('click', this.basculerAffichageCoord);
26
 
26
 
27
	this.surChangementNbreObs();
27
	this.surChangementNbreObs();
28
};
28
};
29
 
29
 
30
WidgetSaisieMissionsFlore.prototype.mettreAJourMarkerPosition = function(latLng) {
30
WidgetSaisieMissionsFlore.prototype.mettreAJourMarkerPosition = function(latLng) {
31
	this.trouverCommune(latLng);
31
	this.trouverCommune(latLng);
32
	this.trouverAltitude(latLng);
32
	this.trouverAltitude(latLng);
33
 
33
 
34
	var lat = latLng.lat().toFixed(5),
34
	var lat = latLng.lat().toFixed(5),
35
		lng = latLng.lng().toFixed(5);
35
		lng = latLng.lng().toFixed(5);
36
	this.remplirChampLatitude(lat);
36
	this.remplirChampLatitude(lat);
37
	this.remplirChampLongitude(lng);
37
	this.remplirChampLongitude(lng);
38
	this.remplirChampsLambert93(lat, lng);
38
	this.remplirChampsLambert93(lat, lng);
39
};
39
};
40
 
40
 
41
proj4.defs([
41
proj4.defs([
42
	['EPSG:4326', '+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs'],
42
	['EPSG:4326', '+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs'],
43
	['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']
43
	['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']
44
]);
44
]);
45
WidgetSaisieMissionsFlore.prototype.remplirChampsLambert93 = function(lat, lng) {
45
WidgetSaisieMissionsFlore.prototype.remplirChampsLambert93 = function(lat, lng) {
46
	// Prendre en compte l'initialisation des projections
46
	// Prendre en compte l'initialisation des projections
47
	var coordinate = {x: lng,y: lat};
47
	var coordinate = {x: lng,y: lat};
48
	proj4(proj4.defs('EPSG:4326'), proj4.defs('EPSG:2154')).forward(coordinate);
48
	proj4(proj4.defs('EPSG:4326'), proj4.defs('EPSG:2154')).forward(coordinate);
49
	$('#l93-x').val(coordinate.x.toFixed(0));
49
	$('#l93-x').val(coordinate.x.toFixed(0));
50
	$('#l93-y').val(coordinate.y.toFixed(0));
50
	$('#l93-y').val(coordinate.y.toFixed(0));
51
};
51
};
52
 
52
 
53
WidgetSaisieMissionsFlore.prototype.trouverAltitude = function(pos) {
53
WidgetSaisieMissionsFlore.prototype.trouverAltitude = function(pos) {
54
	var lthis = this;
54
	var lthis = this;
55
	var url_service = this.serviceAltitudeUrl,
55
	var url_service = this.serviceAltitudeUrl,
56
		urlAltFormatee = url_service.replace('{lat}', pos.lat()).replace('{lon}', pos.lng());
56
		urlAltFormatee = url_service.replace('{lat}', pos.lat()).replace('{lon}', pos.lng());
57
	$.ajax({
57
	$.ajax({
58
		url: urlAltFormatee,
58
		url: urlAltFormatee,
59
		type: 'GET',
59
		type: 'GET',
60
		dataType: 'jsonp',
60
		dataType: 'jsonp',
61
		beforeSend : function() {
61
		beforeSend : function() {
62
			$('#altitude').empty();
62
			$('#altitude').empty();
63
			$('#dialogue-erreur .alert-txt').empty();
63
			$('#dialogue-erreur .alert-txt').empty();
64
		},
64
		},
65
		success : function(data, textStatus, jqXHR) {
65
		success : function(data, textStatus, jqXHR) {
66
			$('#altitude').empty().append(data.altitude);
66
			$('#altitude').empty().append(data.altitude);
67
			$('#marqueur-altitude').data('altitude', data.altitude);
67
			$('#marqueur-altitude').data('altitude', data.altitude);
68
		},
68
		},
69
		statusCode : {
69
		statusCode : {
70
		    500 : function(jqXHR, textStatus, errorThrown) {
70
		    500 : function(jqXHR, textStatus, errorThrown) {
71
				if (lthis.debug) {
71
				if (lthis.debug) {
72
					$('#dialogue-erreur .alert-txt').append('<p id="msg">Un problème est survenu lors de l\'appel au service fournissant l\'altitude.</p>');
72
					$('#dialogue-erreur .alert-txt').append('<p id="msg">Un problème est survenu lors de l\'appel au service fournissant l\'altitude.</p>');
73
					reponse = jQuery.parseJSON(jqXHR.responseText);
73
					reponse = jQuery.parseJSON(jqXHR.responseText);
74
					var erreurMsg = '';
74
					var erreurMsg = '';
75
					if (reponse != null) {
75
					if (reponse != null) {
76
						$.each(reponse, function (cle, valeur) {
76
						$.each(reponse, function (cle, valeur) {
77
							erreurMsg += valeur + '<br />';
77
							erreurMsg += valeur + '<br />';
78
						});
78
						});
79
					}
79
					}
80
 
80
 
81
					$('#dialogue-erreur .alert-txt').append('<p class="msg-erreur">Erreur 500 : '+errorThrown+"<br />"+erreurMsg+'</p>');
81
					$('#dialogue-erreur .alert-txt').append('<p class="msg-erreur">Erreur 500 : '+errorThrown+"<br />"+erreurMsg+'</p>');
82
				}
82
				}
83
		    }
83
		    }
84
		},
84
		},
85
		error : function(jqXHR, textStatus, errorThrown) {
85
		error : function(jqXHR, textStatus, errorThrown) {
86
			if (lthis.debug) {
86
			if (lthis.debug) {
87
				$("#dialogue-erreur .alert-txt").append('<p class="msg">Une erreur Ajax est survenue lors de l\'appel au service fournissant l\'altitude.</p>');
87
				$("#dialogue-erreur .alert-txt").append('<p class="msg">Une erreur Ajax est survenue lors de l\'appel au service fournissant l\'altitude.</p>');
88
				reponse = jQuery.parseJSON(jqXHR.responseText);
88
				reponse = jQuery.parseJSON(jqXHR.responseText);
89
				var erreurMsg = '';
89
				var erreurMsg = '';
90
				if (reponse != null) {
90
				if (reponse != null) {
91
					$.each(reponse, function (cle, valeur) {
91
					$.each(reponse, function (cle, valeur) {
92
						erreurMsg += valeur + '<br />';
92
						erreurMsg += valeur + '<br />';
93
					});
93
					});
94
				}
94
				}
95
 
95
 
96
				$('#dialogue-erreur .alert-txt').append('<p class="msg-erreur">Erreur Ajax : '+errorThrown+' (type : '+textStatus+') <br />'+erreurMsg+'</p>');
96
				$('#dialogue-erreur .alert-txt').append('<p class="msg-erreur">Erreur Ajax : '+errorThrown+' (type : '+textStatus+') <br />'+erreurMsg+'</p>');
97
			}
97
			}
98
		},
98
		},
99
		complete : function(jqXHR, textStatus) {
99
		complete : function(jqXHR, textStatus) {
100
			var debugMsg = extraireEnteteDebug(jqXHR);
100
			var debugMsg = extraireEnteteDebug(jqXHR);
101
			if (debugMsg != '') {
101
			if (debugMsg != '') {
102
				if (lthis.debug) {
102
				if (lthis.debug) {
103
					$('#dialogue-erreur .alert-txt').append('<pre class="msg-debug msg">Débogage : '+debugMsg+'</pre>');
103
					$('#dialogue-erreur .alert-txt').append('<pre class="msg-debug msg">Débogage : '+debugMsg+'</pre>');
104
				}
104
				}
105
			}
105
			}
106
			if ($('#dialogue-erreur .msg').length > 0) {
106
			if ($('#dialogue-erreur .msg').length > 0) {
107
				$('#dialogue-erreur').show();
107
				$('#dialogue-erreur').show();
108
			}
108
			}
109
		}
109
		}
110
	});
110
	});
111
};
111
};
112
 
112
 
113
WidgetSaisieMissionsFlore.prototype.surChangementAbondance = function() {
113
WidgetSaisieMissionsFlore.prototype.surChangementAbondance = function() {
114
	if (this.afficherIndividusNbreGroupe()) {
114
	if (this.afficherIndividusNbreGroupe()) {
115
		$('#individus-nbre-groupe').removeClass('hidden');
115
		$('#individus-nbre-groupe').removeClass('hidden');
116
		$('#individus-nbre').valid();
116
		$('#individus-nbre').valid();
117
	} else {
117
	} else {
118
		$('#individus-nbre-groupe').addClass('hidden');
118
		$('#individus-nbre-groupe').addClass('hidden');
119
	}
119
	}
120
};
120
};
121
 
121
 
122
WidgetSaisieMissionsFlore.prototype.afficherIndividusNbreGroupe = function() {
122
WidgetSaisieMissionsFlore.prototype.afficherIndividusNbreGroupe = function() {
123
	var abondance = $('#abondance').val();
123
	var abondance = $('#abondance').val();
124
	if (abondance === '1-4 individus' || abondance === '5-9 individus' || abondance === '10-49 individus') {
124
	if (abondance === '1-4 individus' || abondance === '5-9 individus' || abondance === '10-49 individus') {
125
		return true;
125
		return true;
126
	} else {
126
	} else {
127
		return false;
127
		return false;
128
	}
128
	}
129
};
129
};
130
 
130
 
131
WidgetSaisieMissionsFlore.prototype.configurerFormValidator = function() {
131
WidgetSaisieMissionsFlore.prototype.configurerFormValidator = function() {
132
	var lthis = this;
132
	var lthis = this;
133
	$.validator.addMethod(
133
	$.validator.addMethod(
134
		'dateCel',
134
		'dateCel',
135
		function (value, element) {
135
		function (value, element) {
136
			return value === '' || (/^[0-9]{2}[-\/][0-9]{2}[-\/][0-9]{4}$/.test(value));
136
			return value === '' || (/^[0-9]{2}[-\/][0-9]{2}[-\/][0-9]{4}$/.test(value));
137
		},
137
		},
138
		'Format : jj/mm/aaaa. Date incomplète, utiliser 0, exemple : 00/12/2011.');
138
		'Format : jj/mm/aaaa. Date incomplète, utiliser 0, exemple : 00/12/2011.');
139
 
139
 
140
	$.validator.addMethod(
140
	$.validator.addMethod(
141
		'individusNbre',
141
		'individusNbre',
142
		function (value, element) {
142
		function (value, element) {
143
			var ok = true;
143
			var ok = true;
144
			if (lthis.afficherIndividusNbreGroupe()) {
144
			if (lthis.afficherIndividusNbreGroupe()) {
145
				var abondance = $('#abondance').val();
145
				var abondance = $('#abondance').val();
146
				if (abondance === '1-4 individus') {
146
				if (abondance === '1-4 individus') {
147
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 1 && value < 5);
147
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 1 && value < 5);
148
				} else if (abondance == '5-9 individus') {
148
				} else if (abondance == '5-9 individus') {
149
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 5 && value < 10);
149
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 5 && value < 10);
150
				} else if (abondance === '10-49 individus') {
150
				} else if (abondance === '10-49 individus') {
151
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 10 && value < 50);
151
					ok = value === '' || (value !== '' && /^[0-9]+$/.test(value) && value >= 10 && value < 50);
152
				}
152
				}
153
			}
153
			}
154
			return ok;
154
			return ok;
155
		},
155
		},
156
		"Veuillez indiquer le nombre d'individus sous forme d'entier positif et compris dans la classe définie par le champ « Abondance » (Ex. : 3, 15 ou 33...).");
156
		"Veuillez indiquer le nombre d'individus sous forme d'entier positif et compris dans la classe définie par le champ « Abondance » (Ex. : 3, 15 ou 33...).");
157
 
157
 
158
	$.validator.addMethod(
158
	$.validator.addMethod(
159
		'isbn',
159
		'isbn',
160
		function (value, element) {
160
		function (value, element) {
161
			var isbn = value.trim();
161
			var isbn = value.trim();
162
			return (value == '' || (/^ISBN(-1(?:(0)|3))?:?( )*[0-9]+[- ][0-9]+[- ][0-9]+[- ][0-9]*[- ]*[xX0-9]$/).test(isbn));
162
			return (value == '' || (/^ISBN(-1(?:(0)|3))?:?( )*[0-9]+[- ][0-9]+[- ][0-9]+[- ][0-9]*[- ]*[xX0-9]$/).test(isbn));
163
		},
163
		},
164
		'Format : ISBN 10 ou 13 avec chaque partie séparée par un espace ou tiret. <br />'+
164
		'Format : ISBN 10 ou 13 avec chaque partie séparée par un espace ou tiret. <br />'+
165
		'Doit débuter par : "ISBN" ou "ISBN-10" ou "ISBN-13". Suivi par ":" ou ": " ou directement le code ISBN.<br />'+
165
		'Doit débuter par : "ISBN" ou "ISBN-10" ou "ISBN-13". Suivi par ":" ou ": " ou directement le code ISBN.<br />'+
166
		'(Ex. : ISBN:978-3-642-11746-6, ISBN:978 3 642 11746 6, ISBN: 978 3 642 11746 6, ISBN-10: 3 642 11746 6).');
166
		'(Ex. : ISBN:978-3-642-11746-6, ISBN:978 3 642 11746 6, ISBN: 978 3 642 11746 6, ISBN-10: 3 642 11746 6).');
167
 
167
 
168
	// Modification des méthodes par défaut de Jquery Validation pour Boostrap 3
168
	// Modification des méthodes par défaut de Jquery Validation pour Boostrap 3
169
	$.validator.setDefaults({
169
	$.validator.setDefaults({
170
		ignore: [],// Forcer Jquery Validate à examiner les éléments en "display:none;"
170
		ignore: [],// Forcer Jquery Validate à examiner les éléments en "display:none;"
171
		highlight: function(element) {
171
		highlight: function(element) {
172
			$(element).closest('.form-group').addClass('has-error');
172
			$(element).closest('.form-group').addClass('has-error');
173
		},
173
		},
174
		unhighlight: function(element) {
174
		unhighlight: function(element) {
175
			$(element).closest('.form-group').removeClass('has-error');
175
			$(element).closest('.form-group').removeClass('has-error');
176
		},
176
		},
177
		success: function(element) {
177
		success: function(element) {
178
			$(element).closest('.form-group').removeClass('has-error').addClass('has-success');
178
			$(element).closest('.form-group').removeClass('has-error').addClass('has-success');
179
 
179
 
180
			if ($(element).attr('id') == 'taxon' && $('#taxon').val() != '') {
180
			if ($(element).attr('id') == 'taxon' && $('#taxon').val() != '') {
181
				// Si le taxon n'est pas lié au référentiel, on vide le data associé
181
				// Si le taxon n'est pas lié au référentiel, on vide le data associé
182
				if ($('#taxon').data('value') != $('#taxon').val()) {
182
				if ($('#taxon').data('value') != $('#taxon').val()) {
183
					$('#taxon').data('numNomSel', '');
183
					$('#taxon').data('numNomSel', '');
184
					$('#taxon').data('nomRet', '');
184
					$('#taxon').data('nomRet', '');
185
					$('#taxon').data('numNomRet', '');
185
					$('#taxon').data('numNomRet', '');
186
					$('#taxon').data('nt', '');
186
					$('#taxon').data('nt', '');
187
					$('#taxon').data('famille', '');
187
					$('#taxon').data('famille', '');
188
				}
188
				}
189
			}
189
			}
190
		},
190
		},
191
		errorElement: 'span',
191
		errorElement: 'span',
192
		errorClass: 'help-block',
192
		errorClass: 'help-block',
193
		errorPlacement: function(error, element) {
193
		errorPlacement: function(error, element) {
194
			//console.log(element.attr('name') +'-'+ element.parent('.input-group').length);
194
			//console.log(element.attr('name') +'-'+ element.parent('.input-group').length);
195
			if (element.parent('.input-group').length) {
195
			if (element.parent('.input-group').length) {
196
				error.insertAfter(element.parent());
196
				error.insertAfter(element.parent());
197
			} else {
197
			} else {
198
				error.insertAfter(element);
198
				error.insertAfter(element);
199
			}
199
			}
200
		}
200
		}
201
	});
201
	});
202
};
202
};
203
 
203
 
204
WidgetSaisieMissionsFlore.prototype.definirReglesFormValidator = function() {
204
WidgetSaisieMissionsFlore.prototype.definirReglesFormValidator = function() {
205
	$('#form-observateur').validate({
205
	$('#form-observateur').validate({
206
		rules: {
206
		rules: {
207
			courriel : {
207
			courriel : {
208
				required : true,
208
				required : true,
209
				email : true},
209
				email : true},
210
			courriel_confirmation : {
210
			courriel_confirmation : {
211
				required : true,
211
				required : true,
212
				equalTo: '#courriel'}
212
				equalTo: '#courriel'}
213
		}
213
		}
214
	});
214
	});
215
	$('#form-station').validate({
215
	$('#form-station').validate({
216
		rules: {
216
		rules: {
217
			latitude : {
217
			latitude : {
218
				range: [-90, 90],
218
				range: [-90, 90],
219
				required: true},
219
				required: true},
220
			longitude : {
220
			longitude : {
221
				range: [-180, 180],
221
				range: [-180, 180],
222
				required: true},
222
				required: true},
223
			'l93-x': 'required',
223
			'l93-x': 'required',
224
			'l93-y': 'required'
224
			'l93-y': 'required'
225
		}
225
		}
226
	});
226
	});
227
	$('#form-obs-date').validate({
227
	$('#form-obs-date').validate({
228
		rules: {
228
		rules: {
229
			date: {
229
			date: {
230
				required: true,
230
				required: true,
231
				'dateCel' : true}
231
				'dateCel' : true}
232
		}
232
		}
233
	});
233
	});
234
	$('#form-obs').validate({
234
	$('#form-obs').validate({
235
		rules: {
235
		rules: {
236
			individusNombre: {individusNbre: true},
236
			individusNombre: {individusNbre: true},
237
			determinationSource: {isbn: true}
237
			determinationSource: {isbn: true}
238
		}
238
		}
239
	});
239
	});
240
};
240
};
241
 
241
 
242
WidgetSaisieMissionsFlore.prototype.basculerOuvertureFermetureCadre = function(element) {
242
WidgetSaisieMissionsFlore.prototype.basculerOuvertureFermetureCadre = function(element) {
243
	if (element.hasClass('glyphicon-plus-sign')) {
243
	if (element.hasClass('glyphicon-plus-sign')) {
244
		element.removeClass('glyphicon-plus-sign').addClass('glyphicon-minus-sign');
244
		element.removeClass('glyphicon-plus-sign').addClass('glyphicon-minus-sign');
245
	} else {
245
	} else {
246
		element.removeClass('glyphicon-minus-sign').addClass('glyphicon-plus-sign');
246
		element.removeClass('glyphicon-minus-sign').addClass('glyphicon-plus-sign');
247
	}
247
	}
248
};
248
};
-
 
249
 
-
 
250
 
249
 
251
 
-
 
252
WidgetSaisieMissionsFlore.prototype.basculerAffichageCoord = function() {
250
WidgetSaisieMissionsFlore.prototype.basculerAffichageCoord = function() {
253
	var textActuel = $(this).text();
251
	var textActuel = $(this).text(),
254
	var textActuel = $(this).text(),
252
		textARemplacer = $(this).data('toggle-text');
255
		textARemplacer = $(this).data('toggle-text');
253
	$(this).text(textARemplacer).data('toggle-text', textActuel);
256
	$(this).text(textARemplacer).data('toggle-text', textActuel);
-
 
257
 
-
 
258
	
254
 
259
	
255
	if ($(this).hasClass('cacher-coord')) {
260
	if ($(this).hasClass('cacher-coord')) {
256
		$(this).removeClass('cacher-coord').addClass('afficher-coord');
261
		$(this).removeClass('cacher-coord').addClass('afficher-coord');
257
		$('#coordonnees-geo').addClass('hidden');
262
		$('#coordonnees-geo').addClass('hidden');
258
	} else {
263
	} else {
259
		$(this).removeClass('afficher-coord').addClass('cacher-coord');
264
		$(this).removeClass('afficher-coord').addClass('cacher-coord');
260
		$('#coordonnees-geo').removeClass('hidden');
265
		$('#coordonnees-geo').removeClass('hidden');
261
	}
266
	}
262
 
267
 
263
	return false;
268
	return false;
264
};
269
};
265
 
270
 
266
WidgetSaisieMissionsFlore.prototype.afficherObs = function() {
271
WidgetSaisieMissionsFlore.prototype.afficherObs = function() {
267
	var date = $('#date').val(),
272
	var date = $('#date').val(),
268
		commune = $('#commune-nom').text(),
273
		commune = $('#commune-nom').text(),
269
		codeInsee = $('#commune-code-insee').text(),
274
		codeInsee = $('#commune-code-insee').text(),
270
		lat = $('input[name="latitude"]').val(),
275
		lat = $('input[name="latitude"]').val(),
271
		lng = $('input[name="longitude"]').val(),
276
		lng = $('input[name="longitude"]').val(),
272
		lieudit = $('#lieudit').val(),
277
		lieudit = $('#lieudit').val(),
273
		station = $('#station').val(),
278
		station = $('#station').val(),
274
 
279
 
275
		milieux = $('#milieu').val(),
280
		milieux = $('#milieu').val(),
276
		exposition = this.getTextOptionSelectionne('station-exposition'),
281
		exposition = this.getTextOptionSelectionne('station-exposition'),
277
		pente = this.getTextOptionSelectionne('station-pente'),
282
		pente = this.getTextOptionSelectionne('station-pente'),
278
 
283
 
279
		phenologie = this.getTextOptionSelectionne('phenologie'),
284
		phenologie = this.getTextOptionSelectionne('phenologie'),
280
		abondance = this.getTextOptionSelectionne('abondance'),
285
		abondance = this.getTextOptionSelectionne('abondance'),
281
		individus = (($('#individus-nbre').val() === undefined || $('#individus-nbre').val() === '') ? '' : ' (' + $('#individus-nbre').val() + ')'),
286
		individus = (($('#individus-nbre').val() === undefined || $('#individus-nbre').val() === '') ? '' : ' (' + $('#individus-nbre').val() + ')'),
282
		typeReleve = this.getTextOptionSelectionne('releve-type'),
287
		typeReleve = this.getTextOptionSelectionne('releve-type'),
283
		sourceDet = $('#determination-source').val(),
288
		sourceDet = $('#determination-source').val(),
284
 
289
 
285
		notes = $('#notes').val();
290
		notes = $('#notes').val();
286
 
291
 
287
	$('#liste-obs').prepend(
292
	$('#liste-obs').prepend(
288
		'<div id="obs'+this.obsNbre+'" class="obs obs'+this.obsNbre+'">'+
293
		'<div id="obs'+this.obsNbre+'" class="obs obs'+this.obsNbre+'">'+
289
				'<div class="well">'+
294
				'<div class="well">'+
290
					'<div class="obs-action pull-right has-tooltip" data-placement="bottom" '+
295
					'<div class="obs-action pull-right has-tooltip" data-placement="bottom" '+
291
						'title="Supprimer cette observation de la liste à transmettre">'+
296
						'title="Supprimer cette observation de la liste à transmettre">'+
292
						'<button class="btn btn-danger supprimer-obs" value="'+this.obsNbre+'" title="'+this.obsNbre+'">'+
297
						'<button class="btn btn-danger supprimer-obs" value="'+this.obsNbre+'" title="'+this.obsNbre+'">'+
293
							'<span class="glyphicon glyphicon-trash icon-white"></i>'+
298
							'<span class="glyphicon glyphicon-trash icon-white"></i>'+
294
						'</button>'+
299
						'</button>'+
295
					'</div> '+
300
					'</div> '+
296
					'<div class="row">'+
301
					'<div class="row">'+
297
						'<div class="col-md-2 obs-miniatures">'+
302
						'<div class="col-md-2 obs-miniatures">'+
298
							this.ajouterImgMiniatureAuTransfert()+
303
							this.ajouterImgMiniatureAuTransfert()+
299
						'</div>'+
304
						'</div>'+
300
						'<div class="col-md-8">'+
305
						'<div class="col-md-8">'+
301
							'<ul class="list-unstyled obs-entete">'+
306
							'<ul class="list-unstyled obs-entete">'+
302
								'<li>'+
307
								'<li>'+
303
									'Observé à ' +
308
									'Observé à ' +
304
									'<span class="commune">' + commune + '</span> ' +
309
									'<span class="commune">' + commune + '</span> ' +
305
									'(' + codeInsee + ') [' + lat +' / ' + lng + ']' +
310
									'(' + codeInsee + ') [' + lat +' / ' + lng + ']' +
306
									' le ' +
311
									' le ' +
307
									'<span class="date">' + date + '</span>' +
312
									'<span class="date">' + date + '</span>' +
308
								'</li>' +
313
								'</li>' +
309
							'</ul>'+
314
							'</ul>'+
310
							'<ul class="list-unstyled obs-details">'+
315
							'<ul class="list-unstyled obs-details">'+
311
								'<li>' +
316
								'<li>' +
312
									'<span>Lieu-dit :</span> ' + lieudit + ' ; ' +
317
									'<span>Lieu-dit :</span> ' + lieudit + ' ; ' +
313
									'<span>Station :</span> ' + station + ' ; ' +
318
									'<span>Station :</span> ' + station + ' ; ' +
314
								'</li>' +
319
								'</li>' +
315
								'<li>' +
320
								'<li>' +
316
									'<span>Milieu :</span> ' + milieux + ' ; ' +
321
									'<span>Milieu :</span> ' + milieux + ' ; ' +
317
									'<span>Exposition :</span> ' + exposition + ' ; ' +
322
									'<span>Exposition :</span> ' + exposition + ' ; ' +
318
									'<span>Pente :</span> ' + pente + ' ; ' +
323
									'<span>Pente :</span> ' + pente + ' ; ' +
319
								'</li>' +
324
								'</li>' +
320
								'<li>' +
325
								'<li>' +
321
									'<span>Phénologie :</span> ' + phenologie + ' ; ' +
326
									'<span>Phénologie :</span> ' + phenologie + ' ; ' +
322
									'<span>Abondance :</span> ' + abondance + individus + ' ; ' +
327
									'<span>Abondance :</span> ' + abondance + individus + ' ; ' +
323
									'<span>Relevé :</span> ' + typeReleve + ' ; ' +
328
									'<span>Relevé :</span> ' + typeReleve + ' ; ' +
324
									'<span>Source :</span> ' + sourceDet + ' ; ' +
329
									'<span>Source :</span> ' + sourceDet + ' ; ' +
325
								'</li>' +
330
								'</li>' +
326
								'<li>' +
331
								'<li>' +
327
									'<span>Commentaires :</span> ' + notes +
332
									'<span>Commentaires :</span> ' + notes +
328
								'</li>'+
333
								'</li>'+
329
							'</ul>'+
334
							'</ul>'+
330
						'</div>'+
335
						'</div>'+
331
					'</div>'+
336
					'</div>'+
332
				'</div>'+
337
				'</div>'+
333
		'</div>');
338
		'</div>');
334
	$('#zone-liste-obs').removeClass("hidden").show();
339
	$('#zone-liste-obs').removeClass("hidden").show();
335
}
340
}
336
 
341
 
337
WidgetSaisieMissionsFlore.prototype.getTextOptionSelectionne = function(id) {
342
WidgetSaisieMissionsFlore.prototype.getTextOptionSelectionne = function(id) {
338
	var optionVal = $('#' + id).val(),
343
	var optionVal = $('#' + id).val(),
339
		optionText = $('#' + id + ' option:selected').text();
344
		optionText = $('#' + id + ' option:selected').text();
340
	return ((optionVal === undefined || optionVal === '') ? '' : optionText);
345
	return ((optionVal === undefined || optionVal === '') ? '' : optionText);
341
};
346
};
342
 
347
 
343
WidgetSaisieMissionsFlore.prototype.stockerObsData = function() {
348
WidgetSaisieMissionsFlore.prototype.stockerObsData = function() {
344
	var numNomSel = $('#taxon').data('numNomSel'),
349
	var numNomSel = $('#taxon').data('numNomSel'),
345
		nomSel = $('#taxon').val(),
350
		nomSel = $('#taxon').val(),
346
		nomRet = $('#taxon').data('nomRet'),
351
		nomRet = $('#taxon').data('nomRet'),
347
		numNomRet = $('#taxon').data('numNomRet'),
352
		numNomRet = $('#taxon').data('numNomRet'),
348
		numTaxon = $('#taxon').data('nt'),
353
		numTaxon = $('#taxon').data('nt'),
349
		famille = $('#taxon').data('famille'),
354
		famille = $('#taxon').data('famille'),
350
		referentiel = (numNomSel == undefined) ? '' : this.nomSciReferentiel;
355
		referentiel = (numNomSel == undefined) ? '' : this.nomSciReferentiel;
351
 
356
 
352
	$('#liste-obs').data('obsId'+this.obsNbre, {
357
	$('#liste-obs').data('obsId'+this.obsNbre, {
353
		'date' : $('#date').val(),
358
		'date' : $('#date').val(),
354
		'notes' : $('#notes').val().trim(),
359
		'notes' : $('#notes').val().trim(),
355
 
360
 
356
		'nom_sel': nomSel,
361
		'nom_sel': nomSel,
357
		'num_nom_sel': numNomSel,
362
		'num_nom_sel': numNomSel,
358
		'nom_ret': nomRet,
363
		'nom_ret': nomRet,
359
		'num_nom_ret': numNomRet,
364
		'num_nom_ret': numNomRet,
360
		'num_taxon': numTaxon,
365
		'num_taxon': numTaxon,
361
		'famille': famille,
366
		'famille': famille,
362
		'referentiel': referentiel,
367
		'referentiel': referentiel,
363
 
368
 
364
		'latitude' : $('#latitude').val(),
369
		'latitude' : $('#latitude').val(),
365
		'longitude' : $('#longitude').val(),
370
		'longitude' : $('#longitude').val(),
366
		'commune_nom' : $('#commune-nom').text(),
371
		'commune_nom' : $('#commune-nom').text(),
367
		'commune_code_insee' : $('#commune-code-insee').text(),
372
		'commune_code_insee' : $('#commune-code-insee').text(),
368
		'altitude': $('#altitude').text(),
373
		'altitude': $('#altitude').text(),
369
		'lieudit': $('#lieudit').val().trim(),
374
		'lieudit': $('#lieudit').val().trim(),
370
		'station': $('#station').val().trim(),
375
		'station': $('#station').val().trim(),
371
		'milieu': $('#milieu').val().trim(),
376
		'milieu': $('#milieu').val().trim(),
372
		'abondance': $('#abondance').val(),
377
		'abondance': $('#abondance').val(),
373
		'phenologie': $('#phenologie').val(),
378
		'phenologie': $('#phenologie').val(),
374
 
379
 
375
		//Ajout des champs images
380
		//Ajout des champs images
376
		'image_nom' : this.getNomsImgsOriginales(),
381
		'image_nom' : this.getNomsImgsOriginales(),
377
 
382
 
378
		// Ajout des champs étendus de l'obs
383
		// Ajout des champs étendus de l'obs
379
		'obs_etendue': this.getObsChpEtendus()
384
		'obs_etendue': this.getObsChpEtendus()
380
	});
385
	});
381
};
386
};
382
 
387
 
383
WidgetSaisieMissionsFlore.prototype.validerFormulaire = function() {
388
WidgetSaisieMissionsFlore.prototype.validerFormulaire = function() {
384
	var observateur = $('#form-observateur').valid(),
389
	var observateur = $('#form-observateur').valid(),
385
		station = $('#form-station').valid(),
390
		station = $('#form-station').valid(),
386
		obsDate = $('#form-obs-date').valid(),
391
		obsDate = $('#form-obs-date').valid(),
387
		obs = $('#form-obs').valid();
392
		obs = $('#form-obs').valid();
388
	return (observateur == true && station == true && obs == true && obsDate == true) ? true : false;
393
	return (observateur == true && station == true && obs == true && obsDate == true) ? true : false;
389
};
394
};