6,7 → 6,6 |
import org.tela_botanica.del.client.composants.pagination.PaginationPresenteur; |
import org.tela_botanica.del.client.composants.pagination.PaginationVue; |
import org.tela_botanica.del.client.composants.presenteur.Presenteur; |
import org.tela_botanica.del.client.i18n.I18n; |
import org.tela_botanica.del.client.modeles.Observation; |
import org.tela_botanica.del.client.modeles.ObservationServiceResultat; |
import org.tela_botanica.del.client.services.rest.ObservationService; |
14,53 → 13,49 |
|
import com.google.gwt.user.client.ui.HasWidgets; |
import com.google.gwt.user.client.ui.IsWidget; |
import com.google.gwt.user.client.ui.RootPanel; |
|
public class RechercheObservationsPresenteur extends Presenteur { |
|
|
private ObservationService serviceObs; |
|
public abstract interface Vue extends IsWidget { |
public HasWidgets getZoneRecherche(); |
|
public HasWidgets getZoneObservations(); |
|
public HasWidgets getZonePaginationHaut(); |
|
public HasWidgets getZonePaginationBas(); |
|
public void startChargement(); |
|
public void stopChargement(); |
|
public void nettoyer(); |
} |
|
private Vue vue; |
private PaginationPresenteur paginationHautPresenteur, paginationBasPresenteur; |
|
/** |
* Ceci sert à éviter que les deux présenteurs paginations fassent deux requêtes par changement de page |
* En attendant d'en discuter avec les autres |
*/ |
private boolean requeteEnCours = false; |
|
|
public RechercheObservationsPresenteur(ObservationService serviceObs, Vue vue) { |
|
this.vue = vue; |
this.serviceObs = serviceObs; |
} |
|
public void go(HasWidgets composite) { |
if (composite == null) { |
composite = RootPanel.get(); |
} |
|
composite.add(vue.asWidget()); |
ajouterMoteurRechercheAvancee(); |
|
ObservationsCallback callback = new ObservationsCallback() { |
@Override |
public void surObservationsRecues( |
ObservationServiceResultat observationsRecues) { |
creerWidgetPagination(observationsRecues.getNbTotalObservationsPourLaRecherche()); |
afficherObservations(observationsRecues); |
public void surObservationsRecues(ObservationServiceResultat observationsRecues) { |
creerWidgetPagination(observationsRecues.getNbTotalObservationsPourLaRecherche()); |
afficherObservations(observationsRecues); |
} |
}; |
|
serviceObs.getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), 0, CacheClient.getInstance().getPasPagination(),callback); |
|
serviceObs.getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), 0, CacheClient.getInstance().getPasPagination(), callback); |
} |
|
protected void ajouterMoteurRechercheAvancee() { |
82,14 → 77,12 |
vue.startChargement(); |
vue.nettoyer(); |
ObservationsCallback callback = new ObservationsCallback() { |
|
|
@Override |
public void surObservationsRecues(ObservationServiceResultat observationsRecues) { |
afficherObservations(observationsRecues); |
requeteEnCours = false; |
public void surObservationsRecues(ObservationServiceResultat observationsRecues) { |
afficherObservations(observationsRecues); |
} |
}; |
requeteEnCours = true; |
serviceObs.getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), debut, fin, callback); |
} |
|
103,7 → 96,7 |
} |
|
private void creerWidgetPagination(int nbObservations) { |
this.paginationHautPresenteur = new PaginationPresenteur(new PaginationVue(), nbObservations, CacheClient.getInstance().getPasPagination()) { |
PaginationPresenteur paginationPresenteurHaut = new PaginationPresenteur(new PaginationVue(), nbObservations, CacheClient.getInstance().getPasPagination()) { |
|
@Override |
public void changerPage(int debut, int fin) { |
115,25 → 108,15 |
public void actualiserPasCache(int pas) { |
CacheClient.getInstance().setPasPagination(pas); |
} |
|
@Override |
public void synchroniser() { |
paginationBasPresenteur.setPas(getPas()); |
paginationBasPresenteur.setPageCourante(getPageCourante()); |
paginationBasPresenteur.setNbPages(getNbPages()); |
paginationBasPresenteur.actualiserLiens(); |
} |
|
}; |
paginationHautPresenteur.go(vue.getZonePaginationHaut()); |
|
this.paginationBasPresenteur = new PaginationPresenteur(new PaginationVue(), nbObservations, CacheClient.getInstance().getPasPagination()) { |
|
PaginationPresenteur paginationPresenteurBas = new PaginationPresenteur(new PaginationVue(), nbObservations, CacheClient.getInstance().getPasPagination()) { |
|
@Override |
public void changerPage(int debut, int fin) { |
if(!requeteEnCours) { |
chargerEtAfficherObservations(debut, fin); |
CacheClient.getInstance().setPageCouranteRechercheObservations(getPageCourante()); |
} |
chargerEtAfficherObservations(debut, fin); |
CacheClient.getInstance().setPageCouranteRechercheObservations(getPageCourante()); |
} |
|
@Override |
140,16 → 123,10 |
public void actualiserPasCache(int pas) { |
CacheClient.getInstance().setPasPagination(pas); |
} |
|
@Override |
public void synchroniser() { |
paginationHautPresenteur.setPas(getPas()); |
paginationHautPresenteur.setPageCourante(getPageCourante()); |
paginationHautPresenteur.setNbPages(getNbPages()); |
paginationHautPresenteur.actualiserLiens(); |
} |
|
}; |
paginationBasPresenteur.go(vue.getZonePaginationBas()); |
paginationPresenteurHaut.go(vue.getZonePaginationHaut()); |
paginationPresenteurBas.go(vue.getZonePaginationBas()); |
} |
|
} |