9,7 → 9,8 |
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.utils.MockDatasource; |
import org.tela_botanica.del.client.services.rest.ObservationService; |
import org.tela_botanica.del.client.services.rest.async.ObservationsCallback; |
|
import com.google.gwt.user.client.ui.HasWidgets; |
import com.google.gwt.user.client.ui.IsWidget; |
16,6 → 17,8 |
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(); |
22,13 → 25,23 |
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; |
|
public RechercheObservationsPresenteur(Vue vue) { |
/** |
* 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) { |
38,9 → 51,16 |
composite.add(vue.asWidget()); |
ajouterMoteurRechercheAvancee(); |
|
ObservationServiceResultat observationServiceResultat = MockDatasource.getInstance().getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), 0, CacheClient.getInstance().getPasPagination()); |
creerWidgetPagination(observationServiceResultat.getNbTotalObservationsPourLaRecherche()); |
afficherObservations(observationServiceResultat); |
ObservationsCallback callback = new ObservationsCallback() { |
@Override |
public void surObservationsRecues( |
ObservationServiceResultat observationsRecues) { |
creerWidgetPagination(observationsRecues.getNbTotalObservationsPourLaRecherche()); |
afficherObservations(observationsRecues); |
} |
}; |
|
serviceObs.getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), 0, CacheClient.getInstance().getPasPagination(),callback); |
} |
|
protected void ajouterMoteurRechercheAvancee() { |
59,16 → 79,27 |
} |
|
public void chargerEtAfficherObservations(int debut, int fin) { |
ObservationServiceResultat observationServiceResultat = MockDatasource.getInstance().getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), debut, fin); |
afficherObservations(observationServiceResultat); |
vue.startChargement(); |
vue.nettoyer(); |
ObservationsCallback callback = new ObservationsCallback() { |
|
@Override |
public void surObservationsRecues(ObservationServiceResultat observationsRecues) { |
afficherObservations(observationsRecues); |
requeteEnCours = false; |
} |
}; |
requeteEnCours = true; |
serviceObs.getObservations(CacheClient.getInstance().getInformationsRechercheObservation(), debut, fin, callback); |
} |
|
private void afficherObservations(ObservationServiceResultat observationServiceResultat) { |
vue.getZoneObservations().clear(); |
vue.nettoyer(); |
for (Observation observation : observationServiceResultat.getObservations()) { |
ObservationPresenteur presenteur = new ObservationPresenteur(new ObservationVue(), observation); |
presenteur.go(vue.getZoneObservations()); |
} |
vue.stopChargement(); |
} |
|
private void creerWidgetPagination(int nbObservations) { |
99,8 → 130,10 |
|
@Override |
public void changerPage(int debut, int fin) { |
chargerEtAfficherObservations(debut, fin); |
CacheClient.getInstance().setPageCouranteRechercheObservations(getPageCourante()); |
if(!requeteEnCours) { |
chargerEtAfficherObservations(debut, fin); |
CacheClient.getInstance().setPageCouranteRechercheObservations(getPageCourante()); |
} |
} |
|
@Override |