diff --git a/create-ria/pom.xml b/create-ria/pom.xml
new file mode 100644
index 0000000..a226194
--- /dev/null
+++ b/create-ria/pom.xml
@@ -0,0 +1,78 @@
+
+
+ 4.0.0
+
+ sling-stanbol
+ org.wymiwyg.sling-stanbol
+ 1.0-SNAPSHOT
+
+
+ org.wymiwyg
+ create-ria
+ 0.1-SNAPSHOT
+ JavaScript RIA
+ js
+ A JavaScript Rich Internet Application using jQuery and jQuery UI.
+
+
+ UTF-8
+
+
+
+
+ org.codehaus.mojo
+ jquery-amd
+ 1.7.1-alpha-1
+ js
+
+
+ org.codehaus.mojo
+ jquery-ui-amd
+ 1.8.16-alpha-1
+ js
+
+
+
+
+
+
+ org.codehaus.mojo
+ javascript-maven-plugin
+ 2.0.0-alpha-1
+
+
+
+
+
+
+
+ snapshots
+ https://nexus.codehaus.org/content/repositories/snapshots/
+
+ false
+
+
+
+
+
+
+
+ snapshots
+ https://nexus.codehaus.org/content/repositories/snapshots/
+
+ false
+
+
+
+
+
+
+
+
+ org.slf4j
+ slf4j-api
+ 1.6.1
+
+
+
+
diff --git a/create-ria/src/main/js/HelloWorld/HelloWorldController.js b/create-ria/src/main/js/HelloWorld/HelloWorldController.js
new file mode 100644
index 0000000..52b2087
--- /dev/null
+++ b/create-ria/src/main/js/HelloWorld/HelloWorldController.js
@@ -0,0 +1,80 @@
+/*global define */
+
+define( ["jquery"], function($) {
+
+ /**
+ * Controls the showing of a 'Hello World' message.
+ *
+ * This is a "supervising controller" otherwise known as a "presenter".
+ * @see http://martinfowler.com/eaaDev/SupervisingPresenter.html
+ *
+ * @class Controls the showing of a 'Hello World' message.
+ * @name HelloWorldController
+ */
+ function HelloWorldController() {
+ }
+
+ /**
+ * The HelloWorldView instance (injected)
+ */
+ HelloWorldController.prototype.view = undefined;
+
+ /**
+ * The HelloWorldCommand instance (injected)
+ */
+ HelloWorldController.prototype.command = undefined;
+
+ /**
+ * Success callback for the HelloWorldCommand.
+ * Show the 'Hello World' message using the view.
+ *
+ * @param message The message to show.
+ */
+ HelloWorldController.prototype.getTextSuccess = function(message) {
+ var self = this;
+
+ self.view.setHelloWorldDivText(message);
+ };
+
+ /**
+ * Failure callback for the HelloWorldCommand.
+ * Show the error message using the view.
+ *
+ * @param errorMessage A description of the error
+ */
+ HelloWorldController.prototype.getTextFailure = function(errorMessage) {
+ var self = this;
+
+ self.view.showError(errorMessage);
+ };
+
+ /**
+ * Initialization method for this controller.
+ */
+ HelloWorldController.prototype.start = function() {
+ var self = this, text;
+
+ // Inject our helloButtonClick handler into the view
+ self.view.helloButtonClick = $.proxy(self.helloButtonClick, self);
+ // Initialize the view
+ self.view.initialize();
+
+ // Fetch the 'hello world' text using a command object
+ text = self.command.execute( $.proxy(self.getTextSuccess, self), $.proxy(self.getTextFailure, self) );
+ };
+
+ /**
+ * Handle a click on the #helloButton element.
+ *
+ * @param event The event object which triggered this handler.
+ */
+ HelloWorldController.prototype.helloButtonClick = function(event) {
+ var self = this;
+
+ self.view.setHelloButtonText("Clicked");
+ };
+
+ // Return the function
+ return HelloWorldController;
+
+});
\ No newline at end of file
diff --git a/create-ria/src/main/js/HelloWorld/desktop/HelloWorldView.js b/create-ria/src/main/js/HelloWorld/desktop/HelloWorldView.js
new file mode 100644
index 0000000..35663cc
--- /dev/null
+++ b/create-ria/src/main/js/HelloWorld/desktop/HelloWorldView.js
@@ -0,0 +1,82 @@
+/*global define, window */
+
+define( ["jquery-ui"], function($) {
+
+ /**
+ * User interface part of HelloWorld*.
+ * Shows messages to the user and reacts to user input.
+ * This view is part of the desktop view implementation.
+ *
+ * This is a "view" as defined by "supervising controller".
+ * @see http://martinfowler.com/eaaDev/SupervisingPresenter.html
+ *
+ * @class User interface part of HelloWorld*.
+ * @name HelloWorldView
+ */
+ function HelloWorldView() {
+ }
+
+ /**
+ * The div used for the hello world message.
+ */
+ HelloWorldView.prototype.div = undefined;
+
+ /**
+ * The event handler for a click on #helloButton.
+ */
+ HelloWorldView.prototype.helloButtonClick = undefined;
+
+ /**
+ * Initialize the view.
+ * - Setup buttons
+ */
+ HelloWorldView.prototype.initialize = function() {
+ var self = this;
+
+ // Setup #helloButton as a button and bind click to helloButtonClick event
+ $("#helloButton", self.div).button()
+ .click( function(event){
+ self.helloButtonClick(event);
+ });
+ };
+
+ /**
+ * Sets the hello world message in the #helloWorld div.
+ *
+ * @param message The message to set.
+ */
+ HelloWorldView.prototype.setHelloWorldDivText = function(message) {
+ var self = this;
+
+ // Set message on the hello world div
+ $("#helloMessage", self.div).text(message);
+ };
+
+ /**
+ * Sets the hello world message in the #helloButton button.
+ *
+ * @param message The message to set.
+ */
+ HelloWorldView.prototype.setHelloButtonText = function(message) {
+ var self = this;
+
+ // Set message on the hello world div
+ $("#helloButton span", self.div).text(message);
+ };
+
+ /**
+ * Show an error message.
+ *
+ * @param message The message to show.
+ */
+ HelloWorldView.prototype.showError = function(message) {
+ var self = this;
+
+ // Show error message
+ window.alert("Error: " + message);
+ };
+
+ // Return the function
+ return HelloWorldView;
+
+});
\ No newline at end of file
diff --git a/create-ria/src/main/js/IndexContext.js b/create-ria/src/main/js/IndexContext.js
new file mode 100644
index 0000000..da5c214
--- /dev/null
+++ b/create-ria/src/main/js/IndexContext.js
@@ -0,0 +1,48 @@
+/*global define */
+
+define([ "jquery", "HelloWorld/HelloWorldController", "HelloWorld/desktop/HelloWorldView", "model/HelloWorldCommand" ],
+ function($, HelloWorldController, HelloWorldView, HelloWorldCommand) {
+
+ /**
+ * Context for our index.html entry point.
+ *
+ * Sets up required objects, handles dependency injection, and starts
+ * the HelloWorldController.
+ *
+ * @class Context for our index.html entry point.
+ * @name IndexContext
+ */
+ function IndexContext(){}
+
+ /**
+ * Initialize this context.
+ *
+ * Instantiates HelloWorld components, injects dependencies, and starts
+ * the HelloWorldController.
+ */
+ IndexContext.prototype.initialize = function() {
+ var controller, view, command;
+
+ // Instantiate objects
+ controller = new HelloWorldController();
+ view = new HelloWorldView();
+ command = new HelloWorldCommand();
+
+ // Perform dependency injection by extending objects
+ $.extend(view, {
+ div: $("#helloWorld")
+ });
+
+ $.extend(controller, {
+ view: view,
+ command: command
+ });
+
+ // Start the HelloWorldController
+ controller.start();
+ };
+
+ // Return the function
+ return IndexContext;
+
+});
diff --git a/create-ria/src/main/js/index.js b/create-ria/src/main/js/index.js
new file mode 100644
index 0000000..751a84a
--- /dev/null
+++ b/create-ria/src/main/js/index.js
@@ -0,0 +1,14 @@
+/*global $, require */
+
+// When the document is ready:
+$().ready(function() {
+
+ require([ "IndexContext" ], function(IndexContext) {
+
+ // Create a new IndexContext and initialize it which will create and
+ // start a HelloWorldController
+ var indexContext = new IndexContext();
+ indexContext.initialize();
+ });
+
+});
diff --git a/create-ria/src/main/js/model/HelloWorldCommand.js b/create-ria/src/main/js/model/HelloWorldCommand.js
new file mode 100644
index 0000000..4f0a4eb
--- /dev/null
+++ b/create-ria/src/main/js/model/HelloWorldCommand.js
@@ -0,0 +1,28 @@
+/*global define*/
+
+define( [] ,function() {
+
+ /**
+ * Command object to retrieve the 'Hello World' text.
+ *
+ * @class Command object to retrieve the 'Hello World' text.
+ * @name HelloWorldCommand
+ */
+ function HelloWorldCommand() {
+ }
+
+ /**
+ * Execute this command and then call the supplied success or
+ * failure callback as appropriate.
+ *
+ * @param success Callback function for a successful execution.
+ * @param failure Callback function for a failed execution.
+ */
+ HelloWorldCommand.prototype.execute = function(success, failure) {
+ success("Hello World");
+ };
+
+ // Return the function
+ return HelloWorldCommand;
+
+});
\ No newline at end of file
diff --git a/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png b/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png
new file mode 100644
index 0000000..954e22d
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_20_666666_40x40.png b/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_20_666666_40x40.png
new file mode 100644
index 0000000..64ece57
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_diagonals-thick_20_666666_40x40.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_flat_10_000000_40x100.png b/create-ria/src/main/resources/css/images/ui-bg_flat_10_000000_40x100.png
new file mode 100644
index 0000000..abdc010
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_flat_10_000000_40x100.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_glass_100_f6f6f6_1x400.png b/create-ria/src/main/resources/css/images/ui-bg_glass_100_f6f6f6_1x400.png
new file mode 100644
index 0000000..9b383f4
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_glass_100_f6f6f6_1x400.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_glass_100_fdf5ce_1x400.png b/create-ria/src/main/resources/css/images/ui-bg_glass_100_fdf5ce_1x400.png
new file mode 100644
index 0000000..a23baad
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_glass_100_fdf5ce_1x400.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_glass_65_ffffff_1x400.png b/create-ria/src/main/resources/css/images/ui-bg_glass_65_ffffff_1x400.png
new file mode 100644
index 0000000..42ccba2
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_glass_65_ffffff_1x400.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png b/create-ria/src/main/resources/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png
new file mode 100644
index 0000000..39d5824
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png b/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png
new file mode 100644
index 0000000..f127367
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png b/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png
new file mode 100644
index 0000000..32f8622
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-icons_222222_256x240.png b/create-ria/src/main/resources/css/images/ui-icons_222222_256x240.png
new file mode 100644
index 0000000..b273ff1
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-icons_222222_256x240.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-icons_228ef1_256x240.png b/create-ria/src/main/resources/css/images/ui-icons_228ef1_256x240.png
new file mode 100644
index 0000000..a641a37
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-icons_228ef1_256x240.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-icons_ef8c08_256x240.png b/create-ria/src/main/resources/css/images/ui-icons_ef8c08_256x240.png
new file mode 100644
index 0000000..85e63e9
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-icons_ef8c08_256x240.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-icons_ffd27a_256x240.png b/create-ria/src/main/resources/css/images/ui-icons_ffd27a_256x240.png
new file mode 100644
index 0000000..d9dc509
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-icons_ffd27a_256x240.png differ
diff --git a/create-ria/src/main/resources/css/images/ui-icons_ffffff_256x240.png b/create-ria/src/main/resources/css/images/ui-icons_ffffff_256x240.png
new file mode 100644
index 0000000..42f8f99
Binary files /dev/null and b/create-ria/src/main/resources/css/images/ui-icons_ffffff_256x240.png differ
diff --git a/create-ria/src/main/resources/css/index.css b/create-ria/src/main/resources/css/index.css
new file mode 100644
index 0000000..12a44ea
--- /dev/null
+++ b/create-ria/src/main/resources/css/index.css
@@ -0,0 +1,26 @@
+@CHARSET "UTF-8";
+
+@import url("jquery-ui-1.8.16.custom.css");
+
+body {
+ padding: 1em;
+ font-family: Verdana, sans-serif;
+ font-size: 10px;
+}
+
+h1 {
+ font-size: 3em;
+ color: #444;
+}
+
+#helloWorld {
+ border: 1px dashed #ddd;
+ padding: 1em;
+ margin-top: 2em;
+}
+#helloWorld #helloMessage {
+ font-size: 2em;
+ color: #888;
+ margin-bottom: 1em;
+}
+#helloWorld #helloButton {}
\ No newline at end of file
diff --git a/create-ria/src/main/resources/css/jquery-ui-1.8.16.custom.css b/create-ria/src/main/resources/css/jquery-ui-1.8.16.custom.css
new file mode 100644
index 0000000..5547c7b
--- /dev/null
+++ b/create-ria/src/main/resources/css/jquery-ui-1.8.16.custom.css
@@ -0,0 +1,568 @@
+/*
+ * jQuery UI CSS Framework 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Theming/API
+ */
+
+/* Layout helpers
+----------------------------------*/
+.ui-helper-hidden { display: none; }
+.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
+.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
+.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
+.ui-helper-clearfix { display: inline-block; }
+/* required comment for clearfix to work in Opera \*/
+* html .ui-helper-clearfix { height:1%; }
+.ui-helper-clearfix { display:block; }
+/* end clearfix */
+.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
+
+
+/* Interaction Cues
+----------------------------------*/
+.ui-state-disabled { cursor: default !important; }
+
+
+/* Icons
+----------------------------------*/
+
+/* states and images */
+.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
+
+
+/* Misc visuals
+----------------------------------*/
+
+/* Overlays */
+.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
+
+
+/*
+ * jQuery UI CSS Framework 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Theming/API
+ *
+ * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Trebuchet%20MS,%20Tahoma,%20Verdana,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=f6a828&bgTextureHeader=12_gloss_wave.png&bgImgOpacityHeader=35&borderColorHeader=e78f08&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=eeeeee&bgTextureContent=03_highlight_soft.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=333333&iconColorContent=222222&bgColorDefault=f6f6f6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=100&borderColorDefault=cccccc&fcDefault=1c94c4&iconColorDefault=ef8c08&bgColorHover=fdf5ce&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=fbcb09&fcHover=c77405&iconColorHover=ef8c08&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=fbd850&fcActive=eb8f00&iconColorActive=ef8c08&bgColorHighlight=ffe45c&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=75&borderColorHighlight=fed22f&fcHighlight=363636&iconColorHighlight=228ef1&bgColorError=b81900&bgTextureError=08_diagonals_thick.png&bgImgOpacityError=18&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffd27a&bgColorOverlay=666666&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=20&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=01_flat.png&bgImgOpacityShadow=10&opacityShadow=20&thicknessShadow=5px&offsetTopShadow=-5px&offsetLeftShadow=-5px&cornerRadiusShadow=5px
+ */
+
+
+/* Component containers
+----------------------------------*/
+.ui-widget { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1.1em; }
+.ui-widget .ui-widget { font-size: 1em; }
+.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1em; }
+.ui-widget-content { border: 1px solid #dddddd; background: #eeeeee url(images/ui-bg_highlight-soft_100_eeeeee_1x100.png) 50% top repeat-x; color: #333333; }
+.ui-widget-content a { color: #333333; }
+.ui-widget-header { border: 1px solid #e78f08; background: #f6a828 url(images/ui-bg_gloss-wave_35_f6a828_500x100.png) 50% 50% repeat-x; color: #ffffff; font-weight: bold; }
+.ui-widget-header a { color: #ffffff; }
+
+/* Interaction states
+----------------------------------*/
+.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #cccccc; background: #f6f6f6 url(images/ui-bg_glass_100_f6f6f6_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #1c94c4; }
+.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #1c94c4; text-decoration: none; }
+.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #fbcb09; background: #fdf5ce url(images/ui-bg_glass_100_fdf5ce_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #c77405; }
+.ui-state-hover a, .ui-state-hover a:hover { color: #c77405; text-decoration: none; }
+.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #fbd850; background: #ffffff url(images/ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #eb8f00; }
+.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #eb8f00; text-decoration: none; }
+.ui-widget :active { outline: none; }
+
+/* Interaction Cues
+----------------------------------*/
+.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fed22f; background: #ffe45c url(images/ui-bg_highlight-soft_75_ffe45c_1x100.png) 50% top repeat-x; color: #363636; }
+.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; }
+.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #b81900 url(images/ui-bg_diagonals-thick_18_b81900_40x40.png) 50% 50% repeat; color: #ffffff; }
+.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; }
+.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; }
+.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
+.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
+.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
+
+/* Icons
+----------------------------------*/
+
+/* states and images */
+.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); }
+.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); }
+.ui-widget-header .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); }
+.ui-state-default .ui-icon { background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-active .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_228ef1_256x240.png); }
+.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffd27a_256x240.png); }
+
+/* positioning */
+.ui-icon-carat-1-n { background-position: 0 0; }
+.ui-icon-carat-1-ne { background-position: -16px 0; }
+.ui-icon-carat-1-e { background-position: -32px 0; }
+.ui-icon-carat-1-se { background-position: -48px 0; }
+.ui-icon-carat-1-s { background-position: -64px 0; }
+.ui-icon-carat-1-sw { background-position: -80px 0; }
+.ui-icon-carat-1-w { background-position: -96px 0; }
+.ui-icon-carat-1-nw { background-position: -112px 0; }
+.ui-icon-carat-2-n-s { background-position: -128px 0; }
+.ui-icon-carat-2-e-w { background-position: -144px 0; }
+.ui-icon-triangle-1-n { background-position: 0 -16px; }
+.ui-icon-triangle-1-ne { background-position: -16px -16px; }
+.ui-icon-triangle-1-e { background-position: -32px -16px; }
+.ui-icon-triangle-1-se { background-position: -48px -16px; }
+.ui-icon-triangle-1-s { background-position: -64px -16px; }
+.ui-icon-triangle-1-sw { background-position: -80px -16px; }
+.ui-icon-triangle-1-w { background-position: -96px -16px; }
+.ui-icon-triangle-1-nw { background-position: -112px -16px; }
+.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
+.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
+.ui-icon-arrow-1-n { background-position: 0 -32px; }
+.ui-icon-arrow-1-ne { background-position: -16px -32px; }
+.ui-icon-arrow-1-e { background-position: -32px -32px; }
+.ui-icon-arrow-1-se { background-position: -48px -32px; }
+.ui-icon-arrow-1-s { background-position: -64px -32px; }
+.ui-icon-arrow-1-sw { background-position: -80px -32px; }
+.ui-icon-arrow-1-w { background-position: -96px -32px; }
+.ui-icon-arrow-1-nw { background-position: -112px -32px; }
+.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
+.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
+.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
+.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
+.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
+.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
+.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
+.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
+.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
+.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
+.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
+.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
+.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
+.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
+.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
+.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
+.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
+.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
+.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
+.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
+.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
+.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
+.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
+.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
+.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
+.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
+.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
+.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
+.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
+.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
+.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
+.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
+.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
+.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
+.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
+.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
+.ui-icon-arrow-4 { background-position: 0 -80px; }
+.ui-icon-arrow-4-diag { background-position: -16px -80px; }
+.ui-icon-extlink { background-position: -32px -80px; }
+.ui-icon-newwin { background-position: -48px -80px; }
+.ui-icon-refresh { background-position: -64px -80px; }
+.ui-icon-shuffle { background-position: -80px -80px; }
+.ui-icon-transfer-e-w { background-position: -96px -80px; }
+.ui-icon-transferthick-e-w { background-position: -112px -80px; }
+.ui-icon-folder-collapsed { background-position: 0 -96px; }
+.ui-icon-folder-open { background-position: -16px -96px; }
+.ui-icon-document { background-position: -32px -96px; }
+.ui-icon-document-b { background-position: -48px -96px; }
+.ui-icon-note { background-position: -64px -96px; }
+.ui-icon-mail-closed { background-position: -80px -96px; }
+.ui-icon-mail-open { background-position: -96px -96px; }
+.ui-icon-suitcase { background-position: -112px -96px; }
+.ui-icon-comment { background-position: -128px -96px; }
+.ui-icon-person { background-position: -144px -96px; }
+.ui-icon-print { background-position: -160px -96px; }
+.ui-icon-trash { background-position: -176px -96px; }
+.ui-icon-locked { background-position: -192px -96px; }
+.ui-icon-unlocked { background-position: -208px -96px; }
+.ui-icon-bookmark { background-position: -224px -96px; }
+.ui-icon-tag { background-position: -240px -96px; }
+.ui-icon-home { background-position: 0 -112px; }
+.ui-icon-flag { background-position: -16px -112px; }
+.ui-icon-calendar { background-position: -32px -112px; }
+.ui-icon-cart { background-position: -48px -112px; }
+.ui-icon-pencil { background-position: -64px -112px; }
+.ui-icon-clock { background-position: -80px -112px; }
+.ui-icon-disk { background-position: -96px -112px; }
+.ui-icon-calculator { background-position: -112px -112px; }
+.ui-icon-zoomin { background-position: -128px -112px; }
+.ui-icon-zoomout { background-position: -144px -112px; }
+.ui-icon-search { background-position: -160px -112px; }
+.ui-icon-wrench { background-position: -176px -112px; }
+.ui-icon-gear { background-position: -192px -112px; }
+.ui-icon-heart { background-position: -208px -112px; }
+.ui-icon-star { background-position: -224px -112px; }
+.ui-icon-link { background-position: -240px -112px; }
+.ui-icon-cancel { background-position: 0 -128px; }
+.ui-icon-plus { background-position: -16px -128px; }
+.ui-icon-plusthick { background-position: -32px -128px; }
+.ui-icon-minus { background-position: -48px -128px; }
+.ui-icon-minusthick { background-position: -64px -128px; }
+.ui-icon-close { background-position: -80px -128px; }
+.ui-icon-closethick { background-position: -96px -128px; }
+.ui-icon-key { background-position: -112px -128px; }
+.ui-icon-lightbulb { background-position: -128px -128px; }
+.ui-icon-scissors { background-position: -144px -128px; }
+.ui-icon-clipboard { background-position: -160px -128px; }
+.ui-icon-copy { background-position: -176px -128px; }
+.ui-icon-contact { background-position: -192px -128px; }
+.ui-icon-image { background-position: -208px -128px; }
+.ui-icon-video { background-position: -224px -128px; }
+.ui-icon-script { background-position: -240px -128px; }
+.ui-icon-alert { background-position: 0 -144px; }
+.ui-icon-info { background-position: -16px -144px; }
+.ui-icon-notice { background-position: -32px -144px; }
+.ui-icon-help { background-position: -48px -144px; }
+.ui-icon-check { background-position: -64px -144px; }
+.ui-icon-bullet { background-position: -80px -144px; }
+.ui-icon-radio-off { background-position: -96px -144px; }
+.ui-icon-radio-on { background-position: -112px -144px; }
+.ui-icon-pin-w { background-position: -128px -144px; }
+.ui-icon-pin-s { background-position: -144px -144px; }
+.ui-icon-play { background-position: 0 -160px; }
+.ui-icon-pause { background-position: -16px -160px; }
+.ui-icon-seek-next { background-position: -32px -160px; }
+.ui-icon-seek-prev { background-position: -48px -160px; }
+.ui-icon-seek-end { background-position: -64px -160px; }
+.ui-icon-seek-start { background-position: -80px -160px; }
+/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
+.ui-icon-seek-first { background-position: -80px -160px; }
+.ui-icon-stop { background-position: -96px -160px; }
+.ui-icon-eject { background-position: -112px -160px; }
+.ui-icon-volume-off { background-position: -128px -160px; }
+.ui-icon-volume-on { background-position: -144px -160px; }
+.ui-icon-power { background-position: 0 -176px; }
+.ui-icon-signal-diag { background-position: -16px -176px; }
+.ui-icon-signal { background-position: -32px -176px; }
+.ui-icon-battery-0 { background-position: -48px -176px; }
+.ui-icon-battery-1 { background-position: -64px -176px; }
+.ui-icon-battery-2 { background-position: -80px -176px; }
+.ui-icon-battery-3 { background-position: -96px -176px; }
+.ui-icon-circle-plus { background-position: 0 -192px; }
+.ui-icon-circle-minus { background-position: -16px -192px; }
+.ui-icon-circle-close { background-position: -32px -192px; }
+.ui-icon-circle-triangle-e { background-position: -48px -192px; }
+.ui-icon-circle-triangle-s { background-position: -64px -192px; }
+.ui-icon-circle-triangle-w { background-position: -80px -192px; }
+.ui-icon-circle-triangle-n { background-position: -96px -192px; }
+.ui-icon-circle-arrow-e { background-position: -112px -192px; }
+.ui-icon-circle-arrow-s { background-position: -128px -192px; }
+.ui-icon-circle-arrow-w { background-position: -144px -192px; }
+.ui-icon-circle-arrow-n { background-position: -160px -192px; }
+.ui-icon-circle-zoomin { background-position: -176px -192px; }
+.ui-icon-circle-zoomout { background-position: -192px -192px; }
+.ui-icon-circle-check { background-position: -208px -192px; }
+.ui-icon-circlesmall-plus { background-position: 0 -208px; }
+.ui-icon-circlesmall-minus { background-position: -16px -208px; }
+.ui-icon-circlesmall-close { background-position: -32px -208px; }
+.ui-icon-squaresmall-plus { background-position: -48px -208px; }
+.ui-icon-squaresmall-minus { background-position: -64px -208px; }
+.ui-icon-squaresmall-close { background-position: -80px -208px; }
+.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
+.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
+.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
+.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
+.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
+.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
+
+
+/* Misc visuals
+----------------------------------*/
+
+/* Corner radius */
+.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; -khtml-border-top-left-radius: 4px; border-top-left-radius: 4px; }
+.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; -khtml-border-top-right-radius: 4px; border-top-right-radius: 4px; }
+.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; -khtml-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; }
+.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; -khtml-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; }
+
+/* Overlays */
+.ui-widget-overlay { background: #666666 url(images/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat; opacity: .50;filter:Alpha(Opacity=50); }
+.ui-widget-shadow { margin: -5px 0 0 -5px; padding: 5px; background: #000000 url(images/ui-bg_flat_10_000000_40x100.png) 50% 50% repeat-x; opacity: .20;filter:Alpha(Opacity=20); -moz-border-radius: 5px; -khtml-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; }/*
+ * jQuery UI Resizable 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Resizable#theming
+ */
+.ui-resizable { position: relative;}
+.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; }
+.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
+.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
+.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
+.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
+.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
+.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
+.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
+.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
+.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*
+ * jQuery UI Selectable 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Selectable#theming
+ */
+.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
+/*
+ * jQuery UI Accordion 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Accordion#theming
+ */
+/* IE/Win - Fix animation bug - #4615 */
+.ui-accordion { width: 100%; }
+.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; }
+.ui-accordion .ui-accordion-li-fix { display: inline; }
+.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; }
+.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; }
+.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; }
+.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
+.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; }
+.ui-accordion .ui-accordion-content-active { display: block; }
+/*
+ * jQuery UI Autocomplete 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Autocomplete#theming
+ */
+.ui-autocomplete { position: absolute; cursor: default; }
+
+/* workarounds */
+* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
+
+/*
+ * jQuery UI Menu 1.8.16
+ *
+ * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Menu#theming
+ */
+.ui-menu {
+ list-style:none;
+ padding: 2px;
+ margin: 0;
+ display:block;
+ float: left;
+}
+.ui-menu .ui-menu {
+ margin-top: -3px;
+}
+.ui-menu .ui-menu-item {
+ margin:0;
+ padding: 0;
+ zoom: 1;
+ float: left;
+ clear: left;
+ width: 100%;
+}
+.ui-menu .ui-menu-item a {
+ text-decoration:none;
+ display:block;
+ padding:.2em .4em;
+ line-height:1.5;
+ zoom:1;
+}
+.ui-menu .ui-menu-item a.ui-state-hover,
+.ui-menu .ui-menu-item a.ui-state-active {
+ font-weight: normal;
+ margin: -1px;
+}
+/*
+ * jQuery UI Button 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Button#theming
+ */
+.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
+.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
+button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
+.ui-button-icons-only { width: 3.4em; }
+button.ui-button-icons-only { width: 3.7em; }
+
+/*button text element */
+.ui-button .ui-button-text { display: block; line-height: 1.4; }
+.ui-button-text-only .ui-button-text { padding: .4em 1em; }
+.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
+.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
+.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
+.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
+/* no icon support for input elements, provide padding by default */
+input.ui-button { padding: .4em 1em; }
+
+/*button icon element(s) */
+.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
+.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
+.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
+.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
+.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
+
+/*button sets*/
+.ui-buttonset { margin-right: 7px; }
+.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }
+
+/* workarounds */
+button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
+/*
+ * jQuery UI Dialog 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Dialog#theming
+ */
+.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; }
+.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; }
+.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
+.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
+.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
+.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
+.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
+.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
+.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
+.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
+.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
+.ui-draggable .ui-dialog-titlebar { cursor: move; }
+/*
+ * jQuery UI Slider 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Slider#theming
+ */
+.ui-slider { position: relative; text-align: left; }
+.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
+.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
+
+.ui-slider-horizontal { height: .8em; }
+.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
+.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
+.ui-slider-horizontal .ui-slider-range-min { left: 0; }
+.ui-slider-horizontal .ui-slider-range-max { right: 0; }
+
+.ui-slider-vertical { width: .8em; height: 100px; }
+.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
+.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
+.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
+.ui-slider-vertical .ui-slider-range-max { top: 0; }/*
+ * jQuery UI Tabs 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Tabs#theming
+ */
+.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
+.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
+.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; }
+.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
+.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; }
+.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; }
+.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
+.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
+.ui-tabs .ui-tabs-hide { display: none !important; }
+/*
+ * jQuery UI Datepicker 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Datepicker#theming
+ */
+.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
+.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
+.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
+.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
+.ui-datepicker .ui-datepicker-prev { left:2px; }
+.ui-datepicker .ui-datepicker-next { right:2px; }
+.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
+.ui-datepicker .ui-datepicker-next-hover { right:1px; }
+.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
+.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
+.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
+.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
+.ui-datepicker select.ui-datepicker-month,
+.ui-datepicker select.ui-datepicker-year { width: 49%;}
+.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
+.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
+.ui-datepicker td { border: 0; padding: 1px; }
+.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
+.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
+.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
+.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
+
+/* with multiple calendars */
+.ui-datepicker.ui-datepicker-multi { width:auto; }
+.ui-datepicker-multi .ui-datepicker-group { float:left; }
+.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
+.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
+.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
+.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
+.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
+.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
+.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
+.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
+
+/* RTL support */
+.ui-datepicker-rtl { direction: rtl; }
+.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
+.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
+.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
+.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
+.ui-datepicker-rtl .ui-datepicker-group { float:right; }
+.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
+.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
+
+/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
+.ui-datepicker-cover {
+ display: none; /*sorry for IE5*/
+ display/**/: block; /*sorry for IE5*/
+ position: absolute; /*must have*/
+ z-index: -1; /*must have*/
+ filter: mask(); /*must have*/
+ top: -4px; /*must have*/
+ left: -4px; /*must have*/
+ width: 200px; /*must have*/
+ height: 200px; /*must have*/
+}/*
+ * jQuery UI Progressbar 1.8.16
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Progressbar#theming
+ */
+.ui-progressbar { height:2em; text-align: left; }
+.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }
\ No newline at end of file
diff --git a/create-ria/src/main/resources/foo.html b/create-ria/src/main/resources/foo.html
new file mode 100644
index 0000000..89b3b5e
--- /dev/null
+++ b/create-ria/src/main/resources/foo.html
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+ JS RIA Hello World
+
+
+
+
+
+ JSRIA Hello World app!!!
+
+ An explanation of the 'Hello World' application
+
+
+
+
+
+
Loading...
+
+
+
Click me
+
+
+
+
+
+
\ No newline at end of file
diff --git a/create-ria/src/main/resources/index.html b/create-ria/src/main/resources/index.html
new file mode 100644
index 0000000..89b3b5e
--- /dev/null
+++ b/create-ria/src/main/resources/index.html
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+ JS RIA Hello World
+
+
+
+
+
+ JSRIA Hello World app!!!
+
+ An explanation of the 'Hello World' application
+
+
+
+
+
+
Loading...
+
+
+
Click me
+
+
+
+
+
+
\ No newline at end of file
diff --git a/create-ria/src/main/webapp/WEB-INF/web.xml b/create-ria/src/main/webapp/WEB-INF/web.xml
new file mode 100644
index 0000000..cb9980b
--- /dev/null
+++ b/create-ria/src/main/webapp/WEB-INF/web.xml
@@ -0,0 +1,5 @@
+
+
+
\ No newline at end of file
diff --git a/create-ria/src/test/java/SuiteTest.java b/create-ria/src/test/java/SuiteTest.java
new file mode 100644
index 0000000..2ddb306
--- /dev/null
+++ b/create-ria/src/test/java/SuiteTest.java
@@ -0,0 +1,9 @@
+import org.codehaus.jstestrunner.junit.JSTestSuiteRunner;
+import org.junit.runner.RunWith;
+
+/**
+ * Run all JS tests associated with this project.
+ */
+@RunWith(JSTestSuiteRunner.class)
+public class SuiteTest {
+}
diff --git a/create-ria/src/test/js/HelloWorld/desktop/HelloWorldViewTest.js b/create-ria/src/test/js/HelloWorld/desktop/HelloWorldViewTest.js
new file mode 100644
index 0000000..ac351ca
--- /dev/null
+++ b/create-ria/src/test/js/HelloWorld/desktop/HelloWorldViewTest.js
@@ -0,0 +1,28 @@
+/*global require */
+
+require([ "jquery", "./HelloWorldView", "qunit" ], function($,
+ HelloWorldView, QUnit) {
+
+ var equal = QUnit.equal, expect = QUnit.expect, test = QUnit.test;
+
+ /**
+ * Test that the setText method sets the text in the #helloWorld div
+ */
+ test("setText sets text in #helloWorld #helloMessage", function() {
+
+ var magicWord, view;
+
+ // Setup test data
+ magicWord = "abracadabra";
+
+ // Setup view and call method under test
+ view = new HelloWorldView();
+ view.div = $("#helloWorld");
+ view.setHelloWorldDivText(magicWord);
+
+ // Expect that the text was set on the expected element
+ equal($("#helloWorld #helloMessage").text(), magicWord,
+ "Expected text not set in '#helloWorld #helloMessage' div");
+ });
+
+});
\ No newline at end of file
diff --git a/create-ria/src/test/resources/HelloWorld/desktop/HelloWorldViewTest.html b/create-ria/src/test/resources/HelloWorld/desktop/HelloWorldViewTest.html
new file mode 100644
index 0000000..4a60c5a
--- /dev/null
+++ b/create-ria/src/test/resources/HelloWorld/desktop/HelloWorldViewTest.html
@@ -0,0 +1,24 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/create-ria/src/test/resources/css/qunit.css b/create-ria/src/test/resources/css/qunit.css
new file mode 100644
index 0000000..bcecc4c
--- /dev/null
+++ b/create-ria/src/test/resources/css/qunit.css
@@ -0,0 +1,226 @@
+/**
+ * QUnit v1.2.0 - A JavaScript Unit Testing Framework
+ *
+ * http://docs.jquery.com/QUnit
+ *
+ * Copyright (c) 2011 John Resig, Jörn Zaefferer
+ * Dual licensed under the MIT (MIT-LICENSE.txt)
+ * or GPL (GPL-LICENSE.txt) licenses.
+ */
+
+/** Font Family and Sizes */
+
+#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult {
+ font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif;
+}
+
+#qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; }
+#qunit-tests { font-size: smaller; }
+
+
+/** Resets */
+
+#qunit-tests, #qunit-tests ol, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult {
+ margin: 0;
+ padding: 0;
+}
+
+
+/** Header */
+
+#qunit-header {
+ padding: 0.5em 0 0.5em 1em;
+
+ color: #8699a4;
+ background-color: #0d3349;
+
+ font-size: 1.5em;
+ line-height: 1em;
+ font-weight: normal;
+
+ border-radius: 15px 15px 0 0;
+ -moz-border-radius: 15px 15px 0 0;
+ -webkit-border-top-right-radius: 15px;
+ -webkit-border-top-left-radius: 15px;
+}
+
+#qunit-header a {
+ text-decoration: none;
+ color: #c2ccd1;
+}
+
+#qunit-header a:hover,
+#qunit-header a:focus {
+ color: #fff;
+}
+
+#qunit-banner {
+ height: 5px;
+}
+
+#qunit-testrunner-toolbar {
+ padding: 0.5em 0 0.5em 2em;
+ color: #5E740B;
+ background-color: #eee;
+}
+
+#qunit-userAgent {
+ padding: 0.5em 0 0.5em 2.5em;
+ background-color: #2b81af;
+ color: #fff;
+ text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px;
+}
+
+
+/** Tests: Pass/Fail */
+
+#qunit-tests {
+ list-style-position: inside;
+}
+
+#qunit-tests li {
+ padding: 0.4em 0.5em 0.4em 2.5em;
+ border-bottom: 1px solid #fff;
+ list-style-position: inside;
+}
+
+#qunit-tests.hidepass li.pass, #qunit-tests.hidepass li.running {
+ display: none;
+}
+
+#qunit-tests li strong {
+ cursor: pointer;
+}
+
+#qunit-tests li a {
+ padding: 0.5em;
+ color: #c2ccd1;
+ text-decoration: none;
+}
+#qunit-tests li a:hover,
+#qunit-tests li a:focus {
+ color: #000;
+}
+
+#qunit-tests ol {
+ margin-top: 0.5em;
+ padding: 0.5em;
+
+ background-color: #fff;
+
+ border-radius: 15px;
+ -moz-border-radius: 15px;
+ -webkit-border-radius: 15px;
+
+ box-shadow: inset 0px 2px 13px #999;
+ -moz-box-shadow: inset 0px 2px 13px #999;
+ -webkit-box-shadow: inset 0px 2px 13px #999;
+}
+
+#qunit-tests table {
+ border-collapse: collapse;
+ margin-top: .2em;
+}
+
+#qunit-tests th {
+ text-align: right;
+ vertical-align: top;
+ padding: 0 .5em 0 0;
+}
+
+#qunit-tests td {
+ vertical-align: top;
+}
+
+#qunit-tests pre {
+ margin: 0;
+ white-space: pre-wrap;
+ word-wrap: break-word;
+}
+
+#qunit-tests del {
+ background-color: #e0f2be;
+ color: #374e0c;
+ text-decoration: none;
+}
+
+#qunit-tests ins {
+ background-color: #ffcaca;
+ color: #500;
+ text-decoration: none;
+}
+
+/*** Test Counts */
+
+#qunit-tests b.counts { color: black; }
+#qunit-tests b.passed { color: #5E740B; }
+#qunit-tests b.failed { color: #710909; }
+
+#qunit-tests li li {
+ margin: 0.5em;
+ padding: 0.4em 0.5em 0.4em 0.5em;
+ background-color: #fff;
+ border-bottom: none;
+ list-style-position: inside;
+}
+
+/*** Passing Styles */
+
+#qunit-tests li li.pass {
+ color: #5E740B;
+ background-color: #fff;
+ border-left: 26px solid #C6E746;
+}
+
+#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; }
+#qunit-tests .pass .test-name { color: #366097; }
+
+#qunit-tests .pass .test-actual,
+#qunit-tests .pass .test-expected { color: #999999; }
+
+#qunit-banner.qunit-pass { background-color: #C6E746; }
+
+/*** Failing Styles */
+
+#qunit-tests li li.fail {
+ color: #710909;
+ background-color: #fff;
+ border-left: 26px solid #EE5757;
+ white-space: pre;
+}
+
+#qunit-tests > li:last-child {
+ border-radius: 0 0 15px 15px;
+ -moz-border-radius: 0 0 15px 15px;
+ -webkit-border-bottom-right-radius: 15px;
+ -webkit-border-bottom-left-radius: 15px;
+}
+
+#qunit-tests .fail { color: #000000; background-color: #EE5757; }
+#qunit-tests .fail .test-name,
+#qunit-tests .fail .module-name { color: #000000; }
+
+#qunit-tests .fail .test-actual { color: #EE5757; }
+#qunit-tests .fail .test-expected { color: green; }
+
+#qunit-banner.qunit-fail { background-color: #EE5757; }
+
+
+/** Result */
+
+#qunit-testresult {
+ padding: 0.5em 0.5em 0.5em 2.5em;
+
+ color: #2b81af;
+ background-color: #D2E0E6;
+
+ border-bottom: 1px solid white;
+}
+
+/** Fixture */
+
+#qunit-fixture {
+ position: absolute;
+ top: -10000px;
+ left: -10000px;
+}
diff --git a/pom.xml b/pom.xml
index 90ef66a..93a3ffa 100644
--- a/pom.xml
+++ b/pom.xml
@@ -14,9 +14,7 @@
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
--->
-
+-->
4.0.0
@@ -41,8 +39,9 @@
sling-stanbol-fragment
sling-stanbol-commons
sling-stanbol-config
- sling-stanbol-launcher
-
+ sling-stanbol-launcher
+ create-ria
+
@@ -74,53 +73,53 @@
org.apache.stanbol
org.apache.stanbol.cmsadapter.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.contenthub.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.data.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.enhancer.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.entityhub.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.ontologymanager.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
org.apache.stanbol
org.apache.stanbol.rules.bundlelist
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
partialbundlelist
provided
-
+
\ No newline at end of file
diff --git a/sling-stanbol-commons/pom.xml b/sling-stanbol-commons/pom.xml
index b9cf199..3bda192 100644
--- a/sling-stanbol-commons/pom.xml
+++ b/sling-stanbol-commons/pom.xml
@@ -49,7 +49,7 @@
org.apache.clerezza
rdf.core
- 0.12-incubating-SNAPSHOT
+ 0.12-incubating
org.apache.sling
diff --git a/sling-stanbol-ui/pom.xml b/sling-stanbol-ui/pom.xml
index 8742709..e4a7781 100644
--- a/sling-stanbol-ui/pom.xml
+++ b/sling-stanbol-ui/pom.xml
@@ -98,11 +98,36 @@
+
+
+
+ maven-dependency-plugin
+
+
+ copy-js-deps
+ generate-sources
+
+ copy-dependencies
+
+
+ js
+ ${project.build.directory}/maven-shared-archive-resources/initial-content/apps/
+
+
+
+
+
+
+ org.wymiwyg
+ create-ria
+ 0.1-SNAPSHOT
+ js
+
org.ccil.cowan.tagsoup
tagsoup
@@ -154,17 +179,17 @@
org.apache.stanbol
org.apache.stanbol.enhancer.servicesapi
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
org.apache.clerezza
rdf.core
- 0.12-incubating-SNAPSHOT
+ 0.12-incubating
org.apache.clerezza
rdf.utils
- 0.13-incubating-SNAPSHOT
+ 0.13-incubating
org.wymiwyg.sling-stanbol
@@ -176,22 +201,22 @@
org.apache.stanbol
org.apache.stanbol.entityhub.servicesapi
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
org.apache.stanbol
org.apache.stanbol.entityhub.core
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
org.apache.stanbol
org.apache.stanbol.entityhub.model.clerezza
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating
org.apache.stanbol
org.apache.stanbol.entityhub.query.clerezza
- 0.9.0-incubating-SNAPSHOT
+ 0.9.0-incubating