Open Source Bridge Touchscreen Presentation

Total Page:16

File Type:pdf, Size:1020Kb

Open Source Bridge Touchscreen Presentation Interactive kiosk display framework Peter Krenesky ([email protected]) Rob McGuire-Dale ([email protected]) http://trac.osuosl.org/touchscreen What is Touchscreen? Interactive kiosk display framework that is: Portable Plugin-based Simple and flexible API Open-source How can Touchscreen be used? Interactive information kiosks How can Touchscreen be used? Public information displays Touchscreen demonstration How we use Touchscreen at the Open Source Lab Technologies in Touchscreen How Touchscreen is built Languages in Touchscreen HTML & CSS JavaScript jQuery (sexy JavaScript library) Raphael (JavaScript SVG graphics library) Python Django (server-side web framework) Twisted (python networking engine) Why not Flash or OpenLaszlo? Original Touchscreen (v1.0) was OpenLaszlo (compiles to Flash) Pros Touchscreen 1.0 Fast Javascript support Could parse XML feeds Cons Niche language poor HTML integration OpenLaszlo has annoying syntax <include href="lib/lzx/screen.lzx" /> <!-- FTP User Map --> <dataset type="http" name="dset_ftpUserMap" src="http://ftp-osl.osuosl.org:8000/"> </dataset> <datapointer xpath="dset_ftpUserMap:/rss/channel" rerunxpath="true"> <method event="ondata"> var label = this.xpathQuery('item[1]/title/text()'); var lat = this.xpathQuery('item[2]/title/text()'); var lon = this.xpathQuery('item[3]/title/text()'); screen_osl_ftpusersmap.createPoint(lat,lon, label); label = null; lat = null; lon = null; </method> </datapointer> <include href="lib/lzx/circle.lzx"/> <resource name="ftpusermap" src="screens/ftpmap/map_1360nolabel.png"/> <include href="screens/ftpmap/ftpusersmap.lzx"/> Why SVG and not canvas? SVG objects can: can be styled with css be manipulated with jQuery receive javascript events Speed Differences SVG better for large objects Canvas better for many smaller objects Conclusion SVG for interactivity Canvas for many animated objects Raphaël: a javascript SVG library provides easy API on top of SVG. works in IE using VML Includes a charting api (gRaphael) Includes mapping api (cartographerJS) http://raphaeljs.com/ How Touchscreen Works Tying it all together Major components Display(s) & Controller (Django) Essentially web pages Message server (Twisted Python) Used for communication between display(s) and controller Plugin system (Muddle) Manages plugins and their settings Plugin System (Muddle) Message server supports multiple screens Screen Plugins Creating display screens Screen plugin directory structure plugins.py: configuration class displayPluginExampleSettings(forms.Form): exampleSetting = forms.CharField( label = 'An example setting', help_text = 'Write something here', initial = 'O hai!', max_length = 128 ) (The Muddle configuration interface) plugins.py: required settings class displayPluginExample(Screen): description = 'Example plugin made osbridge' template = 'displayPluginExample.html' config_form = (displayPluginExampleSettings, ScreenGeneralSettings) show = 'slide' hide = 'slide' Template file: general structure <style> /* Optional CSS styles */ </style> <script type="text/javascript"> {{screen.hash}} = new function() { //javascript } </script> <!-- Other HTML --> <div>foo</div> Template file: the javascript <script type="text/javascript"> {{screen.hash}} = new function() { // hooks this.init = function(){} this.start = function(){} this.stop = function(){} this.resize = function(){} // whatever you want function foo(){} } </script> Template file: the HTML <div id="{{screen.hash}}_tile" class="display_tile"> <h1>{{screen.exampleSetting}}</h1> <img src='static/screens/examplePlugin/examplePic.png'> </div> Template file: the optional CSS <style> #{{screen.hash}}_tile{ width: 400px; } .{{screen.hash}}_content{ font-size: 24pt; margin: 20px; text-align: center; } </style> Simple example plugin demo plugins.py: bit.ly/plugins_py template file: bit.ly/template_html Content Sources Dynamic content is exciting! Content Sources - Cross Site Browsers restrict cross-site AJAX requests include HttpResponse Header Access-Control-Allow-Origin: <origin> | * simple proxy included with touchscreen http://localhost/proxy/url="http://foo.com" Content Sources - jquery ajax // ajax call with jquery url = "http://foo.com" $.get(url, {key:"value"}, process); // process data function process(data) { do_something(); } // alternate more flexible call $.ajax(...) Content Sources - JSON Fast - Native Parser in browser Secure - parsers strip out executable code Easy to work with - json == Javascript Support in nearly every language (json.org) $.getJSON(url, {key:value}, function) $.post(url, {key:value}, function, "json"); url = "http://search.twitter.com/search.json?q=#osb10" $.getJSON('/proxy/', {url:url}, process); function process(data) { // first tweet tweet = data ["results"][0]; // get important data from = tweet["from_user"]; text = tweet["text"]; // update page $("#tweets").append("<div>"+text+"</div>"); } Content Sources - XML <feed> // load xml <user id="1"> xml = $(text); <label>Or</label> <lat>44</lat> <lon>-120</lon> </user> <user id="1"> <label>Or</label> <lat>44</lat> <lon>-120</lon> </user> </feed> Content Sources - XML // select groups users = xml.find("user"); // retrieve attributes user = users[0]; id = user.attr("id"); // retrieve text label =user.children("label").text(); lat = user.children("lat").text(); lon =user.children("lon").text(); Content Source - HTML HTML Strings can also be parsed, searched, and manipulated by jQuery. Content Source - HTML $.get("http://digg.com", {}, process); function process(data){ // grab just the topten list html html = $(data); topten = $html.find("#toptenlist"); // add to screen $("#foo").append(topten); } Touchscreen: http://trac.osuosl.org/touchscreen Slides & Files: http://bit.ly/cXhwwt Peter Krenesky: twitter: @kreneskyp email: [email protected] blog: http://staff.osuosl.org/kreneskyp Rob McGuire - Dale twitter: @robatron email: [email protected].
Recommended publications
  • Rich Internet Applications
    Rich Internet Applications (RIAs) A Comparison Between Adobe Flex, JavaFX and Microsoft Silverlight Master of Science Thesis in the Programme Software Engineering and Technology CARL-DAVID GRANBÄCK Department of Computer Science and Engineering CHALMERS UNIVERSITY OF TECHNOLOGY UNIVERSITY OF GOTHENBURG Göteborg, Sweden, October 2009 The Author grants to Chalmers University of Technology and University of Gothenburg the non-exclusive right to publish the Work electronically and in a non-commercial purpose make it accessible on the Internet. The Author warrants that he/she is the author to the Work, and warrants that the Work does not contain text, pictures or other material that violates copyright law. The Author shall, when transferring the rights of the Work to a third party (for example a publisher or a company), acknowledge the third party about this agreement. If the Author has signed a copyright agreement with a third party regarding the Work, the Author warrants hereby that he/she has obtained any necessary permission from this third party to let Chalmers University of Technology and University of Gothenburg store the Work electronically and make it accessible on the Internet. Rich Internet Applications (RIAs) A Comparison Between Adobe Flex, JavaFX and Microsoft Silverlight CARL-DAVID GRANBÄCK © CARL-DAVID GRANBÄCK, October 2009. Examiner: BJÖRN VON SYDOW Department of Computer Science and Engineering Chalmers University of Technology SE-412 96 Göteborg Sweden Telephone + 46 (0)31-772 1000 Department of Computer Science and Engineering Göteborg, Sweden, October 2009 Abstract This Master's thesis report describes and compares the three Rich Internet Application !RIA" frameworks Adobe Flex, JavaFX and Microsoft Silverlight.
    [Show full text]
  • Open Source Web GUI Toolkits
    Open Source Web GUI Toolkits "A broad and probably far too shallow presentation on stuff that will probably change 180 degrees by the time you hear about it from me" Nathan Schlehlein [email protected] 1 Why Web Developers Drink... Can't get away with knowing one thing A Fairly Typical Web App... ➔ MySQL – Data storage ➔ PHP – Business logic ➔ Javascript - Interactivity ➔ HTML – Presentation stuff ➔ CSS – Presentation formatting stuff ➔ Images – They are... Purdy... ➔ httpd.conf, php.ini, etc. Problems are liable to pop up at any stage... 2 The Worst Thing. Ever. Browser Incompatibilities! Follow the rules, still lose Which is right? ➔ Who cares! You gotta make it work anyways! Solutions More work or less features? ➔ Use browser-specific stuff - Switch via Javascript ➔ Use a subset of HTML that most everyone agrees on 3 Web Application? Web sites are... OK, but... Boring... Bounce users from page to page Stuff gets messed up easily ➔ Bookmarks? Scary... ➔ Back button 4 Why A Web Toolkit? Pros: Let something else worry about difficult things ➔ Layout issues ➔ Session management ➔ Browser cross-compatibility ➔ Annoying RPC stuff 5 >INSERT BUZZWORD HERE< Neat web stuff has been happening lately... AJAX “Web 2.0” Google maps Desktop app characteristics on the web... 6 Problem With >BUZZWORDS< Nice, but... Lots of flux ➔ Technology ➔ Expectations of technology Communications can get tricky Yet another thing to program... ➔ (Correctly) 7 Why A Web Toolkit? Pros: Let something else worry about difficult things ➔ Communications management ➔ Tested Javascript code ➔ Toolkit deals with changes, not the programmer 8 My Criteria Bonuses For... A familiar programming language ➔ Javascript? Unit test capability ➔ Test early, test often, sleep at night Ability to incrementally introduce toolkit Compatibility with existing application Documentation Compelling Examples 9 Web Toolkits – Common Features ■ Widgets ■ Layouts ■ Manipulation of page elements DOM access, etc.
    [Show full text]
  • Design of a Service-Oriented Dashboard
    DESIGN OF A SERVICE-ORIENTED DASHBOARD by GAYATHRI SUNDAR MURAT M. TANIK, COMMITTEE CHAIR DAVID G. GREEN GARY J. GRIMES JOHN L. HARTMAN IV A THESIS Submitted to the graduate faculty of The University of Alabama at Birmingham, in partial fulfillment of the requirements for the degree of Master of Science BIRMINGHAM, ALABAMA 2007 ii DESIGN OF A SERVICE-ORIENTED DASHBOARD GAYATHRI SUNDAR ELECTRICAL ENGINEERING ABSTRACT Service-Oriented Enterprises are currently focused on offering enhanced user ex- periences to customers, employees, and enterprise partners who use the enterprise’s soft- ware applications. A better user experience is delivered through the presentation of ser- vices and business processes to the user in a composite manner, and by facilitating a bet- ter user-application interaction for the user. Our experience with the bioinformatics do- main helped us to see that although existing models of enterprise portals offer an inte- grated environment to present applications and enterprise resources, they are not suffi- cient to address certain complex user-application interactions. In this thesis, we present a design for a Service-Oriented Dashboard to address this deficiency. The service-oriented dashboard leverages Service-Oriented Architecture to pre- sent an integrated environment to access and interact with the diverse and isolated soft- ware tools, applications, and resources of an enterprise. We address the design of the dashboard at three levels: the presentation layer, the task composition layer, and the ser- vices layer. We introduce in the thesis the notion of describing the user’s job function as a composition of tasks. Users, through this approach, will be able to compose applica- tions according to the user’s tasks.
    [Show full text]
  • Interfacing Openlaszlo Applications to Web Services
    1 Interfacing OpenLaszlo Applications to Web Services An Excerpt from “Laszlo in Action” By Norman Klein and Max Carlson with Glenn MacEwen Early Access Release: January 2007 Print Release: November 2007 | 500 pages ISBN: 1-932394-83-4 www.manning.com/laszloinaction For Source Code, Free Chapters, the Author Forum and more information about this title please go to www.manning.com/laszloinaction 1 2 Interfacing OpenLaszlo Applications to Web Services If you've been enviously eyeing the RIA capabilities of OpenLaszlo, but been daunted by its interface requirements, then you'll be glad to know that interfacing to OpenLaszlo is just like that old Talking Heads song "same as it ever was". In other words, OpenLaszlo uses the same HTTP standards that you're familiar with; allowing OpenLaszlo applications to co-exist with your HTML web applications to further leverage your server-side web services. All OpenLaszlo communications with the server are still based on sending and receiving HTTP requests and responses. OpenLaszlo operates just like Ajax by requiring HTTP responses to be composed of XML instead of HTML. The technical term for this is a ReST-based "XML-over-HTTP" service, but this is only a fancy way of describing the familiar operation of the web. So why does it use XML and not HTML? Since an RIA can provide a superior visual presentation, only the data is needed as the HTML presentation details are superfluous. OpenLaszlo's compliance to open standards allows it to interface to any HTTP web server; ranging from basic HTTP web servers such as Apache, Jetty or Microsoft's IIS to the different web frameworks such as Struts, Tapestry, Ruby on Rails, Microsoft .Net that work with servlet containers to provide enterprise class services.
    [Show full text]
  • Developing Rich Internet Applications with Rails, Openlaszlo, and Eclipse Automate Quickly with Rails
    Developing rich Internet applications with Rails, OpenLaszlo, and Eclipse Automate quickly with Rails Skill Level: Intermediate Robi Sen ([email protected]) Freelance Writer Department13 12 May 2006 Explore at a high level how to develop a rich Internet application using OpenLaszlo, Ruby on Rails, MySQL, and Eclipse to provide a common IDE to not only develop your application but also to automate many of the steps in developing a Rails or OpenLaszlo application. This will further speed up and streamline the already fast development cycle of Rails applications. Section 1. Before you start Ruby on Rails has over the past year become one of the fastest growing and most popular open source Web application development frameworks. But because of the focus on building HTML applications, some have criticized Rails as being inflexible. Especially with the emergence of rich Internet applications (RIAs), applications using technologies such as Flash for user interface development and XML for data transport to replicate desktop application functionality, open source developers have wondered if there is some way to easily create RIAs that can exploit the pure object-oriented language of Ruby and the unique rapid application development features of Rails. About this tutorial This tutorial will expose you to two of the hottest platforms in Web development: Ruby on Rails, for fun and rapid Web application development; and OpenLaszlo, the open source RIA server. You will see that creating visually appealing desktop-like Developing rich Internet applications with Rails, OpenLaszlo, and Eclipse © Copyright IBM Corporation 1994, 2008. All rights reserved. Page 1 of 28 developerWorks® ibm.com/developerWorks applications deployed and managed over the Web can be incredibly easy with these platforms.
    [Show full text]
  • The Effect of Ajax on Performance and Usability in Web Environments
    The effect of Ajax on performance and usability in web environments Y.D.C.N. op ’t Roodt, BICT Date of acceptance: August 31st, 2006 One Year Master Course Software Engineering Thesis Supervisor: Dr. Jurgen Vinju Internship Supervisor: Ir. Koen Kam Company or Institute: Hyves (Startphone Limited) Availability: public domain Universiteit van Amsterdam, Hogeschool van Amsterdam, Vrije Universiteit 2 This page intentionally left blank 3 Table of contents 1 Foreword ................................................................................................... 6 2 Motivation ................................................................................................. 7 2.1 Tasks and sources................................................................................ 7 2.2 Research question ............................................................................... 9 3 Research method ..................................................................................... 10 3.1 On implementation........................................................................... 11 4 Background and context of Ajax .............................................................. 12 4.1 Background....................................................................................... 12 4.2 Rich Internet Applications ................................................................ 12 4.3 JavaScript.......................................................................................... 13 4.4 The XMLHttpRequest object..........................................................
    [Show full text]
  • Guaranteeing Responsiveness and Consistency In
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Texas A&amp;M Repository GUARANTEEING RESPONSIVENESS AND CONSISTENCY IN DYNAMIC, ASYNCHRONOUS GRAPHICAL USER INTERFACES A Dissertation by CHARLES GABRIEL FOUST Submitted to the Office of Graduate and Professional Studies of Texas A&M University in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY Chair of Committee, Jaakko J¨arvi Committee Members, Gabriel Dos Reis Paul Gratz Frank Shipman Head of Department, Dilma Da Silva May 2016 Major Subject: Computer Science Copyright 2016 Charles Gabriel Foust ABSTRACT This dissertation proposes a programming model for Graphical User Interfaces (GUIs) that relieves the programmer of a difficult and error-prone task: orchestrating concurrent responses to events to ensure data dependencies are always enforced correctly. In this programming model, rather than defining program responses to events, the programmer defines the data dependencies that exist in the GUI and the methods by which those depen- dencies may be enforced|a run-time system uses this specification to generate responses to events. The approach gives the following guarantee: the same sequence of events produces the same results, regardless of the timing of those events. The dissertation demonstrates the benefits of the proposed programming model with implementations of several example user interfaces. At the core of this programming model is a data structure known as a property model. A property model composes responses to individual events into a single reactive program that runs asynchronously. The program's results are used to update the GUI. The program is constructed in a manner that respects all data dependencies, thereby guaranteeing that results are consistent regardless of the length of time taken by individual responses.
    [Show full text]
  • Open Ajax" to Drive Collaborative Innovation to Make the Web Easier to Use
    TECH TITANS PROPOSE OPEN SOURCE PROJECTS FOR BROWSER-BOOSTING AJAX TECHNOLOGY "Open Ajax" to Drive Collaborative Innovation to Make the Web Easier to Use Armonk, NY, February 1, 2006 . Prominent computer industry vendors and Internet-based businesses today announced that they are making it easier for an open-source community to form and popularize Ajax. Ajax is a fast-growing open client technology that businesses are incorporating into their external and internal Web sites to simplify the browsing experience, and make it easier for users to shop, work, plan, correspond and navigate online. Ajax makes it unnecessary to manually refresh one's browser to send or receive information over the Web. Instead, information is automatically updated and available on demand, allowing you to "drag and drop" or input information and get a response without refreshing the browser, much like you would do on a PC desktop. It can reduce the steps needed to complete a transaction over the Web or create a competitive edge for enterprise companies and Web designers, for example. The initial supporting members of the new initiative -- dubbed Open Ajax -- include BEA, Borland, the Dojo Foundation, Eclipse Foundation, Google, IBM, Laszlo Systems, Mozilla Corporation, Novell, Openwave Systems, Oracle, Red Hat, Yahoo, Zend and Zimbra. They intend to promote Ajax's promise of universal compatibility with any computer device, application, desktop or operating system, and easy incorporation into new and existing software programs. Ajax -- short for Asynchronous JavaScript and XML -- is a type of "Rich Internet Application." It enables Web innovations, including: * The ability to update portions of a Web page without refreshing the entire screen.
    [Show full text]
  • The Server-Side Architecture Behind Openlaszlo Applications
    The Server-side Architecture Behind OpenLaszlo Applications Geert Bevin [email protected] http://www.uwyn.com http://www.rifers.org Agenda What are Rich Internet Applications? Why use OpenLaszlo? Architecture comparison with regular web MVC Designing a multi-purpose RIA server-side solution Implications for the client-side Making your RIA applications maintainable Q&A Who am I? Geert Bevin CEO of Uwyn, a small custom application development company (http://uwyn.com) founder of the RIFE Java web application framework (http://rifers.org) official contributor to OpenLaszlo creator of Bla-bla List, open-source RIA to-do list tracker in OpenLaszlo (http://blablalist.com) What are Rich Internet Applications? full-featured web-based interactive GUI applications launch without any installation run in a secure sandbox to protect the local machine information is stored on the server the application can be used from anywhere platform independent Examples Amazon Store This RIA interpretation of an Amazon music store demonstrates presenting a range of functionality all in one window, drag & drop between windows, a dynamic shopping cart, and more, including pulling live data from Amazon's back-end database. http://www.laszlosystems.com/partners/support/demos/ Examples Bla-bla List Bla-bla List is a free, secure, simple and sharable to-do list service. It’s open-source and written to explore the world of rich internet applications. The first implementation uses OpenLaszlo, and the plan is to implement the same features in other RIA technologies http://www.blablalist.com Examples Pandora Pandora is an intelligent radio station that automatically suggests the songs that are played according to your musical preference and taste.
    [Show full text]
  • Plasticité Des IHM & Web2.0
    IHM du Web 2.0 & plasticité Module Plasticité SI5 – Master IFI http://users.polytech.unice.fr/~pinna/MODULEIHM/Plasticite/ (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 1 - Plan du cours • Nouveaux usages d'Internet => naissance du Web2.0 • Impacts sur les IHM => naissance des interfaces dites “riches”, les RIA (Rich Internet Applications) • Vers un Web3.0 ? Analyse des besoins Evaluation ergonomique Tests Utilisateurs Espace de conception Conception Propriétés ergonomiques Tests d’intégration Conception logicielle Modèle d’architecture Tests Unitaires logicielle Boîtes à outils Codage Mécanismes généraux (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 2 - IHM du web2.0 & plasticité . Plasticité ? capacité d’adaptation d’une IHM : à la conception / exécution au contexte d’usage : langage, plate-forme logicielle/matérielle, utilisateur, environement, ... dans le respect de la valeur attendue par l’utilisateur cible : utilisabilité, ergonomie . Quelles formes de plasticité pour les IHM du web2.0 ? (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 3 - Web2.0 : nouveaux usages (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 4 - Evolution d'Internet : point de vue des usages Web1.0Web1.0 Web2.0Web2.0 Admin Admin Admin Admin publie publie gère gère Interagissent (RSS, services web, mashups) consultent consultent contribuent contribuent Utilisateurs Utilisateurs Utilisateurs/communauté Utilisateurs/communauté (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 5 - Évolution des IHMs source: adobe.org (c) 2009, Occello Audrey, Plasticité IHM / Web2.0 - 6 - Web2.0, définition et points clé . Met l'accent sur l'agilité et la réutilisabilité des applis : Focalisation sur les services rendus et sur les données mais pas sur les applications Faiblement couplé pour faciliter l’assemblage de services en applications Faciliter la réutilisabilité des contenus .
    [Show full text]
  • Marsily-Msc2010
    U C L L S M . Richer Web Applications On Trends, Techniques and Standards Supervisor: Prof. J. V Master esis: Partial Fulllment of the Requirements for the Degree of Master in Business Engineering Charles M 2323.05.00 INGE22MS/G [email protected] Academic Year 2009-2010 . Acknowledgment I would like to thank my supervisor Prof. Jean V for providing me a subject as interesting as rich web applications. Writing this document has redened how I use the Web today. e e e In addition, this work might not have been possible without my family’s continuous support. .. C C i L F iii I v Disclaimer.................................................................. vi Content & objectives........................................................ vi 1 U RIA 1 1.1 Denition and criteria ................................................. 1 ick vs. thin applications ................................................. 3 Client/server applications vs. web applications................................. 4 RIA features and characteristics ............................................. 5 Deployment alternatives ................................................... 6 1.2 Why RIAs are emerging? .............................................. 6 1.3 Limitations ........................................................... 8 1.4 Web applications vs. native apps: what to choose for the iPhone?. 9 1.5 RIAs as a part of a broader Web 2.0 era ................................. 11 1.6 RIAs for enterprises ................................................... 14
    [Show full text]
  • Dive Into RIFE
    The State of AJAX Geert Bevin CTO Uwyn bvba [email protected] http://uwyn.com http://rifers.org The State of AJAX | 2006 JavaOneSM Afterglow Quick overview of today’s leading AJAX solutions for Java The State of AJAX | 2006 JavaOneSM Afterglow Google Web Toolkit (GWT) http://code.google.com/webtoolkit The State of AJAX | 2006 JavaOneSM Afterglow Google Web Toolkit (GWT) Compiles Java code into JavaScript code instead of byte-code JavaScript implementation of a subset of the core Java class libraries • 27 classes, 11 interfaces, and 18 exception types found in the java.util and java.lang (as of GWT 1.0.21) “Hosted mode” for running your GWT application as byte-code into the Eclipse IDE and preview pane While it feels like you’re writing server-side Java code, it really is a client-side only solution The State of AJAX | 2006 JavaOneSM Afterglow Google Web Toolkit (GWT) Very young and unproven No support for MacOSX No support for other IDEs besides Eclipse, nor other browsers besides SWT browser widget in “Hosted Mode” Important parts (compiler) aren’t open-source Only free as in beer Comes from Google Leverages your knowledge of Java to develop AJAX The State of AJAX | 2006 JavaOneSM Afterglow Direct Web Remoting (DWR) http://getahead.ltd.uk/dwr The State of AJAX | 2006 JavaOneSM Afterglow Direct Web Remoting (DWR) Remotes your Java classes from JavaScript Generates JavaScript classes and stubs that call your Java code through AJAX Integration with Spring, Struts, JSF, WebWork, RIFE All parameters are automagically marshalled
    [Show full text]