Subversion Repositories eFlore/Applications.coel

Compare Revisions

Ignore whitespace Rev 592 → Rev 593

/trunk/src/org/tela_botanica/client/modeles/PersonneListe.java
1,7 → 1,16
package org.tela_botanica.client.modeles;
 
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.ListePaginable;
import org.tela_botanica.client.interfaces.Rafraichissable;
 
import com.extjs.gxt.ui.client.Registry;
import com.google.gwt.i18n.client.Dictionary;
import com.google.gwt.json.client.JSONArray;
import com.google.gwt.json.client.JSONNumber;
import com.google.gwt.json.client.JSONObject;
import com.google.gwt.json.client.JSONString;
 
/**
* Table de hachage composée d'informations sur les Valeurs des listes, renvoyé par un objet de type DAO
10,10 → 19,13
* @author david delon
*
*/
public class PersonneListe extends aDonneeListe<Personne> {
public class PersonneListe extends aDonneeListe<Personne> implements ListePaginable{
private static final long serialVersionUID = 2930530504922300155L;
private int currentPage = 0;
private int nbElementsPage = Integer.valueOf(((Dictionary) Dictionary.getDictionary("configuration")).get("nbElementsPage"));
private int nbElementsTotal;
private Rafraichissable vueARafraichir;
/**
* Constructeur sans paramètres
*/
45,6 → 57,88
this.put(personne.getId(), personne);
}
}
}
public PersonneListe(JSONArray personneListe, JSONNumber nbElements, Rafraichissable vueARafraichir) {
super(personneListe.size());
this.nbElementsTotal = Integer.valueOf(nbElements.toString());
final int taillemax = personneListe.size();
for (int i = 0; i < taillemax; i++) {
JSONObject personneCourante = personneListe.get(i).isObject() ;
if (personneCourante != null) {
Personne personne = new Personne(personneCourante);
this.put(personne.getId(), personne);
}
}
this.vueARafraichir = vueARafraichir;
}
public int[] getPageTable() {
int[] page = new int[4];
//nombre de pages au total
page[0] = calculerNbPages();
//Page En Cours
page[1] = currentPage;
//nbElementsParPage
page[2] = nbElementsPage;
// et le dernier le nombre total d'éléments
page[3] = nbElementsTotal;
return page;
}
/**
* Calcule le nombre de pages nécessaires pour afficher un nombre d'élements donnés en fonction de la taille de page
* en cours
* @return le nombre de pages
*/
public int calculerNbPages()
{
// A cause de la betise de java pour les conversion implicite on fait quelques conversions manuellement
// pour eviter qu'il arrondisse mal la division
// nombre de pages = (nombre d'element / taille de la page) arrondie à l'entier superieur
double nPage = (1.0*nbElementsTotal)/(1.0*nbElementsPage) ;
double nPageRound = Math.ceil(nPage) ;
Double nPageInt = new Double(nPageRound) ;
// on convertit en entier
return nPageInt.intValue() ;
}
@Override
public void changerNumeroPage(int pageCourante) {
currentPage = pageCourante;
selectionnerPersonne();
}
 
@Override
public void changerTaillePage(int nouvelleTaillePage) {
nbElementsPage = nouvelleTaillePage;
selectionnerPersonne();
}
public void setPageCourante(int pageCourante) {
this.currentPage = pageCourante;
};
public void selectionnerPersonne() {
Mediateur mediateur =(Mediateur) Registry.get(RegistreId.MEDIATEUR);
mediateur.selectionnerPersonne(vueARafraichir, null, null, currentPage, 15);
}
}
/trunk/src/org/tela_botanica/client/modeles/PersonneAsyncDao.java
1,5 → 1,7
package org.tela_botanica.client.modeles;
 
import java.util.HashMap;
 
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.Rafraichissable;
26,7 → 28,7
vueARafraichir = vue;
}
 
public void selectionner(String personneId, String projetId, String nomComplet) {
public void selectionner(String personneId, String projetId, String nomComplet, final int pageCourante, int nbElements) {
// Ajout des paramètres et données à selectionner dans l'URL
String[] parametres = new String[3];
33,7 → 35,14
parametres[0] = (personneId == null ? "*" : personneId);
parametres[1] = (projetId == null ? "*" : projetId);
parametres[2] = (nomComplet == null ? "*" : nomComplet);
final RequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres);
HashMap<String, String> hmRestrictions = new HashMap<String, String>();
hmRestrictions.put("start", String.valueOf(pageCourante));
if (nbElements != -1) {
hmRestrictions.put("limit", String.valueOf(nbElements));
}
final RequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, hmRestrictions, "GET");
try {
rb.sendRequest(null, new RequestCallback() {
 
63,10 → 72,16
final JSONArray reponse = responseValue.isArray();
// Transformation du tableau JSON réponse en ListeInstitution
Information info = new Information("liste_personne");
PersonneListe personnes = new PersonneListe(reponse);
PersonneListe personnes;
if (reponse.get(0).isArray() != null) {
personnes = new PersonneListe(reponse);
} else {
personnes = new PersonneListe(reponse.get(1).isArray(), reponse.get(0).isNumber(), vueARafraichir);
}
personnes.setPageCourante(pageCourante);
info.setDonnee(0, personnes);
// et on met à jour le demandeur des données
System.out.println("PADAO.82"+vueARafraichir);
vueARafraichir.rafraichir(info);
} else {
GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un talbeau JSON et vaut : "+responseValue.toString(), null);
99,7 → 114,6
parametres[0] = utilisateurId;
parametres[1] = structureId;
//System.out.println(structureId);
RequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, parametres, "POST");