Subversion Repositories eFlore/Applications.del

Compare Revisions

Ignore whitespace Rev 391 → Rev 392

/trunk/src/org/tela_botanica/del/client/vues/rechercheobservations/RechercheObservationsVue.java
10,6 → 10,9
 
public class RechercheObservationsVue extends Composite implements RechercheObservationsPresenteur.Vue {
 
@UiField
Panel panneauChargement;
// Gestion d'UiBinder
interface Binder extends UiBinder<Widget, RechercheObservationsVue> {
}
41,5 → 44,23
public HasWidgets getZonePaginationBas() {
return zonePaginationBas;
}
/**
* Nettoie et remet à zéro les composants du panneau qui doivent l'être
* */
@Override
public void nettoyer() {
zoneObservations.clear();
}
 
@Override
public void startChargement() {
panneauChargement.setHeight(zoneObservations.getOffsetHeight()+"px");
panneauChargement.setVisible(true);
}
 
@Override
public void stopChargement() {
panneauChargement.setVisible(false);
}
}
/trunk/src/org/tela_botanica/del/client/vues/rechercheobservations/RechercheObservationsVue.ui.xml
11,6 → 11,9
</g:HTMLPanel>
<g:HTMLPanel>
<g:VerticalPanel ui:field="zonePaginationHaut" />
<g:VerticalPanel ui:field="panneauChargement" >
<g:Image url="./img/wait.gif"></g:Image>
</g:VerticalPanel>
<g:HTMLPanel ui:field="zoneObservations" styleName="{style.zoneObservation}"/>
<g:VerticalPanel ui:field="zonePaginationBas" />
</g:HTMLPanel>
/trunk/src/org/tela_botanica/del/client/vues/rechercheobservations/RechercheObservationsPresenteur.java
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