Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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