Subversion Repositories eFlore/Archives.cel-v2

Rev

Rev 43 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 43 Rev 48
1
package org.tela_botanica.client.modeles;
1
package org.tela_botanica.client.modeles;
2
 
-
 
3
import org.tela_botanica.client.image.ImageMediateur;
2
 
4
import org.tela_botanica.client.image.ImageModele;
3
import org.tela_botanica.client.image.ImageModele;
5
import org.tela_botanica.client.interfaces.Rafraichissable;
4
import org.tela_botanica.client.interfaces.Rafraichissable;
6
 
-
 
7
import com.google.gwt.json.client.JSONArray;
-
 
8
import com.google.gwt.json.client.JSONObject;
5
 
9
import com.google.gwt.json.client.JSONParser;
6
import com.google.gwt.json.client.JSONParser;
10
import com.google.gwt.json.client.JSONString;
7
import com.google.gwt.json.client.JSONString;
11
import com.google.gwt.json.client.JSONValue;
8
import com.google.gwt.json.client.JSONValue;
12
import com.google.gwt.user.client.HTTPRequest;
9
import com.google.gwt.user.client.HTTPRequest;
13
import com.google.gwt.user.client.ResponseTextHandler;
10
import com.google.gwt.user.client.ResponseTextHandler;
14
import com.google.gwt.user.client.Window;
-
 
15
import com.google.gwt.user.client.ui.Image;
-
 
16
 
11
 
17
/**
12
/**
18
 * DAO qui renvoie le nombre d'image associées à différents critères donnés (utile pour la pagination)
13
 * DAO qui renvoie le nombre d'image associées à différents critères donnés (utile pour la pagination)
19
 * @author aurelien
14
 * @author aurelien
20
 *
15
 *
21
 */
16
 */
22
public class NombreImageAsynchroneDAO {
17
public class NombreImageAsynchroneDAO {
23
 
18
 
24
	/**
19
	/**
25
	 * Le modèle associé au DAO
20
	 * Le modèle associé au DAO
26
	 */
21
	 */
27
	private ImageModele iModele = null ;
22
	private ImageModele iModele = null ;
-
 
23
	
-
 
24
	public NombreImageAsynchroneDAO(ImageModele im)
-
 
25
	{
-
 
26
		iModele = im ;
-
 
27
	}
28
	
28
	
29
	/**
29
	/**
30
	 * Setteur pour le modèle
30
	 * Setteur pour le modèle
31
	 * @param im le modèlme à associer
31
	 * @param im le modèlme à associer
32
	 */
32
	 */
33
	public void setIModele(ImageModele im)
33
	public void setIModele(ImageModele im)
34
	{
34
	{
35
		iModele = im ;
35
		iModele = im ;
36
	}
36
	}
37
	
37
	
38
	/**
38
	/**
39
	 * Envoie une requete au serveur jrest pour obtenir le nombre d'images correspondant
39
	 * Envoie une requete au serveur jrest pour obtenir le nombre d'images correspondant
40
	 * à des critères données en paramètres
40
	 * à des critères données en paramètres
41
	 * @param r le rafraichissable qui demande la mise à jour
41
	 * @param r le rafraichissable qui demande la mise à jour
42
	 * @param criteres un tableau nom/valeur des critères pour les images
42
	 * @param criteres un tableau nom/valeur des critères pour les images
43
	 */
43
	 */
44
	public void obtenirNombreImages(final Rafraichissable r, String[][] criteres)
44
	public void obtenirNombreImages(final Rafraichissable r, String[][] criteres)
45
	{
45
	{
46
		String requete = "" ;
46
		String requete = "" ;
47
			
47
			
48
		if(criteres != null)
48
		if(criteres != null)
49
		{
49
		{
50
			// on construit les paramètres du get avec les critères (&critere1=valeur1&critere2=valeur2 etc...)
50
			// on construit les paramètres du get avec les critères (&critere1=valeur1&critere2=valeur2 etc...)
51
			for (int i = 0; i < criteres.length; i++) {
51
			for (int i = 0; i < criteres.length; i++) {
52
			
52
			
53
				if(!criteres[i][0].equals("ci_ordre"))
53
				if(!criteres[i][0].equals("ci_ordre"))
54
				{	
54
				{	
55
					if(!criteres[i][1].equals(""))
55
					if(!criteres[i][1].equals(""))
56
					{
56
					{
57
						if(i!= 0)
57
						if(i!= 0)
58
						{
58
						{
59
							requete += "&";
59
							requete += "&";
60
						}
60
						}
61
						requete += criteres[i][0]+"="+criteres[i][1] ;
61
						requete += criteres[i][0]+"="+criteres[i][1] ;
62
					}
62
					}
63
				}
63
				}
64
			}
64
			}
65
		}
65
		}
66
		
66
		
67
		// on fait un get asynchrone
67
		// on fait un get asynchrone
68
		HTTPRequest.asyncGet("jrest/InventoryImageCount/"+iModele.getIdentifiant()+"/"+requete, new ResponseTextHandler() {
68
		HTTPRequest.asyncGet("jrest/InventoryImageCount/"+iModele.getIdentifiant()+"/"+requete, new ResponseTextHandler() {
69
			public void onCompletion(String responseText) {
69
			public void onCompletion(String responseText) {
70
			
70
			
71
				
71
				
72
				final JSONValue responseValue = JSONParser.parse(responseText);
72
				final JSONValue responseValue = JSONParser.parse(responseText);
73
				
73
				
74
				// si la requete se passe bien on reçoit un tableau JSON
74
				// si la requete se passe bien on reçoit un tableau JSON
75
				if(responseValue.isArray() != null)
75
				if(responseValue.isArray() != null)
76
				{
76
				{
77
					// qui contient une valeur : le nombre d'images correspondant au critères
77
					// qui contient une valeur : le nombre d'images correspondant au critères
78
					JSONValue res = responseValue.isArray().get(0) ;
78
					JSONValue res = responseValue.isArray().get(0) ;
79
						JSONString reponseNombre = res.isString() ;
79
						JSONString reponseNombre = res.isString() ;
80
						int maxImages = (int)Integer.parseInt(reponseNombre.stringValue()) ;
80
						int maxImages = Integer.parseInt(reponseNombre.stringValue()) ;
81
						int[] nbImages = {maxImages} ;
81
						int[] nbImages = {maxImages} ;
82
						// on le met dans un tableau d'entiers qu'on tranmset au demandeur de la mise à jour
82
						// on le met dans un tableau d'entiers qu'on tranmset au demandeur de la mise à jour
83
						r.rafraichir(nbImages, true) ;
83
						r.rafraichir(nbImages, true) ;
84
				}
84
				}
85
				
85
				
86
			}
86
			}
87
			
87
			
88
		}) ;
88
		}) ;
89
	}
89
	}
90
	
90
	
91
}
91
}