Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 1488 | Rev 1510 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
480 jpm 1
//+----------------------------------------------------------------------------------------------------------+
2
// Onglets et Portlets
391 aurelien 3
/**
4
 * Les variables suivantes ont été ajoutée par php
5
 *
6
 * var urlTexteBrutSectionWikiTpl : url pour obtenir le texte brut d'une section de wiki
7
 * var urlEditionSectionWikiTpl : url pour éditer une section du wiki
8
 * var urlTexteFormateSectionWikiTpl : url pour obtenir le texte formaté en html d'une section de wiki
9
 * var pageWikiTaxon : url pour obtenir le texte formaté en html d'une section de wiki
917 aurelien 10
 * var urlPopup = url de base pour les popup contenant du code un peu complexe
391 aurelien 11
 *
12
*/
13
 
14
/**
15
 * Variables globales du script
16
 */
227 delphine 17
var modules = Array();
18
var tableauOnglets = Array();
233 aurelien 19
var nbOngletsInvisibles = 0;
480 jpm 20
var ongletSyntheseCharge = true;
1123 mathias 21
var ongletIllustrationsCharge = false;
480 jpm 22
 
227 delphine 23
/** Classe Module
24
* Définit un module de type portlet
25
**/
26
function Module(id, module, onglet, statique) {
27
 
28
	// Variables de classe : identifiant, titre, et le HTML du résumé à afficher dans le contenu
29
	this.id = id;
30
	this.titre;
31
	this.htmlResume;
32
	this.statique = statique;
33
 
34
	// Les objets Portlet et Onglet que l'ont garde en mémoire pour pouvoir y accéder facilement
35
	this.portlet = module;
36
	this.onglet;
37
 
38
	// creerPortlet
39
	// Créer l'objet Portlet HTML à afficher et le stocker dans les variables de classe
40
	this.creerPortlet = function() {
41
		var objet = this;
42
 
43
		var titre = $(module).children('.titre');
44
		titre.className = 'titre ui-widget-header ui-corner-all';
45
		titre.id = 'titre-' + this.id;
242 aurelien 46
 
47
 
227 delphine 48
		var contenu = $(module).children('.contenu');
49
		contenu.id = 'contenu-' + this.id;
50
		contenu.className ='contenu';
51
 
52
		var lienToggle = document.createElement('span');
53
		lienToggle.className = 'lienToggle ui-icon ui-icon-minusthick';
54
		$(titre).append(lienToggle);
55
		$(lienToggle).click(function() {
56
			objet.afficherCacherModule();
57
		});
58
 
59
		this.portlet = module;
60
		return module;
242 aurelien 61
	}
62
 
63
	this.ongletEstAffiche = function() {
64
		return $(this.onglet.selector).is(':visible');
65
	}
227 delphine 66
 
242 aurelien 67
	// Crée l'objet Onglet HTML
227 delphine 68
	this.creerOnglet = function() {
69
		var objet = this;
70
		this.onglet = onglet;
71
	}
72
 
73
	// Initialisation de l'objet
74
	this.creerPortlet();
75
	this.creerOnglet();
76
 
77
	// Accesseurs de la classe
78
	this.getOnglet = function() {
79
		return this.onglet;
80
	}
81
 
82
	this.getPortlet = function() {
83
		return this.portlet;
84
	}
85
 
86
	// fonctions d'affichage et cachage (je sais pas si on dit ça comme ça) des onglets
87
	this.afficherCacherModule = function() {
88
		$(this.portlet).find(".lienToggle").toggleClass("ui-icon-plusthick");
89
		$(this.portlet).find(".lienToggle").toggleClass("ui-icon-minusthick");
510 gduche 90
		$(this.portlet).find(".titreOnglet").toggleClass("pasDeCurseur");
227 delphine 91
		$(this.portlet).find(".contenu").toggle();
92
	}
93
}
231 aurelien 94
 
480 jpm 95
function getUrlVars() {
242 aurelien 96
    var vars = [], hash;
97
    var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
480 jpm 98
    for (var i = 0; i < hashes.length; i++) {
242 aurelien 99
        hash = hashes[i].split('=');
100
        vars.push(hash[0]);
101
        vars[hash[0]] = hash[1];
102
    }
103
    return vars;
104
}
105
 
106
function afficherOngletsPourNiveau() {
107
	/* affiche les onglets par default selon niveau*/
480 jpm 108
	for (indice in tableauOnglets) {
242 aurelien 109
		var ongletEnCours = tableauOnglets[indice];
277 aurelien 110
		titre_onglet = ongletEnCours.titre;
111
		titre_onglet = $.trim(titre_onglet);
112
		if (!Array.indexOf) {
113
			  Array.prototype.indexOf = function (obj, start) {
114
			    for (var i = (start || 0); i < this.length; i++) {
115
			      if (this[i] == obj) {
116
			        return i;
117
			      }
118
			    }
119
			    return -1;
120
			  }
121
			}
122
		if (ongletsDefaut.indexOf(titre_onglet) == -1) {
242 aurelien 123
			ongletEnCours.afficherCacherModule();
124
			nbOngletsInvisibles++;
125
		}
126
	}
127
}
128
 
334 aurelien 129
function obtenirOngletCookiePourPage() {
130
	var urlVars = getUrlVars();
131
	var id_cookie = 'onglet_eflore';
480 jpm 132
	if (urlVars['num_nom']) {
334 aurelien 133
		id_cookie += '_'+urlVars['num_nom'];
480 jpm 134
	}
334 aurelien 135
	return $.cookie(id_cookie) ? $.cookie(id_cookie) : null;
136
}
137
 
138
function enregistrerOngletCookiePourPage(valeur) {
139
	var urlVars = getUrlVars();
140
	var id_cookie = 'onglet_eflore';
141
	if(urlVars['num_nom'] && urlVars['num_nom'] != undefined) {
142
		id_cookie += '_'+urlVars['num_nom'];
143
	}
144
	$.cookie(id_cookie, valeur);
145
}
146
 
242 aurelien 147
function lierModulesEtOnglets() {
148
	var i = 1;
227 delphine 149
 
150
	//Parcourir la totalité des modules générés et les lier grâce à la classe Module
151
	$(".module").each(function () {
152
		i++;
153
		identifiantOnglet = "#zone_onglets>ul>li:nth-child(" + i +")";
154
		var module = new Module(i, this, $(identifiantOnglet));
242 aurelien 155
		var titre = $(this).children('h3').text();
156
		module.titre = titre;
157
 
227 delphine 158
		tableauOnglets[identifiantOnglet] = module;
159
	});
1243 aurelien 160
}
161
 
162
// remplace des liens directs vers les onglets par des liens permettant de ne charger
163
// que le contenu de l'onglet (pour le plugin tab)
164
function remplacerUrlsOnglets() {
1502 delphine 165
		$(".lien-onglet").each(function() {
506 jpm 166
		var urlOnglet = $(this).attr('href');
892 aurelien 167
		var urlVars = urlOnglet.slice(urlOnglet.indexOf('?') + 1);
168
		urlBase = base_url_application_onglets+"?"+urlVars;
169
		urlOnglet = urlBase.replace('action=fiche','action=onglet');
506 jpm 170
		$(this).attr('href', urlOnglet);
1502 delphine 171
	});
242 aurelien 172
}
227 delphine 173
 
1243 aurelien 174
ongletsInitialises = false;
175
numOngletEnCours = null;
176
nePasEmpilerUrl = false;
1272 aurelien 177
popStateOriginal = true;
1243 aurelien 178
function initialiserOnglets() {
179
	// replacement du chargement de toute la page par un lien vers uniquement le contenu de l'onglet
180
	// pour le module tab qui charge les url désignée dans les liens des tabs
1482 delphine 181
	//remplacerUrlsOnglets();
1243 aurelien 182
 
183
	// analyse de l'onglet désigné comme selectionné par défaut
184
	// (on peut accéder directement à un onglet précis à travers un param url)
185
	var tabSelectionneDefaut = $('#onglets li.ui-state-active');
186
	var indexTabSelectionneDefaut = $("#onglets li").index($(tabSelectionneDefaut));
1266 aurelien 187
 
1243 aurelien 188
	$('#zone_onglets').tabs({
189
		create: function( event, ui ) {
190
			// par défaut, le contenu déjà chargé est dans une autre zone
191
			// on le déplace donc comme s'il avait été chargé par le plugin tab
192
			var contenuZoneFiche = $("#zone_contenu_fiche > div").detach();
193
			contenuZoneFiche.appendTo('#ui-tabs-'+(indexTabSelectionneDefaut+1));
194
			$("#zone_contenu_fiche").hide();
195
			$('#ui-tabs-'+(indexTabSelectionneDefaut+1)).show();
1246 aurelien 196
			ongletNomCode = $('#ui-tabs-'+(indexTabSelectionneDefaut+1)).children(".onglet_contenu").attr("id");
197
			$(".lien_retour_synthese").toggle((ongletNomCode != "synthese"));
1243 aurelien 198
		},
199
		active: indexTabSelectionneDefaut ,
200
		beforeLoad: function( event, ui ) {
201
			// il est inutile de recharger un onglet déjà chargé (les onglets déjà chargé sont l'onglet par défaut
202
			// et (lors du chargement de la fiche), l'onglet déjà chargé par php
203
			// +1 car les tabs sont zéros indexées
204
			var idPanelCharge = ui.tab.index()+1;
205
			var panelCharge = $('#ui-tabs-'+idPanelCharge);
206
 
207
			numOngletEnCours = idPanelCharge;
208
 
209
			if(!panelCharge.is(':empty') || indexTabSelectionneDefaut+1 == idPanelCharge) {
210
				// si le panneau est déjà chargé on peut mettre à jour l'url immédiatement
211
				var ongletNomCode = panelCharge.children(".onglet_contenu").attr("id");
212
				if(!nePasEmpilerUrl) {
213
					mettreAJourUrl(permalienNumNom+"-"+ongletNomCode, ongletNomCode);
214
					nePasEmpilerUrl = false;
215
				}
1244 aurelien 216
 
217
				$(".lien_retour_synthese").toggle((ongletNomCode != "synthese"));
1243 aurelien 218
				panelCharge.show();
219
				return false;
220
			} else {
221
				// si l'onglet n'est pas chargé alors on affiche le message de chargement
222
				// pendant que le plugin s'occupe du reste
223
				fancyboxinitialise = false;
224
				var panel = $('#ui-tabs-'+idPanelCharge);
225
				panel.append("<div class='tab-chargement'>Chargement des informations...</div>");
226
				return true;
227
			}
228
		},
229
		load: function(event, ui) {
230
			// sur les panneaux qui ne sont pas encore chargés, on doit attendre la fin
231
			// du chargement pour mettre à jour l'url (à cause de la récupération de l'id sur les enfants)
232
			var ongletNomCode = ui.panel.children(".onglet_contenu").attr("id");
1452 mathias 233
			// stats
234
			if (prod) {
235
				var ga_json = '{"nn": "' + ga_current_nn + '", "nom_sci": "' + ga_current_ns + '"}';
236
				ga('eFloreTracker.send', 'event', 'fiche', 'consultation-' + ongletNomCode, ga_json, 1);
237
			}
238
 
1244 aurelien 239
			$(".lien_retour_synthese").toggle((ongletNomCode != "synthese"));
1243 aurelien 240
			mettreAJourUrl(permalienNumNom+"-"+ongletNomCode, ongletNomCode);
1358 aurelien 241
			$(document).trigger('dictionnaireRechercherDefinitions', '#'+ongletNomCode);
1243 aurelien 242
		}
243
	});
244
 
245
	$(window).bind('popstate', function(event) {
246
		if(!!event.originalEvent.state) {
247
			nePasEmpilerUrl = true;
248
			$("#onglets > li > a[rel='"+event.originalEvent.state+"']").click();
249
		} else {
1272 aurelien 250
			// chrome fait un popstate au chargement de la page, ce qui la fait recharger
251
			// indéfiniment, ce comportement étant compréhensible, il vaut mieux s'en prévenir
252
			if(!popStateOriginal) {
253
				window.location = window.location.href;
254
			}
255
			popStateOriginal = false;
1243 aurelien 256
		}
257
	});
258
}
259
 
480 jpm 260
//+----------------------------------------------------------------------------------------------------------+
261
// Wikini Flora
262
var htmlWikiOriginal = '';
263
var objetContenuWiki = null;
264
 
391 aurelien 265
function getTemplateFormulaireEditionWiki(page, section, texte) {
266
	var urlWebServiceWiki = getUrlEditionPourPageEtSection(page, section);
267
	var formulaire =
268
		'<form method="post" id="formulaire_edition_wiki" name="formulaire_edition_wiki" action="'+urlWebServiceWiki+'">'+
269
		  '<div>'+
270
		  	'<textarea id="pageContenu" name="pageContenu" class="champ_edition_wiki">'+texte+'</textarea>'+
271
		  '</div>'+
272
		  '<input type="hidden" name="pageSectionTitre" id="pageSectionTitre" value="'+section+'" />'+
273
		  '<input type="submit" text="sauver" />'+
274
	  	  '<input class="bouton_annuler_edition" type="button" value="annuler" />';
275
		'</form>';
276
	return formulaire;
277
}
278
 
279
function getSection() {
407 aurelien 280
	return objetContenuWiki.attr("title");
391 aurelien 281
}
282
 
283
function getPageWikiTaxon() {
284
	return pageWikiTaxon;
285
}
286
 
287
function getUrlEditionPourPageEtSection(page, section) {
1375 mathias 288
	var url = urlEditionSectionWikiTpl.replace('{pageTag}', page).replace('{sectionTitre}', section);
289
	return url;
391 aurelien 290
}
291
 
292
function getUrlTextePourPageSectionBrute(page, section) {
293
	return urlTexteBrutSectionWikiTpl.replace('{pageTag}', page).replace('{sectionTitre}', section);
294
}
295
 
296
function getUrlTextePourPageSectionFormatee(page, section) {
297
	return urlTexteFormateSectionWikiTpl.replace('{pageTag}', page).replace('{sectionTitre}', section);
298
}
299
 
300
function remplacerContenuWikiParFormulaireEdition(objet_contenu) {
407 aurelien 301
	objetContenuWiki = objet_contenu;
453 aurelien 302
	var adresse = getUrlEditionPourPageEtSection(getPageWikiTaxon(), getSection());
391 aurelien 303
	htmlWikiOriginal = objet_contenu.html();
304
	$.getJSON(adresse, function(data) {
999 raphael 305
		$(objetContenuWiki).removeClass('editable_sur_clic').html(getTemplateFormulaireEditionWiki(getPageWikiTaxon(), getSection(), data.texte));
391 aurelien 306
	});
307
}
308
 
309
function gererEvenementsWiki() {
400 aurelien 310
	//TODO: ajout automatique d'un lien ouvrant une page d'aide (un popup) au formatage des pages wikini
999 raphael 311
	$('.editable_sur_clic').live('dblclick',function(event) {
312
		remplacerContenuWikiParFormulaireEdition($(this));
391 aurelien 313
	});
314
 
315
	$('#formulaire_edition_wiki').live('submit',function(event) {
316
	    event.preventDefault();
317
		var valeurs = $(this).serialize();
318
		$.post($(this).attr('action'), valeurs, function(data) {
319
			var adresse = getUrlTextePourPageSectionFormatee(getPageWikiTaxon(), getSection());
320
			$.getJSON(adresse, function(data) {
999 raphael 321
				$(objetContenuWiki).addClass('editable_sur_clic').html(data.texte);
391 aurelien 322
			});
323
		});
324
	});
325
 
326
	$('.bouton_annuler_edition').live('click', function(event) {
999 raphael 327
		event.preventDefault();
328
		$(objetContenuWiki).addClass('editable_sur_clic').html(htmlWikiOriginal);
391 aurelien 329
	});
638 aurelien 330
 
331
	rendreLienAffichableDansNouvelleFenetre('.contenu_editable');
391 aurelien 332
}
333
 
480 jpm 334
//+----------------------------------------------------------------------------------------------------------+
638 aurelien 335
//Affichage dans une nouvelle fenetre
336
function rendreLienAffichableDansNouvelleFenetre(selecteur) {
337
	$(selecteur).find('a').live('click', function(event) {
338
		window.open($(this).attr('href'));
339
		event.preventDefault();
340
		return false;
341
	});
342
}
343
 
344
//+----------------------------------------------------------------------------------------------------------+
480 jpm 345
// Plier / déplier
474 aurelien 346
function plierTout() {
347
	$('.nom').children('.imagetteMoins').removeClass('imagetteMoins').addClass('imagettePlus');
348
	$('.plus').css('display', 'none');
349
}
350
 
351
function deplierTout() {
352
	$('.nom').children('.imagettePlus').removeClass('imagettePlus').addClass('imagetteMoins');
353
	$('.plus').css('display', 'inline');
354
}
355
 
356
function gestionBiblio(parent) {
1389 aurelien 357
	$('.nom').each(function () {
358
		if ($(this).children('.plus').length == 0) {
359
			html = $(this).html();
474 aurelien 360
 
1389 aurelien 361
			// La partie biblio commence au premier crochet ouvrant
362
			// ou bien au span de la biblio à exclure
363
			posCrochetGauche = html.indexOf('[');
1390 aurelien 364
			posbiblioAExclure = html.indexOf('<span class="bib_excl">');
365
 
366
			if(posCrochetGauche < 0 || (posbiblioAExclure > 0 && posbiblioAExclure < posCrochetGauche)) {
367
				posCrochetGauche = posbiblioAExclure;
1389 aurelien 368
			}
474 aurelien 369
 
1390 aurelien 370
			console.log(posCrochetGauche+" "+posbiblioAExclure);
371
 
372
 
1389 aurelien 373
			if (posCrochetGauche > 0) {
374
				nom = html.substr(0, posCrochetGauche);
375
				biblio = html.substr(posCrochetGauche, html.length);
376
				$(this).html(nom);
377
 
378
				imagettePlus = document.createElement('div');
379
				$(imagettePlus).addClass('imagettePlus');
380
				$(this).prepend($(imagettePlus));
381
 
382
				plus = document.createElement('span');
383
				$(plus).addClass('plus');
384
				$(plus).html(biblio);
385
				$(plus).hide();
386
 
387
				$(this).click(function(e) {
388
					// test pour ne réagir que sur le clic sur le + ou -
389
					// TODO: fusionner ce bout de code en doublon avec synthese.js
390
					if($(e.target).hasClass("imagettePlus") || $(e.target).hasClass("imagetteMoins")) {
391
						if (!$(this).children('.plus').is(':visible')) {
392
							$(this).children('.imagettePlus').removeClass('imagettePlus').addClass('imagetteMoins');
393
							$(this).children('.plus').css('display', 'inline');
394
						} else {
395
							$(this).children('.imagetteMoins').removeClass('imagetteMoins').addClass('imagettePlus');
396
							$(this).children('.plus').css('display', 'none');
397
						}
398
					}
399
 
400
				});
401
 
402
				$(this).append($(plus));
403
 
404
			}
474 aurelien 405
		}
406
	});
407
}
408
 
409
function gererEvenementsPliage() {
410
	$('.lien_tout_deplier').live('click', function() {
411
		deplierTout();
412
	});
413
	$('.lien_tout_plier').live('click', function() {
414
		plierTout();
415
	});
416
	gestionBiblio(document);
417
}
418
 
480 jpm 419
//+----------------------------------------------------------------------------------------------------------+
626 mathilde 420
//Pop Up images
421
function ouvrirPopUpImg(event) {
422
	event.preventDefault();
1306 aurelien 423
	window.open($(this).attr('href'),"Photo_"+$(this).children("img").attr("data-num-image"),
966 aurelien 424
			'"'+'height='+event.data.h+',width='+event.data.w+',top='+event.data.t+',left='+event.data.l
425
			+',toolbar='+event.data.toolbar+',menubar='+event.data.menubar +',location='
426
			+event.data.location+',resizable='+event.data.resizable+',scrollbars='+event.data.scrollbars
427
			+',status='+event.data.status+'"');
626 mathilde 428
}
429
 
480 jpm 430
//+----------------------------------------------------------------------------------------------------------+
761 aurelien 431
// Message de chargement pour les graphique écologie
432
function gererChargementGraphiqueEcologie() {
433
	$('.ecologie_svg').addClass('chargement');
434
}
971 aurelien 435
 
436
function gererAffichageLegendeEcologie() {
437
	$('.voir').live('click', function() {
438
		$(this).siblings('.legende_graphique').show();
439
		$(this).siblings('.cacher').show();
440
		$(this).hide();
441
	});
442
 
443
	$('.cacher').live('click', function() {
444
		$(this).siblings('.legende_graphique').hide();
445
		$(this).siblings('.voir').show();
446
		$(this).hide();
447
	});
448
}
449
 
450
 
761 aurelien 451
//+----------------------------------------------------------------------------------------------------------+
480 jpm 452
// Initialisation
317 aurelien 453
var fancyboxinitialise = false;
626 mathilde 454
var param_popup_Coste = {h: 650, w: 550, t: 100, l: 100,
455
		toolbar: 'no', menubar: 'no', location: 'no', resizable: 'yes', scrollbars: 'yes', status: 'no'};
317 aurelien 456
 
626 mathilde 457
var param_popup_Cel = {h: 750, w: 630, t: 100, l: 100,
458
		toolbar: 'no', menubar: 'no', location: 'no', resizable: 'yes', scrollbars: 'yes', status: 'no'};
459
 
1243 aurelien 460
//Initialisation (uniquement sur la présence de la div bloc-fiche, qui contient la fiche eflore)
1272 aurelien 461
$(document).one('ficheSyntheseChargee', function() {
1243 aurelien 462
	initialiserOnglets();
463
 
356 gduche 464
	// TODO : devrait être .on() à la place de live()
277 aurelien 465
	$('.lien_popup').live('click',function(event) {
466
		event.preventDefault();
467
		$.fancybox(this,{
468
			autoDimensions:false,
321 aurelien 469
			width:580
277 aurelien 470
		});
471
	});
472
 
1126 aurelien 473
	// TODO : devrait être .on() à la place de live()
474
	$('.lien_popup.lien_metadonnees').live('click',function(event) {
475
		event.preventDefault();
476
		$.fancybox(this,{
477
			autoDimensions:true
478
		});
479
	});
1243 aurelien 480
 
626 mathilde 481
	$('.lien-image-cel').live('click', param_popup_Cel , ouvrirPopUpImg);
482
	$('.lien-image-coste').live('click', param_popup_Coste , ouvrirPopUpImg);
483
 
242 aurelien 484
	afficherOngletsPourNiveau();
1123 mathias 485
 
391 aurelien 486
	gererEvenementsWiki();
474 aurelien 487
	gererEvenementsPliage();
887 delphine 488
 
489
	$('a.lien_retour_synthese').click(function(event) {
490
		$('#onglet_synthese a').click();
491
		event.preventDefault();
492
	});
966 aurelien 493
 
494
	$(window).resize(function() {
495
		redimensionnerOnglets();
496
	});
497
	redimensionnerOnglets();
1243 aurelien 498
 
499
	if($("#bloc-fiche").length > 0) {
500
		// initialisation de l'url avec l'onglet par défaut ou bien
501
		// celui qui a été explicitement demandé
502
		mettreAJourUrl(permalienNumNom+"-"+onglet, onglet);
503
	}
1246 aurelien 504
	gererInteractionsPermaliens();
324 gduche 505
});
506
 
1266 aurelien 507
function ajouterEvenement(elementHtml, nomEvenement, functionCallBack) {
508
	if(!!elementHtml && elementHtml != null) {
509
		if(elementHtml.attachEvent) {// Internet Explorer
510
			elementHtml.attachEvent("on" + nomEvenement, function() {functionCallBack.call(elementHtml);});
511
		} else if(elementHtml.addEventListener) { // Firefox & autres
512
			elementHtml.addEventListener(nomEvenement, functionCallBack, false);
513
		}
514
	}
1370 mathias 515
}
1257 aurelien 516
 
517
$(document).one('ongletRepartitionCharge', function() {
1370 mathias 518
	var contRepObs = $(".conteneur_repartition_observations");
519
	contRepObs.addClass("chargement_repartition");
1257 aurelien 520
	// utilisation d'une fonction native car jQuery refuse d'ajouter un évènement load
521
	// sur autre chose qu'une image
1266 aurelien 522
	$('#repartition_observations').ready(function() {
523
		ajouterEvenement(document.getElementById("repartition_observations"), "load", function() {
1370 mathias 524
			contRepObs.removeClass("chargement_repartition");
1266 aurelien 525
		});
1257 aurelien 526
	});
1370 mathias 527
	// lien "recalculer la carte de moissonnage"
528
	$('#lien_recalculer_carte').click(function() {
529
		var carteMoissonnageSvg = $('#repartition_observations'); // c'est plutôt "moissonnage" que "répartition" => squelette pourave power
530
		var urlCarte = carteMoissonnageSvg.attr("data");
531
		urlCarte += '&recalculer=1';
532
		contRepObs.addClass("chargement_repartition");
533
		carteMoissonnageSvg.attr("data", urlCarte);ajouterEvenement(document.getElementById("repartition_observations"), "load", function() {
534
			contRepObs.removeClass("chargement_repartition");
535
		});
536
		return false;
537
	});
1257 aurelien 538
});
539
 
1243 aurelien 540
$(document).one('ongletSyntheseCharge', function() {
541
	lierModulesEtOnglets();
542
 
543
	/* mouvement des blocs */
544
	$(".colonne").sortable({
545
		connectWith: ".colonne",
546
		handle: $(".module").children('h3') // mouvement seulement sur les titres
547
	});
548
 
549
	$('.lien_ouverture_onglet_parent').live('click', function(event) {
550
		event.preventDefault();
551
		$(this).parents(".module").find("a.titreOnglet").click();
552
	});
553
 
554
	gererClicIllustrationsFiche();
555
	gererEvenementsPliage();
556
});
557
 
1123 mathias 558
// À la fin du chargement de l'onglet Illustrations
1243 aurelien 559
$(document).one('ongletIllustrationsCharge', function() {
560
	$('a.lien-images-organes.fourni').live('click', afficherOngletOrgane);
561
	$('a.lien-grande-image-organe').live('click', afficherGrandeImageOrgane);
562
	// pour que la galerie soit ouverte par défaut sur le premier organe non vide
563
	var premier = $('a.lien-images-organes.fourni').first().data('tag');
564
	afficherOngletOrgane(null, premier);
1289 aurelien 565
 
1400 aurelien 566
	$('a.lien_telechargement_image').live('click',function(e) {
567
		if($(e.target).data('oneclicked')!='yes')
568
		{
569
			$(e.target).data('oneclicked','yes');
570
			$(this).fancybox({
571
				"type" : "iframe",
572
				"autoDimensions" : false,
573
				"width" : 800,
574
				"height" : 405,
575
				"titleShow" : false
576
			}).click();
577
		}
578
 
579
		e.preventDefault();
580
		return false;
1289 aurelien 581
	});
1123 mathias 582
});
583
 
584
// Affiche les n images ayant le plus de votes, pour l'organe $tag
585
function afficherOngletOrgane(e, tag) {
586
	var onglets = $('div.onglet-organe'),
587
		contenu = $('#galerie-organes-contenu'),
588
		organeOnglet;
589
 
590
	if (tag === undefined) {
591
		tag = $(this).data('tag')
592
	}
593
	if ($(this).parent().hasClass('active')) { // replier
594
		$(this).parent().removeClass('active')
595
		contenu.hide();
596
		return false;
597
	}
598
 
599
	onglets.each(function() {
600
		organeOnglet = $(this).data('tag');
601
		var li = $('a.lien-images-organes[data-tag="' + organeOnglet + '"]').parent();
602
		if (organeOnglet == tag) {
603
			$(this).show();
604
			li.addClass('active');
605
		} else {
606
			$(this).hide();
607
			li.removeClass('active');
608
		}
609
	});
610
 
611
	contenu.show();
612
 
613
	var premierLienGrandeImage = $('div.onglet-organe:visible').find('a.lien-grande-image-organe').first(),
614
		grandeImage = $('#grande-image-organe').find('img');
615
	premierLienGrandeImage.trigger('click');
616
	grandeImage.show('fast');
617
 
618
	return false;
619
}
620
 
621
// Affiche en grand sous les miniatures l'image d'organe sur laquelle on a cliqué
622
function afficherGrandeImageOrgane() {
1488 delphine 623
	if ($(this).data('id-image') === "") {
624
		return false;
625
	}
1123 mathias 626
	var grandeImage = $('#grande-image-organe').find('img'),
627
		source = $(this).find('img').attr('src');
1303 aurelien 628
	source = obtenirUrlMoyenFormatIdImage($(this).data('id-image'));
1131 mathias 629
	// chargement image et lien popup
1123 mathias 630
	grandeImage.attr('src', source);
1361 mathias 631
	// important pour Pinterest et cie.
632
	grandeImage.attr('alt', $(this).data('auteur') + ' - ' + $(this).data('titre'));
1305 aurelien 633
	grandeImage.parent().attr('href',obtenirUrlGrandFormatIdImage($(this).data('id-image')));
1123 mathias 634
	// métadonnées
635
	var metadonnees = ['id-image', 'titre', 'description', 'localisation', 'auteur'],
636
		clef;
637
	for (var i = 0; i < metadonnees.length; i++) {
638
		clef = metadonnees[i];
1303 aurelien 639
		var contenu = $(this).data(clef);
640
		if(clef == 'id-image') {
641
			contenu +=
1314 aurelien 642
				'<a title="T\xE9l\xE9charger cette image" class="lien_telechargement_image" href="'+urlBaseWidget+'telechargement?id_image='+$(this).data(clef)+'">'+
1303 aurelien 643
					'<img class="icone_action_ill" src="'+urlCssImages+'sauver.png" />'+
644
				'</a>'+
1305 aurelien 645
				'<a title="Voir plus d\'informations sur cette image (s\'ouvre dans un popup)" class="lien-image-cel" href="'+urlPopup+'?module=popup-illustrations&action=fiche&referentiel=bdtfx&id=' + $(this).data('id-image')+'">'+
1320 aurelien 646
					'<img class="icone_action_ill" src="'+urlCssImages+'infos_image.png" />'+
1349 mathias 647
				'</a>'+
1350 mathias 648
				'<a title="Signaler une mauvaise identification ou en proposer une autre via l\'outil identiplante" class="signaler-mauvaise-identification" href="' + $(this).data('url-mauvaise-ident') + '" target="_blank">' +
1349 mathias 649
					'<img class="icone_action_ill" src="'+urlCssImages+'mauvaise_id.png">' +
1303 aurelien 650
				'</a>';
651
		}
652
		$('#grande-image-legende-' + clef).html(contenu);
653
 
1123 mathias 654
	}
1361 mathias 655
	// valeurs génériques
1303 aurelien 656
	$('#grande-image-legende-' + clef).html($(this).data(clef));
1123 mathias 657
	$('#grande-image-legende-date').html(formaterDateVersFrancais($(this).data('date')));
1192 aurelien 658
	$('#grande-image-legende-id-destinataire').attr('href', urlPopup+'?module=popup-contact&action=form&referentiel='+REFERENTIEL+'&id_destinataire=' +
1208 mathias 659
			$(this).data('id-destinataire') + '&id_img=' + $(this).data('id-image'));
1317 aurelien 660
	$('#grande-image-legende-id-destinataire').attr('title', "Envoyer un message \xE0 l'auteur \xE0 propos de cette image (n\xE9cessite d'\xEAtre identifi\xE9)");
1131 mathias 661
	$('#grande-image-legende-auteur').attr('href', 'http://tela-botanica.org/profil:' + $(this).data('id-destinataire'));
1208 mathias 662
	$('#grande-image-legende-auteur').attr('target', '_blank');
1317 aurelien 663
	$('#grande-image-legende-auteur').attr('title', "Voir le profil de cet utilisateur (n\xE9cessite d'\xEAtre identifi\xE9)");
1309 aurelien 664
 
665
 
666
	$('#grande-image-legende-id-image a.lien_telechargement_image').unbind('click.fb').fancybox({
667
		"type" : "iframe",
668
		"autoDimensions" : false,
669
		"width" : 800,
670
		"height" : 405,
671
		"titleShow" : false
672
	});
1123 mathias 673
}
674
 
1303 aurelien 675
function obtenirUrlMoyenFormatIdImage(idImage) {
676
	idImage = remplirChaineDebut(idImage, "0", 9);
677
	return urlImagesOrganesMoyenFormatTpl.replace('{id_image}', idImage);
678
}
679
 
680
function obtenirUrlGrandFormatIdImage(idImage) {
681
	idImage = remplirChaineDebut(idImage, "0", 9);
682
	return urlImagesOrganesGrandFormatTpl.replace('{id_image}', idImage);
683
}
684
 
685
function remplirChaineDebut(chaine, remplissage, longueur) {
686
	while(chaine.toString().length < longueur) {
687
		chaine = remplissage.toString()+chaine.toString();
688
	}
689
	return chaine;
690
}
691
 
1123 mathias 692
// transforme une date du type "2012-04-06" en "06 avril 2012"
693
function formaterDateVersFrancais(date) {
694
	var mois = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'],
695
		amj_hms = date.split(' '),
696
		amj = amj_hms[0].split('-');
697
	return amj[2] + ' ' + mois[parseInt(amj[1]) - 1] + ' ' + amj[0];
698
}
699
 
966 aurelien 700
function redimensionnerOnglets() {
701
 
702
	var largeurTotale = $('#zone_onglets').width();
703
	var largeurOnglets = 0;
704
	var largeurDernierOnglet = 0;
705
	$('#onglets li').each(function() {
706
		largeurDernierOnglet = $(this).outerWidth();
707
		largeurOnglets += $(this).outerWidth();
708
	});
709
 
710
	var espaceRestant = largeurTotale - largeurOnglets;
711
	if(espaceRestant < largeurDernierOnglet) {
712
		var pxALiberer = (largeurDernierOnglet - espaceRestant)/ $('#onglets li').size();
713
		$('#onglets li').each(function() {
714
			$(this).width($(this).width() - (pxALiberer - 4));
715
			$(this).css("font-size", "0.9em");
716
		});
717
	} else {
718
		$('#onglets li').each(function() {
719
			$(this).css("width", "auto");
720
			$(this).css("font-size", "1em");
721
		});
722
	}
723
}
724
 
1123 mathias 725
// ouvre le popup de galerie lors d'un clic sur l'illustration dans la fiche synthèse
864 aurelien 726
function gererClicIllustrationsFiche() {
917 aurelien 727
	$('.illustration_cel').live('click', function() {
728
		var url_image = $(this).attr('src');
922 aurelien 729
		var titre = $('.nomenclature').first().text();
1136 mathias 730
		var url = urlPopup+"?module=popup-galerie&action=fiche&num_nom="+$(this).attr('data-num-nom')+"&titre="+encodeURIComponent(titre)+"&url_image="+encodeURIComponent(url_image)+"&referentiel="+REFERENTIEL;
731
		//var url = urlPopup+"?module=popup-galerie-organes&action=fiche&num_nom="+$(this).attr('data-num-nom')+"&titre="+encodeURIComponent(titre)+"&url_image="+encodeURIComponent(url_image)+"&referentiel="+REFERENTIEL;
1123 mathias 732
		//alert(url);
733
		//return false;
984 aurelien 734
		window.open(url, $(this).attr('data-num-nom'), 'directories=no,titlebar=no,toolbar=no,location=no,status=no,menubar=no,scrollbars=no,resizable=no, width='+(400)+', height='+(375));
864 aurelien 735
	});
736
}
737
 
738
function ouvrirFenetreIllustrationFiche(url, titre, hauteur, largeur) {
928 aurelien 739
	var fenetre = window.open('_blank', '','directories=no,titlebar=no,toolbar=no,location=no,status=no,menubar=no,scrollbars=no,resizable=no, width='+(largeur+17)+', height='+(hauteur+17));
864 aurelien 740
	var tmp = fenetre.document;
741
	tmp.write('<html><head><title>'+titre+'</title>');
742
	tmp.write('</head><body>');
743
	tmp.write('<p style="height='+hauteur+'px;text-align:center;line-height='+hauteur+'px;"><img id="image_agrandie" height="'+hauteur+'" width="'+largeur+'" style="vertical-align:middle;" src="'+url+'" /></p>');
744
	tmp.write('</body></html>');
745
	tmp.close();
746
}
747
 
1246 aurelien 748
 
749
// met à jour l'url dans la barre du navigateur ainsi que dans le permalien en bas
750
// de la fiche
1243 aurelien 751
function mettreAJourUrl(nouvelleUrl, etat) {
1246 aurelien 752
	$('#permalien_num_nom').val(nouvelleUrl);
1243 aurelien 753
	if (!!(window.history && window.history.pushState)) {
754
		var currentState = window.history.state;
755
		if (currentState != nouvelleUrl && !!etat) {
756
			window.history.pushState(etat, "", nouvelleUrl);
757
		}
758
	}
759
}
760
 
1246 aurelien 761
function gererInteractionsPermaliens() {
762
	$(".conteneur_permalien > a").each(function() {
763
		var txt = '<input type="text" id="'+$(this).attr('id')+'" readonly="readonly" class="lien_externe" value="'+$(this).attr('href')+'">';
764
		$(this).replaceWith(txt);
765
	});
766
	$(".conteneur_permalien > input").each(function() {
767
		$(this).attr('size', $(this).val().length - 7);
768
	});
769
	$(".conteneur_permalien > input").hover(
770
		function() {
771
			 $(this).select();
772
		}, function() {
773
			// rien à faire sur le mouseout
774
		}
775
	);
776
}
777
 
1381 aurelien 778
function gererTemplatesChargementALaDemande() {
1400 aurelien 779
	$('.lien-ajax-tpl a.lien-ajax-tpl-chargement').live('click', function(e) {
1381 aurelien 780
		if($(this).attr('data-loading') != "true") {
781
			$(this).attr('data-loading', "true");
782
			e.preventDefault();
783
			urlTpl = $(this).attr('href');
784
			$(this).hide();
785
			thisElementParent = $(this).parent();
786
			thisElementParent.append("<div class='tab-chargement'>Chargement des informations...</div>");
787
			$.get(urlTpl, function( data ) {
788
				thisElementParent.replaceWith( data );
789
			});
790
			return false;
791
		}
792
	});
793
}
794
 
324 gduche 795
$(document).ajaxStop(function() {
761 aurelien 796
	gererChargementGraphiqueEcologie();
971 aurelien 797
	gererAffichageLegendeEcologie();
1381 aurelien 798
	gererTemplatesChargementALaDemande();
324 gduche 799
	if (document.implementation.hasFeature('http://www.w3.org/TR/SVG11/feature#BasicStructure', '1.1') == false) {
480 jpm 800
		$('.svg').each(function() {
801
			alt = $(this).attr('alt');
802
			img = document.createElement('img');
803
			img.src = alt;
804
			$(this).replaceWith(img);
805
		});
324 gduche 806
	}
999 raphael 807
});
1381 aurelien 808