Subversion Repositories eFlore/Applications.eflore-consultation

Rev

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