Subversion Repositories eFlore/Applications.cel

Rev

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