summaryrefslogtreecommitdiffstats
path: root/documentation/articles/IntegrationExperiences.asciidoc
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/articles/IntegrationExperiences.asciidoc')
-rw-r--r--documentation/articles/IntegrationExperiences.asciidoc417
1 files changed, 417 insertions, 0 deletions
diff --git a/documentation/articles/IntegrationExperiences.asciidoc b/documentation/articles/IntegrationExperiences.asciidoc
new file mode 100644
index 0000000000..121a3606ea
--- /dev/null
+++ b/documentation/articles/IntegrationExperiences.asciidoc
@@ -0,0 +1,417 @@
+[[integrating-vaadin-applications-with-other-technologies]]
+Integrating Vaadin Applications with other technologies
+-------------------------------------------------------
+
+[[preface]]
+Preface
+~~~~~~~
+
+The intention of this article is not to show how to integrate
+http://vaadin.com/[Vaadin] with some other technology, but to tell
+user-stories from both easy and hard customer cases where Vaadin has
+been combined with something else. It should also give you a pointer to
+what is possible and what is not.
+
+Please see the http://vaadin.com/wiki[wiki] for more extensive technical
+articles on various subjects. If you are interested in learning more
+from our developers, please contact us through
+http://vaadin.com/forum[our forums]. The forum messages are usually
+answered very rapidly (read: within a few hours during business hours).
+
+[[user-stories]]
+User stories
+~~~~~~~~~~~~
+
+[[cloud-computing-and-vaadin]]
+Cloud computing and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Amazon's EC2 really takes creating and serving Vaadin applications to
+a new level. You can literally have a new server running with server,
+portal and application in couple of minutes and it all just works. Of
+course this not only applies to Vaadin applications, but together they
+are a perfect fit! -*Joonas Lehtinen*
+===============================
+
+link:https://aws.amazon.com/ec2/[Amazon EC2]
+
+[[cms-ala-liferay-and-vaadin]]
+CMS (ala Liferay) and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+We wanted to be able to show some pop-up application windows that were
+part of our Vaadin application and that the customer themselves could
+write the links in their CMS without hassle. What we did was that we
+created an invisible Vaadin application that listened to the URL and
+whenever it changed due to a click on a link, it launched a new pop-up
+window. The solution was also highly scalable as 30.000+ users are using
+it daily already. -*Johannes Tuikkala*
+===============================
+
+[[custom-ui-components-to-browser-with-java]]
+Custom UI components to browser with Java
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Creating your own widget for Vaadin is very easy thanks to the new
+eclipse plugin. All you need to do is select "Create new Widget" in
+eclipse and all the server and client side code is automatically
+generated for you. Then you'll just create the widget using Java and
+GWT. Using the eclipse plugin it is also much faster to set up a new
+Vaadin project. -*Matti Tahvonen*
+===============================
+
+[[drools-and-vaadin]]
+Drools and Vaadin
+^^^^^^^^^^^^^^^^^
+
+===============================
+We required a flexible way to validate internal dependencies in highly
+dynamic data structures. We solved our need by integrating the Drools
+rule engine in our application, and with it we got a powerful
+content-triggered autocompletion mechanism as a freebie. We wrapped the
+rule engine behind a general API in a EJB, so the rule mechanism can be
+used by all components of the application architecture. -*Henri
+Muurimaa*
+===============================
+
+http://jboss.org/drools[Drools]
+
+[[extending-existing-components]]
+Extending existing components
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+We had a real business need for few important widgets that just were
+not available in Vaadin. So we extended the current table and came up
+with hierarchical table aka treetable. Another simple but important
+widget was multilingual text field. It acts just like normal textfield
+but when opened, you get the java field opened with multiple locale
+instances, it has nice UI too including user friendly flags. Great for
+handling i18n based data in your UI. We got multiple customercases that
+enjoy these new widgets. -*Jani Laakso*
+===============================
+
+
+[[flex-and-vaadin]]
+Flex and Vaadin
+^^^^^^^^^^^^^^^
+
+===============================
+Flex is really excellent for animations and flashy things and in this
+way is an ideal candidate for creating something really good looking
+together with Vaadin. I created a proof-of-concept flex-Vaadin
+application that communicates through GWT by wrapping the flex component
+and implementing Vaadin's paintable interface. If you know flex from
+before or have teams that know flex and others that know Java then this
+is an ideal combination. -*Kim Leppänen*
+===============================
+
+http://demo.vaadin.com/coverflow/[Coverflow example with Flex+Vaadin]
+
+[[google-analytics-integration]]
+Google Analytics Integration
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+For the Sampler application, we wanted to be able to see which
+'samples' are interesting to the users. GWT makes it easy to integrate
+with JavaScript APIs, and thus making a Google Analytics component was a
+breeze, even without using existing GWT/Java efforts. -*Marc Englund*
+===============================
+
+http://demo.vaadin.com/sampler/[Sampler]
+
+[[graphics-with-jfreechart]]
+Graphics with JFreeChart
+^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+It turned out surprisingly easy to add various charts to reports
+generated by a web application. All we needed to do is create the
+JFreeChart chart object and an Vaadin component automatically displays
+it as SVG or PNG graphics depending on the browser used. -*Henri Sara*
+===============================
+
+http://dev.vaadin.com/browser/incubator/JFreeChartComponent[Vaadin:JFreeChart
+Component] +
+http://www.jfree.org/jfreechart/[JFreeChart]
+
+[[gwt-components-to-vaadin]]
+GWT Components to Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+I wanted to create a Vaadin component out of Google's !GoogleMaps GWT
+Widget. In order to do this you needed to create a widgetset that
+includes the component and implement two methods that are required for
+communication between the client and the server. Quite straight forward.
+See the code in the incubator (link below). -*Henri Muurimaa*
+===============================
+
+https://new.vaadin.com/directory/component/googlemaps-add-on[GoogleMaps
+add-on]
+
+[[javascript-libraries-and-vaadin]]
+Javascript libraries and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+For the Sampler application, I made a code formatting and colorizing
+component, which makes use of the "google-code-prettify" JavaScript
+library. I've found existing JavaScript libraries are easy to use with
+GWT on the client-side. -*Marc Englund*
+===============================
+
+http://demo.vaadin.com/sampler/[Sampler] +
+http://code.google.com/p/google-code-prettify/[Prettify]
+
+[[jquery-dojo-and-prototype-with-vaadin]]
+JQuery, Dojo and Prototype with Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Combining Vaadin applications and client-side javascript libraries is
+a very interesting use-case and a very easy one to implement as well.
+The easiest way to accomplish this is to use a !CustomLayout with the
+Javascript you want. See a short demo I made below. -*Joonas Lehtinen*
+===============================
+
+http://vaadin.com/forum/-/message_boards/message/18611[Discussions on
+the forum] +
+http://jole.virtuallypreinstalled.com/JQTest/[Live example of
+JQuery and Vaadin collaboration]
+
+[[latex-and-vaadin]]
+LaTeX and Vaadin
+^^^^^^^^^^^^^^^^
+
+===============================
+This was no doubt a very exotic combination. Our customer wanted to be
+able to create books that could be sent to printing based on huge
+amounts of data. We wrote an advanced parser (using DOM and SAX parsers)
+that created a file that LaTeX could interpret. LaTeX then created a PDF
+that was saved in a database and a link showed up in the webshop.
+Whenever you clicked on the link, you got finalized PDF that could be
+sent to printing and as a result you got a full several hundred pages
+long book. -*Jani Laakso*
+===============================
+
+http://www.latex-project.org/[LaTeX]
+
+[[leveraging-existing-java-libraries-in-the-browser]]
+Leveraging existing Java libraries in the browser
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Recently, while making a gesture recognition component, I was able to
+use the Levensthein Distance algorithm implementation from the Jakarta
+Commons project, without any modification.The use of GWT makes it
+possible to leverage existing Java code on the client side - within own
+projects, or by making use of the vast amount of libraries available for
+Java. -*Marc Englund*
+===============================
+
+[[moss-and-vaadin-through-iframe]]
+MOSS and Vaadin through IFrame
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+The goal was to get a Vaadin application running inside the Microsoft
+Office Sharepoint Server (MOSS) as a portlet. What we did was that we
+wrote our Vaadin application and deployed it on a JBoss portal. We then
+took the application's URL and used MOSS' !PageViewer Webpart to have it
+include the application inside an IFrame. It was actually much easier
+that I thought. -*Johannes Tuikkala*
+===============================
+
+http://blogs.technet.com/josebda/archive/2007/04/05/integrating-sharepoint-with-other-portals-and-web-applications.aspx[Integrating
+Sharepoint with other portals and web applications]
+
+[[moss-and-vaadin-with-sharepoint-sso]]
+MOSS and Vaadin with Sharepoint SSO
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+The goal was to integrate a Vaadin application to MOSS as portal.
+Priority was to use SSO by Sharepoint. This was accomplished doing
+custom integration Webpart with C# that transfered authentication
+information to Vaadin before it was opened with-in IFRAME. -*Mauno
+Haukila*
+===============================
+
+[[n-tier-jee-architecture-with-vaadin]]
+N-tier JEE architecture with Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+We have found in several larger customer cases that the best possible
+architecture is to separate the UI-layer from the rest. Never mix your
+business logic inside UI logic, there's no need to. This way the UI can
+be replaced in the future and also when updating old systems to use
+Vaadin (e.g. SWING applications that are written this way) it has been a
+breeze when the only thing that needs to be rewritten is the UI. Another
+very imporant factor is security, trust your data layer, do not trust
+your clients, using enterprise beans with JNDI helps you. Scalability
+and high-availability are also easier to cope with. Scale up with
+multiple cheap Tomcat machines acting as Vaadin clients, few powerful
+data servers as JBoss cluster and a good SQL server. -*Jani
+Laakso*
+===============================
+
+image:img/n-tier.png[N-tier]
+
+[[offline-standalone-applications]]
+Offline / standalone applications
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+I've made offline / standalone Vaadin applications by integrating an
+embedded servlet container (Jetty and Winstone so far) with Xulrunner.
+This is actually a quite straightforward process, requiring only a few
+lines of code for the basic functionality. It's really the distribution
+(making installers and such), and the actual application that's the hard
+part. -*Marc Englund*
+===============================
+
+http://www.itmill.com/articles/Packaging_web_applications_for_desktop_use.htm[Packaging
+web applications for desktop use]
+
+[[opensource-stack-for-customer-projects]]
+Opensource stack for customer projects
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+One of our customers asked us to help them with selecting an open
+source stack for their open source product portfolio. What we came up
+with was based on our own experiences and is by no means the only
+possibility. What it shows though, is how Vaadin is only part of the UI
+layer and everything beneath it can be almost anything. -*Ville
+Ingman*
+===============================
+
+image:img/OSStack.png[OS Stack] +
+link:img/OSStack.pdf[OS Stack PDF]
+
+[[pentaho-bi-suite-and-vaadin]]
+Pentaho BI Suite and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Yet another way to create PDF files, but this time really tightly
+integrated with Vaadin. We had some data in a Vaadin table that we
+wanted to print as a PDF file. As each component in Vaadin has a
+container, the most natural way was to take the data from the container,
+send it through a wrapper and give it to Pentaho. Pentaho then created
+the PDF files without any problems. So whenever somebody wanted to print
+the data they were viewing in a scrollable table, they just clicked a
+button and everything was taken care of in the background. -*Jani
+Laakso*
+===============================
+
+http://www.pentaho.com/[Pentaho BI Suite]
+
+[[portlets-with-vaadin]]
+Portlets with Vaadin
+^^^^^^^^^^^^^^^^^^^^
+
+===============================
+The only thing you have to do in practice when you want to write a
+portlet is add the portlet.xml file, where you define Vaadin's
+!ApplicationPortlet as the entry point. After this your application will
+work inside the portal. The only situation where you need to edit the
+Java code as well is when you want to use some portal/portlet specific
+features. This gives you the possibility to first develop a standard
+Vaadin application and then later, by just adding the portlet.xml file
+you have it working inside a portal. -*Jonas Granvik*
+===============================
+
+http://dev.vaadin.com/wiki/Articles/PortalTools[Portal Tools]
+
+[[pdfs-fopitext-and-vaadin]]
+PDFs (FOP+iText) and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+When creating my printing service I used Apache FOP and iText to
+create PDF files from multiple XML/XSLT/PDF files just as you would
+normally in any Java application. The thing I found the most powerful
+however was the combination with these two products together with
+Vaadin's Embedded component. I just created the object, setSource() to
+my byte array and the PDF showed up in my browser together with all the
+buttons and widgets I also wanted on the screen. The user experience was
+significantly enhanced compared to having to download the PDF and click
+on some button in an external window. -*Fredrik Rönnlund*
+===============================
+
+http://vaadin.com/book/-/page/components.embedded.html[Vaadin:Embedded] +
+http://xmlgraphics.apache.org/fop/[Apache FOP] +
+http://www.lowagie.com/iText/[iText]
+
+[[saas-with-vaadin]]
+SAAS with Vaadin
+^^^^^^^^^^^^^^^^
+
+===============================
+When writing our application as a service we had to do some serious
+planning beforehand as the application was going to be used by so many
+people. What we did was that we had one database for all users and then
+inserted the instance ID in all HQL/SQL clauses to be sure we were
+always accessing the correct instance. The instance was select at login.
+This didn't require any specific things from the UI part, which was
+created using Vaadin. -*Jani Laakso*
+===============================
+
+[[single-sign-on-sso-to-liferay]]
+Single Sign On (SSO) to Liferay
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Writing a Single Sign On portlet was really easy. A Vaadin application
+by default only requires to be packaged as a portlet in order to work
+inside a portal and then by using the provided API to the portal you can
+easily retrieve all login information. This way the user doesn't need to
+login several times and context handling is also done easily. -*Jani
+Laakso*
+===============================
+
+[[unit-testing-vaadin-applications]]
+Unit testing Vaadin applications
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Unit testing Vaadin applications is no different from unit testing any
+java application. What we have done however is separate the GUI from the
+!BusinessLogic (even so far that they are running on physically
+different servers). This way our most extensive testing is done on the
+business logic, but also on our Controller in the GUI. Having Unit tests
+in general has helped us build more solid applications, on all
+layers. -*Kim Leppänen*
+===============================
+
+[[web-2.0-apis-and-vaadin]]
+Web 2.0 APIs and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Many "Web 2.0" APIs already have GWT bindings, making it trivial to
+use these. Even without existing bindings, it's easy to use JavaScript
+APIs from GWT, or REST/JSON/XML/etc APIs from the server-side.Google
+Maps, Google Analytics, Flickr, Youtube - these are some "Web 2.0" APIs
+that have been used. -*Marc Englund*
+===============================
+
+[[webservices-and-vaadin]]
+Webservices and Vaadin
+^^^^^^^^^^^^^^^^^^^^^^
+
+===============================
+Integrating a webservice with Vaadin was really a no brainer. What we
+had was a UI that had to check something through a service-provider's
+Webservice. So when ever the UI launched the check, we called the
+webservice (with Pojos created by the WSDL file that we got from the
+service provider) and got some other Pojos as a reply. The reply then
+dictated what the UI would look like. -*Johannes Tuikkala*
+===============================