Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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

Rev Author Line No. Line
119 aurelien 1
/**-------------------------- Objets globaux -----------------------------------*/
2
/*
3
 * Les variables suivantes sont ajoutée automatiquement dans le squelette du moteur de
4
 * recherche par php, elles sont commentées ici pour qu'elles n'aient pas l'air
5
 * de sortir de la cuisse de Jupiter
6
 *
457 jpm 7
 * var AUTOCOMPLETION_ELEMENTS_NBRE : indique le nombre d'éléments à afficher dans la liste d'autocomplétion.
8
 *
9
 * var URL_SERVICE_AUTOCOMPLETION_NOM_SCI : url de base du service de complétion de noms scientifiques
119 aurelien 10
 * pour le projet en cours de consultation.
11
 * Exemple : http://localhost/service:eflore:0.1/bdtfx/noms?recherche=etendue&retour.format=min&masque=Ace%mo
12
 *
457 jpm 13
 * var URL_SERVICE_AUTOCOMPLETION_NOM_VERNA : url de base du service de complétion de noms vernaculaires
119 aurelien 14
 * pour le projet en cours de consultation.
131 delphine 15
 * Exemple : http://localhost/service:eflore:0.1/nvjfl/noms-vernaculaires?recherche=etendue&retour.format=oss&masque=aca&masque.lg=fra
119 aurelien 16
 *
457 jpm 17
 * var VALEUR_DEFAUT_NOM_SCI : Contient la valeur par défaut affichée dans le formulaire en mode sci
119 aurelien 18
 * Exemple: Rechercher un nom scientifique
457 jpm 19
 *
20
 * var VALEUR_DEFAUT_NOM_VERNA : Contient la valeur par défaut affichée dans le formulaire en mode verna
119 aurelien 21
 * Exemple: Recherche un nom commun
22
 */
23
 
457 jpm 24
$(document).ready(function() {
25
	ajouterAutocompletionNoms();
26
	ajouterActionClicSurTexteRecherche();
27
	gererAffichageValeursParDefaut();
28
	afficherValeurParDefaut();
29
});
119 aurelien 30
 
457 jpm 31
/**------------------- Fonctions de gestion de l'autocompletion ---------------------------------*/
32
function ajouterAutocompletionNoms() {
33
	$('#nom').autocomplete({
34
		source: function(requete, add){
35
			// la variable de requête doit être vidée car sinon le parametre "term" est ajouté
36
			requete = "";
37
			var url = getUrlAppelCompletion();
38
			$.getJSON(url, requete, function(data) {
39
				var suggestions = [];
40
				if (nomVernaculaireEstDemande()) {
41
					suggestions = traiterRetourNomsVerna(data);
42
				} else if (nomSciEstDemande()) {
43
					suggestions = traiterRetourNomsSci(data);
44
				}
45
				add(suggestions);
46
            });
47
        },
48
        html: true
49
	});
105 aurelien 50
 
459 jpm 51
	$("#nom").bind("autocompleteselect", function(event, ui) {
457 jpm 52
		if (ui.item.retenu == true) {
53
			$("#nom").addClass('ns-retenu');
54
			console.log('ici');
55
		} else {
56
			$("#nom").removeClass('ns-retenu');
57
		}
58
	});
105 aurelien 59
}
60
 
119 aurelien 61
function traiterRetourNomsSci(data) {
131 delphine 62
	var suggestions = [];
457 jpm 63
	if (data.resultat != undefined) {
131 delphine 64
		$.each(data.resultat, function(i, val) {
457 jpm 65
			val.nn = i;
66
			var nom = {label : '', value : '', retenu : false};
67
			if (suggestions.length >= AUTOCOMPLETION_ELEMENTS_NBRE) {
68
				nom.label = "...";
69
				nom.value = $('#nom').val();
70
				suggestions.push(nom);
71
				return false;
72
			} else {
73
				nom.label = val.nom_sci_complet;
74
				nom.value = val.nom_sci;
75
				nom.nn = val.nn;
76
				nom.retenu = (val.retenu == 'false') ? false : true;
77
				suggestions.push(nom);
78
			}
131 delphine 79
		});
119 aurelien 80
	}
81
	return suggestions;
82
}
83
 
84
function traiterRetourNomsVerna(data) {
131 delphine 85
	var suggestions = [];
457 jpm 86
	if (jQuery.type(data) == "array") {
131 delphine 87
		$.each(data[1], function(i, val){
457 jpm 88
			var nom = {label : '', value : ''};
89
			if (suggestions.length >= AUTOCOMPLETION_ELEMENTS_NBRE) {
90
				nom.label = "...";
91
				nom.value = $('#nom').val();
92
				suggestions.push(nom);
93
				return false;
94
			} else {
95
				nom.label = val;
96
				nom.value = val;
97
				suggestions.push(val);
98
			}
131 delphine 99
		});
119 aurelien 100
	}
101
	return suggestions;
102
}
103
 
105 aurelien 104
 
457 jpm 105
/**------------ Fonctions de gestion des urls d'autocompletion et des fiches ------------------*/
106
function getUrlAppelCompletion() {
107
	var url = '';
108
	var mots = $('#nom').val();
109
	if (nomSciEstDemande()) {
110
		url = getUrlAutocompletionNomsSci(mots);
111
	} else if (nomVernaculaireEstDemande()) {
112
		mots = mots.replace('  ',' ');
113
		mots = mots.replace(' ','_');
114
		url = getUrlAutocompletionNomsVerna(mots);
115
	}
116
	return url;
117
}
105 aurelien 118
 
457 jpm 119
function getUrlAutocompletionNomsSci(requete) {
120
	var url = getUrlAutocompletion(URL_SERVICE_AUTOCOMPLETION_NOM_SCI, requete, 'min')+
121
		"&ns.structure=au,an";
122
	return url;
119 aurelien 123
}
124
 
457 jpm 125
function getUrlAutocompletionNomsVerna(requete) {
126
	var url = getUrlAutocompletion(URL_SERVICE_AUTOCOMPLETION_NOM_VERNA, requete, 'oss')+
127
		"&masque.lg=fra";
128
	return url;
129
}
130
 
131
function getUrlAutocompletion(baseUrl, requete, format) {
132
	var url = baseUrl+"?"+
133
		"masque="+requete+"&"+
134
		"recherche=etendue&"+
135
		"retour.format="+format+"&"+
136
		"navigation.limite="+AUTOCOMPLETION_ELEMENTS_NBRE;
137
	return url;
138
}
139
 
140
/**------------ Fonctions de détection de l'état du formulaire ------------------*/
141
function nomSciEstDemande()  {
142
	var boutonRadioNomSci = $('#type_nom_scientifique');
143
	return (boutonRadioNomSci.attr("checked") != "undefined" && boutonRadioNomSci.attr("checked") == "checked");
144
}
145
 
146
function nomVernaculaireEstDemande()  {
147
	var boutonRadioNomSci = $('#type_nom_vernaculaire');
148
	return (boutonRadioNomSci.attr("checked") != "undefined" && boutonRadioNomSci.attr("checked") == "checked");
149
}
150
 
119 aurelien 151
/**------------ Fonctions de gestion de l'affichage des valeurs par defaut ----------------------*/
152
function ajouterActionClicSurTexteRecherche() {
153
	$('#nom').click(function() {
457 jpm 154
		if (formulaireAfficheValeurParDefaut()) {
119 aurelien 155
			$('#nom').val('');
156
		}
457 jpm 157
		if ($('#nom').hasClass('valeur-defaut-recherche')) {
119 aurelien 158
			$('#nom').removeClass('valeur-defaut-recherche');
159
		}
160
	});
161
}
162
 
163
function formulaireAfficheValeurParDefaut() {
278 aurelien 164
	valeur_form = $('#nom').val();
165
	valeur_form = $.trim(valeur_form);
457 jpm 166
	return valeur_form == '' || valeur_form == VALEUR_DEFAUT_NOM_SCI || valeur_form == VALEUR_DEFAUT_NOM_VERNA;
119 aurelien 167
}
168
 
169
function gererAffichageValeursParDefaut() {
170
	$('input[name="type_nom"]').click(function() {
171
		afficherValeurParDefaut();
172
	});
173
 
174
	$('#nom').focus(function() {
175
		$('#nom').removeClass('valeur-defaut-recherche');
457 jpm 176
		if (formulaireAfficheValeurParDefaut()) {
119 aurelien 177
			$('#nom').val('');
178
		} else {
179
			$('#nom').select();
180
		}
181
	});
182
}
183
 
184
function afficherValeurParDefaut() {
185
	if($('#nom') != undefined && $('#nom').val() != undefined) {
278 aurelien 186
		valeur_form = $('#nom').val();
187
		valeur_form = $.trim(valeur_form);
457 jpm 188
		if (formulaireAfficheValeurParDefaut()) {
189
			if (nomSciEstDemande()) {
190
	    		$('#nom').val(VALEUR_DEFAUT_NOM_SCI);
119 aurelien 191
	    	} else {
457 jpm 192
	    		$('#nom').val(VALEUR_DEFAUT_NOM_VERNA);
119 aurelien 193
	    	}
194
			$('#nom').addClass('valeur-defaut-recherche');
195
		}
466 aurelien 196
 
197
		if (nomSciEstDemande()) {
198
			$('#eflore_nomenclature_fiche').show();
199
		} else {
200
			$('#eflore_nomenclature_fiche').hide();
201
		}
119 aurelien 202
	}
203
}
204
 
205
/*
206
 * jQuery UI Autocomplete HTML Extension
207
 *
208
 * Copyright 2010, Scott González (http://scottgonzalez.com)
209
 * Dual licensed under the MIT or GPL Version 2 licenses.
210
 *
211
 * http://github.com/scottgonzalez/jquery-ui-extensions
212
 *
213
 * Adaptation par Aurélien Peronnet pour la mise en gras des noms de taxons valides
214
 */
215
(function( $ ) {
457 jpm 216
	var proto = $.ui.autocomplete.prototype,
217
		initSource = proto._initSource;
218
 
219
	function filter( array, term ) {
220
		var matcher = new RegExp( $.ui.autocomplete.escapeRegex(term), "i" );
221
		return $.grep( array, function(value) {
222
			return matcher.test( $( "<div>" ).html( value.label || value.value || value ).text() );
223
		});
224
	}
225
 
226
	$.extend( proto, {
227
		_initSource: function() {
228
			if (this.options.html && $.isArray(this.options.source) ) {
229
				this.source = function( request, response ) {
230
					response( filter( this.options.source, request.term ) );
231
				};
232
			} else {
233
				initSource.call( this );
234
			}
235
		},
236
		_renderItem: function( ul, item) {
237
			if (item.retenu == true) {
238
				item.label = "<strong>"+item.label+"</strong>";
239
			}
240
 
241
			return $("<li></li>")
242
				.data("item.autocomplete", item)
243
				.append( $("<a></a>")[ this.options.html ? "html" : "text" ](item.label))
244
				.appendTo(ul);
245
		}
119 aurelien 246
	});
457 jpm 247
})( jQuery );