Subversion Repositories eFlore/Applications.coel

Rev

Rev 1764 | Details | Compare with Previous | Last modification | View Log | RSS feed

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