Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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

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