Subversion Repositories eFlore/Applications.coel

Rev

Rev 1383 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1383 Rev 1470
Line 27... Line 27...
27
		if (Mediateur.DEBUG) System.out.println("|| CommentaireAsyncDao > vueARafraichir = "+vueARafraichirCourrante.getClass().toString());
27
		if (Mediateur.DEBUG) System.out.println("|| CommentaireAsyncDao > vueARafraichir = "+vueARafraichirCourrante.getClass().toString());
28
		vueARafraichir = vueARafraichirCourrante ;
28
		vueARafraichir = vueARafraichirCourrante ;
29
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
29
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
30
	}
30
	}
Line -... Line 31...
-
 
31
 
-
 
32
	
-
 
33
	/**
-
 
34
	 * 
-
 
35
	 * @param paginationProgressive : définit le mode de consultation de la base de données
-
 
36
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
-
 
37
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
-
 
38
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
-
 
39
	 * 						est renvoyé à l'appelant
-
 
40
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
31
 
41
	 */
-
 
42
	public void selectionner(final boolean paginationProgressive, final String commentaireId, final String projetId, final String titre, final int start, final int nbElements, final Integer seqId) {
-
 
43
 
-
 
44
		// Ajout des paramètres et données à selectionner dans l'URL
32
	public void selectionner(final String commentaireId, String projetId, String titre, final int pageCourante, final int nbElements, final Integer seqId) {
45
		String nom = (titre == null) ? "%" : titre+"%";
Line 33... Line 46...
33
		String[] parametres = {projetId, commentaireId, titre};
46
		String[] parametres = {projetId, commentaireId, nom};
34
		
-
 
-
 
47
		
35
		HashMap<String, String> restrictions = new HashMap<String, String>();
48
		HashMap<String, String> restrictions = new HashMap<String, String>();
36
		restrictions.put("start", String.valueOf(pageCourante*nbElements));
49
		
37
		if (nbElements != -1)	{
50
		if (nbElements != -1)	{
-
 
51
			restrictions.put("limit", String.valueOf(nbElements));
38
			restrictions.put("limit", String.valueOf(nbElements));
52
		}
-
 
53
		restrictions.put("orderby", "ccm_titre ASC");
-
 
54
 
-
 
55
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
-
 
56
		if (paginationProgressive) {
39
		}
57
 
40
		
58
			/** DEFINITION DU TUPLE DE DEPART **/
-
 
59
			restrictions.put("start", String.valueOf(start));
41
		restrictions.put("orderby", "cc_nom ASC");
60
			
-
 
61
			/** CONSTRUCTION DE LA REQUETE **/
-
 
62
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
42
		
63
 
43
		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
64
    		/** ENVOI DE LA REQUETE **/
-
 
65
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
44
		rb.envoyerRequete(null, new JsonRestRequestCallback() {
66
    		{
45
			@Override
67
    			/** RECEPTION DE LA REPONSE **/
46
			public void surReponse(JSONValue responseValue) {
68
    			public void surReponse(JSONValue responseValue)
47
				if (responseValue != null) {
69
    			{
48
					// Si la requête est un succès, réception d'un objet ou d'un tableau
70
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
49
					JSONArray responseArray = responseValue.isArray();
-
 
50
					
-
 
51
					if (responseArray.get(1).isObject() != null) {
-
 
52
						final JSONObject reponse = responseArray.get(1).isObject();
-
 
53
						// Transformation du tableau JSON réponse en ListeInstitution
-
 
54
						Commentaire commentaire = new Commentaire(reponse);
71
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
-
 
72
    				
55
						// et on met à jour le demandeur des données
73
					if (seqId != null)	{
56
						if (seqId != null)	{
74
						if (Mediateur.DEBUG) System.out.println("<-- CommentairesASyncDao > Liste paginée, retour au sequenceur");
57
							Reponse reponseRequete = new Reponse(commentaire, seqId);
75
						Reponse reponseRequete = new Reponse(responseValue, seqId);
58
							vueARafraichir.rafraichir(reponseRequete);
76
						vueARafraichir.rafraichir(reponseRequete);
-
 
77
					}
59
						}
78
					else	{
60
						else	{
79
						if (Mediateur.DEBUG) System.out.println("<-- CommentairesASyncDao > Liste paginée, retour à "+vueARafraichir.getClass().toString());
-
 
80
						vueARafraichir.rafraichir(responseValue);
-
 
81
					}
-
 
82
    			}
61
							vueARafraichir.rafraichir(commentaire);
83
    		});
-
 
84
		}
-
 
85
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
62
						}			
86
		else {
63
					} else if (responseValue.isArray() != null) {
87
 
-
 
88
			/** DEFINITION DU TUPLE DE DEPART **/
64
						final JSONArray reponse = responseValue.isArray();						
89
			restrictions.put("start", String.valueOf(start*nbElements));
-
 
90
			
65
						CommentaireListe commentaires;
91
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
66
						if (reponse.get(1).isObject() != null)	{
92
			
67
							commentaires = new CommentaireListe(reponse.get(1).isArray());
93
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
68
						} else	{
-
 
69
							commentaires = new CommentaireListe(reponse.get(1).isArray(), reponse.get(0).isNumber(), vueARafraichir);
94
				@Override
-
 
95
				public void surReponse(JSONValue responseValue) {
70
						}
96
					if (responseValue != null) {
Line -... Line 97...
-
 
97
 
-
 
98
						JSONObject responseObject = responseValue.isObject();
-
 
99
 
-
 
100
						if (responseObject != null) {
-
 
101
							// Si la réponse est un tableau, alors c'est une liste de commentaires qui a été retournée
-
 
102
							if (responseObject.get("commentaires").isArray() != null) {
-
 
103
								
-
 
104
								final JSONArray reponse = responseObject.get("commentaires").isArray();
-
 
105
								
-
 
106
								CommentaireListe commentaires;
-
 
107
								if (reponse.get(1).isObject() != null)	{
-
 
108
									commentaires = new CommentaireListe(reponse.get(1).isArray());
-
 
109
								} else	{
-
 
110
									commentaires = new CommentaireListe(reponse.get(1).isArray(), reponse.get(0).isNumber(), vueARafraichir);
-
 
111
								}
-
 
112
								
-
 
113
								commentaires.setTaillePage(nbElements);
-
 
114
								commentaires.setPageCourante(start);		
-
 
115
								
-
 
116
								vueARafraichir.rafraichir(commentaires);
-
 
117
 
-
 
118
							// Si la réponse est un objet, alors c'est un unique commentaire qui a été retournée
-
 
119
							} else if (responseObject.get("commentaires").isObject() != null) {
-
 
120
 
-
 
121
								final JSONObject reponse = responseObject.get("commentaires").isObject();
71
						commentaires.setTaillePage(nbElements);
122
								Commentaire commentaire = new Commentaire(reponse);
-
 
123
								
72
						commentaires.setPageCourante(pageCourante);							
124
								// et on met à jour le demandeur des données
73
 
125
								if (seqId != null)	{
-
 
126
									if (Mediateur.DEBUG) System.out.println("<-- CommentairesASyncDao > Liste non paginée, retour au sequenceur");
-
 
127
									Reponse reponseRequete = new Reponse(commentaire, seqId);
-
 
128
									vueARafraichir.rafraichir(reponseRequete);
-
 
129
								}
-
 
130
								else	{
-
 
131
									if (Mediateur.DEBUG) System.out.println("<-- CommentairesASyncDao > Liste non paginée, retour à "+vueARafraichir.getClass().toString());
-
 
132
									vueARafraichir.rafraichir(commentaire);
-
 
133
								}
74
						if (seqId != null)	{
134
							}
75
							Reponse reponseRequete = new Reponse(commentaires, seqId);
-
 
76
							vueARafraichir.rafraichir(reponseRequete);
-
 
77
						}
-
 
78
						else	{
135
						} else {
79
							vueARafraichir.rafraichir(commentaires);
-
 
80
						}						
-
 
81
					} else {
-
 
82
						GWT.log("La réponse n'est pas un objet ou un talbeau JSON et vaut : "+responseValue.toString(), null);
136
							GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un objet ou un talbeau JSON et vaut : "+responseValue.toString(), null);
83
					}
137
						}
84
				} else {
138
					} else {
85
					// Dans le cas, où nous demandons toutes les publication et qu'il n'y en a pas, nous retournons un objet vide
139
						// Dans le cas, où nous demandons toutes les institutions et qu'il n'y en a pas, nous retournons un objet vide
86
					if (commentaireId == null) {
140
						if (commentaireId == null) {
87
						CommentaireListe commentaires = new CommentaireListe(0);
141
							CommentaireListe commentaires = new CommentaireListe(0);
-
 
142
							if (seqId != null)	{
-
 
143
								Reponse reponseRequete = new Reponse(commentaires, seqId);
-
 
144
								vueARafraichir.rafraichir(reponseRequete);
-
 
145
							}
88
						if (seqId != null)	{
146
							else {
89
							Reponse reponseRequete = new Reponse(commentaires, seqId);
-
 
90
							vueARafraichir.rafraichir(reponseRequete);
-
 
91
						}
-
 
92
						else	{
147
								vueARafraichir.rafraichir(commentaires);
93
							vueARafraichir.rafraichir(commentaires);
148
							}					
94
						}			
149
						}
95
					}
150
					}
96
				}
151
				}
Line 97... Line 152...
97
			}
152
			});
98
		});
153
		}