Subversion Repositories eFlore/Applications.cel

Rev

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