Subversion Repositories eFlore/Applications.cel

Rev

Blame | Last modification | View Log | RSS feed

package org.tela_botanica.client.modeles;

import org.tela_botanica.client.image.ImageModele;
import org.tela_botanica.client.interfaces.Rafraichissable;
import com.google.gwt.http.client.Request;
import com.google.gwt.http.client.RequestBuilder;
import com.google.gwt.http.client.RequestCallback;
import com.google.gwt.http.client.RequestException;
import com.google.gwt.http.client.Response;
import com.google.gwt.json.client.JSONParser;
import com.google.gwt.json.client.JSONString;
import com.google.gwt.json.client.JSONValue;

/**
 * DAO qui renvoie le nombre d'image associées à différents critères donnés (utile pour la pagination)
 * @author aurelien
 *
 */
public class NombreImageAsynchroneDAO {

        /**
         * Le modèle associé au DAO
         */
        private ImageModele iModele = null ;
        
        public NombreImageAsynchroneDAO(ImageModele im)
        {
                iModele = im ;
        }
        
        /**
         * Setteur pour le modèle
         * @param im le modèlme à associer
         */
        public void setIModele(ImageModele im)
        {
                iModele = im ;
        }
        
        /**
         * Envoie une requete au serveur jrest pour obtenir le nombre d'images correspondant
         * à des critères données en paramètres
         * @param r le rafraichissable qui demande la mise à jour
         * @param criteres un tableau nom/valeur des critères pour les images
         */
        public void obtenirNombreImages(final Rafraichissable r, String[][] criteres)
        {
                String requete = "" ;
                        
                if(criteres != null)
                {
                        // on construit les paramètres du get avec les critères (&critere1=valeur1&critere2=valeur2 etc...)
                        for (int i = 0; i < criteres.length; i++) {
                                
                                if(!criteres[i][1].equals(""))
                                {
                                        if(i!= 0)
                                        {
                                                requete += "&";
                                        }
                                        requete += criteres[i][0]+"="+criteres[i][1] ;
                                }
                        }
                }
                
                // on fait un get asynchrone
                RequestBuilder rb = new RequestBuilder(RequestBuilder.GET, iModele.getConfig().getServiceBaseUrl()+"/InventoryImageCount/"+iModele.getIdentifiant()+"/"+requete) ;
                try {
                        rb.sendRequest(null, new RequestCallback() {

                                public void onError(Request request, Throwable exception) {
                                        // TODO Auto-generated method stub
                                        
                                }

                                public void onResponseReceived(Request request, Response response) {
                                        
                                        final JSONValue responseValue = JSONParser.parse(response.getText());
                                        
                                        // si la requete se passe bien on reçoit un tableau JSON
                                        if(responseValue.isArray() != null)
                                        {
                                                // qui contient une valeur : le nombre d'images correspondant au critères
                                                JSONValue res = responseValue.isArray().get(0) ;
                                                        JSONString reponseNombre = res.isString() ;
                                                        int maxImages = Integer.parseInt(reponseNombre.stringValue()) ;
                                                        int[] nbImages = {maxImages} ;
                                                        // on le met dans un tableau d'entiers qu'on transmet au demandeur de la mise à jour
                                                        r.rafraichir(nbImages, true) ;
                                        }
                                        
                                }
                                
                        }) ;
                } catch (RequestException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }
                
        }
        
}