Subversion Repositories eFlore/Applications.coel

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
126 gduche 1
package org.tela_botanica.client.modeles;
2
 
3
import org.tela_botanica.client.RegistreId;
4
import org.tela_botanica.client.interfaces.Rafraichissable;
146 gduche 5
import org.tela_botanica.client.util.UtilDAO;
126 gduche 6
 
7
import com.extjs.gxt.ui.client.Registry;
8
import com.google.gwt.core.client.GWT;
9
import com.google.gwt.http.client.Request;
10
import com.google.gwt.http.client.RequestBuilder;
11
import com.google.gwt.http.client.RequestCallback;
12
import com.google.gwt.http.client.RequestException;
13
import com.google.gwt.http.client.Response;
14
import com.google.gwt.json.client.JSONArray;
15
import com.google.gwt.json.client.JSONException;
16
import com.google.gwt.json.client.JSONParser;
17
import com.google.gwt.json.client.JSONValue;
18
import com.google.gwt.user.client.Window;
19
 
20
 
146 gduche 21
public class PersonnesAsyncDao {
126 gduche 22
 
23
 
24
	private PersonneListe personnes = null;
25
	private Rafraichissable rafraichissement = null;
26
 
146 gduche 27
	public PersonnesAsyncDao(Rafraichissable r) {
126 gduche 28
		rafraichissement = r;
29
	}
30
 
146 gduche 31
	public void obtenirDetailPersonne(String personneId)	{
32
		//RequestBuilder rb = UtilDAO.construireRequete("CoelPersonneListe");
33
		Window.alert("lalal");
34
	}
35
 
126 gduche 36
	public void obtenirListePersonnes()	{
37
 
38
	// Appel du service JREST pour avoir toutes les personnes
146 gduche 39
	RequestBuilder rb = UtilDAO.construireRequete("CoelPersonneListe");
126 gduche 40
 
41
	try {
42
			rb.sendRequest(null, new RequestCallback() {
43
 
44
				public void onError(Request request, Throwable exception) {
45
					/*
46
					 * Gestion de l'exception lorsque la requête ne se termine pas correctement
47
					 * */
48
					GWT.log("Erreur à l'exécution du service CoelPersonneListe", exception);
49
					Window.alert("Une erreur s'est produite lors de l'accès aux données");
50
				}
51
 
52
				public void onResponseReceived(Request request, Response response) {
53
 
54
					/*
55
					 * La requête doit renvoyer une chaîne de caratères, parsable avec JSON
56
					 * Si ce n'est pas le cas, on log une erreur
57
					 * */
58
 
59
					if (!response.getText().equals(""))	{
60
 
61
						try	{
62
								final JSONValue responseValue = JSONParser.parse(response.getText());
63
 
64
								// Si la requête est un succès, reception d'un tableau
65
								if (responseValue.isArray() != null)	{
66
 
67
									final JSONArray reponse = responseValue.isArray();
68
 
69
									// Transformation du tableau JSON réponse en ListePersonnes
138 gduche 70
									personnes = new PersonneListe(reponse);
71
 
126 gduche 72
								}
73
 
74
							}
75
						catch (JSONException e)	{
76
 
77
								// Cette exception est levée si la chaîne de caractère n'a pu être parsée par JSON
78
								GWT.log("ERREUR parsing JSON", e);
79
								Window.alert("Une erreur s'est produite lors de la récupération des personnes.");
80
							}
81
						}
82
 
83
						if (personnes == null)	{
84
 
85
							// Si la requete est vide, il faut toutefois retourner une liste, vide.
86
							personnes = new PersonneListe();
87
						}
88
 
89
						// On met à jour le demandeur des données
90
						rafraichissement.rafraichir(personnes);
91
 
92
				}
93
			});
94
 
95
		} catch (RequestException e) {
96
 
97
				// Erreur à la création de la requête : url non-valide?
98
				GWT.log("Erreur à la création de la requete pour CoelPersonneListe", e);
99
				Window.alert("Une erreur s'est produite lors de l'accès aux données");
100
		}
101
 
102
 
103
	}
104
 
105
}