Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
836 jpm 1
/*+--------------------------------------------------------------------------------------------------------+*/
2
// PARAMÊTRES et CONSTANTES
1041 aurelien 3
/**
1586 jpm 4
* Indication de certaines variables ajoutée par php
1041 aurelien 5
* var communeImageUrl ;
6
* var pointImageUrl ;
7
* var groupeImageUrlTpl ;
8
*/
1586 jpm 9
var DEBUG = false,// Mettre à true pour afficher les messages de débogage
10
	pointsOrigine = null,
11
	boundsOrigine = null,
12
	markerClusterer = null,
13
	map = null,
14
	infoBulle = new google.maps.InfoWindow(),
15
	stations = null,
16
	pointClique = null,
17
	carteCentre = new google.maps.LatLng(25, 10),
18
	carteOptions = {
19
		zoom: 3,
20
		center:carteCentre,
21
		mapTypeId: google.maps.MapTypeId.ROADMAP,
22
		mapTypeControlOptions: {
23
			mapTypeIds: ['OSM',
24
				google.maps.MapTypeId.ROADMAP,
25
				google.maps.MapTypeId.HYBRID,
26
				google.maps.MapTypeId.SATELLITE,
27
				google.maps.MapTypeId.TERRAIN]
28
		},
29
		zoomControlOptions: {
30
			style: google.maps.ZoomControlStyle.LARGE,
31
			position: google.maps.ControlPosition.LEFT_CENTER
32
		},
33
		panControl: false
1438 aurelien 34
	},
1586 jpm 35
	osmMapType = new google.maps.ImageMapType({
36
		getTileUrl: function(coord, zoom) {
37
			return "http://tile.openstreetmap.org/" +
38
			zoom + "/" + coord.x + "/" + coord.y + ".png";
39
		},
40
		tileSize: new google.maps.Size(256, 256),
41
		isPng: true,
42
		alt: "OpenStreetMap",
43
		name: "OSM",
44
		maxZoom: 19
45
	}),
46
	ctaLayer = null,
47
	pagineur = {'limite':300, 'start':0, 'total':0, 'stationId':null, 'format':'tableau'},
48
	station = {'commune':'', 'obsNbre':0},
49
	obsStation = new Array(),
50
	obsPage = new Array(),
51
	taxonsCarte = new Array(),
52
	mgr = null,
53
	marqueursCache = new Array(),
54
	zonesCache = new Array(),
55
	requeteChargementPoints,
56
	urlVars = null;
57
 
836 jpm 58
/*+--------------------------------------------------------------------------------------------------------+*/
59
// INITIALISATION DU CODE
60
 
61
//Déclenchement d'actions quand JQuery et le document HTML sont OK
62
$(document).ready(function() {
63
	initialiserWidget();
64
});
65
 
66
function initialiserWidget() {
1142 aurelien 67
	urlVars = getUrlVars();
1448 aurelien 68
	dimensionnerCarte();
1442 aurelien 69
	definirTailleOverlay();
1450 aurelien 70
	initialiserCarte();
1442 aurelien 71
	attribuerListenersOverlay();
1438 aurelien 72
	centrerTitreEtStats();
836 jpm 73
	initialiserAffichagePanneauLateral();
980 jpm 74
	initialiserGestionnaireMarqueurs()
836 jpm 75
	initialiserInfoBulle();
941 jpm 76
	initialiserFormulaireContact();
836 jpm 77
	chargerLimitesCommunales();
1032 aurelien 78
	attribuerListenerCarte();
836 jpm 79
}
80
 
1586 jpm 81
function getUrlVars() {
82
	var vars = [], hash;
83
	if (window.location.href.indexOf('?') != -1) {
84
		var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
85
		for (var i = 0; i < hashes.length; i++) {
86
			hash = hashes[i].split('=');
87
			vars.push(hash[0]);
88
			vars[hash[0]] = hash[1];
89
		}
90
	}
91
	return vars;
1142 aurelien 92
}
93
 
915 jpm 94
/*+--------------------------------------------------------------------------------------------------------+*/
95
// AFFICHAGE GÉNÉRAL
96
 
1438 aurelien 97
function afficherTitreCarteEtStats() {
980 jpm 98
	if (stations != null && taxonsCarte.length > 0) {
1039 aurelien 99
		var obsNbre = stations.stats.observations;
1173 aurelien 100
		var obsNbreFormate = obsNbre;
101
		if(obsNbre != 0) {
102
		    obsNbreFormate = stations.stats.observations.formaterNombre();
103
		}
1039 aurelien 104
		var plteNbre = taxonsCarte.length;
1173 aurelien 105
		var plteNbreFormate = plteNbre;
1586 jpm 106
		if (plteNbre != 0) {
107
			plteNbreFormate = taxonsCarte.length.formaterNombre();
1173 aurelien 108
		}
1039 aurelien 109
		var communeNbre = stations.stats.communes;
1173 aurelien 110
		var communeNbreFormate = communeNbre;
111
		if(communeNbre != 0) {
112
		   communeNbreFormate = stations.stats.communes.formaterNombre();
113
		}
1172 aurelien 114
		var stationNbre = stations.stats.stations;
1173 aurelien 115
		var stationNbreFormate = stationNbre;
116
		if(stationNbre != 0) {
117
		  	stationNbreFormate = stations.stats.stations.formaterNombre();
118
		}
980 jpm 119
 
1438 aurelien 120
		var stats = obsNbreFormate+' observation';
121
		stats += (obsNbre > 1) ? 's' : '' ;
1434 aurelien 122
 
1586 jpm 123
		if (photos != null && photos == 1) {
1438 aurelien 124
			stats += ' avec photos ';
1434 aurelien 125
		}
980 jpm 126
 
1438 aurelien 127
		stats += ' sur '+(stationNbre+ communeNbre)+' station';
128
		stats += (stationNbre > 1) ? 's' : '' ;
1447 aurelien 129
 
980 jpm 130
		if (nt == '*') {
1438 aurelien 131
			stats += ' parmi '+plteNbreFormate+' plante';
132
			stats += (plteNbre > 1) ? 's' : '' ;
980 jpm 133
		} else {
1430 aurelien 134
			if($('.taxon-actif .taxon').text() != '') {
135
				var element = $('.taxon-actif .taxon').clone();
136
				element.children().remove();
1586 jpm 137
				var taxon = element.text();
138
				stats += ' pour '+taxon;
1430 aurelien 139
			} else {
140
				if (taxonsCarte[0]) {
141
					var taxon = taxonsCarte[0];
1438 aurelien 142
					stats += ' pour '+taxon.nom;
1430 aurelien 143
				}
980 jpm 144
			}
145
		}
146
 
1514 aurelien 147
		if(utilisateur != '*') {
148
			stats += ' pour l\'utilisateur '+utilisateur+' ';
149
		}
150
 
1438 aurelien 151
		$('#zone-stats').show();
1448 aurelien 152
	} else {
153
		stats = "Aucune observation pour ces critères ou pour cette zone";
980 jpm 154
	}
1448 aurelien 155
 
156
	$('#zone-stats > h1').text(stats);
1438 aurelien 157
	centrerTitreEtStats();
836 jpm 158
}
159
 
1442 aurelien 160
function attribuerListenersOverlay() {
161
	$(window).resize(function() {
1448 aurelien 162
		dimensionnerCarte();
1442 aurelien 163
		definirTailleOverlay();
164
		centrerTitreEtStats();
1445 aurelien 165
		programmerRafraichissementCarte();
1450 aurelien 166
		google.maps.event.trigger($('#carte'), 'resize');
1442 aurelien 167
	});
168
 
169
	$('#lien_plein_ecran a').click(function(event) {
170
		window.open(window.location.href);
1445 aurelien 171
		event.preventDefault();
1442 aurelien 172
	});
173
 
1447 aurelien 174
	$('#lien-voir-cc a').click(function(event) {
175
		ouvrirPopUp(this, 'Avertissement', event);
1445 aurelien 176
		event.preventDefault();
1442 aurelien 177
	});
178
}
179
 
1514 aurelien 180
var tailleMaxFiltreUtilisateur;
1442 aurelien 181
function definirTailleOverlay() {
1586 jpm 182
	var largeurViewPort = $(window).width(),
183
		taille = '1.6',
184
		tailleMaxLogo = 60,
185
		tailleMaxIcones = 10,
186
		padding_icones = 8,
187
		tailleFiltre = 80;
1514 aurelien 188
	tailleMaxFiltreUtilisateur = 350;
189
	$('#raz-filtre-utilisateur').css('display', 'block');
1448 aurelien 190
	if (largeurViewPort <= 450) {
191
		taille = '1';
192
		tailleMaxIcones = 10;
193
		tailleFiltre = 65;
194
		padding_icones = 2;
195
		var tailleMaxLogo = 50;
1514 aurelien 196
		$('#raz-filtre-utilisateur').css('display', 'inline');
1448 aurelien 197
	} else if (largeurViewPort <= 500) {
1447 aurelien 198
		taille = '1.2';
1442 aurelien 199
		tailleMaxIcones = 10;
1447 aurelien 200
		tailleFiltre = 65;
201
		padding_icones = 2;
1448 aurelien 202
		var tailleMaxLogo = 50;
1514 aurelien 203
		tailleMaxFiltreUtilisateur = 200;
204
		$('#raz-filtre-utilisateur').css('display', 'inline');
1442 aurelien 205
	} else if (largeurViewPort > 500 && largeurViewPort <= 800) {
1447 aurelien 206
		taille = '1.4';
1442 aurelien 207
		tailleMaxIcones = 15;
208
		padding_icones = 6;
1447 aurelien 209
		tailleFiltre = 65;
1448 aurelien 210
		var tailleMaxLogo = 55;
1514 aurelien 211
		tailleMaxFiltreUtilisateur = 250;
1442 aurelien 212
	} else if (largeurViewPort > 800) {
980 jpm 213
		taille = '1.6';
1442 aurelien 214
		tailleMaxIcones = 20;
215
		padding_icones = 8;
1445 aurelien 216
		tailleFiltre = 80;
1514 aurelien 217
		tailleMaxFiltreUtilisateur = 350;
980 jpm 218
	}
1438 aurelien 219
 
220
	// Aménagement de la taille de police selon l'écran
980 jpm 221
	$("#carte-titre").css('font-size', taille+'em');
1442 aurelien 222
 
1448 aurelien 223
	$("#zone-stats h1").css('font-size', Math.round((taille*0.75*100))/100+'em');
1447 aurelien 224
	$("#zone-stats").css('padding', padding_icones+"px "+padding_icones+"px "+Math.round(padding_icones/4)+"px");
225
	$('#zone-stats').height(tailleMaxIcones*1.5);
1438 aurelien 226
 
1447 aurelien 227
	$("#zone-titre h1").css('font-size', (taille)+'em');
228
	$("#zone-titre").css('padding', padding_icones+"px "+padding_icones+"px "+Math.round(padding_icones/4)+"px");
229
	$('#zone-titre').height(tailleMaxIcones*2);
230
 
1442 aurelien 231
	$('.icone').height(tailleMaxIcones);
232
	$('#lien_plein_ecran').css("padding", padding_icones+"px "+padding_icones+"px "+Math.ceil(padding_icones/2)+"px");
233
 
1447 aurelien 234
	$('#lien-voir-cc').css("font-size", taille+"em");
235
	$('#lien-voir-cc').css("padding", padding_icones+"px");
1442 aurelien 236
 
1447 aurelien 237
	$("#panneau-lateral").css('font-size', (taille*0.9)+'em');
238
	$("#pl-contenu").css('font-size', (taille/2)+'em');
239
 
1445 aurelien 240
	$("#panneau-lateral").css('padding', padding_icones+"px "+padding_icones+"px "+Math.round(padding_icones/4)+"px");
1447 aurelien 241
	$('#pl-ouverture').height(((padding_icones*2)+$('#panneau-lateral').height())+"px");
1445 aurelien 242
	$("#panneau-lateral").width(tailleFiltre);
1514 aurelien 243
 
244
	$('#lien-affichage-filtre-utilisateur').width(tailleFiltre);
245
	$('#lien-affichage-filtre-utilisateur').height(tailleFiltre*0.35);
246
	$('#lien-affichage-filtre-utilisateur').css('font-size', (taille*0.9)+'em');
247
	$('#conteneur-filtre-utilisateur').css('max-width',tailleMaxFiltreUtilisateur);
1448 aurelien 248
 
249
	dimensionnerLogo(tailleMaxLogo);
250
	dimensionnerImage(largeurViewPort);
251
	redimensionnerControleTypeCarte(largeurViewPort);
252
}
253
 
254
function dimensionnerLogo(tailleMaxLogo) {
255
	// Dimensionnement du logo
1447 aurelien 256
	hauteurLogo = $('.image-logo').height();
257
	// Redimensionnement du logo s'il est trop grand
258
	// on perd en qualité mais ça vaut mieux que de casser l'affichage
1586 jpm 259
	if (hauteurLogo > tailleMaxLogo) {
1447 aurelien 260
		hauteurLogo = tailleMaxLogo;
261
		$('.image-logo').css("top", "5px");
262
		$('.image-logo').height(tailleMaxLogo);
1438 aurelien 263
	}
1447 aurelien 264
 
1586 jpm 265
	if (hauteurLogo == 0) {
1447 aurelien 266
		$('.image-logo').load(function(event) {
267
			definirTailleOverlay();
268
		});
269
		return;
270
	}
271
 
272
	largeurLogo = $('#logo img').width();
980 jpm 273
}
274
 
1448 aurelien 275
function dimensionnerImage(largeurViewPort) {
276
	// Dimensionnement de l'image
1586 jpm 277
	if (largeurViewPort > 500) {
1448 aurelien 278
		largeurLogo = 155;
279
	} else {
280
		largeurLogo = 70;
281
	}
282
 
283
	$('#image-utilisateur img').width(largeurLogo);
284
}
285
 
286
function redimensionnerControleTypeCarte(largeurViewPort) {
287
	if (largeurViewPort <= 500) {
288
		carteOptions.mapTypeControlOptions.style = google.maps.MapTypeControlStyle.DROPDOWN_MENU;
289
	} else {
290
		carteOptions.mapTypeControlOptions.style = google.maps.MapTypeControlStyle.DEFAULT;
291
	}
292
 
1586 jpm 293
	if (map != null) {
1450 aurelien 294
		map.setOptions(carteOptions);
295
	}
1448 aurelien 296
}
297
 
1438 aurelien 298
function centrerTitreEtStats() {
1442 aurelien 299
	centrerTitre();
300
	centrerStats();
301
}
302
 
303
function centrerTitre() {
1586 jpm 304
	var largeurViewPort = $(window).width(),
305
		largeurTitre = $('#zone-titre').width(),
306
		marge = (largeurViewPort - largeurTitre)/2;
1438 aurelien 307
	$('#zone-titre').css("margin-left",marge);
1586 jpm 308
 
1445 aurelien 309
	var tailleRestante = largeurViewPort - (marge + largeurTitre);
1586 jpm 310
	if (tailleRestante <= 170) {
1445 aurelien 311
		$('#zone-titre').css("top", "25px");
312
	} else {
313
		$('#zone-titre').css("top", "5px");
314
	}
1442 aurelien 315
}
316
 
317
function centrerStats() {
1586 jpm 318
	var largeurViewPort = $(window).width(),
319
		largeurStats = $('#zone-stats').width(),
320
		marge = ((largeurViewPort - largeurStats)/2);
1448 aurelien 321
	$('#zone-stats').css("margin-left",marge);
1438 aurelien 322
}
323
 
915 jpm 324
/*+--------------------------------------------------------------------------------------------------------+*/
325
// CARTE
326
 
1448 aurelien 327
function dimensionnerCarte() {
1450 aurelien 328
	var largeurViewPort = $(window).width();
329
	var hauteurViewPort = $(window).height();
330
	$('#carte').height(hauteurViewPort);
331
	$('#carte').width(largeurViewPort);
836 jpm 332
}
333
 
334
function initialiserCarte() {
335
	map = new google.maps.Map(document.getElementById('carte'), carteOptions);
336
	// Ajout de la couche OSM à la carte
337
	map.mapTypes.set('OSM', osmMapType);
338
}
339
 
980 jpm 340
function initialiserGestionnaireMarqueurs() {
341
	mgr = new MarkerManager(map);
342
}
836 jpm 343
 
344
function chargerLimitesCommunales() {
345
	if (urlsLimitesCommunales != null) {
346
		for (urlId in urlsLimitesCommunales) {
347
			var url = urlsLimitesCommunales[urlId];
1107 aurelien 348
			ctaLayer = new google.maps.KmlLayer(url, {preserveViewport: true});
836 jpm 349
			ctaLayer.setMap(map);
350
		}
351
	}
352
}
1039 aurelien 353
 
1586 jpm 354
var listener = null,
355
	timer = null;
356
 
1032 aurelien 357
function attribuerListenerCarte() {
980 jpm 358
	listener = google.maps.event.addListener(map, 'bounds_changed', function(){
1032 aurelien 359
		programmerRafraichissementCarte();
980 jpm 360
	});
1032 aurelien 361
	listener = google.maps.event.addListener(map, 'zoom_changed', function(){
362
		programmerRafraichissementCarte();
363
	});
980 jpm 364
}
1586 jpm 365
 
1032 aurelien 366
function programmerRafraichissementCarte() {
1586 jpm 367
	if (timer != null) {
368
		window.clearTimeout(timer);
369
	}
370
	if (requeteChargementPoints != null) {
1035 aurelien 371
		requeteChargementPoints.abort();
372
	}
1032 aurelien 373
	timer = window.setTimeout(function() {
1586 jpm 374
		if (map.getBounds() != undefined) {
375
			var zoom = map.getZoom(),
376
				lngNE = map.getBounds().getNorthEast().lng(),
377
				lngSW = map.getBounds().getSouthWest().lng()
378
			if (map.getBounds().getNorthEast().lng() < map.getBounds().getSouthWest().lng()) {
1434 aurelien 379
				lngNE = 176;
380
				lngSW = -156;
381
			}
1586 jpm 382
			var NELatLng = (map.getBounds().getNorthEast().lat())+'|'+(lngNE),
383
				SWLatLng = (map.getBounds().getSouthWest().lat())+'|'+(lngSW);
1342 aurelien 384
			chargerMarqueurs(zoom, NELatLng, SWLatLng);
385
		} else {
386
			programmerRafraichissementCarte();
387
		}
1586 jpm 388
	}, 400);
1032 aurelien 389
}
836 jpm 390
 
980 jpm 391
var marqueurs = new Array();
392
function chargerMarqueurs(zoom, NELatLng, SWLatLng) {
1445 aurelien 393
	cacherMessageAucuneObs()
980 jpm 394
	var url = stationsUrl+
395
		'&zoom='+zoom+
396
		'&ne='+NELatLng+
397
		'&sw='+SWLatLng;
398
 
1586 jpm 399
	if (infoBulleOuverte) {
1032 aurelien 400
		return;
401
	}
402
 
1586 jpm 403
	if (requeteChargementPoints != null) {
1035 aurelien 404
		requeteChargementPoints.abort();
1037 aurelien 405
		cacherMessageChargementPoints();
1035 aurelien 406
	}
407
 
408
	afficherMessageChargementPoints();
409
	requeteChargementPoints = $.getJSON(url, function(data) {
410
		rafraichirMarqueurs(data);
411
		cacherMessageChargementPoints();
980 jpm 412
	});
413
}
414
 
1442 aurelien 415
function centrerDansLaPage(selecteur) {
1586 jpm 416
	var largeurViewport = $(window).width(),
417
		hauteurViewport = $(window).height();
1442 aurelien 418
	selecteur.css('display','block');
1586 jpm 419
	var left = (largeurViewport/2) - (selecteur.width())/2,
420
		top = (hauteurViewport/2) - (selecteur.height())/2
1442 aurelien 421
	selecteur.css('left',left);
422
	selecteur.css('top',top);
423
}
424
 
1035 aurelien 425
function afficherMessageChargementPoints() {
1442 aurelien 426
	centrerDansLaPage($('#zone-chargement-point'));
1035 aurelien 427
	$('#zone-chargement-point').css('display','block');
428
}
429
 
430
function cacherMessageChargementPoints() {
431
	$('#zone-chargement-point').css('display','none');
432
}
433
 
1442 aurelien 434
function afficherMessageAucuneObs() {
435
	centrerDansLaPage($('#message-aucune-obs'));
1445 aurelien 436
	$('#message-aucune-obs').show();
1442 aurelien 437
}
438
 
1445 aurelien 439
function cacherMessageAucuneObs() {
440
	centrerDansLaPage($('#message-aucune-obs'));
441
	$('#message-aucune-obs').hide();
442
}
443
 
1107 aurelien 444
premierChargement = true;
1142 aurelien 445
function doitCentrerCarte() {
446
	return premierChargement && urlVars != null && urlVars.length > 0;
447
}
1107 aurelien 448
 
1035 aurelien 449
function rafraichirMarqueurs(data) {
1450 aurelien 450
	$.each(marqueurs, function(index, marqueur) {
451
		marqueur.setMap(null);
452
	});
453
 
1448 aurelien 454
	marqueurs = new Array();
455
	stations = null;
456
 
1586 jpm 457
	if (data.points.length > 0) {
1442 aurelien 458
		marqueurs = new Array();
459
		stations = data;
460
 
461
		$.each(stations.points, function (index, station) {
462
			if(station != null) {
463
				var nouveauMarqueur = creerMarqueur(station);
464
				marqueurs.push(nouveauMarqueur);
465
			}
466
		});
467
 
1586 jpm 468
		if (doitCentrerCarte()) {
1442 aurelien 469
			premierChargement = false;
1586 jpm 470
			var bounds = new google.maps.LatLngBounds(),
471
				latMax = new google.maps.LatLng(data.stats.coordmax.latMax, data.stats.coordmax.lngMax),
472
				latMin = new google.maps.LatLng(data.stats.coordmax.latMin, data.stats.coordmax.lngMin);
1442 aurelien 473
			bounds.extend(latMax);
474
			bounds.extend(latMin);
475
			rendrePointsVisibles(bounds);
1035 aurelien 476
		}
1107 aurelien 477
	}
1448 aurelien 478
 
479
	afficherTitreCarteEtStats();
1035 aurelien 480
}
481
 
980 jpm 482
function creerMarqueur(station) {
1037 aurelien 483
	var titre = '';
1586 jpm 484
	if (station.nbreMarqueur) {
1037 aurelien 485
		titre = station.nbreMarqueur+' points renseignés';
486
	} else {
487
		if(station.nom) {
488
			titre = station.nom;
489
		}
490
	}
1434 aurelien 491
 
1586 jpm 492
	var icone = attribuerImageMarqueur(station['id'], station['nbreMarqueur']),
493
		latLng = new google.maps.LatLng(station['lat'], station['lng']),
494
			marqueur = new google.maps.Marker({
495
				position: latLng,
496
				icon: icone,
497
				title: ''+titre,
498
				map: map,
499
				stationInfos: station
500
			});
980 jpm 501
	attribuerListenerClick(marqueur, station['id']);
502
	marqueur.setMap(map);
1586 jpm 503
	return marqueur;
980 jpm 504
}
505
 
1039 aurelien 506
function rendrePointsVisibles(bounds) {
507
	map.setCenter(bounds.getCenter());
508
	map.fitBounds(bounds);
509
}
510
 
980 jpm 511
function attribuerImageMarqueur(id, nbreMarqueur) {
512
	var marqueurImage = null;
513
	if (etreMarqueurCommune(id)) {
514
		marqueurImage = new google.maps.MarkerImage(communeImageUrl, new google.maps.Size(24, 32));
515
	} else if (etreMarqueurStation(id)) {
516
		marqueurImage = new google.maps.MarkerImage(pointImageUrl, new google.maps.Size(16, 16));
517
	} else if (etreMarqueurGroupe(id)) {
1586 jpm 518
		var type = 0,
519
			largeur = 0,
520
			hauteur = 0;
980 jpm 521
		if (nbreMarqueur != null) {
522
			if (nbreMarqueur >= 2 && nbreMarqueur < 100 ) {
523
				type = '1';
524
				largeur = 53;
525
				hauteur = 52;
526
			} else if (nbreMarqueur >= 100 && nbreMarqueur < 1000 ) {
527
				type = '2';
528
				largeur = 56;
529
				hauteur = 55;
530
			} else if (nbreMarqueur >= 1000 && nbreMarqueur < 10000 ) {
531
				type = '3';
532
				largeur = 66;
533
				hauteur = 65;
534
			} else if (nbreMarqueur >= 10000 && nbreMarqueur < 20000 ) {
535
				type = '4';
536
				largeur = 78;
537
				hauteur = 77;
538
			} else if (nbreMarqueur >= 20000) {
539
				type = '5';
540
				largeur = 66;
541
				hauteur = 65;
542
			}
543
		}
544
		groupeImageUrl = groupeImageUrlTpl.replace(/\{type\}/, type);
545
		groupeImageUrl = groupeImageUrl.replace(/\{nbre\}/, nbreMarqueur);
546
		marqueurImage = new google.maps.MarkerImage(groupeImageUrl, new google.maps.Size(largeur, hauteur));
547
	}
548
	return marqueurImage
549
}
550
 
551
function attribuerListenerClick(marqueur, id) {
552
	if (etreMarqueurCommune(id) || etreMarqueurStation(id)) {
553
		google.maps.event.addListener(marqueur, 'click', surClickMarqueur);
554
	} else if (etreMarqueurGroupe(id)) {
555
		google.maps.event.addListener(marqueur, 'click', surClickGroupe);
556
	}
557
}
558
 
1445 aurelien 559
var pointCentreAvantAffichageInfoBulle = null;
1032 aurelien 560
function surClickMarqueur(event) {
1445 aurelien 561
	pointCentreAvantAffichageInfoBulle = map.getCenter();
1586 jpm 562
 
1039 aurelien 563
	if(infoBulleOuverte) {
1586 jpm 564
		infoBulle.close();
1039 aurelien 565
	}
1586 jpm 566
 
1035 aurelien 567
	pointClique = this;
980 jpm 568
	infoBulle.open(map, this);
569
	actualiserPagineur();
1586 jpm 570
 
571
	var limites = map.getBounds(),
572
		centre = limites.getCenter(),
573
		nordEst = limites.getNorthEast(),
574
		centreSudLatLng = new google.maps.LatLng(nordEst.lat(), centre.lng());
1035 aurelien 575
	map.panTo(centreSudLatLng);
576
 
980 jpm 577
	afficherInfoBulle();
578
}
579
 
580
function surClickGroupe() {
581
	map.setCenter(this.getPosition());
582
	var nouveauZoom = map.getZoom() + 2;
583
	map.setZoom(nouveauZoom);
584
	mgr.clearMarkers();
585
}
586
 
587
function etreMarqueurGroupe(id) {
1586 jpm 588
	var groupe = false,
589
		motif = /^GROUPE/;
980 jpm 590
	if (motif.test(id)) {
591
		groupe = true;
592
	}
593
	return groupe;
594
}
595
 
596
function etreMarqueurCommune(id) {
1586 jpm 597
	var commune = false,
598
		motif = /^COMMUNE:/;
980 jpm 599
	if (motif.test(id)) {
600
		commune = true;
601
	}
602
	return commune;
603
}
604
 
605
function etreMarqueurStation(id) {
1586 jpm 606
	var station = false,
607
		motif = /^STATION:/;
980 jpm 608
	if (motif.test(id)) {
609
		station = true;
610
	}
611
	return station;
612
}
613
 
614
function deplacerCarteSurPointClique() {
915 jpm 615
	map.panTo(pointClique.position);
616
}
617
 
618
/*+--------------------------------------------------------------------------------------------------------+*/
619
// INFO BULLE
1032 aurelien 620
var infoBulleOuverte = false;
915 jpm 621
function initialiserInfoBulle() {
622
	google.maps.event.addListener(infoBulle, 'domready', initialiserContenuInfoBulle);
980 jpm 623
	google.maps.event.addListener(infoBulle, 'closeclick', surFermetureInfoBulle);
624
	google.maps.event.addListener(infoBulle, 'content_changed', definirLargeurInfoBulle);
1513 aurelien 625
	attribuerListenerLienSaisie();
915 jpm 626
}
627
 
1513 aurelien 628
function attribuerListenerLienSaisie() {
629
	$('.lien-widget-saisie').live('click', function(event) {
630
		event.preventDefault();
631
		window.open($(this).attr('href'), '_blank');
632
		return false;
633
	});
634
}
635
 
980 jpm 636
function surFermetureInfoBulle() {
1032 aurelien 637
	infoBulleOuverte = false;
1445 aurelien 638
	map.panTo(pointCentreAvantAffichageInfoBulle);
1032 aurelien 639
	programmerRafraichissementCarte();
980 jpm 640
}
641
 
642
function centrerInfoBulle() {
1586 jpm 643
	var limites = map.getBounds(),
644
		centre = limites.getCenter(),
645
		nordEst = limites.getNorthEast(),
646
		centreSudLatLng = new google.maps.LatLng(nordEst.lat(), centre.lng());
980 jpm 647
	map.panTo(centreSudLatLng);
648
}
649
 
915 jpm 650
function afficherInfoBulle() {
1586 jpm 651
	var obsHtml = $('#tpl-obs').html(),
652
		largeur = definirLargeurInfoBulle(),
653
		taillePolice = definirTaillePoliceInfoBulle();
980 jpm 654
	obsHtml = obsHtml.replace(/\{largeur\}/, largeur);
915 jpm 655
	infoBulle.setContent(obsHtml);
1586 jpm 656
	$('#observations').css('font-size', taillePolice + 'em');
1035 aurelien 657
	chargerObs(0, 0);
1032 aurelien 658
	infoBulleOuverte = true;
915 jpm 659
}
660
 
1513 aurelien 661
//TODO utiliser cette fonction lors des remplacements de
662
//paramètres url sur changement de filtre
663
function parserFiltre(filtre) {
1586 jpm 664
	var nvpair = {},
665
		qs = filtre.replace('?', ''),
666
		pairs = qs.split('&');
1513 aurelien 667
	$.each(pairs, function(i, v){
668
		var pair = v.split('=');
669
		nvpair[pair[0]] = pair[1];
670
	});
671
	return nvpair;
672
}
673
 
1586 jpm 674
function mettreAJourUrlSaisie(obs) {
675
	if (obs.observations.length > 0) {
676
		var filtreTableau = parserFiltre(filtreCommun),
677
			filtresGardes = new Array()
678
			idObs = obs.observations[0].idObs;
679
		filtre = '';
680
		for (i in filtreTableau) {
681
			if (filtreTableau[i] != undefined && filtreTableau[i] != '' && decodeURIComponent(filtreTableau[i]) != '*') {
682
				console.log(i + '  ' + filtreTableau[i]);
683
				filtresGardes.push(i + '=' + filtreTableau[i]);
684
			}
1513 aurelien 685
		}
1586 jpm 686
		filtresGardes.push('id-obs=' + idObs);
687
		if (filtresGardes.length > 0) {
688
			filtre = '?' + filtresGardes.join('&');
689
		}
690
		var urlAvecFiltre = urlWidgetSaisie + filtre;
691
		$('.lien-widget-saisie').attr('href', urlAvecFiltre).parents('.conteneur-lien-saisie').show();
1513 aurelien 692
	}
693
}
694
 
980 jpm 695
function definirLargeurInfoBulle() {
1586 jpm 696
	var largeurViewPort = $(window).width(),
697
		largeurInfoBulle = null;
1445 aurelien 698
	if (largeurViewPort < 400) {
699
		largeurInfoBulle = 300;
700
	} else if (largeurViewPort < 800) {
980 jpm 701
		largeurInfoBulle = 400;
702
	} else if (largeurViewPort >= 800 && largeurViewPort < 1200) {
703
		largeurInfoBulle = 500;
704
	} else if (largeurViewPort >= 1200) {
705
		largeurInfoBulle = 600;
706
	}
707
	return largeurInfoBulle;
708
}
709
 
1445 aurelien 710
function definirTaillePoliceInfoBulle() {
1586 jpm 711
	var largeurViewPort = $(window).width(),
712
		taillePolice = null;
1445 aurelien 713
	if (largeurViewPort < 400) {
714
		taillePolice = 0.8;
715
	} else if (largeurViewPort < 800) {
716
		taillePolice = 1;
717
	}
718
	return taillePolice;
719
}
720
 
915 jpm 721
function afficherMessageChargement(element) {
722
	if ($('#chargement').get() == '') {
723
		$('#tpl-chargement').tmpl().appendTo(element);
724
	}
725
}
726
 
1035 aurelien 727
function afficherMessageChargementTitreInfoBulle() {
728
	$("#obs-station-titre").text("Chargement des observations");
729
}
730
 
915 jpm 731
function supprimerMessageChargement() {
732
	$('#chargement').remove();
733
}
734
 
735
function chargerObs(depart, total) {
939 jpm 736
	if (depart == 0 || depart < total) {
915 jpm 737
		var limite = 300;
738
		if (depart == 0) {
1036 aurelien 739
			viderTableauObs();
915 jpm 740
		}
1035 aurelien 741
 
939 jpm 742
		var urlObs = observationsUrl+'&start={start}&limit='+limite;
1166 aurelien 743
		urlObs = urlObs.replace(/\{stationId\}/g, encodeURIComponent(pointClique.stationInfos.id));
1044 aurelien 744
		if (pointClique.stationInfos.type_emplacement == 'communes') {
1342 aurelien 745
			urlObs = urlObs.replace(/commune=%2A/g, formaterParametreCommunePourRequete(pointClique.stationInfos.nom));
1042 aurelien 746
		}
939 jpm 747
		urlObs = urlObs.replace(/\{nt\}/g, nt);
915 jpm 748
		urlObs = urlObs.replace(/\{start\}/g, depart);
749
 
750
		$.getJSON(urlObs, function(observations){
1036 aurelien 751
			surRetourChargementObs(observations, depart, total);
1035 aurelien 752
			chargerObs(depart+limite, observations.total);
915 jpm 753
		});
1036 aurelien 754
	}
755
}
756
 
1342 aurelien 757
function formaterParametreCommunePourRequete(nomCommune) {
758
	var chaineRequete = "";
759
	if(nomCommune.indexOf("(", 0) !== false) {
760
		var infosCommune = nomCommune.split("(");
761
		var commune = infosCommune[0];
762
		chaineRequete = 'commune='+encodeURIComponent($.trim(commune));
763
	} else {
764
		chaineRequete = 'commune='+encodeURIComponent($.trim(nomCommune));
765
	}
766
	return chaineRequete;
767
}
768
 
1036 aurelien 769
function viderTableauObs() {
770
	obsStation = new Array();
771
	surClicPagePagination(0, null);
772
}
773
 
774
function surRetourChargementObs(observations, depart, total) {
775
	obsStation = obsStation.concat(observations.observations);
776
	if (depart == 0) {
777
		actualiserInfosStation(observations);
778
		creerTitreInfoBulle();
1586 jpm 779
		surClicPagePagination(0, null);
780
		console.log(observations);
781
		mettreAJourUrlSaisie(observations);
915 jpm 782
	}
1036 aurelien 783
 
1039 aurelien 784
	afficherPagination();
1036 aurelien 785
	actualiserPagineur();
1041 aurelien 786
	selectionnerOnglet("#obs-vue-"+pagineur.format);
915 jpm 787
}
788
 
1035 aurelien 789
function actualiserInfosStation(infos) {
790
	pointClique.stationInfos.commune = infos.commune;
791
	pointClique.stationInfos.obsNbre = infos.total;
792
}
793
 
794
function creerTitreInfoBulle() {
1586 jpm 795
	$('#obs-total').text(station.obsNbre);
796
	$('#obs-commune').text(station.commune);
1035 aurelien 797
	var titre = '';
798
	titre += pointClique.stationInfos.obsNbre+' observation';
799
	titre += (pointClique.stationInfos.obsNbre > 1) ? 's': '' ;
800
	titre += ' pour ';
801
	if (etreMarqueurCommune(pointClique.stationInfos.id)) {
802
		nomStation = 'la commune : ';
803
	} else {
804
		nomStation = 'la station : ';
805
	}
806
	titre += pointClique.stationInfos.nom;
1586 jpm 807
	$('#obs-station-titre').text(titre);
1035 aurelien 808
}
809
 
939 jpm 810
function actualiserPagineur() {
980 jpm 811
	pagineur.stationId = pointClique.stationInfos.id;
1035 aurelien 812
	pagineur.total = pointClique.stationInfos.obsNbre;
1435 aurelien 813
	// Si on est en mode photo on reste en mode liste quelque soit le
814
	// nombre de résultats
1438 aurelien 815
	if (pagineur.total > 4 && photos != 1) {
939 jpm 816
		pagineur.format = 'tableau';
817
	} else {
818
		pagineur.format = 'liste';
819
	}
820
}
821
 
915 jpm 822
function afficherPagination(observations) {
1586 jpm 823
	$('.navigation').pagination(pagineur.total, {
915 jpm 824
		items_per_page:pagineur.limite,
825
		callback:surClicPagePagination,
826
		next_text:'Suivant',
827
		prev_text:'Précédent',
828
		prev_show_always:false,
829
		num_edge_entries:1,
953 jpm 830
		num_display_entries:4,
915 jpm 831
		load_first_page:true
832
	});
833
}
834
 
835
function surClicPagePagination(pageIndex, paginationConteneur) {
1586 jpm 836
	var index = pageIndex * pagineur.limite,
837
		indexMax = index + pagineur.limite;
915 jpm 838
	pagineur.depart = index;
839
	obsPage = new Array();
1586 jpm 840
	for (index; index < indexMax; index++) {
841
		obsPage.push(obsStation[index]);
842
	}
843
 
844
	supprimerMessageChargement();
845
	mettreAJourObservations();
915 jpm 846
	return false;
847
}
848
 
849
function mettreAJourObservations() {
1586 jpm 850
	$('#obs-'+pagineur.format+'-lignes').empty();
851
	$('#obs-vue-'+pagineur.format).css('display', 'block');
852
	$('.obs-conteneur').css('counter-reset', 'item '+pagineur.depart);
853
	$('#tpl-obs-'+pagineur.format).tmpl(obsPage).appendTo('#obs-'+pagineur.format+'-lignes');
915 jpm 854
 
855
	// Actualisation de Fancybox
1586 jpm 856
	ajouterFormulaireContact('a.contact');
915 jpm 857
	if (pagineur.format == 'liste') {
1586 jpm 858
		ajouterGaleriePhoto('a.cel-img');
836 jpm 859
	}
860
}
861
 
915 jpm 862
function initialiserContenuInfoBulle() {
980 jpm 863
	afficherMessageChargement('#observations');
864
	cacherContenuOnglets();
915 jpm 865
	afficherOnglets();
1586 jpm 866
	ajouterTableauTriable('#obs-tableau');
915 jpm 867
	afficherTextStationId();
868
	corrigerLargeurInfoWindow();
869
}
870
 
980 jpm 871
function cacherContenuOnglets() {
1586 jpm 872
	$('#obs-vue-tableau').css('display', 'none');
873
	$('#obs-vue-liste').css('display', 'none');
980 jpm 874
}
875
 
915 jpm 876
function afficherOnglets() {
877
	var $tabs = $('#obs').tabs();
878
	$('#obs').bind('tabsselect', function(event, ui) {
879
		if (ui.panel.id == 'obs-vue-tableau') {
880
			surClicAffichageTableau();
881
		} else if (ui.panel.id == 'obs-vue-liste') {
882
			surClicAffichageListe();
883
		}
884
	});
980 jpm 885
	if (pointClique.stationInfos.nbre > 4) {
886
		$tabs.tabs('select', "#obs-vue-tableau");
887
	} else {
888
		$tabs.tabs('select', "#obs-vue-liste");
889
	}
890
 
915 jpm 891
}
892
 
939 jpm 893
function selectionnerOnglet(onglet) {
980 jpm 894
	$(onglet).css('display', 'block');
939 jpm 895
	$('#obs').tabs('select', onglet);
896
}
897
 
915 jpm 898
function afficherTextStationId() {
980 jpm 899
	$('#obs-station-id').text(pointClique.stationInfos.id);
915 jpm 900
}
901
 
902
function corrigerLargeurInfoWindow() {
953 jpm 903
	$("#info-bulle").width($("#info-bulle").width() - 17);
915 jpm 904
}
905
 
906
function surClicAffichageTableau(event) {
907
	pagineur.format = 'tableau';
908
	mettreAJourObservations();
909
	mettreAJourTableauTriable("#obs-tableau");
910
}
911
 
912
function surClicAffichageListe(event) {
913
	pagineur.format = 'liste';
914
	mettreAJourObservations();
915
	ajouterGaleriePhoto("a.cel-img");
916
}
917
 
836 jpm 918
function ajouterTableauTriable(element) {
919
	// add parser through the tablesorter addParser method
920
	$.tablesorter.addParser({
921
		// Définition d'un id unique pour ce parsseur
922
		id: 'date_cel',
923
		is: function(s) {
915 jpm 924
			// doit retourner false si le parsseur n'est pas autodétecté
925
			return /^\s*\d{2}[\/-]\d{2}[\/-]\d{4}\s*$/.test(s);
836 jpm 926
		},
915 jpm 927
		format: function(date) {
836 jpm 928
			// Transformation date jj/mm/aaaa en aaaa/mm/jj
915 jpm 929
			date = date.replace(/^\s*(\d{2})[\/-](\d{2})[\/-](\d{4})\s*$/, "$3/$2/$1");
836 jpm 930
			// Remplace la date par un nombre de millisecondes pour trier numériquement
915 jpm 931
			return $.tablesorter.formatFloat(new Date(date).getTime());
836 jpm 932
		},
933
		// set type, either numeric or text
934
		type: 'numeric'
935
	});
936
	$(element).tablesorter({
1586 jpm 937
		headers: {
915 jpm 938
			1: {
1586 jpm 939
				sorter: 'date_cel'
940
			}
941
		}
915 jpm 942
	});
836 jpm 943
}
944
 
915 jpm 945
function mettreAJourTableauTriable(element) {
946
	$(element).trigger('update');
947
}
948
 
836 jpm 949
function ajouterGaleriePhoto(element) {
950
	$(element).fancybox({
1586 jpm 951
		transitionIn: 'elastic',
952
		transitionOut: 'elastic',
953
		speedIn: 600,
954
		speedOut: 200,
955
		overlayShow: true,
956
		titleShow: true,
957
		titlePosition: 'inside',
958
		titleFormat: function (titre, currentArray, currentIndex, currentOpts) {
915 jpm 959
			var motif = /urn:lsid:tela-botanica[.]org:cel:img([0-9]+)$/;
960
			motif.exec(titre);
1586 jpm 961
			var id = RegExp.$1,
962
				info = $('#cel-info-'+id).clone().html(),
963
				tpl =
964
					'<div class="cel-legende">'+
965
					'<p class="cel-legende-vei">'+'Image n°' + (currentIndex + 1) + ' sur ' + currentArray.length +'<\/p>'+
966
					(titre && titre.length ? '<p>'+info+'<\/p>' : '' )+
967
					'<\/div>';
915 jpm 968
			return tpl;
836 jpm 969
		}
1032 aurelien 970
	}).live('click', function(e) {
971
		if (e.stopPropagation) {
972
			e.stopPropagation();
973
		}
974
		return false;
975
	});
836 jpm 976
}
977
 
1414 aurelien 978
function ajouterFormulaireContact(element) {
941 jpm 979
	$(element).fancybox({
980
		transitionIn:'elastic',
981
		transitionOut:'elastic',
982
		speedIn	:600,
983
		speedOut:200,
984
		scrolling: 'no',
985
		titleShow: false,
986
		onStart: function(selectedArray, selectedIndex, selectedOpts) {
987
			var element = selectedArray[selectedIndex];
988
			var motif = / contributeur-([0-9]+)$/;
989
			motif.exec($(element).attr('class'));
1494 aurelien 990
			// si la classe ne contient pas d'id contributeur
991
			// alors il faut stocker le numéro d'observation
941 jpm 992
			var id = RegExp.$1;
1494 aurelien 993
			if(id == "") {
994
				$("#fc_type_envoi").attr('value', 'non-inscrit');
995
				var motif = / obs-([0-9]+)$/;
996
				motif.exec($(element).attr('class'));
997
				var id = RegExp.$1;
998
			} else {
999
				$("#fc_type_envoi").attr('value', 'inscrit');
1000
			}
1001
 
941 jpm 1002
			$("#fc_destinataire_id").attr('value', id);
1003
 
1494 aurelien 1004
			var motif = / obs-([0-9]+)/;
941 jpm 1005
			motif.exec($(element).attr('class'));
1006
			var id = RegExp.$1;
950 jpm 1007
			//console.log('Obs id : '+id);
941 jpm 1008
			chargerInfoObsPourMessage(id);
1009
		},
1010
		onCleanup: function() {
950 jpm 1011
			//console.log('Avant fermeture fancybox');
941 jpm 1012
			$("#fc_destinataire_id").attr('value', '');
1013
			$("#fc_sujet").attr('value', '');
1014
			$("#fc_message").text('');
1015
		},
1016
		onClosed: function(e) {
950 jpm 1017
			//console.log('Fermeture fancybox');
941 jpm 1018
			if (e.stopPropagation) {
1019
				e.stopPropagation();
1020
			}
1021
			return false;
1022
		}
1023
	});
1024
}
1025
 
1026
function chargerInfoObsPourMessage(idObs) {
980 jpm 1027
	var nomSci = jQuery.trim($(".cel-obs-"+idObs+" .nom-sci:eq(0)").text());
1028
	var date = jQuery.trim($(".cel-obs-"+idObs+" .date:eq(0)").text());
1029
	var lieu = jQuery.trim($(".cel-obs-"+idObs+" .lieu:eq(0)").text());
953 jpm 1030
	var sujet = "Observation #"+idObs+" de "+nomSci;
1031
	var message = "\n\n\n\n\n\n\n\n--\nConcerne l'observation de \""+nomSci+'" du "'+date+'" au lieu "'+lieu+'".';
941 jpm 1032
	$("#fc_sujet").attr('value', sujet);
1033
	$("#fc_message").text(message);
1034
}
1035
 
1036
function initialiserFormulaireContact() {
950 jpm 1037
	//console.log('Initialisation du form contact');
941 jpm 1038
	$("#form-contact").validate({
1039
		rules: {
1040
			fc_sujet : "required",
1041
			fc_message : "required",
953 jpm 1042
			fc_utilisateur_courriel : {
1043
				required : true,
1044
				email : true}
941 jpm 1045
		}
1046
	});
1047
	$("#form-contact").bind("submit", envoyerCourriel);
950 jpm 1048
	$("#fc_annuler").bind("click", function() {$.fancybox.close();});
941 jpm 1049
 
1050
}
1051
 
1052
function envoyerCourriel() {
950 jpm 1053
	//console.log('Formulaire soumis');
941 jpm 1054
	if ($("#form-contact").valid()) {
950 jpm 1055
		//console.log('Formulaire valide');
941 jpm 1056
		//$.fancybox.showActivity();
1057
		var destinataireId = $("#fc_destinataire_id").attr('value');
1494 aurelien 1058
		var typeEnvoi = $("#fc_type_envoi").attr('value');
1059
		if(typeEnvoi == "non-inscrit") {
1060
			// l'envoi au non inscrits passe par le service intermédiaire du cel
1061
			// qui va récupérer le courriel associé à l'obs indiquée
1062
			var urlMessage = "http://www.tela-botanica.org/service:cel:celMessage/obs/"+destinataireId;
1063
		} else {
1064
			var urlMessage = "http://www.tela-botanica.org/service:annuaire:Utilisateur/"+destinataireId+"/message";
1065
		}
941 jpm 1066
		var erreurMsg = "";
1067
		var donnees = new Array();
1068
		$.each($(this).serializeArray(), function (index, champ) {
1069
			var cle = champ.name;
1070
			cle = cle.replace(/^fc_/, '');
953 jpm 1071
 
980 jpm 1072
			if (cle == 'sujet') {
953 jpm 1073
				champ.value += " - Carnet en ligne - Tela Botanica";
1074
			}
1075
			if (cle == 'message') {
1076
				champ.value += "\n--\n"+
980 jpm 1077
					"Ce message vous est envoyé par l'intermédiaire du widget carto "+
953 jpm 1078
					"du Carnet en Ligne du réseau Tela Botanica.\n"+
1079
					"http://www.tela-botanica.org/widget:cel:carto";
1080
			}
1081
 
941 jpm 1082
			donnees[index] = {'name':cle,'value':champ.value};
1083
		});
1084
		$.ajax({
1085
			type : "POST",
1086
			cache : false,
1087
			url : urlMessage,
1088
			data : donnees,
1089
			beforeSend : function() {
1090
				$(".msg").remove();
1091
			},
1092
			success : function(data) {
1093
				$("#fc-zone-dialogue").append('<pre class="msg info">'+data.message+'</pre>');
1094
			},
1095
			error : function(jqXHR, textStatus, errorThrown) {
1096
				erreurMsg += "Erreur Ajax :\ntype : "+textStatus+' '+errorThrown+"\n";
1097
				reponse = jQuery.parseJSON(jqXHR.responseText);
1098
				if (reponse != null) {
1099
					$.each(reponse, function (cle, valeur) {
1100
						erreurMsg += valeur + "\n";
1101
					});
1102
				}
1103
			},
1104
			complete : function(jqXHR, textStatus) {
1105
				var debugMsg = '';
1106
				if (jqXHR.getResponseHeader("X-DebugJrest-Data") != '') {
1107
					debugInfos = jQuery.parseJSON(jqXHR.getResponseHeader("X-DebugJrest-Data"));
1108
					if (debugInfos != null) {
1109
						$.each(debugInfos, function (cle, valeur) {
1110
							debugMsg += valeur + "\n";
1111
						});
1112
					}
1113
				}
1114
				if (erreurMsg != '') {
1115
					$("#fc-zone-dialogue").append('<p class="msg">'+
1116
							'Une erreur est survenue lors de la transmission de votre message.'+'<br />'+
1117
							'Vous pouvez signaler le disfonctionnement à <a href="'+
1118
							'mailto:cel@tela-botanica.org'+'?'+
980 jpm 1119
							'subject=Disfonctionnement du widget carto'+
941 jpm 1120
							"&body="+erreurMsg+"\nDébogage :\n"+debugMsg+
1121
							'">cel@tela-botanica.org</a>.'+
1122
							'</p>');
1123
				}
1124
				if (DEBUG) {
1125
					console.log('Débogage : '+debugMsg);
1126
				}
950 jpm 1127
				//console.log('Débogage : '+debugMsg);
1128
				//console.log('Erreur : '+erreurMsg);
941 jpm 1129
			}
1130
		});
1131
	}
1132
	return false;
1133
}
915 jpm 1134
/*+--------------------------------------------------------------------------------------------------------+*/
1135
// PANNEAU LATÉRAL
1513 aurelien 1136
var nbTaxons = 0;
1438 aurelien 1137
function initialiserAffichagePanneauLateral() {
915 jpm 1138
	if (nt == '*') {
1139
		$('#pl-ouverture').bind('click', afficherPanneauLateral);
1140
		$('#pl-fermeture').bind('click', cacherPanneauLateral);
1430 aurelien 1141
	} else {
1142
		$('#panneau-lateral').width(0);
1143
		$('#carte').width('100%');
836 jpm 1144
	}
1513 aurelien 1145
	attribuerListenersFiltreUtilisateur();
939 jpm 1146
	chargerTaxons(0, 0);
836 jpm 1147
}
1148
 
1513 aurelien 1149
function attribuerListenersFiltreUtilisateur() {
1150
	$('#valider-filtre-utilisateur').click(function() {
1151
		var utilisateur = $('#filtre-utilisateur').val();
1152
		filtrerParUtilisateur(utilisateur);
1153
		$('#raz-filtre-utilisateur').show();
1154
	});
1155
 
1156
	$('#filtre-utilisateur').keypress(function(e) {
1586 jpm 1157
		if (e.which == 13) {
1158
			var utilisateur = $('#filtre-utilisateur').val();
1513 aurelien 1159
			filtrerParUtilisateur(utilisateur);
1160
			$('#raz-filtre-utilisateur').show();
1586 jpm 1161
		}
1513 aurelien 1162
	});
1163
 
1164
	$('#raz-filtre-utilisateur').click(function() {
1165
		$('#filtre-utilisateur').val('');
1166
		filtrerParUtilisateur('*');
1514 aurelien 1167
		afficherCacherFiltreUtilisateur();
1513 aurelien 1168
		$('#raz-filtre-utilisateur').hide();
1169
	});
1514 aurelien 1170
 
1171
	$('#lien-affichage-filtre-utilisateur').click(function() {
1172
		afficherCacherFiltreUtilisateur();
1173
	});
1586 jpm 1174
 
1514 aurelien 1175
	$('#raz-filtre-utilisateur').hide();
1176
	$('#formulaire-filtre-utilisateur').hide();
1513 aurelien 1177
}
1178
 
1514 aurelien 1179
function afficherCacherFiltreUtilisateur() {
1180
	$('#formulaire-filtre-utilisateur').slideToggle();
1181
	$('#conteneur-filtre-utilisateur').toggleClass('ferme');
1586 jpm 1182
	if (!$('#conteneur-filtre-utilisateur').hasClass('ferme')) {
1514 aurelien 1183
		$('#conteneur-filtre-utilisateur').width(tailleMaxFiltreUtilisateur);
1184
	} else {
1185
		$('#conteneur-filtre-utilisateur').width('auto');
1186
	}
1187
}
1188
 
1513 aurelien 1189
function filtrerParUtilisateur(utilisateurFiltre) {
1586 jpm 1190
	if (utilisateurFiltre == '') {
1513 aurelien 1191
		utilisateurFiltre = '*';
1192
	}
1514 aurelien 1193
	utilisateur = utilisateurFiltre;
1586 jpm 1194
	var pattern = /utilisateur=[^&]*/i,
1195
		utilisateurCourant = pattern.exec(stationsUrl);
1513 aurelien 1196
	stationsUrl = stationsUrl.replace(utilisateurCourant, "utilisateur="+utilisateurFiltre);
1197
	taxonsUrl = taxonsUrl.replace(utilisateurCourant, "utilisateur="+utilisateurFiltre);
1198
	observationsUrl = observationsUrl.replace(utilisateurCourant, "utilisateur="+utilisateurFiltre);
1199
	filtreCommun = filtreCommun.replace(utilisateurCourant, "utilisateur="+utilisateurFiltre);
1200
	$("#taxons").html('');
1201
	chargerTaxons(0,0);
1202
	programmerRafraichissementCarte();
1203
}
1204
 
939 jpm 1205
function chargerTaxons(depart, total) {
1206
	if (depart == 0 || depart < total) {
1513 aurelien 1207
		if(depart == 0) {
1208
			nbTaxons = 0;
1209
			taxonsCarte = new Array();
1210
		}
1211
 
1212
		var limite = 2000;
950 jpm 1213
		//console.log("Chargement des taxons de "+depart+" à "+(depart+limite));
939 jpm 1214
		var urlTax = taxonsUrl+'&start={start}&limit='+limite;
1215
		urlTax = urlTax.replace(/\{start\}/g, depart);
1513 aurelien 1216
		//console.log(urlTax);
939 jpm 1217
		$.getJSON(urlTax, function(infos) {
1513 aurelien 1218
			nbTaxons += infos.taxons.length;
1586 jpm 1219
			$('.plantes-nbre').text(nbTaxons);
1220
			$('#tpl-taxons-liste').tmpl({'taxons': infos.taxons}).appendTo('#taxons');
939 jpm 1221
			taxonsCarte = taxonsCarte.concat(infos.taxons);
950 jpm 1222
			//console.log("Nbre taxons :"+taxonsCarte.length);
939 jpm 1223
			chargerTaxons(depart+limite, infos.total);
1224
		});
1225
	} else {
1226
		if (nt == '*') {
1227
			afficherTaxons();
1228
		}
1438 aurelien 1229
		afficherTitreCarteEtStats();
939 jpm 1230
	}
1231
}
1232
 
1233
function afficherTaxons() {
1234
	$('.taxon').live('click', filtrerParTaxon);
1445 aurelien 1235
	$('.raz-filtre-taxons').live('click', viderFiltreTaxon);
939 jpm 1236
}
1237
 
1445 aurelien 1238
var largeurPanneauLateralFerme = null;
915 jpm 1239
function afficherPanneauLateral() {
1447 aurelien 1240
	// fixer la hauteur
1445 aurelien 1241
	$('#panneau-lateral').height($(window).height() - $('#panneau-lateral').offset().top);
1242
	largeurPanneauLateralFerme = $('#panneau-lateral').width();
836 jpm 1243
	$('#panneau-lateral').width(300);
1244
	$('#pl-contenu').css('display', 'block');
1245
	$('#pl-ouverture').css('display', 'none');
1246
	$('#pl-fermeture').css('display', 'block');
1445 aurelien 1247
	// correction pour la taille de la liste des taxons
1248
	$('#pl-corps').height($(window).height() - $('#pl-corps').offset().top);
836 jpm 1249
 
1250
	google.maps.event.trigger(map, 'resize');
1251
};
1252
 
915 jpm 1253
function cacherPanneauLateral() {
1586 jpm 1254
	$('#panneau-lateral').height(25 + 'px');
1255
	$('#panneau-lateral').width(largeurPanneauLateralFerme + 'px');
836 jpm 1256
	$('#pl-contenu').css('display', 'none');
1257
	$('#pl-ouverture').css('display', 'block');
1258
	$('#pl-fermeture').css('display', 'none');
1259
 
1260
	google.maps.event.trigger(map, 'resize');
1261
};
1262
 
1445 aurelien 1263
function viderFiltreTaxon() {
1264
	$('.taxon-actif .taxon').click();
1265
}
1266
 
836 jpm 1267
function filtrerParTaxon() {
1268
	var ntAFiltrer = $('.nt', this).text();
1269
	infoBulle.close();
1037 aurelien 1270
	var zoom = map.getZoom();
1271
	var NELatLng = map.getBounds().getNorthEast().lat()+'|'+map.getBounds().getNorthEast().lng();
1272
	var SWLatLng = map.getBounds().getSouthWest().lat()+'|'+map.getBounds().getSouthWest().lng();
1273
 
1447 aurelien 1274
	$('.raz-filtre-taxons').removeClass('taxon-actif');
836 jpm 1275
	$('#taxon-'+nt).removeClass('taxon-actif');
1447 aurelien 1276
 
836 jpm 1277
	if (nt == ntAFiltrer) {
1278
		nt = '*';
1037 aurelien 1279
		stationsUrl = stationsUrl.replace(/num_taxon=[*0-9]+/, 'num_taxon='+nt);
1280
		chargerMarqueurs(zoom, NELatLng, SWLatLng);
836 jpm 1281
	} else {
1035 aurelien 1282
		stationsUrl = stationsUrl.replace(/num_taxon=[*0-9]+/, 'num_taxon='+ntAFiltrer);
1283
		url = stationsUrl;
1284
		url += '&zoom='+zoom+
1285
			'&ne='+NELatLng+
1286
			'&sw='+SWLatLng;
1287
		requeteChargementPoints = $.getJSON(url, function (stationsFiltrees) {
939 jpm 1288
			stations = stationsFiltrees;
836 jpm 1289
			nt = ntAFiltrer;
1290
			$('#taxon-'+nt).addClass('taxon-actif');
1035 aurelien 1291
			rafraichirMarqueurs(stations);
836 jpm 1292
		});
1293
	}
1294
};
1295
 
915 jpm 1296
/*+--------------------------------------------------------------------------------------------------------+*/
1297
// FONCTIONS UTILITAIRES
1298
 
980 jpm 1299
function ouvrirPopUp(element, nomPopUp, event) {
1300
	var options =
1301
		'width=650,'+
1302
		'height=600,'+
1303
		'scrollbars=yes,'+
1304
		'directories=no,'+
1305
		'location=no,'+
1306
		'menubar=no,'+
1307
		'status=no,'+
1308
		'toolbar=no';
1309
	var popUp = window.open(element.href, nomPopUp, options);
1310
	if (window.focus) {
1311
		popUp.focus();
1312
	}
1313
	return arreter(event);
1314
};
1315
 
1316
function ouvrirNouvelleFenetre(element, event) {
1317
	window.open(element.href);
1318
	return arreter(event);
1319
}
1320
 
915 jpm 1321
function arreter(event) {
1322
	if (event.stopPropagation) {
1323
		event.stopPropagation();
1324
	} else if (window.event) {
1325
		window.event.cancelBubble = true;
1326
	}
980 jpm 1327
	if (event.preventDefault) {
1328
		event.preventDefault();
1329
	}
1330
	event.returnValue = false;
915 jpm 1331
	return false;
1332
}
1333
 
836 jpm 1334
/**
1335
 * +-------------------------------------+
1336
 * Number.prototype.formaterNombre
1337
 * +-------------------------------------+
1338
 * Params (facultatifs):
1339
 * - Int decimales: nombre de decimales (exemple: 2)
1340
 * - String signe: le signe precedent les decimales (exemple: "," ou ".")
1341
 * - String separateurMilliers: comme son nom l'indique
1342
 * Returns:
1343
 * - String chaine formatee
1344
 * @author	::mastahbenus::
1345
 * @author	Jean-Pascal MILCENT <jpm@tela-botanica.org> : ajout détection auto entier/flotant
1346
 * @souce	http://www.javascriptfr.com/codes/FORMATER-NOMBRE-FACON-NUMBER-FORMAT-PHP_40060.aspx
1347
 */
1348
Number.prototype.formaterNombre = function (decimales, signe, separateurMilliers) {
1349
	var _sNombre = String(this), i, _sRetour = "", _sDecimales = "";
1350
 
1351
	function is_int(nbre) {
1352
		nbre = nbre.replace(',', '.');
1353
		return !(parseFloat(nbre)-parseInt(nbre) > 0);
1354
	}
1355
 
1356
	if (decimales == undefined) {
1357
		if (is_int(_sNombre)) {
1358
			decimales = 0;
1359
		} else {
1360
			decimales = 2;
1361
		}
1362
	}
1363
	if (signe == undefined) {
1364
		if (is_int(_sNombre)) {
1365
			signe = '';
1366
		} else {
1367
			signe = '.';
1368
		}
1369
	}
1370
	if (separateurMilliers == undefined) {
1371
		separateurMilliers = ' ';
1372
	}
1373
 
1374
	function separeMilliers (sNombre) {
1375
		var sRetour = "";
1376
		while (sNombre.length % 3 != 0) {
1377
			sNombre = "0"+sNombre;
1378
		}
1379
		for (i = 0; i < sNombre.length; i += 3) {
1380
			if (i == sNombre.length-1) separateurMilliers = '';
1381
			sRetour += sNombre.substr(i, 3) + separateurMilliers;
1382
		}
1383
		while (sRetour.substr(0, 1) == "0") {
1384
			sRetour = sRetour.substr(1);
1385
		}
1386
		return sRetour.substr(0, sRetour.lastIndexOf(separateurMilliers));
1387
	}
1388
 
1389
	if (_sNombre.indexOf('.') == -1) {
1390
		for (i = 0; i < decimales; i++) {
1586 jpm 1391
			_sDecimales += '0';
836 jpm 1392
		}
1393
		_sRetour = separeMilliers(_sNombre) + signe + _sDecimales;
1394
	} else {
1395
		var sDecimalesTmp = (_sNombre.substr(_sNombre.indexOf('.')+1));
1396
		if (sDecimalesTmp.length > decimales) {
1397
			var nDecimalesManquantes = sDecimalesTmp.length - decimales;
1398
			var nDiv = 1;
1399
			for (i = 0; i < nDecimalesManquantes; i++) {
1400
				nDiv *= 10;
1401
			}
1402
			_sDecimales = Math.round(Number(sDecimalesTmp) / nDiv);
1403
		}
1404
		_sRetour = separeMilliers(_sNombre.substr(0, _sNombre.indexOf('.')))+String(signe)+_sDecimales;
1405
	}
1406
	return _sRetour;
915 jpm 1407
}
1408
 
1409
function debug(objet) {
1410
	var msg = '';
1411
	if (objet != null) {
1412
		$.each(objet, function (cle, valeur) {
1586 jpm 1413
			msg += cle+':'+valeur + "\n";
915 jpm 1414
		});
1415
	} else {
1586 jpm 1416
		msg = 'La variable vaut null.';
915 jpm 1417
	}
1418
	console.log(msg);
836 jpm 1419
}