VaadinWorker
Eases the use of background-threads for building slick UIs.
VaadinWorker's purpose is it to provide an easy to use interface for both executing tasks in background-threads and displaying their progress towards the user. The addon consists of a class "VaadinWorker", which exposes the two methods "runInBackground()" and "updateUI()". The runInBackground()-method should be used for executing the long-running logic, whose result can be communicated towards the Client using the updateUI()-method. Proper synchronization on the Application-class will be done by the VaadinWorker-template-class. For in-between-updates you can use a ProgressListener. The updateProgress()-method of that interface will also called in a synchronized-block, so that it is safe to do arbitrary UI-updates from that method. To trigger the ProgressListeners you just need to call VaadinWorker#updateProgress(int,String). The int-Parameter communicates the actual progress in form of a procentual progress, while the String is just a description of the work currently done.
The second important part of the Addon is the BackgroundExecutor-component, which not only communicates the progress towards the User but also keeps the UI updating itself using the "Spinning-ProgressIndicator-Pattern". VaadinWorkers get submitted for execution in background by calling BackgroundExecutor#submit(VaadinWorker). They are then handed over towards an ExecutorService. This ExecutorService is retrieved by an ExecutorServiceProvider. This way you can decide for example to reuse an ExecutorService your ApplicationServer already provides. For Servlet-environments the addon contains a mechanism to register an ExecutorService with the ServletContext and later on retrieving it from there again. I'm not using Portals at home, so I didn't had the chance to build a neat solution for portlets as well, but maybe I will get to do that in my day-job ...
At the moment the Addon is marked as experimental as the documentation is lacking and the code has not been tested in any bigger project so far. Let me know what you think about VaadinWorker!
Sample code
public class LongRunningTask extends VaadinWorker { private final String name; public LongRunningTask(String name, boolean cancelable, boolean indeterminate, VaadinWorkerExampleApplication app) { super(app); this.name = name; setCancelable(cancelable); setIndeterminate(indeterminate); } @Override public void runInBackground() { for(int i = 0; i < 100 && !isCanceled(); i++) { updateProgress(i, i + "%"); try { Thread.sleep(500); } catch (InterruptedException e) { cancel(); } } } @Override public void updateUI() { VaadinWorkerExampleApplication app = (VaadinWorkerExampleApplication) getApplication(); Label finishLabel = app.getFinishLabel(); finishLabel.setValue(finishLabel.getValue() + "<br />" + name); } }
Links
Compatibility
Was this helpful? Need more help?
Leave a comment or a question below. You can also join
the chat on Discord or
ask questions on StackOverflow.
Version
Fixed licensing issues.
- Released
- 2012-06-03
- Maturity
- EXPERIMENTAL
- License
- GNU Affero General Public License v3.0
Compatibility
- Framework
- Vaadin 6.7+
- Browser
- Browser Independent