Subversion Repositories eFlore/Applications.coel

Rev

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

Rev Author Line No. Line
69 jpm 1
package org.tela_botanica.client.modeles;
2
 
570 jp_milcent 3
import java.util.HashMap;
4
 
773 jpm 5
import org.tela_botanica.client.http.JsonRestRequestBuilder;
6
import org.tela_botanica.client.http.JsonRestRequestCallback;
69 jpm 7
import org.tela_botanica.client.interfaces.Rafraichissable;
1288 cyprien 8
import org.tela_botanica.client.util.Debug;
299 gduche 9
import org.tela_botanica.client.util.UtilDAO;
69 jpm 10
 
11
import com.google.gwt.json.client.JSONArray;
1288 cyprien 12
import com.google.gwt.json.client.JSONBoolean;
13
import com.google.gwt.json.client.JSONNumber;
91 jpm 14
import com.google.gwt.json.client.JSONObject;
15
import com.google.gwt.json.client.JSONString;
69 jpm 16
import com.google.gwt.json.client.JSONValue;
17
 
18
public class ValeurListeAsyncDao {
570 jp_milcent 19
 
1288 cyprien 20
	private static HashMap<String, Object> ontologieCache = new HashMap<String, Object>();
21
 
268 jp_milcent 22
	private static final String SERVICE_NOM = "CoelValeurListe";
570 jp_milcent 23
	private Rafraichissable vueARafraichir = null;
1288 cyprien 24
	private int cptPage = 0;
1327 cyprien 25
	// FIXME : limiteJREST devrait être récupéré depuis un registre/dictionnaire
1288 cyprien 26
	private int limiteJREST = 150;
27
 
570 jp_milcent 28
	public ValeurListeAsyncDao(Rafraichissable vueCourante) {
29
		vueARafraichir = vueCourante;
268 jp_milcent 30
	}
31
 
1288 cyprien 32
	public static HashMap<String, Object> getOntologieCache() {
33
		return ontologieCache;
292 gduche 34
	}
35
 
1288 cyprien 36
	public void obtenirListe(Integer cle)	{
37
		selectionner("id", cle, null, null, false, null, -1, -1);
38
	}
39
 
40
	public void obtenirListe(String type, String identifiantValeur)	{
41
		selectionner(type, null, null, identifiantValeur, false, null, -1, -1);
42
	}
43
 
44
	public void obtenirListe(Integer cle, boolean pagination, String recherche, int start, int limit)	{
45
		selectionner("nom", cle, null, null, pagination, recherche, start, limit);
46
	}
47
 
1038 gduche 48
	public void selectionner(String type, Integer cle, String abv, String idValeur) {
1288 cyprien 49
		selectionner(type, cle, abv, idValeur, false, null, -1, -1);
1327 cyprien 50
	}
51
 
52
	/****************************************************************************************************
53
	 ** selectionner(final String type, final Integer cle, final String abv, final String idValeur, final boolean pagination, final String recherche, final int start, final int limit)
54
	/****************************************************************************************************
55
	 * Action :
56
	 * --------
57
	 * 		Récupère un nombre défini de Valeurs en s'aidant du nom partiel ou complet d'une valeur.
58
	 * 		Cette méthode gère deux types de sélection de données :
59
	 * 		- la sélection en cache (ontologieCache) --> pagination = FALSE
60
	 * 		- la sélection "au fur et à mesure" --> pagination = TRUE
61
	 *
62
	 * 		Gestion du cache :
63
	 * 		------------------
64
	 * 		- Le cache est utilisé si et seulement si 'pagination' est à FAUX car dans le cas où PAGINATION est
65
	 * 			à VRAI, les enregistrements sont chargés au fur et à mesure de la consultation des pages par
66
	 * 			l'utilisateur.
67
	 * 		- Si la taille de la liste chargée est supérieure au nombre maximum d'enregistrements retourné
68
	 * 		par le service JREST, alors on charge des blocs de valeurs jusqu'à ce que la totalité de la
69
	 * 		liste soit chargée.
70
	 *
71
	 * Description des paramètres :
72
	 * ----------------------------
73
	 *  @param 'type' est un paramètre directement destiné au service JREST. Il permet de définir le type
74
	 *  		de requête SQL à exécuter.
75
	 *  @param 	'cle' est l'identifiant de la liste de valeurs à récupérer (cas d'un noeud dans l'arbre).
76
	 *  @param 	'abv' sert pour la liste des régions. Il représente l'abréviation du nom d'un pays. Ce
77
	 *  		paramètre est concaténé à la clé pour former une clé particulière dont on se sert pour
78
	 *  		stocker la liste en cache.
79
	 *  @param	'idValeur' est l'identifiant de la valeur à récupérer (cas d'une feuille dans l'arbre).
80
	 *  @param	'pagination' est un booléen qui définit si la requête doit être paginée ou non.
81
	 *  @param	'recherche' est une chaîne de caractères représentant tout ou partie du nom d'un projet.
82
	 *  		Si la chaîne est vide, alors tous les projets sont recherchés.
83
	 *  @param	'start' et 'limit' sont les paramètres indispensables à la pagination. 'start'
84
	 *  		est le paramètre qui décrit le numéro du tuple de départ et 'limit' le nombre
85
	 *  		d'éléments à collecter.
86
	 *
87
	 *****************************************************************************************************/
1288 cyprien 88
	public void selectionner(final String type, final Integer cle, final String abv, final String idValeur, final boolean pagination, final String recherche, final int start, final int limit) {
89
 
1327 cyprien 90
		/**
91
		 * La cleParent en Integer est insuffisante pour les liste valeurs comme Région qui on plusieurs
92
		 * sections sur leur liste (ex : on ne sélectionne que les régions FR.__ puis les régions ES.__ sur la liste 1078 ....
93
		 **/
1288 cyprien 94
		final String cleParentPourCache = cle + (abv == null ? "" : abv);
95
		final String cleParent = cle+"";
1038 gduche 96
 
1327 cyprien 97
		/** GESTION DU PARAMETRE 'recherche' **/
1288 cyprien 98
		String nom = "";
99
		if ( (recherche == null) || (recherche.equals("")) ) nom = "";
100
		else {
101
			nom = recherche+"%";
102
		}
103
 
1327 cyprien 104
		/** GESTION DU PARAMETRE 'abréviation' **/
1288 cyprien 105
		String abreviation = "";
106
		String paramAbv = "";
107
		if (type.equals("ab") || type.equals("abv")) {
108
			int positionPoint = abv.indexOf(".");
109
			if (positionPoint != -1) abreviation = abv.substring(0, positionPoint)+"%";
110
			else abreviation=abv+"%";
111
		}
112
		paramAbv = abreviation;
113
 
1327 cyprien 114
		/** GESTION DES PARAMETRES à transmettre au JREST **/
1288 cyprien 115
		String[] parametres = {type, cleParent, paramAbv, idValeur, nom};
116
		HashMap<String, String> restrictions = new HashMap<String, String>();
117
 
1327 cyprien 118
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée **/
1288 cyprien 119
		if (pagination)	{
120
 
121
			restrictions.put("limit", String.valueOf(limit));
122
			restrictions.put("start", String.valueOf(start));
123
			restrictions.put("orderby", "cmlv_nom");
124
 
1327 cyprien 125
			/** CONSTRUCTION DE LA REQUETE **/
1288 cyprien 126
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
1327 cyprien 127
 
128
    		/** ENVOI DE LA REQUETE **/
1288 cyprien 129
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
130
    		{
1327 cyprien 131
    			/** RECEPTION DE LA REPONSE **/
1288 cyprien 132
    			public void surReponse(JSONValue responseValue)
1327 cyprien 133
    			{
134
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
135
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
1288 cyprien 136
    				vueARafraichir.rafraichir(responseValue);
773 jpm 137
    			}
138
    		});
1288 cyprien 139
		}
1327 cyprien 140
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée **/
1288 cyprien 141
		else
142
		{
1327 cyprien 143
			/** si start est supérieur à zéro, alors cela signifie que l'on doit charger une nouvelle page **/
1288 cyprien 144
			boolean nextPage = (start > 0);
145
 
1327 cyprien 146
			/** définition des contraintes sur la requête SQL **/
147
			if (nextPage) {
1288 cyprien 148
				restrictions.put("start", String.valueOf(start));
149
				restrictions.put("limit", String.valueOf(limit));
150
				restrictions.put("orderby", "cmlv_nom");
151
			}
1327 cyprien 152
			else {
1288 cyprien 153
				restrictions.put("orderby", "cmlv_nom");
154
			}
155
 
1327 cyprien 156
			/** Si l'on est pas dans un processus de récupération d'une liste, alors si le cache contient déjà la liste recherchée **/
157
			if (!nextPage && ontologieCache.containsKey(cleParentPourCache)) {
158
 
159
				/** on retourne à la vue la liste contenue dans le cache **/
1288 cyprien 160
				vueARafraichir.rafraichir(ontologieCache.get(cleParentPourCache));
1327 cyprien 161
			}
162
			/** Si l'on est en train de récupérer une liste (c-a-d que l'on est en train de charger des blocs de données afin de récupérer totalement une liste) **/
163
			else {
164
 
165
				/** CONSTRUCTION DE LA REQUETE **/
1288 cyprien 166
	    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
1327 cyprien 167
 
168
	    		/** ENVOI DE LA REQUETE **/
169
	    		rb.envoyerRequete(null, new JsonRestRequestCallback() {
170
 
171
	    			/** RECEPTION DE LA REPONSE **/
172
	    			public void surReponse(JSONValue responseValue) {
173
 
174
	    				/** Si la réponse n'est pas vide **/
175
	    				if (responseValue.isObject() != null) {
176
 
177
	    					/** Récupération des différents paramètres de la réponse JSON **/
1288 cyprien 178
							final JSONObject reponse = responseValue.isObject();
179
							JSONString listeId = reponse.get("id").isString();
180
							JSONArray listeValeurs = reponse.get("valeurs").isArray();
181
							JSONNumber nbElements = reponse.get("nbElements").isNumber();
182
							JSONBoolean getNextPage = reponse.get("getNextPage").isBoolean();
183
 
184
							/** Gestion de l'abreviation (pour la liste des régions) **/
185
							String abreviationStr = "";
186
							if (reponse.get("abreviation") != null) {
187
								abreviationStr = reponse.get("abreviation").isString().stringValue();
188
								int a = abreviationStr.indexOf("%", 1);
189
								abreviationStr = abreviationStr.substring(1, a);
190
							}
191
							else {
192
								abreviationStr = "";
193
							}
194
 
1327 cyprien 195
							/** Si l'on a bien reçu une liste de valeurs **/
1288 cyprien 196
							if (listeId != null)
197
							{
198
								/** Transformation du tableau JSON réponse en ValeurListe **/
199
								String id = listeId.stringValue();
200
								ValeurListe liste = new ValeurListe(new JSONString(id), abreviationStr, listeValeurs, nbElements);
201
 
202
								/** Si la liste existe deja en cache **/
203
								String identifiantCache = (abreviationStr=="") ? id : (id+abreviationStr);
204
								if (ontologieCache.get(id) != null)
205
								{
206
									/** Alors on concatène la liste existante avec celle qu'on vient de recevoir **/
207
									((ValeurListe)ontologieCache.get(identifiantCache)).concatenerListe(liste);
208
								}
209
								/** Sinon on l'insère simplement dans le cache **/
210
								else {
211
									ontologieCache.put(identifiantCache,liste);
212
								}
213
 
214
								/** Appel à la méthode qui gère le retour à l'appelant ou la suite du chargement **/
215
								chargerListe(getNextPage.booleanValue(), type, liste.getId(), abv, idValeur, pagination, recherche, start, limit);
216
							}
217
	    				}
218
	    			}
219
	    		});
220
	    	}
221
		}
69 jpm 222
	}
1327 cyprien 223
 
224
	/********************************************************************************************************
225
	 * Action :
226
	 * --------
227
	 * 		Clotûre le chargement d'une liste de valeurs si le chargement est terminé, ou lance le chargement
228
	 * 		du prochain bloc de données si la liste n'est pas chargée en totalité.
229
	 *
230
	 * Paramètres :
231
	 * ------------
232
	 * @param nextPage : est VRAI s'il faut faut continuer de charger la liste car elle n'est pas entièrement chargée et FAUX sinon
233
	 * @param Tous les autres paramètres sont les mêmes que pour la méthode 'selectionner'
234
	 *
235
	 *********************************************************************************************************/
236
	public void chargerListe(boolean nextPage, String type, Integer cle, String abv, String idValeur, boolean pagination, String recherche, int start, int nbElements) {
237
 
238
		/** Si nextpage est VRAI, alors cela signifie que l'on doit relancer une requete pour obtenir
239
		la page suivante **/
240
		if (nextPage) {
241
			cptPage++;
242
			selectionner(type, cle, abv, idValeur, pagination, recherche, cptPage*limiteJREST, limiteJREST);
243
		}
244
 
245
		/** Sinon cela signifie que le chargement de la liste est terminé et on peut
246
		la mettre en cache et retourner la réponse au demandeur **/
247
		else {
248
			// recupération de l'idenfiant de la liste
249
			String id = String.valueOf(cle);
250
 
251
			// gestion de l'abréviation pour la liste des régions
252
			String abreviationStr = "";
253
			if (abv != null) {
254
				abreviationStr = abv;
255
				int indexPoint = abreviationStr.indexOf(".", 0);
256
				abreviationStr = abreviationStr.substring(0, indexPoint);
257
				id = id+abreviationStr;
258
			}
259
 
260
			// réinitialisation du compteur
261
			cptPage = 0;
262
 
263
			/** On retourne la liste à la vue **/
264
			if (ontologieCache.get(id) != null) {
265
				vueARafraichir.rafraichir(ontologieCache.get(id));
266
			}
267
		}
268
	}
1288 cyprien 269
}