Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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

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