Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 1257 | Rev 1272 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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