Subversion Repositories eFlore/Applications.cel

Rev

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