Subversion Repositories eFlore/Applications.coel

Rev

Rev 1736 | Rev 1764 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1736 Rev 1762
1
package org.tela_botanica.client.modeles.personne;
1
package org.tela_botanica.client.modeles.personne;
2
 
2
 
3
import java.util.HashMap;
3
import java.util.HashMap;
4
 
4
 
5
import org.tela_botanica.client.Mediateur;
5
import org.tela_botanica.client.Mediateur;
6
import org.tela_botanica.client.RegistreId;
6
import org.tela_botanica.client.RegistreId;
7
import org.tela_botanica.client.http.JsonRestRequestBuilder;
7
import org.tela_botanica.client.http.JsonRestRequestBuilder;
8
import org.tela_botanica.client.http.JsonRestRequestCallback;
8
import org.tela_botanica.client.http.JsonRestRequestCallback;
9
import org.tela_botanica.client.interfaces.Rafraichissable;
9
import org.tela_botanica.client.interfaces.Rafraichissable;
10
import org.tela_botanica.client.modeles.Information;
10
import org.tela_botanica.client.modeles.Information;
11
import org.tela_botanica.client.synchronisation.Reponse;
11
import org.tela_botanica.client.synchronisation.Reponse;
12
import org.tela_botanica.client.synchronisation.Sequenceur;
12
import org.tela_botanica.client.synchronisation.Sequenceur;
13
import org.tela_botanica.client.util.Debug;
13
import org.tela_botanica.client.util.Debug;
14
import org.tela_botanica.client.util.UtilDAO;
14
import org.tela_botanica.client.util.UtilDAO;
15
 
15
 
16
import com.extjs.gxt.ui.client.Registry;
16
import com.extjs.gxt.ui.client.Registry;
17
import com.google.gwt.core.client.GWT;
17
import com.google.gwt.core.client.GWT;
18
import com.google.gwt.json.client.JSONArray;
18
import com.google.gwt.json.client.JSONArray;
19
import com.google.gwt.json.client.JSONObject;
19
import com.google.gwt.json.client.JSONObject;
20
import com.google.gwt.json.client.JSONValue;
20
import com.google.gwt.json.client.JSONValue;
21
import com.google.gwt.user.client.Window;
21
import com.google.gwt.user.client.Window;
22
 
22
 
23
public class PersonneAsyncDao {
23
public class PersonneAsyncDao {
24
	private static final String SERVICE_NOM = "CoelPersonne";
24
	private static final String SERVICE_NOM = "CoelPersonne";
-
 
25
	public static String tri = null;
25
	
26
	
26
	private String utilisateurId = null;
27
	private String utilisateurId = null;
27
	private Rafraichissable vueARafraichir = null;
28
	private Rafraichissable vueARafraichir = null;
28
	
29
	
29
	public PersonneAsyncDao(Rafraichissable vue) {
30
	public PersonneAsyncDao(Rafraichissable vue) {
30
		if (Mediateur.DEBUG) System.out.println("|| PersonneAsyncDao > vueARafraichir = "+vue.getClass().toString());
31
		if (Mediateur.DEBUG) System.out.println("|| PersonneAsyncDao > vueARafraichir = "+vue.getClass().toString());
31
		vueARafraichir = vue;
32
		vueARafraichir = vue;
32
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
33
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
33
	}	
34
	}	
34
	
35
	
35
	/**
36
	/**
36
	 * @param paginationProgressive : définit le mode de consultation de la base de données
37
	 * @param paginationProgressive : définit le mode de consultation de la base de données
37
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
38
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
38
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
39
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
39
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
40
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
40
	 * 						est renvoyé à l'appelant
41
	 * 						est renvoyé à l'appelant
41
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
42
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
42
	 */	
43
	 */	
43
	public void selectionner(final boolean paginationProgressive, String personneId, String projetId, String nomComplet, final int start, final int nbElements, final Integer seqId) {
44
	public void selectionner(final boolean paginationProgressive, String personneId, String projetId, String nomComplet, final int start, final int nbElements, final Integer seqId) {
44
 
45
 
45
		String nom = (nomComplet == null) ? "%" : "%"+nomComplet+"%";		
46
		String nom = (nomComplet == null) ? "%" : "%"+nomComplet+"%";		
46
		String[] parametres = {personneId, projetId, nom};
47
		String[] parametres = {personneId, projetId, nom};
47
		
48
		
48
		HashMap<String, String> restrictions = new HashMap<String, String>();
49
		HashMap<String, String> restrictions = new HashMap<String, String>();
49
		
50
		
50
		if (nbElements != -1)	{
51
		if (nbElements != -1)	{
51
			restrictions.put("limit", String.valueOf(nbElements));
52
			restrictions.put("limit", String.valueOf(nbElements));
52
		}
53
		}
-
 
54
 
-
 
55
		if(tri != null) {
-
 
56
			restrictions.put("orderby", tri);
-
 
57
		}
53
		
58
		
54
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
59
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
55
		if (paginationProgressive) {
60
		if (paginationProgressive) {
56
 
61
 
57
			/** DEFINITION DU TUPLE DE DEPART **/
62
			/** DEFINITION DU TUPLE DE DEPART **/
58
			restrictions.put("start", String.valueOf(start));
63
			restrictions.put("start", String.valueOf(start));
59
			
64
			
60
			/** CONSTRUCTION DE LA REQUETE **/
65
			/** CONSTRUCTION DE LA REQUETE **/
61
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
66
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
62
 
67
 
63
    		/** ENVOI DE LA REQUETE **/
68
    		/** ENVOI DE LA REQUETE **/
64
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
69
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
65
    		{
70
    		{
66
    			/** RECEPTION DE LA REPONSE **/
71
    			/** RECEPTION DE LA REPONSE **/
67
    			public void surReponse(JSONValue responseValue)
72
    			public void surReponse(JSONValue responseValue)
68
    			{
73
    			{
69
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
74
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
70
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
75
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
71
    				
76
    				
72
					if (seqId != null)	{
77
					if (seqId != null)	{
73
						if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste paginée, retour au sequenceur");
78
						if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste paginée, retour au sequenceur");
74
						Reponse reponseRequete = new Reponse(responseValue, seqId);
79
						Reponse reponseRequete = new Reponse(responseValue, seqId);
75
						vueARafraichir.rafraichir(reponseRequete);
80
						vueARafraichir.rafraichir(reponseRequete);
76
					}
81
					}
77
					else	{
82
					else	{
78
						if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste paginée, retour à "+vueARafraichir.getClass().toString());
83
						if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste paginée, retour à "+vueARafraichir.getClass().toString());
79
						vueARafraichir.rafraichir(responseValue);
84
						vueARafraichir.rafraichir(responseValue);
80
					}
85
					}
81
    			}
86
    			}
82
    		});
87
    		});
83
		}
88
		}
84
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
89
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
85
		else {
90
		else {
86
			
91
			
87
			/** DEFINITION DU TUPLE DE DEPART **/
92
			/** DEFINITION DU TUPLE DE DEPART **/
88
			restrictions.put("start", String.valueOf(start*nbElements));
93
			restrictions.put("start", String.valueOf(start*nbElements));
89
			
94
			
90
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
95
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, restrictions);
91
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
96
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
92
				@Override
97
				@Override
93
				public void surReponse(JSONValue responseValue) {
98
				public void surReponse(JSONValue responseValue) {
94
					
99
					
95
					if (responseValue != null) {
100
					if (responseValue != null) {
96
						JSONObject reponseObject = responseValue.isObject();
101
						JSONObject reponseObject = responseValue.isObject();
97
						
102
						
98
						if (reponseObject.get("personnes").isArray() != null) {
103
						if (reponseObject.get("personnes").isArray() != null) {
99
							JSONArray reponse = responseValue.isArray();
104
							JSONArray reponse = responseValue.isArray();
100
							
105
							
101
							// Transformation du tableau JSON réponse en ListePersonne
106
							// Transformation du tableau JSON réponse en ListePersonne
102
							Information info = new Information("liste_personne");
107
							Information info = new Information("liste_personne");
103
							PersonneListe personnes;
108
							PersonneListe personnes;
104
							personnes = new PersonneListe(reponseObject.get("personnes").isArray(), reponseObject.get("nbElements").isNumber(), vueARafraichir);
109
							personnes = new PersonneListe(reponseObject.get("personnes").isArray(), reponseObject.get("nbElements").isNumber(), vueARafraichir);
105
							personnes.setTaillePage(nbElements);
110
							personnes.setTaillePage(nbElements);
106
							personnes.setPageCourante(start);							
111
							personnes.setPageCourante(start);							
107
							info.setDonnee(0, personnes);
112
							info.setDonnee(0, personnes);
108
							
113
							
109
							// et on met à jour le demandeur des données
114
							// et on met à jour le demandeur des données
110
							if (seqId != null)	{
115
							if (seqId != null)	{
111
								if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste non paginée, retour au sequenceur");
116
								if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste non paginée, retour au sequenceur");
112
								Reponse reponseRequete = new Reponse(info, seqId);
117
								Reponse reponseRequete = new Reponse(info, seqId);
113
								vueARafraichir.rafraichir(reponseRequete);
118
								vueARafraichir.rafraichir(reponseRequete);
114
							}
119
							}
115
							else	{
120
							else	{
116
								if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste non paginée, retour à "+vueARafraichir.getClass().toString());
121
								if (Mediateur.DEBUG) System.out.println("<-- PersonneAsyncDao > Liste non paginée, retour à "+vueARafraichir.getClass().toString());
117
								vueARafraichir.rafraichir(info);
122
								vueARafraichir.rafraichir(info);
118
							}
123
							}
119
						}
124
						}
120
					} else {
125
					} else {
121
						GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un tableau JSON et vaut : "+responseValue.toString(), null);
126
						GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un tableau JSON et vaut : "+responseValue.toString(), null);
122
					}
127
					}
123
				}
128
				}
124
			});	
129
			});	
125
		}
130
		}
126
	}
131
	}
127
	
132
	
128
	public void ajouter(Personne personne) {		
133
	public void ajouter(Personne personne) {		
129
		String postDonneesEncodees = personne.obtenirChainePOST();
134
		String postDonneesEncodees = personne.obtenirChainePOST();
130
		postDonneesEncodees += "&cmhl_ce_modifier_par=" + utilisateurId;		
135
		postDonneesEncodees += "&cmhl_ce_modifier_par=" + utilisateurId;		
131
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM);	
136
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM);	
132
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
137
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
133
			@Override
138
			@Override
134
			public void surReponse(JSONValue responseValue) {
139
			public void surReponse(JSONValue responseValue) {
135
				if (responseValue.isString() != null) {
140
				if (responseValue.isString() != null) {
136
					Information info = new Information("ajout_personne");
141
					Information info = new Information("ajout_personne");
137
					String structureIdOuMessage = responseValue.isString().stringValue();
142
					String structureIdOuMessage = responseValue.isString().stringValue();
138
					if (structureIdOuMessage.matches("^[0-9]+$")) {
143
					if (structureIdOuMessage.matches("^[0-9]+$")) {
139
						info.setDonnee(structureIdOuMessage);
144
						info.setDonnee(structureIdOuMessage);
140
					} else {
145
					} else {
141
						info.setMessage(structureIdOuMessage);
146
						info.setMessage(structureIdOuMessage);
142
					}
147
					}
143
					vueARafraichir.rafraichir(info);
148
					vueARafraichir.rafraichir(info);
144
				} else {
149
				} else {
145
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
150
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
146
				}
151
				}
147
			}
152
			}
148
		});		
153
		});		
149
	}
154
	}
150
	
155
	
151
	public void modifier(Personne personne) {
156
	public void modifier(Personne personne) {
152
		String postDonneesEncodees = personne.obtenirChainePOST();
157
		String postDonneesEncodees = personne.obtenirChainePOST();
153
		postDonneesEncodees += "&cmhl_ce_modifier_par=" + utilisateurId;
158
		postDonneesEncodees += "&cmhl_ce_modifier_par=" + utilisateurId;
154
		GWT.log(postDonneesEncodees, null);
159
		GWT.log(postDonneesEncodees, null);
155
		String[] parametres = {personne.getId()};
160
		String[] parametres = {personne.getId()};
156
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
161
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
157
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
162
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
158
			@Override
163
			@Override
159
			public void surReponse(JSONValue responseValue) {
164
			public void surReponse(JSONValue responseValue) {
160
				// Si la requête est un succès, reception d'une chaine
165
				// Si la requête est un succès, reception d'une chaine
161
				if (responseValue.isString() != null) {
166
				if (responseValue.isString() != null) {
162
					Information info = new Information("modification_personne");
167
					Information info = new Information("modification_personne");
163
					info.setMessage(responseValue.isString().stringValue());
168
					info.setMessage(responseValue.isString().stringValue());
164
					vueARafraichir.rafraichir(info);
169
					vueARafraichir.rafraichir(info);
165
				} else {
170
				} else {
166
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
171
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
167
				}
172
				}
168
			}
173
			}
169
		});
174
		});
170
	}
175
	}
171
 
176
 
172
	public void supprimer(String personnesId) {		
177
	public void supprimer(String personnesId) {		
173
		String[] parametres = {utilisateurId, personnesId};
178
		String[] parametres = {utilisateurId, personnesId};
174
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
179
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
175
		rb.envoyerRequeteSuppression(new JsonRestRequestCallback() {
180
		rb.envoyerRequeteSuppression(new JsonRestRequestCallback() {
176
			@Override
181
			@Override
177
			public void surReponse(JSONValue responseValue) {
182
			public void surReponse(JSONValue responseValue) {
178
				if (responseValue.isString() != null) {
183
				if (responseValue.isString() != null) {
179
					Information info = new Information("suppression_personne");
184
					Information info = new Information("suppression_personne");
180
					info.setMessage(responseValue.isString().stringValue());
185
					info.setMessage(responseValue.isString().stringValue());
181
					vueARafraichir.rafraichir(info);
186
					vueARafraichir.rafraichir(info);
182
				} else {
187
				} else {
183
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
188
					GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas une chaine JSON.", null);
184
				}
189
				}
185
			}
190
			}
186
		});
191
		});
187
	}
192
	}
188
	
193
	
189
}
194
}