Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 1044 Rev 1799
1
/*+--------------------------------------------------------------------------------------------------------+*/
1
/*+--------------------------------------------------------------------------------------------------------+*/
2
// PARAMÊTRES et CONSTANTES
2
// PARAMÊTRES et CONSTANTES
3
// Mettre à true pour afficher les messages de débogage
3
// Mettre à true pour afficher les messages de débogage
4
var DEBUG = false; 
4
var DEBUG = false; 
5
/**
-
 
6
 * Indication de certaines variables ajoutée par php
5
var pointImageUrl = 'http://chart.apis.google.com/chart?cht=mm&chs=24x32&chco=FFFFFF,008CFF,000000&ext=.png';
7
* var communeImageUrl ;
-
 
8
* var pointImageUrl ;
-
 
9
* var groupeImageUrlTpl ;
-
 
10
*/
-
 
11
var pointsOrigine = null;
6
var pointsOrigine = null;
12
var boundsOrigine = null;
7
var boundsOrigine = null;
13
var markerClusterer = null;
8
var markerClusterer = null;
14
var map = null;
9
var map = null;
15
var infoBulle = new google.maps.InfoWindow();
10
var infoBulle = new google.maps.InfoWindow();
16
var stations = null;
-
 
17
var pointClique = null;
11
var pointClique = null;
18
var carteCentre = new google.maps.LatLng(25, 10);
12
var carteCentre = new google.maps.LatLng(46.4, 3.10);
19
var carteOptions = {
13
var carteOptions = {
20
	zoom: 3,
14
	zoom: 6,
21
	center:carteCentre,
-
 
22
	mapTypeId: google.maps.MapTypeId.ROADMAP,
15
	mapTypeId: google.maps.MapTypeId.ROADMAP,
23
	mapTypeControlOptions: {
16
	mapTypeControlOptions: {
24
		mapTypeIds: ['OSM', 
17
		mapTypeIds: ['OSM', 
25
		             google.maps.MapTypeId.ROADMAP, 
18
		             google.maps.MapTypeId.ROADMAP, 
26
		             google.maps.MapTypeId.HYBRID, 
19
		             google.maps.MapTypeId.HYBRID, 
27
		             google.maps.MapTypeId.SATELLITE, 
20
		             google.maps.MapTypeId.SATELLITE, 
28
		             google.maps.MapTypeId.TERRAIN]
21
		             google.maps.MapTypeId.TERRAIN]
29
	}
22
	}
30
};			
23
};			
-
 
24
var ctaLayer = null;
31
var osmMapType = new google.maps.ImageMapType({
25
var osmMapType = new google.maps.ImageMapType({
32
	getTileUrl: function(coord, zoom) {
26
	getTileUrl: function(coord, zoom) {
33
		return "http://tile.openstreetmap.org/" +
27
		return "http://tile.openstreetmap.org/" +
34
		zoom + "/" + coord.x + "/" + coord.y + ".png";
28
		zoom + "/" + coord.x + "/" + coord.y + ".png";
35
	},
29
	},
36
	tileSize: new google.maps.Size(256, 256),
30
	tileSize: new google.maps.Size(256, 256),
37
	isPng: true,
31
	isPng: true,
38
	alt: "OpenStreetMap",
32
	alt: "OpenStreetMap",
39
	name: "OSM",
33
	name: "OSM",
40
	maxZoom: 19
34
	maxZoom: 19
41
});
35
});
42
var ctaLayer = null;
-
 
43
var pagineur = {'limite':50, 'start':0, 'total':0, 'stationId':null, 'format':'tableau'};
36
var pagineur = {'limite':50, 'start':0, 'total':0, 'stationId':null, 'format':'tableau'};
44
var station = {'commune':'', 'obsNbre':0};
37
var station = {'commune':'', 'obsNbre':0};
45
var obsStation = new Array();
38
var obsStation = new Array();
46
var obsPage = new Array();
39
var obsPage = new Array();
47
var taxonsCarte = new Array();
40
var taxonsCarte = new Array();
48
var mgr = null;
-
 
49
var marqueursCache = new Array();
-
 
50
var zonesCache = new Array();
-
 
51
var requeteChargementPoints;
-
 
52
/*+--------------------------------------------------------------------------------------------------------+*/
41
/*+--------------------------------------------------------------------------------------------------------+*/
53
// INITIALISATION DU CODE
42
// INITIALISATION DU CODE
54
 
43
 
55
//Déclenchement d'actions quand JQuery et le document HTML sont OK
44
//Déclenchement d'actions quand JQuery et le document HTML sont OK
56
$(document).ready(function() {
45
$(document).ready(function() {
57
	initialiserWidget();
46
	initialiserWidget();
58
});
47
});
59
 
48
 
60
function initialiserWidget() {
49
function initialiserWidget() {
-
 
50
	afficherStats();
61
	definirTailleTitre();
51
	definirTailleTitre();
62
	initialiserAffichageCarte();
52
	initialiserAffichageCarte();
63
	initialiserAffichagePanneauLateral();
53
	initialiserAffichagePanneauLateral();
-
 
54
	
64
	initialiserCarte();
55
	initialiserCarte();
65
	initialiserGestionnaireMarqueurs()
-
 
66
	initialiserInfoBulle();
56
	initialiserInfoBulle();
67
	initialiserFormulaireContact();
57
	initialiserFormulaireContact();
68
	chargerLimitesCommunales();
58
	chargerLimitesCommunales();
69
	attribuerListenerCarte();
59
	rafraichirCarte();
70
	programmerRafraichissementCarte();
-
 
71
}
60
}
72
 
61
 
73
/*+--------------------------------------------------------------------------------------------------------+*/
62
/*+--------------------------------------------------------------------------------------------------------+*/
74
// AFFICHAGE GÉNÉRAL
63
// AFFICHAGE GÉNÉRAL
75
 
64
 
76
function afficherTitreCarte() {
-
 
77
	if (stations != null && taxonsCarte.length > 0) {
-
 
78
		var obsNbre = stations.stats.observations;
65
function afficherStats() {
79
		var obsNbreFormate = stations.stats.observations.formaterNombre();
-
 
80
		var plteNbre = taxonsCarte.length;
-
 
81
		var plteNbreFormate = taxonsCarte.length.formaterNombre();
-
 
82
		var communeNbre = stations.stats.communes;
66
	// Ajout du nombre de communes où des observations ont eu lieu
83
		var communeNbreFormate = stations.stats.communes.formaterNombre();
-
 
84
	
67
	$('#commune-nbre').text(stations.stats.communes.formaterNombre());
85
		var titre = obsNbreFormate+' observation';
-
 
86
		titre += (obsNbre > 1) ? 's' : '' ;
-
 
87
		
-
 
88
		if (nt == '*') {
-
 
89
			titre += ' de '+plteNbreFormate+' plante';
-
 
90
			titre += (plteNbre > 1) ? 's' : '' ;
-
 
91
		} else {
-
 
92
			if (taxonsCarte[0]) {
-
 
93
				var taxon = taxonsCarte[0];
-
 
94
				titre += ' pour '+taxon.nom;
-
 
95
			}
-
 
96
		}
-
 
97
		
-
 
98
		titre += ' sur '+communeNbreFormate+' commune';
-
 
99
		titre += (communeNbre > 1) ? 's' : '' ;
-
 
100
		
68
	// Ajout du nombre d'observations
101
		$('#carte-titre-infos').text(titre);
-
 
102
	}
69
	$('#obs-nbre').text(stations.stats.observations.formaterNombre());
103
}
70
}
104
 
71
 
105
function definirTailleTitre() {
72
function definirTailleTitre() {
106
	var largeurViewPort = $(window).width();
73
	var largeurViewPort = $(window).width();
107
	var taille = null;
74
	var taille = null;
108
	if (largeurViewPort < 400) {
75
	if (largeurViewPort < 400) {
109
		taille = '0.8';
76
		taille = '0.8';
110
	} else if (largeurViewPort >= 400 && largeurViewPort < 800) {
77
	} else if (largeurViewPort >= 400 && largeurViewPort < 800) {
111
		taille = '1.0';
78
		taille = '1.0';
112
	} else if (largeurViewPort >= 800) {
79
	} else if (largeurViewPort >= 800) {
113
		taille = '1.6';
80
		taille = '1.6';
114
	}
81
	}
115
	$("#carte-titre").css('font-size', taille+'em');
82
	$("#carte-titre").css('font-size', taille+'em');
116
}
83
}
117
 
84
 
118
/*+--------------------------------------------------------------------------------------------------------+*/
85
/*+--------------------------------------------------------------------------------------------------------+*/
119
// CARTE
86
// CARTE
120
 
87
 
121
function initialiserAffichageCarte() {
88
function initialiserAffichageCarte() {
122
	$('#carte').height($(window).height() - 35);
89
	$('#carte').height($(window).height() - 35);
123
	$('#carte').width($(window).width() - 24);
90
	$('#carte').width($(window).width() - 24);
124
 
91
	
125
	if (nt != '*') {
92
	if (nt != '*') {
126
		$('#carte').css('left', 0);
93
		$('#carte').css('left', 0);
127
	}
94
	}
128
}
95
}
129
 
96
 
130
function initialiserCarte() {
97
function initialiserCarte() {
131
	map = new google.maps.Map(document.getElementById('carte'), carteOptions);
98
	map = new google.maps.Map(document.getElementById('carte'), carteOptions);
132
	// Ajout de la couche OSM à la carte
99
	// Ajout de la couche OSM à la carte
133
	map.mapTypes.set('OSM', osmMapType);
100
	map.mapTypes.set('OSM', osmMapType);
134
}
101
}
135
 
-
 
136
function initialiserGestionnaireMarqueurs() {
-
 
137
	mgr = new MarkerManager(map);
-
 
138
}
102
 
139
 
103
 
140
function chargerLimitesCommunales() {
104
function chargerLimitesCommunales() {
141
	if (urlsLimitesCommunales != null) {
105
	if (urlsLimitesCommunales != null) {
142
		for (urlId in urlsLimitesCommunales) { 
106
		for (urlId in urlsLimitesCommunales) { 
143
			var url = urlsLimitesCommunales[urlId];
107
			var url = urlsLimitesCommunales[urlId];
144
			ctaLayer = new google.maps.KmlLayer(url, {preserveViewport: false});
108
			ctaLayer = new google.maps.KmlLayer(url, {preserveViewport: true});
145
			ctaLayer.setMap(map);
109
			ctaLayer.setMap(map);
146
		}
110
		}
147
	}
111
	}
148
}
112
}
149
 
-
 
150
var listener = null;
-
 
151
var timer = null;
-
 
152
function attribuerListenerCarte() {
-
 
153
	listener = google.maps.event.addListener(map, 'bounds_changed', function(){
-
 
154
		programmerRafraichissementCarte();
-
 
155
	});
-
 
156
	listener = google.maps.event.addListener(map, 'zoom_changed', function(){
-
 
157
		programmerRafraichissementCarte();
-
 
158
	});
-
 
159
}
-
 
160
function programmerRafraichissementCarte() {
-
 
161
	if(timer != null) {
-
 
162
        window.clearTimeout(timer);
-
 
163
    }
-
 
164
	if(requeteChargementPoints != null) {
-
 
165
		requeteChargementPoints.abort();
-
 
166
	}
-
 
167
	timer = window.setTimeout(function() {
-
 
168
		var zoom = map.getZoom();
-
 
169
		var NELatLng = (map.getBounds().getNorthEast().lat())+'|'+(map.getBounds().getNorthEast().lng());
-
 
170
		var SWLatLng = (map.getBounds().getSouthWest().lat())+'|'+(map.getBounds().getSouthWest().lng());
-
 
171
		chargerMarqueurs(zoom, NELatLng, SWLatLng);
-
 
172
    }, 400);		
-
 
173
}
-
 
174
 
-
 
175
var marqueurs = new Array();
-
 
176
function chargerMarqueurs(zoom, NELatLng, SWLatLng) {
-
 
177
	var url = stationsUrl+
-
 
178
		'&zoom='+zoom+
-
 
179
		'&ne='+NELatLng+
-
 
180
		'&sw='+SWLatLng;
-
 
181
	
-
 
182
	if(infoBulleOuverte) {
-
 
183
		return;
-
 
184
	}
-
 
185
	
-
 
186
	if(requeteChargementPoints != null) {
-
 
187
		requeteChargementPoints.abort();
-
 
188
		cacherMessageChargementPoints();
-
 
189
	}
-
 
190
	
-
 
191
	afficherMessageChargementPoints();
-
 
192
	requeteChargementPoints = $.getJSON(url, function(data) {
-
 
193
		rafraichirMarqueurs(data);
-
 
194
		cacherMessageChargementPoints();
-
 
195
	});
-
 
196
}
-
 
197
 
-
 
198
function afficherMessageChargementPoints() {
-
 
199
	$('#zone-chargement-point').css('display','block');
-
 
200
}
-
 
201
 
-
 
202
function cacherMessageChargementPoints() {
-
 
203
	$('#zone-chargement-point').css('display','none');
-
 
204
}
-
 
205
 
113
 
206
function rafraichirMarqueurs(data) {
-
 
207
	$.each(marqueurs, function(index, marqueur) {
-
 
208
		marqueur.setMap(null);
-
 
209
	});
-
 
210
	marqueurs = new Array();
-
 
211
	
-
 
212
	stations = data;
-
 
213
	afficherTitreCarte();
-
 
214
	
-
 
215
	$.each(stations.points, function (index, station) {		
-
 
216
		if(station != null) {
-
 
217
			var nouveauMarqueur = creerMarqueur(station);
-
 
218
			marqueurs.push(nouveauMarqueur);
-
 
219
		}
-
 
220
	});
-
 
221
}
-
 
222
 
-
 
223
function creerMarqueur(station) {
-
 
224
	var titre = '';
-
 
225
	if(station.nbreMarqueur) {
-
 
226
		titre = station.nbreMarqueur+' points renseignés';
-
 
227
	} else {
-
 
228
		if(station.nom) {
-
 
229
			titre = station.nom;
-
 
230
		}
-
 
231
	}
-
 
232
	//var titre = station['nbreMarqueur'];
-
 
233
	var icone = attribuerImageMarqueur(station['id'], station['nbreMarqueur']);
-
 
234
	var latLng = new google.maps.LatLng(station['lat'], station['lng']);
-
 
235
	var marqueur = new google.maps.Marker({
-
 
236
		position: latLng,
-
 
237
		icon: icone,
-
 
238
		title: ''+titre,
-
 
239
		map: map,
-
 
240
		stationInfos: station
-
 
241
	});
-
 
242
	attribuerListenerClick(marqueur, station['id']);
-
 
243
	marqueur.setMap(map);
-
 
244
    return marqueur;
-
 
245
}
-
 
246
 
-
 
247
function rendrePointsVisibles(bounds) {
-
 
248
	map.setCenter(bounds.getCenter());
-
 
249
	map.fitBounds(bounds);
-
 
250
	map.panToBounds(bounds);
-
 
251
}
-
 
252
 
-
 
253
function programmerRafraichissementCarteSauv() {
-
 
254
	
114
function rafraichirCarte() {
255
	var points = [];
115
	var points = [];
256
	var bounds = new google.maps.LatLngBounds();
116
	var bounds = new google.maps.LatLngBounds();
257
	for (var i = 0; i < stations.points.length; ++i) {
-
 
258
		var point = stations.points[i];
117
	for (var i = 0; i < stations.stats.communes; ++i) {
259
		var maLatLng = new google.maps.LatLng(point.lat, point.lng);
118
		var maLatLng = new google.maps.LatLng(stations.points[i].latitude, stations.points[i].longitude);
260
		var stationImage = attribuerImageMarqueur(point.id); 
119
		var pointImage = new google.maps.MarkerImage(pointImageUrl, new google.maps.Size(24, 32));
261
		var point = new google.maps.Marker({
120
		var point = new google.maps.Marker({
262
			position: maLatLng,
121
			position: maLatLng,
263
			map: map,
122
			map: map,
264
			icon: stationImage,
123
			icon: pointImage,
265
			stationInfos: point
124
			stationId: stations.points[i].id
266
		});
125
		});
267
		bounds.extend(maLatLng);
-
 
268
		google.maps.event.addListener(point, 'click', surClickMarqueur);
-
 
269
		points.push(point);
-
 
270
	}
-
 
271
 
-
 
272
	if (pointsOrigine == null && boundsOrigine == null) {
-
 
273
		pointsOrigine = points;
126
 
274
		boundsOrigine = bounds;
-
 
275
	}
-
 
276
	
-
 
277
	executerMarkerClusterer(points, bounds);
-
 
278
}
-
 
279
 
-
 
280
function attribuerImageMarqueur(id, nbreMarqueur) {
-
 
281
	var marqueurImage = null;
-
 
282
	if (etreMarqueurCommune(id)) {
-
 
283
		marqueurImage = new google.maps.MarkerImage(communeImageUrl, new google.maps.Size(24, 32));
-
 
284
	} else if (etreMarqueurStation(id)) {
-
 
285
		marqueurImage = new google.maps.MarkerImage(pointImageUrl, new google.maps.Size(16, 16));
-
 
286
	} else if (etreMarqueurGroupe(id)) {
-
 
287
		var type = 0;
-
 
288
		var largeur = 0;
-
 
289
		var hauteur = 0;
-
 
290
		if (nbreMarqueur != null) {
-
 
291
			if (nbreMarqueur >= 2 && nbreMarqueur < 100 ) {
-
 
292
				type = '1';
-
 
293
				largeur = 53;
-
 
294
				hauteur = 52;
-
 
295
			} else if (nbreMarqueur >= 100 && nbreMarqueur < 1000 ) {
-
 
296
				type = '2';
-
 
297
				largeur = 56;
-
 
298
				hauteur = 55;
-
 
299
			} else if (nbreMarqueur >= 1000 && nbreMarqueur < 10000 ) {
-
 
300
				type = '3';
-
 
301
				largeur = 66;
-
 
302
				hauteur = 65;
-
 
303
			} else if (nbreMarqueur >= 10000 && nbreMarqueur < 20000 ) {
-
 
304
				type = '4';
-
 
305
				largeur = 78;
-
 
306
				hauteur = 77;
-
 
307
			} else if (nbreMarqueur >= 20000) {
-
 
308
				type = '5';
-
 
309
				largeur = 66;
-
 
310
				hauteur = 65;
-
 
311
			}
-
 
312
		}
-
 
313
		groupeImageUrl = groupeImageUrlTpl.replace(/\{type\}/, type);
-
 
314
		groupeImageUrl = groupeImageUrl.replace(/\{nbre\}/, nbreMarqueur);
-
 
315
		marqueurImage = new google.maps.MarkerImage(groupeImageUrl, new google.maps.Size(largeur, hauteur));
-
 
316
	}
-
 
317
	return marqueurImage
-
 
318
}
-
 
319
 
-
 
320
function attribuerListenerClick(marqueur, id) {
-
 
321
	if (etreMarqueurCommune(id) || etreMarqueurStation(id)) {
-
 
322
		google.maps.event.addListener(marqueur, 'click', surClickMarqueur);
-
 
323
	} else if (etreMarqueurGroupe(id)) {
-
 
324
		google.maps.event.addListener(marqueur, 'click', surClickGroupe);
-
 
325
	}
-
 
326
}
-
 
327
 
-
 
328
function surClickMarqueur(event) {
-
 
329
 
-
 
330
	if(infoBulleOuverte) {
-
 
331
	    infoBulle.close();
-
 
-
 
127
		bounds.extend(maLatLng);
332
	}
128
		
333
  
129
		google.maps.event.addListener(point, 'click', function() {
334
	pointClique = this;
-
 
335
	infoBulle.open(map, this);
130
			pointClique =  this;
336
	actualiserPagineur();
131
			infoBulle.open(map, this);
337
	
132
			
338
	var limites = map.getBounds();
133
			var limites = map.getBounds();
339
	var centre = limites.getCenter();
134
			var centre = limites.getCenter();
340
	var nordEst = limites.getNorthEast();
135
			var nordEst = limites.getNorthEast();
341
	var centreSudLatLng = new google.maps.LatLng(nordEst.lat(), centre.lng());
136
			var centreSudLatLng = new google.maps.LatLng(nordEst.lat(), centre.lng());
342
	map.panTo(centreSudLatLng);
137
			map.panTo(centreSudLatLng);
343
	
138
			
344
	afficherInfoBulle();
139
			afficherInfoBulle();
345
}
-
 
346
 
-
 
347
function surClickGroupe() {
-
 
348
	map.setCenter(this.getPosition());
-
 
349
	var nouveauZoom = map.getZoom() + 2;
-
 
350
	map.setZoom(nouveauZoom);
-
 
351
	mgr.clearMarkers();
140
			chargerObs(0, 0);
352
}
141
		});
353
 
-
 
354
function etreMarqueurGroupe(id) {
-
 
355
	var groupe = false;
-
 
356
	var motif = /^GROUPE/;
142
		
357
	if (motif.test(id)) {
-
 
358
		groupe = true;
-
 
359
	}
-
 
360
	return groupe;
143
		points.push(point);
361
}
144
	}
362
 
145
 
363
function etreMarqueurCommune(id) {
-
 
364
	var commune = false;
-
 
365
	var motif = /^COMMUNE:/;
146
	if (pointsOrigine == null && boundsOrigine == null) {
366
	if (motif.test(id)) {
-
 
367
		commune = true;
-
 
368
	}
147
		pointsOrigine = points;
369
	return commune;
148
		boundsOrigine = bounds;
370
}
-
 
371
 
-
 
372
function etreMarqueurStation(id) {
-
 
373
	var station = false;
-
 
374
	var motif = /^STATION:/;
-
 
375
	if (motif.test(id)) {
-
 
376
		station = true;
149
	}
377
	}
150
	
378
	return station;
151
	executerMarkerClusterer(points, bounds);
379
}
152
}
380
 
153
 
381
function deplacerCarteSurPointClique() {
154
function deplacerCartePointClique() {
382
	map.panTo(pointClique.position);
155
	map.panTo(pointClique.position);
383
}
156
}
384
 
157
 
385
function executerMarkerClusterer(points, bounds) {
158
function executerMarkerClusterer(points, bounds) {
386
	if (markerClusterer) {
159
	if (markerClusterer) {
387
		markerClusterer.clearMarkers();
160
		markerClusterer.clearMarkers();
388
	}
161
	}
389
	markerClusterer = new MarkerClusterer(map, points, {gridSize: 50, maxZoom: 18});
162
	markerClusterer = new MarkerClusterer(map, points);
390
	map.fitBounds(bounds);
163
	map.fitBounds(bounds);
391
}
164
}
392
 
165
 
393
/*+--------------------------------------------------------------------------------------------------------+*/
166
/*+--------------------------------------------------------------------------------------------------------+*/
394
// INFO BULLE
167
// INFO BULLE
395
var infoBulleOuverte = false;
-
 
-
 
168
 
396
function initialiserInfoBulle() {
169
function initialiserInfoBulle() {
397
	google.maps.event.addListener(infoBulle, 'domready', initialiserContenuInfoBulle);
170
	google.maps.event.addListener(infoBulle, 'domready', initialiserContenuInfoBulle);
398
	google.maps.event.addListener(infoBulle, 'closeclick', surFermetureInfoBulle);
171
	google.maps.event.addListener(infoBulle, 'closeclick', deplacerCartePointClique);
399
	google.maps.event.addListener(infoBulle, 'content_changed', definirLargeurInfoBulle);
-
 
400
}
-
 
401
 
-
 
402
function surFermetureInfoBulle() {
-
 
403
	infoBulleOuverte = false;
-
 
404
	programmerRafraichissementCarte();
-
 
405
}
-
 
406
 
-
 
407
function centrerInfoBulle() {
-
 
408
	var limites = map.getBounds();
-
 
409
	var centre = limites.getCenter();
-
 
410
	var nordEst = limites.getNorthEast();
-
 
411
	var centreSudLatLng = new google.maps.LatLng(nordEst.lat(), centre.lng());
-
 
412
	map.panTo(centreSudLatLng);
-
 
413
}
172
}
414
 
173
 
415
function afficherInfoBulle() {
174
function afficherInfoBulle() {
416
	var obsHtml = $("#tpl-obs").html();
175
	var obsHtml = $("#tpl-obs").html();
417
	var largeur = definirLargeurInfoBulle();
176
	var largeur = definirLargeurInfoBulle();
418
	obsHtml = obsHtml.replace(/\{largeur\}/, largeur);
177
	obsHtml = obsHtml.replace(/\{largeur\}/, largeur);
419
	infoBulle.setContent(obsHtml);
178
	infoBulle.setContent(obsHtml);
420
	chargerObs(0, 0);
-
 
421
	infoBulleOuverte = true;
-
 
422
}
179
}
423
 
180
 
424
function definirLargeurInfoBulle() {
181
function definirLargeurInfoBulle() {
425
	var largeurViewPort = $(window).width();
182
	var largeurViewPort = $(window).width();
426
	var lageurInfoBulle = null;
183
	var lageurInfoBulle = null;
427
	if (largeurViewPort < 800) {
184
	if (largeurViewPort < 800) {
428
		largeurInfoBulle = 400;
185
		largeurInfoBulle = 400;
429
	} else if (largeurViewPort >= 800 && largeurViewPort < 1200) {
186
	} else if (largeurViewPort >= 800 && largeurViewPort < 1200) {
430
		largeurInfoBulle = 500;
187
		largeurInfoBulle = 500;
431
	} else if (largeurViewPort >= 1200) {
188
	} else if (largeurViewPort >= 1200) {
432
		largeurInfoBulle = 600;
189
		largeurInfoBulle = 600;
433
	}
190
	}
434
	return largeurInfoBulle;
191
	return largeurInfoBulle;
435
}
192
}
436
 
193
 
437
function afficherMessageChargement(element) {
194
function afficherMessageChargement(element) {
438
	if ($('#chargement').get() == '') {
195
	if ($('#chargement').get() == '') {
439
		$('#tpl-chargement').tmpl().appendTo(element);
196
		$('#tpl-chargement').tmpl().appendTo(element);
440
	}
197
	}
441
}
198
}
442
 
-
 
443
function afficherMessageChargementTitreInfoBulle() {
-
 
444
	$("#obs-station-titre").text("Chargement des observations");	
-
 
445
}
-
 
446
 
199
 
447
function supprimerMessageChargement() {
200
function supprimerMessageChargement() {
448
	$('#chargement').remove();
201
	$('#chargement').remove();
449
}
202
}
450
 
203
 
451
function chargerObs(depart, total) {
204
function chargerObs(depart, total) {
452
	if (depart == 0 || depart < total) {
205
	if (depart == 0 || depart < total) {
453
		var limite = 300;
206
		var limite = 300;
454
		if (depart == 0) {
207
		if (depart == 0) {
455
			viderTableauObs();
208
			obsStation = new Array();
456
		}
209
		}
457
		
-
 
-
 
210
		//console.log("Chargement de "+depart+" à "+(depart+limite));
458
		var urlObs = observationsUrl+'&start={start}&limit='+limite;
211
		var urlObs = observationsUrl+'&start={start}&limit='+limite;
459
		urlObs = urlObs.replace(/\{stationId\}/g, pointClique.stationInfos.id);
212
		urlObs = urlObs.replace(/\{stationId\}/g, pointClique.stationId);
460
		if (pointClique.stationInfos.type_emplacement == 'communes') {
-
 
461
			urlObs = urlObs.replace(/commune=%2A/g, 'commune='+pointClique.stationInfos.nom);
-
 
462
		}
-
 
463
		urlObs = urlObs.replace(/\{nt\}/g, nt);
213
		urlObs = urlObs.replace(/\{nt\}/g, nt);
464
		urlObs = urlObs.replace(/\{start\}/g, depart);
214
		urlObs = urlObs.replace(/\{start\}/g, depart);
465
		
215
		
466
		$.getJSON(urlObs, function(observations){
216
		$.getJSON(urlObs, function(observations){
467
			surRetourChargementObs(observations, depart, total);
-
 
468
			chargerObs(depart+limite, observations.total);
-
 
469
		});
-
 
470
	}
-
 
471
}
-
 
472
 
-
 
473
function viderTableauObs() {
-
 
474
	obsStation = new Array();	
-
 
475
	surClicPagePagination(0, null);
-
 
476
}
-
 
477
 
-
 
478
function surRetourChargementObs(observations, depart, total) {
-
 
479
	obsStation = obsStation.concat(observations.observations);
217
			obsStation = obsStation.concat(observations.observations);
480
	if (depart == 0) {
218
			if (depart == 0) {
481
		actualiserInfosStation(observations);
219
				actualiserInfosStation(observations);
-
 
220
				actualiserPagineur();
482
		creerTitreInfoBulle();
221
				creerTitreInfoBulle();
483
		surClicPagePagination(0, null);	
-
 
484
	}
222
			}
-
 
223
			//console.log("Chargement ok");
-
 
224
			chargerObs(depart+limite, station.obsNbre);
485
	
225
		});
-
 
226
	} else {
-
 
227
		if (pagineur.limite < total) {
486
	afficherPagination();
228
			afficherPagination();
-
 
229
		} else {
487
	actualiserPagineur();
230
			surClicPagePagination(0, null);
488
	selectionnerOnglet("#obs-vue-"+pagineur.format);
231
			selectionnerOnglet("#obs-vue-"+pagineur.format);
489
}
232
		}
490
 
-
 
491
function actualiserInfosStation(infos) {
-
 
492
	pointClique.stationInfos.commune = infos.commune;
-
 
493
	pointClique.stationInfos.obsNbre = infos.total;
-
 
494
}
233
	}
495
 
-
 
496
function creerTitreInfoBulle() {
-
 
497
	$("#obs-total").text(station.obsNbre);
-
 
498
	$("#obs-commune").text(station.commune);
-
 
499
	var titre = '';
-
 
500
	titre += pointClique.stationInfos.obsNbre+' observation';
-
 
501
	titre += (pointClique.stationInfos.obsNbre > 1) ? 's': '' ;
-
 
502
	titre += ' pour ';
-
 
503
	if (etreMarqueurCommune(pointClique.stationInfos.id)) {
-
 
504
		nomStation = 'la commune : ';
-
 
505
	} else {
-
 
506
		nomStation = 'la station : ';
-
 
507
	}
234
}
-
 
235
 
508
	titre += pointClique.stationInfos.nom;
236
function actualiserInfosStation(infos) {
-
 
237
	station.commune = infos.commune;
509
	$("#obs-station-titre").text(titre);	
238
	station.obsNbre = infos.total;
510
}
239
}
511
 
240
 
512
function actualiserPagineur() {
241
function actualiserPagineur() {
513
	pagineur.stationId = pointClique.stationInfos.id;
242
	pagineur.stationId = pointClique.stationId;
514
	pagineur.total = pointClique.stationInfos.obsNbre;
243
	pagineur.total = station.obsNbre;
-
 
244
	//console.log("Total pagineur: "+pagineur.total);
515
	if (pagineur.total > 4) {
245
	if (pagineur.total > 4) {
516
		pagineur.format = 'tableau';
246
		pagineur.format = 'tableau';
517
	} else {
247
	} else {
518
		pagineur.format = 'liste';
248
		pagineur.format = 'liste';
519
	}
249
	}
520
}
250
}
521
 
251
 
522
function afficherPagination(observations) {
252
function afficherPagination(observations) {
523
	$(".navigation").pagination(pagineur.total, {
253
	$(".navigation").pagination(pagineur.total, {
524
		items_per_page:pagineur.limite,
254
		items_per_page:pagineur.limite,
525
		callback:surClicPagePagination,
255
		callback:surClicPagePagination,
526
		next_text:'Suivant',
256
		next_text:'Suivant',
527
		prev_text:'Précédent',
257
		prev_text:'Précédent',
528
		prev_show_always:false,
258
		prev_show_always:false,
529
		num_edge_entries:1,
259
		num_edge_entries:1,
530
		num_display_entries:4,
260
		num_display_entries:4,
531
		load_first_page:true
261
		load_first_page:true
532
	});
262
	});
533
}
263
}
534
 
264
 
535
function surClicPagePagination(pageIndex, paginationConteneur) {
265
function surClicPagePagination(pageIndex, paginationConteneur) {
536
	var index = pageIndex * pagineur.limite;
266
	var index = pageIndex * pagineur.limite;
537
	var indexMax = index + pagineur.limite;
267
	var indexMax = index + pagineur.limite;
538
	pagineur.depart = index;
268
	pagineur.depart = index;
539
	obsPage = new Array();
269
	obsPage = new Array();
540
    for(index; index < indexMax; index++) {
270
    for(index; index < indexMax; index++) {
541
    	obsPage.push(obsStation[index]);
271
    	obsPage.push(obsStation[index]);
542
    }
272
    }
543
    
273
    
544
    supprimerMessageChargement();
274
    supprimerMessageChargement();
545
    mettreAJourObservations();
275
    mettreAJourObservations();
546
	return false;
276
	return false;
547
}
277
}
548
 
278
 
549
function mettreAJourObservations() {
279
function mettreAJourObservations() {
550
	$("#obs-"+pagineur.format+"-lignes").empty();
280
	$("#obs-"+pagineur.format+"-lignes").empty();
551
   	$("#obs-vue-"+pagineur.format).css('display', 'block');
281
   	$("#obs-vue-"+pagineur.format).css('display', 'block');
552
   	$(".obs-conteneur").css('counter-reset', 'item '+pagineur.depart);
282
   	$(".obs-conteneur").css('counter-reset', 'item '+pagineur.depart);
553
	$("#tpl-obs-"+pagineur.format).tmpl(obsPage).appendTo("#obs-"+pagineur.format+"-lignes");
283
	$("#tpl-obs-"+pagineur.format).tmpl(obsPage).appendTo("#obs-"+pagineur.format+"-lignes");
554
	
284
	
555
	// Actualisation de Fancybox
285
	// Actualisation de Fancybox
556
	ajouterFomulaireContact("a.contact");
286
	ajouterFomulaireContact("a.contact");
557
	if (pagineur.format == 'liste') {
287
	if (pagineur.format == 'liste') {
558
		ajouterGaleriePhoto("a.cel-img");
288
		ajouterGaleriePhoto("a.cel-img");
559
	}
289
	}
560
}
290
}
-
 
291
 
-
 
292
function creerTitreInfoBulle() {
-
 
293
	$("#obs-total").text(station.obsNbre);
-
 
294
	$("#obs-commune").text(station.commune);	
-
 
295
}
561
 
296
 
562
function initialiserContenuInfoBulle() {
-
 
563
	afficherMessageChargement('#observations');
-
 
564
	cacherContenuOnglets();
297
function initialiserContenuInfoBulle() {
-
 
298
	afficherOnglets();
565
	afficherOnglets();
299
	afficherMessageChargement('#observations');
566
	ajouterTableauTriable("#obs-tableau");
300
	ajouterTableauTriable("#obs-tableau");
567
	afficherTextStationId();
301
	afficherTextStationId();
568
	corrigerLargeurInfoWindow();
302
	corrigerLargeurInfoWindow();
569
}
303
}
570
 
-
 
571
function cacherContenuOnglets() {
-
 
572
	$("#obs-vue-tableau").css("display", "none");
-
 
573
	$("#obs-vue-liste").css("display", "none");
-
 
574
}
-
 
575
 
304
 
576
function afficherOnglets() {
305
function afficherOnglets() {
577
	var $tabs = $('#obs').tabs();
306
	var $tabs = $('#obs').tabs();
578
	$('#obs').bind('tabsselect', function(event, ui) {
307
	$('#obs').bind('tabsselect', function(event, ui) {
579
		if (ui.panel.id == 'obs-vue-tableau') {
308
		if (ui.panel.id == 'obs-vue-tableau') {
580
			surClicAffichageTableau();
309
			surClicAffichageTableau();
581
		} else if (ui.panel.id == 'obs-vue-liste') {
310
		} else if (ui.panel.id == 'obs-vue-liste') {
582
			surClicAffichageListe();
311
			surClicAffichageListe();
583
		}
312
		}
584
	});
313
	});
585
	if (pointClique.stationInfos.nbre > 4) {
-
 
586
		$tabs.tabs('select', "#obs-vue-tableau");
314
	$tabs.tabs('select', "#obs-vue-"+pagineur.format);
587
	} else {
-
 
588
		$tabs.tabs('select', "#obs-vue-liste");
-
 
589
	}
-
 
590
	
-
 
591
}
315
}
592
 
316
 
593
function selectionnerOnglet(onglet) {
317
function selectionnerOnglet(onglet) {
594
	$(onglet).css('display', 'block');
-
 
595
	$('#obs').tabs('select', onglet);
318
	$('#obs').tabs('select', onglet);
596
}
319
}
597
 
320
 
598
function afficherTextStationId() {
321
function afficherTextStationId() {
599
	$('#obs-station-id').text(pointClique.stationInfos.id);
322
	$('#obs-station-id').text(pointClique.stationId);
600
}
323
}
601
 
324
 
602
function corrigerLargeurInfoWindow() {
325
function corrigerLargeurInfoWindow() {
603
	$("#info-bulle").width($("#info-bulle").width() - 17);
326
	$("#info-bulle").width($("#info-bulle").width() - 17);
604
}
327
}
605
 
328
 
606
function surClicAffichageTableau(event) {
329
function surClicAffichageTableau(event) {
-
 
330
	//console.log('tableau');
607
	pagineur.format = 'tableau';
331
	pagineur.format = 'tableau';
608
	mettreAJourObservations();
332
	mettreAJourObservations();
609
	mettreAJourTableauTriable("#obs-tableau");
333
	mettreAJourTableauTriable("#obs-tableau");
610
}
334
}
611
 
335
 
612
function surClicAffichageListe(event) {
336
function surClicAffichageListe(event) {
-
 
337
	//console.log('liste');
613
	pagineur.format = 'liste';
338
	pagineur.format = 'liste';
614
	mettreAJourObservations();
339
	mettreAJourObservations();
615
	ajouterGaleriePhoto("a.cel-img");
340
	ajouterGaleriePhoto("a.cel-img");
616
}
341
}
617
 
342
 
618
function ajouterTableauTriable(element) {
343
function ajouterTableauTriable(element) {
619
	// add parser through the tablesorter addParser method 
344
	// add parser through the tablesorter addParser method 
620
	$.tablesorter.addParser({ 
345
	$.tablesorter.addParser({ 
621
		// Définition d'un id unique pour ce parsseur 
346
		// Définition d'un id unique pour ce parsseur 
622
		id: 'date_cel', 
347
		id: 'date_cel', 
623
		is: function(s) { 
348
		is: function(s) { 
624
			// doit retourner false si le parsseur n'est pas autodétecté
349
			// doit retourner false si le parsseur n'est pas autodétecté
625
			return /^\s*\d{2}[\/-]\d{2}[\/-]\d{4}\s*$/.test(s);
350
			return /^\s*\d{2}[\/-]\d{2}[\/-]\d{4}\s*$/.test(s);
626
		}, 
351
		}, 
627
		format: function(date) { 
352
		format: function(date) { 
628
			// Transformation date jj/mm/aaaa en aaaa/mm/jj
353
			// Transformation date jj/mm/aaaa en aaaa/mm/jj
629
			date = date.replace(/^\s*(\d{2})[\/-](\d{2})[\/-](\d{4})\s*$/, "$3/$2/$1");
354
			date = date.replace(/^\s*(\d{2})[\/-](\d{2})[\/-](\d{4})\s*$/, "$3/$2/$1");
630
			// Remplace la date par un nombre de millisecondes pour trier numériquement
355
			// Remplace la date par un nombre de millisecondes pour trier numériquement
631
			return $.tablesorter.formatFloat(new Date(date).getTime());
356
			return $.tablesorter.formatFloat(new Date(date).getTime());
632
		}, 
357
		}, 
633
		// set type, either numeric or text 
358
		// set type, either numeric or text 
634
		type: 'numeric' 
359
		type: 'numeric' 
635
	});
360
	});
636
	$(element).tablesorter({ 
361
	$(element).tablesorter({ 
637
        headers: { 
362
        headers: { 
638
			1: { 
363
			1: { 
639
            	sorter:'date_cel' 
364
            	sorter:'date_cel' 
640
        	} 
365
        	} 
641
    	} 
366
    	} 
642
	});
367
	});
643
}
368
}
644
 
369
 
645
function mettreAJourTableauTriable(element) {
370
function mettreAJourTableauTriable(element) {
646
	$(element).trigger('update');
371
	$(element).trigger('update');
647
}
372
}
648
 
373
 
649
function ajouterGaleriePhoto(element) {
374
function ajouterGaleriePhoto(element) {
650
	$(element).fancybox({
375
	$(element).fancybox({
651
		transitionIn:'elastic',
376
		transitionIn:'elastic',
652
		transitionOut:'elastic',
377
		transitionOut:'elastic',
653
		speedIn	:600, 
378
		speedIn	:600, 
654
		speedOut:200,
379
		speedOut:200,
655
		overlayShow:true,
380
		overlayShow:true,
656
		titleShow:true,
381
		titleShow:true,
657
		titlePosition:'inside',
382
		titlePosition:'inside',
658
		titleFormat:function (titre, currentArray, currentIndex, currentOpts) {
383
		titleFormat:function (titre, currentArray, currentIndex, currentOpts) {
659
			var motif = /urn:lsid:tela-botanica[.]org:cel:img([0-9]+)$/;
384
			var motif = /urn:lsid:tela-botanica[.]org:cel:img([0-9]+)$/;
660
			motif.exec(titre);
385
			motif.exec(titre);
661
			var id = RegExp.$1;
386
			var id = RegExp.$1;
662
			var info = $('#cel-info-'+id).clone().html();
387
			var info = $('#cel-info-'+id).clone().html();
663
			var tpl = 
388
			var tpl = 
664
				'<div class="cel-legende">'+
389
				'<div class="cel-legende">'+
665
				'<p class="cel-legende-vei">'+'Image n°' + (currentIndex + 1) + ' sur ' + currentArray.length +'<\/p>'+	
390
				'<p class="cel-legende-vei">'+'Image n°' + (currentIndex + 1) + ' sur ' + currentArray.length +'<\/p>'+	
666
				(titre && titre.length ? '<p>'+info+'<\/p>' : '' )+
391
				(titre && titre.length ? '<p>'+info+'<\/p>' : '' )+
667
				'<\/div>';
392
				'<\/div>';
668
			return tpl;
393
			return tpl;
669
		}
394
		}
670
	}).live('click', function(e) {
395
		}).live('click', function(e) {
671
		if (e.stopPropagation) {
396
			if (e.stopPropagation) {
672
			e.stopPropagation();
397
				e.stopPropagation();
673
		}
398
			}
674
		return false;
399
			return false;
675
	});
400
		});
676
}
401
}
677
 
402
 
678
function ajouterFomulaireContact(element) {
403
function ajouterFomulaireContact(element) {
679
	$(element).fancybox({
404
	$(element).fancybox({
680
		transitionIn:'elastic',
405
		transitionIn:'elastic',
681
		transitionOut:'elastic',
406
		transitionOut:'elastic',
682
		speedIn	:600, 
407
		speedIn	:600, 
683
		speedOut:200,
408
		speedOut:200,
684
		scrolling: 'no',
409
		scrolling: 'no',
685
		titleShow: false,
410
		titleShow: false,
686
		onStart: function(selectedArray, selectedIndex, selectedOpts) {
411
		onStart: function(selectedArray, selectedIndex, selectedOpts) {
687
			var element = selectedArray[selectedIndex];
412
			var element = selectedArray[selectedIndex];
688
 
413
 
689
			var motif = / contributeur-([0-9]+)$/;
414
			var motif = / contributeur-([0-9]+)$/;
690
			motif.exec($(element).attr('class'));
415
			motif.exec($(element).attr('class'));
691
			var id = RegExp.$1;
416
			var id = RegExp.$1;
692
			//console.log('Destinataire id : '+id);
417
			//console.log('Destinataire id : '+id);
693
			$("#fc_destinataire_id").attr('value', id);
418
			$("#fc_destinataire_id").attr('value', id);
694
		
419
		
695
			var motif = / obs-([0-9]+) /;
420
			var motif = / obs-([0-9]+) /;
696
			motif.exec($(element).attr('class'));
421
			motif.exec($(element).attr('class'));
697
			var id = RegExp.$1;
422
			var id = RegExp.$1;
698
			//console.log('Obs id : '+id);
423
			//console.log('Obs id : '+id);
699
			chargerInfoObsPourMessage(id);
424
			chargerInfoObsPourMessage(id);
700
		},
425
		},
701
		onCleanup: function() {
426
		onCleanup: function() {
702
			//console.log('Avant fermeture fancybox');
427
			//console.log('Avant fermeture fancybox');
703
			$("#fc_destinataire_id").attr('value', '');
428
			$("#fc_destinataire_id").attr('value', '');
704
			$("#fc_sujet").attr('value', '');
429
			$("#fc_sujet").attr('value', '');
705
			$("#fc_message").text('');
430
			$("#fc_message").text('');
706
		},
431
		},
707
		onClosed: function(e) {
432
		onClosed: function(e) {
708
			//console.log('Fermeture fancybox');
433
			//console.log('Fermeture fancybox');
709
			if (e.stopPropagation) {
434
			if (e.stopPropagation) {
710
				e.stopPropagation();
435
				e.stopPropagation();
711
			}
436
			}
712
			return false;
437
			return false;
713
		}
438
		}
714
	});
439
	});
715
}
440
}
716
 
441
 
717
function chargerInfoObsPourMessage(idObs) {
442
function chargerInfoObsPourMessage(idObs) {
718
	var nomSci = jQuery.trim($(".cel-obs-"+idObs+" .nom-sci:eq(0)").text());
443
	var nomSci = trim($(".cel-obs-"+idObs+" .nom-sci:eq(0)").text());
719
	var date = jQuery.trim($(".cel-obs-"+idObs+" .date:eq(0)").text());
444
	var date = trim($(".cel-obs-"+idObs+" .date:eq(0)").text());
720
	var lieu = jQuery.trim($(".cel-obs-"+idObs+" .lieu:eq(0)").text());
445
	var lieu = trim($(".cel-obs-"+idObs+" .lieu:eq(0)").text());
721
	var sujet = "Observation #"+idObs+" de "+nomSci;
446
	var sujet = "Observation #"+idObs+" de "+nomSci;
722
	var message = "\n\n\n\n\n\n\n\n--\nConcerne l'observation de \""+nomSci+'" du "'+date+'" au lieu "'+lieu+'".';
447
	var message = "\n\n\n\n\n\n\n\n--\nConcerne l'observation de \""+nomSci+'" du "'+date+'" au lieu "'+lieu+'".';
723
	$("#fc_sujet").attr('value', sujet);
448
	$("#fc_sujet").attr('value', sujet);
724
	$("#fc_message").text(message);
449
	$("#fc_message").text(message);
725
}
450
}
726
 
451
 
727
function initialiserFormulaireContact() {
452
function initialiserFormulaireContact() {
728
	//console.log('Initialisation du form contact');
453
	//console.log('Initialisation du form contact');
729
	$("#form-contact").validate({
454
	$("#form-contact").validate({
730
		rules: {
455
		rules: {
731
			fc_sujet : "required",
456
			fc_sujet : "required",
732
			fc_message : "required",
457
			fc_message : "required",
733
			fc_utilisateur_courriel : {
458
			fc_utilisateur_courriel : {
734
				required : true,
459
				required : true,
735
				email : true}
460
				email : true}
736
		}
461
		}
737
	});
462
	});
738
	$("#form-contact").bind("submit", envoyerCourriel);
463
	$("#form-contact").bind("submit", envoyerCourriel);
739
	$("#fc_annuler").bind("click", function() {$.fancybox.close();});
464
	$("#fc_annuler").bind("click", function() {$.fancybox.close();});
740
	
465
	
741
}
466
}
742
 
467
 
743
function envoyerCourriel() {
468
function envoyerCourriel() {
744
	//console.log('Formulaire soumis');
469
	//console.log('Formulaire soumis');
745
	if ($("#form-contact").valid()) {
470
	if ($("#form-contact").valid()) {
746
		//console.log('Formulaire valide');
471
		//console.log('Formulaire valide');
747
		//$.fancybox.showActivity();
472
		//$.fancybox.showActivity();
748
		var destinataireId = $("#fc_destinataire_id").attr('value');
473
		var destinataireId = $("#fc_destinataire_id").attr('value');
749
		var urlMessage = "http://www.tela-botanica.org/service:annuaire:Utilisateur/"+destinataireId+"/message"
474
		var urlMessage = "http://www.tela-botanica.org/service:annuaire:Utilisateur/"+destinataireId+"/message"
750
		var erreurMsg = "";
475
		var erreurMsg = "";
751
		var donnees = new Array();
476
		var donnees = new Array();
752
		$.each($(this).serializeArray(), function (index, champ) {
477
		$.each($(this).serializeArray(), function (index, champ) {
753
			var cle = champ.name;
478
			var cle = champ.name;
754
			cle = cle.replace(/^fc_/, '');
479
			cle = cle.replace(/^fc_/, '');
755
			
480
			
756
			if (cle == 'sujet') {
481
			if (cle == 'sujet') {
757
				champ.value += " - Carnet en ligne - Tela Botanica";
482
				champ.value += " - Carnet en ligne - Tela Botanica";
758
			}
483
			}
759
			if (cle == 'message') {
484
			if (cle == 'message') {
760
				champ.value += "\n--\n"+
485
				champ.value += "\n--\n"+
761
					"Ce message vous est envoyé par l'intermédiaire du widget carto "+
486
					"Ce message vous est envoyé par l'intermédiaire du widget Cartographique "+
762
					"du Carnet en Ligne du réseau Tela Botanica.\n"+
487
					"du Carnet en Ligne du réseau Tela Botanica.\n"+
763
					"http://www.tela-botanica.org/widget:cel:carto";
488
					"http://www.tela-botanica.org/widget:cel:carto";
764
			}
489
			}
765
			
490
			
766
			donnees[index] = {'name':cle,'value':champ.value};
491
			donnees[index] = {'name':cle,'value':champ.value};
767
		});
492
		});
768
		$.ajax({
493
		$.ajax({
769
			type : "POST",
494
			type : "POST",
770
			cache : false,
495
			cache : false,
771
			url : urlMessage,
496
			url : urlMessage,
772
			data : donnees,
497
			data : donnees,
773
			beforeSend : function() {
498
			beforeSend : function() {
774
				$(".msg").remove();
499
				$(".msg").remove();
775
			},
500
			},
776
			success : function(data) {
501
			success : function(data) {
777
				$("#fc-zone-dialogue").append('<pre class="msg info">'+data.message+'</pre>');
502
				$("#fc-zone-dialogue").append('<pre class="msg info">'+data.message+'</pre>');
778
			},
503
			},
779
			error : function(jqXHR, textStatus, errorThrown) {
504
			error : function(jqXHR, textStatus, errorThrown) {
780
				erreurMsg += "Erreur Ajax :\ntype : "+textStatus+' '+errorThrown+"\n";
505
				erreurMsg += "Erreur Ajax :\ntype : "+textStatus+' '+errorThrown+"\n";
781
				reponse = jQuery.parseJSON(jqXHR.responseText);
506
				reponse = jQuery.parseJSON(jqXHR.responseText);
782
				if (reponse != null) {
507
				if (reponse != null) {
783
					$.each(reponse, function (cle, valeur) {
508
					$.each(reponse, function (cle, valeur) {
784
						erreurMsg += valeur + "\n";
509
						erreurMsg += valeur + "\n";
785
					});
510
					});
786
				}				
511
				}				
787
			},
512
			},
788
			complete : function(jqXHR, textStatus) {
513
			complete : function(jqXHR, textStatus) {
789
				var debugMsg = '';
514
				var debugMsg = '';
790
				if (jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {
515
				if (jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {
791
					debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));
516
					debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));
792
					if (debugInfos != null) {
517
					if (debugInfos != null) {
793
						$.each(debugInfos, function (cle, valeur) {
518
						$.each(debugInfos, function (cle, valeur) {
794
							debugMsg += valeur + "\n";
519
							debugMsg += valeur + "\n";
795
						});
520
						});
796
					}
521
					}
797
				}
522
				}
798
				if (erreurMsg != '') {
523
				if (erreurMsg != '') {
799
					$("#fc-zone-dialogue").append('<p class="msg">'+
524
					$("#fc-zone-dialogue").append('<p class="msg">'+
800
							'Une erreur est survenue lors de la transmission de votre message.'+'<br />'+
525
							'Une erreur est survenue lors de la transmission de votre message.'+'<br />'+
801
							'Vous pouvez signaler le disfonctionnement à <a href="'+
526
							'Vous pouvez signaler le disfonctionnement à <a href="'+
802
							'mailto:cel@tela-botanica.org'+'?'+
527
							'mailto:cel@tela-botanica.org'+'?'+
803
							'subject=Disfonctionnement du widget carto'+
528
							'subject=Disfonctionnement du widget de Cartographie'+
804
							"&body="+erreurMsg+"\nDébogage :\n"+debugMsg+
529
							"&body="+erreurMsg+"\nDébogage :\n"+debugMsg+
805
							'">cel@tela-botanica.org</a>.'+
530
							'">cel@tela-botanica.org</a>.'+
806
							'</p>');
531
							'</p>');
807
				}
532
				}
808
				if (DEBUG) {
533
				if (DEBUG) {
809
					console.log('Débogage : '+debugMsg);
534
					console.log('Débogage : '+debugMsg);
810
				}
535
				}
811
				//console.log('Débogage : '+debugMsg);
536
				//console.log('Débogage : '+debugMsg);
812
				//console.log('Erreur : '+erreurMsg);
537
				//console.log('Erreur : '+erreurMsg);
813
			}
538
			}
814
		});
539
		});
815
	}
540
	}
816
	return false;
541
	return false;
817
}
542
}
818
/*+--------------------------------------------------------------------------------------------------------+*/
543
/*+--------------------------------------------------------------------------------------------------------+*/
819
// PANNEAU LATÉRAL
544
// PANNEAU LATÉRAL
820
 
545
 
821
function initialiserAffichagePanneauLateral() {
546
function initialiserAffichagePanneauLateral() {
822
	$('#panneau-lateral').height($(window).height() - 35);
547
	$('#panneau-lateral').height($(window).height() - 35);
823
	
548
	
824
	if (nt == '*') {
549
	if (nt == '*') {
825
		$('#pl-ouverture').bind('click', afficherPanneauLateral);
550
		$('#pl-ouverture').bind('click', afficherPanneauLateral);
826
		$('#pl-fermeture').bind('click', cacherPanneauLateral);
551
		$('#pl-fermeture').bind('click', cacherPanneauLateral);
827
	}
552
	}
828
	chargerTaxons(0, 0);
553
	chargerTaxons(0, 0);
829
}
554
}
830
 
555
 
831
function chargerTaxons(depart, total) {
556
function chargerTaxons(depart, total) {
832
	if (depart == 0 || depart < total) {
557
	if (depart == 0 || depart < total) {
833
		var limite = 7000;
558
		var limite = 7000;
834
		//console.log("Chargement des taxons de "+depart+" à "+(depart+limite));
559
		//console.log("Chargement des taxons de "+depart+" à "+(depart+limite));
835
		var urlTax = taxonsUrl+'&start={start}&limit='+limite;
560
		var urlTax = taxonsUrl+'&start={start}&limit='+limite;
836
		urlTax = urlTax.replace(/\{start\}/g, depart);
561
		urlTax = urlTax.replace(/\{start\}/g, depart);
837
		$.getJSON(urlTax, function(infos) {
562
		$.getJSON(urlTax, function(infos) {
838
			taxonsCarte = taxonsCarte.concat(infos.taxons);
563
			taxonsCarte = taxonsCarte.concat(infos.taxons);
839
			//console.log("Nbre taxons :"+taxonsCarte.length);
564
			//console.log("Nbre taxons :"+taxonsCarte.length);
840
			chargerTaxons(depart+limite, infos.total);
565
			chargerTaxons(depart+limite, infos.total);
841
		});
566
		});
842
	} else {
567
	} else {
843
		if (nt == '*') {
568
		if (nt == '*') {
844
			afficherTaxons();
569
			afficherTaxons();
-
 
570
		} else {
-
 
571
			afficherNomPlante();
845
		}
572
		}
846
		afficherTitreCarte();
-
 
847
	}
573
	}
848
}
574
}
849
 
575
 
850
function afficherTaxons() {
576
function afficherTaxons() {
-
 
577
	// Ajout du nombre de plantes au titre
851
	$(".plantes-nbre").text(taxonsCarte.length);
578
	$('.plantes-nbre').text(taxonsCarte.length.formaterNombre());
-
 
579
	
852
	$("#tpl-taxons-liste").tmpl({'taxons':taxonsCarte}).appendTo("#pl-corps");
580
	$("#tpl-taxons-liste").tmpl({'taxons':taxonsCarte}).appendTo("#pl-corps");
853
	$('.taxon').live('click', filtrerParTaxon);
581
	$('.taxon').live('click', filtrerParTaxon);
854
}
582
}
-
 
583
 
-
 
584
function afficherNomPlante() {
-
 
585
	if (nt != '*') {
-
 
586
		var taxon = taxonsCarte[0];
-
 
587
		$('.plante-titre').text('pour '+taxon.nom);
-
 
588
	}
855
 
589
}
856
 
590
 
857
function afficherPanneauLateral() {
591
function afficherPanneauLateral() {
858
	$('#panneau-lateral').width(300);
592
	$('#panneau-lateral').width(300);
859
	$('#pl-contenu').css('display', 'block');
593
	$('#pl-contenu').css('display', 'block');
860
	$('#pl-ouverture').css('display', 'none');
594
	$('#pl-ouverture').css('display', 'none');
861
	$('#pl-fermeture').css('display', 'block');
595
	$('#pl-fermeture').css('display', 'block');
862
	$('#carte').css('left', '300px');
596
	$('#carte').css('left', '300px');
863
 
597
 
864
	google.maps.event.trigger(map, 'resize');
598
	google.maps.event.trigger(map, 'resize');
865
};
599
};
866
 
600
 
867
function cacherPanneauLateral() {
601
function cacherPanneauLateral() {
868
	$('#panneau-lateral').width(24);
602
	$('#panneau-lateral').width(24);
869
	$('#pl-contenu').css('display', 'none');
603
	$('#pl-contenu').css('display', 'none');
870
	$('#pl-ouverture').css('display', 'block');
604
	$('#pl-ouverture').css('display', 'block');
871
	$('#pl-fermeture').css('display', 'none');
605
	$('#pl-fermeture').css('display', 'none');
872
	$('#carte').css('left', '24px');
606
	$('#carte').css('left', '24px');
873
	
607
	
874
	google.maps.event.trigger(map, 'resize');
608
	google.maps.event.trigger(map, 'resize');
875
};
609
};
-
 
610
 
-
 
611
function ouvrirPopUp(url, nom) {
-
 
612
	window.open(url, nom, 'scrollbars=yes,width=650,height=600,directories=no,location=no,menubar=no,status=no,toolbar=no');
-
 
613
};
876
 
614
 
877
function filtrerParTaxon() {
615
function filtrerParTaxon() {
878
	var ntAFiltrer = $('.nt', this).text();
616
	var ntAFiltrer = $('.nt', this).text();
879
	infoBulle.close();
617
	infoBulle.close();
880
	var zoom = map.getZoom();
-
 
881
	var NELatLng = map.getBounds().getNorthEast().lat()+'|'+map.getBounds().getNorthEast().lng();
-
 
882
	var SWLatLng = map.getBounds().getSouthWest().lat()+'|'+map.getBounds().getSouthWest().lng();
-
 
883
	
-
 
884
	$('#taxon-'+nt).removeClass('taxon-actif');
618
	$('#taxon-'+nt).removeClass('taxon-actif');
885
	if (nt == ntAFiltrer) {
619
	if (nt == ntAFiltrer) {
886
		nt = '*';
620
		nt = '*';
887
		stationsUrl = stationsUrl.replace(/num_taxon=[*0-9]+/, 'num_taxon='+nt);
-
 
888
		chargerMarqueurs(zoom, NELatLng, SWLatLng);
621
		executerMarkerClusterer(pointsOrigine, boundsOrigine);
889
	} else {
622
	} else {
890
		stationsUrl = stationsUrl.replace(/num_taxon=[*0-9]+/, 'num_taxon='+ntAFiltrer);
623
		var url = stationsUrl.replace(/num_taxon=[*0-9]+/, 'num_taxon='+ntAFiltrer)+
891
		url = stationsUrl;
-
 
892
		url += '&zoom='+zoom+
-
 
893
			'&ne='+NELatLng+
624
			'&formatRetour=jsonP'+
894
			'&sw='+SWLatLng;
625
			'&callback=?';
895
		requeteChargementPoints = $.getJSON(url, function (stationsFiltrees) {
626
		$.getJSON(url, function (stationsFiltrees) {
896
			stations = stationsFiltrees;
627
			stations = stationsFiltrees;
897
			nt = ntAFiltrer;
628
			nt = ntAFiltrer;
898
			$('#taxon-'+nt).addClass('taxon-actif');
629
			$('#taxon-'+nt).addClass('taxon-actif');
899
			rafraichirMarqueurs(stations);
630
			rafraichirCarte();
900
		});
631
		});
901
	}
632
	}
902
};
633
};
903
 
634
 
904
/*+--------------------------------------------------------------------------------------------------------+*/
635
/*+--------------------------------------------------------------------------------------------------------+*/
905
// FONCTIONS UTILITAIRES
636
// FONCTIONS UTILITAIRES
906
 
-
 
907
function ouvrirPopUp(element, nomPopUp, event) {
-
 
908
	var options = 
-
 
909
		'width=650,'+
-
 
910
		'height=600,'+
-
 
911
		'scrollbars=yes,'+
-
 
912
		'directories=no,'+
-
 
913
		'location=no,'+
-
 
914
		'menubar=no,'+
-
 
915
		'status=no,'+
-
 
916
		'toolbar=no';
-
 
917
	var popUp = window.open(element.href, nomPopUp, options);
-
 
918
	if (window.focus) {
-
 
919
		popUp.focus();
-
 
920
	}
-
 
921
	return arreter(event);
-
 
922
};
-
 
923
 
-
 
924
function ouvrirNouvelleFenetre(element, event) {
-
 
925
	window.open(element.href);
-
 
926
	return arreter(event);
-
 
927
}
-
 
928
 
637
 
929
function arreter(event) {
638
function arreter(event) {
930
	if (event.stopPropagation) {
639
	if (event.stopPropagation) {
931
		event.stopPropagation();
640
		event.stopPropagation();
932
	} else if (window.event) {
641
	} else if (window.event) {
933
		window.event.cancelBubble = true;
642
		window.event.cancelBubble = true;
934
	}
643
	}
935
	if (event.preventDefault) {
-
 
936
		event.preventDefault();
-
 
937
	}
-
 
938
	event.returnValue = false;
-
 
939
	return false;
644
	return false;
940
}
645
}
941
 
646
 
942
/**
647
/**
943
 * +-------------------------------------+
648
 * +-------------------------------------+
944
 * Number.prototype.formaterNombre
649
 * Number.prototype.formaterNombre
945
 * +-------------------------------------+
650
 * +-------------------------------------+
946
 * Params (facultatifs):
651
 * Params (facultatifs):
947
 * - Int decimales: nombre de decimales (exemple: 2)
652
 * - Int decimales: nombre de decimales (exemple: 2)
948
 * - String signe: le signe precedent les decimales (exemple: "," ou ".")
653
 * - String signe: le signe precedent les decimales (exemple: "," ou ".")
949
 * - String separateurMilliers: comme son nom l'indique
654
 * - String separateurMilliers: comme son nom l'indique
950
 * Returns:
655
 * Returns:
951
 * - String chaine formatee
656
 * - String chaine formatee
952
 * @author	::mastahbenus::
657
 * @author	::mastahbenus::
953
 * @author	Jean-Pascal MILCENT <jpm@tela-botanica.org> : ajout détection auto entier/flotant
658
 * @author	Jean-Pascal MILCENT <jpm@tela-botanica.org> : ajout détection auto entier/flotant
954
 * @souce	http://www.javascriptfr.com/codes/FORMATER-NOMBRE-FACON-NUMBER-FORMAT-PHP_40060.aspx
659
 * @souce	http://www.javascriptfr.com/codes/FORMATER-NOMBRE-FACON-NUMBER-FORMAT-PHP_40060.aspx
955
 */
660
 */
956
Number.prototype.formaterNombre = function (decimales, signe, separateurMilliers) {
661
Number.prototype.formaterNombre = function (decimales, signe, separateurMilliers) {
957
	var _sNombre = String(this), i, _sRetour = "", _sDecimales = "";
662
	var _sNombre = String(this), i, _sRetour = "", _sDecimales = "";
958
	
663
	
959
	function is_int(nbre) {
664
	function is_int(nbre) {
960
		nbre = nbre.replace(',', '.');
665
		nbre = nbre.replace(',', '.');
961
		return !(parseFloat(nbre)-parseInt(nbre) > 0);
666
		return !(parseFloat(nbre)-parseInt(nbre) > 0);
962
	}
667
	}
963
 
668
 
964
	if (decimales == undefined) {
669
	if (decimales == undefined) {
965
		if (is_int(_sNombre)) {
670
		if (is_int(_sNombre)) {
966
			decimales = 0;
671
			decimales = 0;
967
		} else {
672
		} else {
968
			decimales = 2;
673
			decimales = 2;
969
		}
674
		}
970
	}
675
	}
971
	if (signe == undefined) {
676
	if (signe == undefined) {
972
		if (is_int(_sNombre)) {
677
		if (is_int(_sNombre)) {
973
			signe = '';
678
			signe = '';
974
		} else {
679
		} else {
975
			signe = '.';
680
			signe = '.';
976
		}
681
		}
977
	}
682
	}
978
	if (separateurMilliers == undefined) {
683
	if (separateurMilliers == undefined) {
979
		separateurMilliers = ' ';
684
		separateurMilliers = ' ';
980
	}
685
	}
981
	
686
	
982
	function separeMilliers (sNombre) {
687
	function separeMilliers (sNombre) {
983
		var sRetour = "";
688
		var sRetour = "";
984
		while (sNombre.length % 3 != 0) {
689
		while (sNombre.length % 3 != 0) {
985
			sNombre = "0"+sNombre;
690
			sNombre = "0"+sNombre;
986
		}
691
		}
987
		for (i = 0; i < sNombre.length; i += 3) {
692
		for (i = 0; i < sNombre.length; i += 3) {
988
			if (i == sNombre.length-1) separateurMilliers = '';
693
			if (i == sNombre.length-1) separateurMilliers = '';
989
			sRetour += sNombre.substr(i, 3) + separateurMilliers;
694
			sRetour += sNombre.substr(i, 3) + separateurMilliers;
990
		}
695
		}
991
		while (sRetour.substr(0, 1) == "0") {
696
		while (sRetour.substr(0, 1) == "0") {
992
			sRetour = sRetour.substr(1);
697
			sRetour = sRetour.substr(1);
993
		}
698
		}
994
		return sRetour.substr(0, sRetour.lastIndexOf(separateurMilliers));
699
		return sRetour.substr(0, sRetour.lastIndexOf(separateurMilliers));
995
	}
700
	}
996
	
701
	
997
	if (_sNombre.indexOf('.') == -1) {
702
	if (_sNombre.indexOf('.') == -1) {
998
		for (i = 0; i < decimales; i++) {
703
		for (i = 0; i < decimales; i++) {
999
			_sDecimales += "0";
704
			_sDecimales += "0";
1000
		}
705
		}
1001
		_sRetour = separeMilliers(_sNombre) + signe + _sDecimales;
706
		_sRetour = separeMilliers(_sNombre) + signe + _sDecimales;
1002
	} else {
707
	} else {
1003
		var sDecimalesTmp = (_sNombre.substr(_sNombre.indexOf('.')+1));
708
		var sDecimalesTmp = (_sNombre.substr(_sNombre.indexOf('.')+1));
1004
		if (sDecimalesTmp.length > decimales) {
709
		if (sDecimalesTmp.length > decimales) {
1005
			var nDecimalesManquantes = sDecimalesTmp.length - decimales;
710
			var nDecimalesManquantes = sDecimalesTmp.length - decimales;
1006
			var nDiv = 1;
711
			var nDiv = 1;
1007
			for (i = 0; i < nDecimalesManquantes; i++) {
712
			for (i = 0; i < nDecimalesManquantes; i++) {
1008
				nDiv *= 10;
713
				nDiv *= 10;
1009
			}
714
			}
1010
			_sDecimales = Math.round(Number(sDecimalesTmp) / nDiv);
715
			_sDecimales = Math.round(Number(sDecimalesTmp) / nDiv);
1011
		}
716
		}
1012
		_sRetour = separeMilliers(_sNombre.substr(0, _sNombre.indexOf('.')))+String(signe)+_sDecimales;
717
		_sRetour = separeMilliers(_sNombre.substr(0, _sNombre.indexOf('.')))+String(signe)+_sDecimales;
1013
	}
718
	}
1014
	return _sRetour;
719
	return _sRetour;
1015
}
720
}
1016
 
721
 
1017
function debug(objet) {
722
function debug(objet) {
1018
	var msg = '';
723
	var msg = '';
1019
	if (objet != null) {
724
	if (objet != null) {
1020
		$.each(objet, function (cle, valeur) {
725
		$.each(objet, function (cle, valeur) {
1021
			msg += cle+":"+valeur + "\n";
726
			msg += cle+":"+valeur + "\n";
1022
		});
727
		});
1023
	} else {
728
	} else {
1024
		msg = "La variable vaut null.";
729
		msg = "La variable vaut null.";
1025
	}
730
	}
1026
	console.log(msg);
731
	console.log(msg);
1027
}
732
}
1028
733
 
-
 
734
function trim (chaine) {
-
 
735
	return chaine.replace(/^\s+/g, '').replace(/\s+$/g, '');
-
 
736
}
-
 
737