Subversion Repositories eFlore/Applications.coel

Rev

Rev 1255 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1255 Rev 1327
Line 11... Line 11...
11
import org.tela_botanica.client.util.Debug;
11
import org.tela_botanica.client.util.Debug;
12
import org.tela_botanica.client.util.UtilDAO;
12
import org.tela_botanica.client.util.UtilDAO;
13
import com.extjs.gxt.ui.client.Registry;
13
import com.extjs.gxt.ui.client.Registry;
14
import com.google.gwt.core.client.GWT;
14
import com.google.gwt.core.client.GWT;
15
import com.google.gwt.json.client.JSONArray;
15
import com.google.gwt.json.client.JSONArray;
-
 
16
import com.google.gwt.json.client.JSONObject;
16
import com.google.gwt.json.client.JSONValue;
17
import com.google.gwt.json.client.JSONValue;
Line 17... Line 18...
17
 
18
 
18
public class PersonneAsyncDao {
19
public class PersonneAsyncDao {
Line 24... Line 25...
24
	public PersonneAsyncDao(Rafraichissable vue) {
25
	public PersonneAsyncDao(Rafraichissable vue) {
25
		vueARafraichir = vue;
26
		vueARafraichir = vue;
26
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
27
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
27
	}
28
	}
Line -... Line 29...
-
 
29
 
-
 
30
	/**
-
 
31
	 * @param paginationProgressive : définit le mode de consultation de la base de données
-
 
32
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
-
 
33
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
-
 
34
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
-
 
35
	 * 						est renvoyé à l'appelant
-
 
36
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
28
 
37
	 */	
-
 
38
	public void selectionner(final boolean paginationProgressive, String personneId, String projetId, String nomComplet, final int start, final int nbElements) {
-
 
39
 
29
	public void selectionner(String personneId, String projetId, String nomComplet, final int pageCourante, final int nbElements) {
40
		String nom = (nomComplet == null) ? "%" : nomComplet+"%";		
Line 30... Line 41...
30
		String[] parametres = {personneId, projetId, nomComplet};
41
		String[] parametres = {personneId, projetId, nom};
31
		
-
 
Line 32... Line 42...
32
		HashMap<String, String> restrictions = new HashMap<String, String>();
42
		
33
		restrictions.put("start", String.valueOf(pageCourante*nbElements));
43
		HashMap<String, String> restrictions = new HashMap<String, String>();
34
		
44
		
Line -... Line 45...
-
 
45
		if (nbElements != -1)	{
-
 
46
			restrictions.put("limit", String.valueOf(nbElements));
-
 
47
		}
-
 
48
		
-
 
49
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
-
 
50
		if (paginationProgressive) {
-
 
51
 
35
		if (nbElements != -1)	{
52
			/** DEFINITION DU TUPLE DE DEPART **/
-
 
53
			restrictions.put("start", String.valueOf(start));
-
 
54
			
36
			restrictions.put("limit", String.valueOf(nbElements));
55
			/** CONSTRUCTION DE LA REQUETE **/
37
		}
56
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
-
 
57
 
38
		
58
    		/** ENVOI DE LA REQUETE **/
-
 
59
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
39
		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
60
    		{
-
 
61
    			/** RECEPTION DE LA REPONSE **/
-
 
62
    			public void surReponse(JSONValue responseValue)
-
 
63
    			{
-
 
64
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
-
 
65
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
-
 
66
    				vueARafraichir.rafraichir(responseValue);
-
 
67
    			}
-
 
68
    		});
40
		rb.envoyerRequete(null, new JsonRestRequestCallback() {
69
		}
-
 
70
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
-
 
71
		else {
-
 
72
			
-
 
73
			/** DEFINITION DU TUPLE DE DEPART **/
-
 
74
			restrictions.put("start", String.valueOf(start*nbElements));
41
			@Override
75
			
Line -... Line 76...
-
 
76
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
-
 
77
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
-
 
78
				@Override
-
 
79
				public void surReponse(JSONValue responseValue) {
-
 
80
					
-
 
81
					if (responseValue != null) {
42
			public void surReponse(JSONValue responseValue) {
82
						JSONObject reponseObject = responseValue.isObject();
43
				// Si la requête est un succès, réception d'un tableau
83
						
44
				if (responseValue.isArray() != null) {
84
						if (reponseObject.get("personnes").isArray() != null) {
-
 
85
							JSONArray reponse = responseValue.isArray();
45
					final JSONArray reponse = responseValue.isArray();
86
							
46
					
87
							// Transformation du tableau JSON réponse en ListePersonne
-
 
88
							Information info = new Information("liste_personne");
-
 
89
							PersonneListe personnes;
-
 
90
							personnes = new PersonneListe(reponseObject.get("personnes").isArray(), reponseObject.get("nbElements").isNumber(), vueARafraichir);
-
 
91
							personnes.setTaillePage(nbElements);
-
 
92
							personnes.setPageCourante(start);							
47
					// Transformation du tableau JSON réponse en ListeInstitution
93
							info.setDonnee(0, personnes);
48
					Information info = new Information("liste_personne");
94
							
49
					PersonneListe personnes;
95
							// et on met à jour le demandeur des données
50
					if (reponse.get(0).isArray() != null)	{
-
 
51
						personnes = new PersonneListe(reponse);
-
 
52
					} else {
-
 
53
						personnes = new PersonneListe(reponse.get(1).isArray(), reponse.get(0).isNumber(), vueARafraichir);
-
 
54
					}				
-
 
55
					personnes.setTaillePage(nbElements);
-
 
56
					personnes.setPageCourante(pageCourante);							
-
 
57
					info.setDonnee(0, personnes);
-
 
58
					
96
							vueARafraichir.rafraichir(info);
59
					// et on met à jour le demandeur des données
97
						}
60
					vueARafraichir.rafraichir(info);
98
					} else {
61
				} else {
99
						GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un tableau JSON et vaut : "+responseValue.toString(), null);
Line 62... Line 100...
62
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un tableau JSON et vaut : "+responseValue.toString(), null);
100
					}
63
				}
101
				}
64
			}
102
			});