/** * */ package org.gcube.portlets.user.td.sdmximportwidget.client.progress; import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; import com.allen_sauer.gwt.log.client.Log; import com.sencha.gxt.widget.core.client.ProgressBar; /** * Updates a {@link ProgressBar} progress and text based on {@link OperationProgressListener} events. * * @author "Giancarlo Panichi" * g.panichi@isti.cnr.it * */ public class ImportProgressBarUpdater implements OperationProgressListener { protected ProgressBar progressBar; /** * Creates a new {@link ProgressBar} updater. * @param progressBar the {@link ProgressBar} to update. */ public ImportProgressBarUpdater(ProgressBar progressBar) { this.progressBar = progressBar; } /** * {@inheritDoc} */ public void operationComplete(TRId trId) { Log.info("Import complete"); progressBar.updateProgress(1, "Import complete."); } /** * {@inheritDoc} */ public void operationFailed(Throwable caught, String reason, String failureDetails) { Log.info("Import failed"); progressBar.updateText("Import failed."); } public void operationInitializing() { Log.info("Inport inizializing"); progressBar.updateProgress(0, "Initializing..."); } public void operationUpdate(float elaborated) { Log.info("Import elaborated: "+elaborated); if (elaborated == 0) progressBar.updateProgress(0, "Initializing..."); if (elaborated>0 && elaborated<1) { Log.trace("progress "+elaborated); int elab=new Float(elaborated*100).intValue(); progressBar.updateProgress(elaborated,elab+"% Importing..."); } if (elaborated == 1) progressBar.updateProgress(1, "Completed"); } }