From 900b9581ed0b6277ee5f98b9b1e1bcd7739dde02 Mon Sep 17 00:00:00 2001 From: Vincent Bechu <vincent.bechu@nexedi.com> Date: Mon, 30 Jan 2017 13:25:36 +0000 Subject: [PATCH] erp5_officejs: get last version of bookmark manager from officejs prod --- ..._bookmark_manager_gadget_landing_html.html | 66 + ...s_bookmark_manager_gadget_landing_html.xml | 328 ++ .../gadget_officejs_dav_delete_js.js | 162 + .../gadget_officejs_dav_delete_js.xml | 322 ++ .../gadget_officejs_handlebars_js.html | 4608 +++++++++++++++++ .../gadget_officejs_handlebars_js.xml | 322 ++ ...adget_officejs_jio_bookmark_view_html.html | 47 + ...gadget_officejs_jio_bookmark_view_html.xml | 322 ++ .../gadget_officejs_jio_bookmark_view_js.js | 142 + .../gadget_officejs_jio_bookmark_view_js.xml | 322 ++ .../gadget_officejs_jio_url_view_html.html | 92 +- .../gadget_officejs_jio_url_view_html.xml | 20 +- .../gadget_officejs_jio_url_view_js.js | 248 +- .../gadget_officejs_jio_url_view_js.xml | 30 +- ...fficejs_jio_web_illustration_view_html.xml | 10 +- ..._officejs_jio_web_illustration_view_js.xml | 8 +- ...gadget_officejs_jio_web_page_view_html.xml | 8 +- .../gadget_officejs_jio_web_page_view_js.xml | 8 +- .../gadget_officejs_liberator_html.html | 20 + .../gadget_officejs_liberator_html.xml | 326 ++ .../gadget_officejs_liberator_js.js | 98 + .../gadget_officejs_liberator_js.xml | 328 ++ .../gadget_officejs_logo_bookmark.xml | 437 ++ ...adget_officejs_page_add_bookmark_html.html | 38 +- ...gadget_officejs_page_add_bookmark_html.xml | 59 +- .../gadget_officejs_page_add_bookmark_js.js | 138 +- .../gadget_officejs_page_add_bookmark_js.xml | 59 +- ...fficejs_page_bookmark_dispatcher_html.html | 2 +- ...officejs_page_bookmark_dispatcher_html.xml | 8 +- ...et_officejs_page_bookmark_dispatcher_js.js | 219 +- ...t_officejs_page_bookmark_dispatcher_js.xml | 59 +- ...adget_officejs_page_bookmark_list_html.xml | 8 +- .../gadget_officejs_page_bookmark_list_js.js | 212 +- .../gadget_officejs_page_bookmark_list_js.xml | 59 +- ...officejs_page_bookmark_preference_html.xml | 8 +- ...t_officejs_page_bookmark_preference_js.xml | 8 +- ...ficejs_page_jio_dav_configurator_html.html | 151 +- ...fficejs_page_jio_dav_configurator_html.xml | 28 +- ...js_page_jio_dropbox_configurator_html.html | 52 + ...ejs_page_jio_dropbox_configurator_html.xml | 322 ++ ...icejs_page_jio_dropbox_configurator_js.txt | 138 + ...icejs_page_jio_dropbox_configurator_js.xml | 322 ++ ...icejs_page_jio_erp5_configurator_html.html | 144 +- ...ficejs_page_jio_erp5_configurator_html.xml | 63 +- .../gadget_officejs_page_login_html.html | 94 +- .../gadget_officejs_page_login_html.xml | 30 +- .../gadget_officejs_page_login_js.js | 100 +- .../gadget_officejs_page_login_js.xml | 34 +- .../gadget_officejs_page_logout_html.html | 64 +- .../gadget_officejs_page_logout_html.xml | 30 +- .../gadget_officejs_page_logout_js.js | 118 +- .../gadget_officejs_page_logout_js.xml | 34 +- .../gadget_officejs_page_sync_html.html | 88 +- .../gadget_officejs_page_sync_html.xml | 85 +- .../gadget_officejs_widget_listbox_html.html | 120 +- .../gadget_officejs_widget_listbox_html.xml | 30 +- .../gadget_officejs_widget_listbox_js.js | 317 +- .../gadget_officejs_widget_listbox_js.xml | 32 +- .../officejs_bookmark_manager.xml | 74 +- .../{rjsunsafe.xml => development.xml} | 162 +- .../{hateoas.xml => hateoasnoauth.xml} | 74 +- 61 files changed, 10311 insertions(+), 1546 deletions(-) create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.html create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.js create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.html create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.html create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.js create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.html create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.js create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_logo_bookmark.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.html create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.xml create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.txt create mode 100644 bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.xml rename bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/{rjsunsafe.xml => development.xml} (60%) rename bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/{hateoas.xml => hateoasnoauth.xml} (85%) diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.html new file mode 100644 index 0000000000..d773d2d0e7 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.html @@ -0,0 +1,66 @@ + +<!DOCTYPE html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + <link rel="shortcut icon" href="favicon.ico"> + + <title>Bookmark Manager</title> + + <link href="//netdna.bootstrapcdn.com/font-awesome/4.2.0/css/font-awesome.min.css" rel="stylesheet" type="text/css" /> + <link rel="stylesheet" href="jquerymobile.css"> + <link rel="stylesheet" href="gadget_erp5.css"> + + <script data-renderjs-configuration="application_title" type="text/x-renderjs-configuration">Bookmark Manager</script> + <script data-renderjs-configuration="panel_gadget" type="text/x-renderjs-configuration">gadget_officejs_bookmark_manager_panel.html</script> + <script data-renderjs-configuration="action_view" type="text/x-renderjs-configuration">object_view</script> + <script data-renderjs-configuration="default_view_reference" type="text/x-renderjs-configuration">view</script> + <script data-renderjs-configuration="hateoas_url" type="text/x-renderjs-configuration">hateoas/</script> + + <script src="jquery.js"></script> + <script src="jquerymobile.js"></script> + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="gadget_global.js" ></script> + <script src="erp5_launcher.js"></script> + + </head> + + <body> + <div data-role="page"> + + <div data-gadget-url="gadget_jio.html" + data-gadget-scope="setting_gadget" + data-gadget-sandbox="public"></div> + + <div data-gadget-url="gadget_officejs_bookmark_manager_router.html" + data-gadget-scope="router" + data-gadget-sandbox="public"></div> + + <div data-gadget-url="gadget_translation.html" + data-gadget-scope="translation_gadget" + data-gadget-sandbox="public"></div> + + <div data-gadget-url="gadget_officejs_header.html" + data-gadget-scope="header" + data-gadget-sandbox="public"></div> + + <div data-gadget-url="gadget_officejs_jio.html" + data-gadget-scope="jio_gadget" + data-gadget-sandbox="public"></div> + + + <div data-gadget-url="gadget_erp5_editor_panel.html" + data-gadget-scope="editor_panel" + data-gadget-sandbox="public"></div> + + <div data-gadget-url="gadget_officejs_bookmark_manager_panel.html" + data-gadget-scope="panel" + data-gadget-sandbox="public"></div> + + <div role="main" class="ui-content gadget-content"></div> + </div> + + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.xml new file mode 100644 index 0000000000..f8c97023d4 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_bookmark_manager_gadget_landing_html.xml @@ -0,0 +1,328 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Page" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/html</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>bookmark_manager_gadget_landing.html</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_bookmark_manager_gadget_landing_html</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> <string>en</string> </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Page</string> </value> + </item> + <item> + <key> <string>short_title</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>Bookmark Manager Landing Page</string> </value> + </item> + <item> + <key> <string>url_string</string> </key> + <value> <string>/</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781950.11</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64514.17340.60757</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781940.22</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>detect_converted_file</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>converted</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485770925.12</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.js new file mode 100644 index 0000000000..3a3784143c --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.js @@ -0,0 +1,162 @@ +/*global window, rJS, RSVP, URI, location, + loopEventListener, btoa */ +/*jslint nomen: true, indent: 2, maxerr: 3*/ +(function (window, rJS, RSVP) { + "use strict"; + + function setjIODAVConfiguration(gadget) { + return gadget.getSetting("portal_type") + .push(function (portal_type) { + var old_date = new Date(), + configuration = {}; + // We are looking for documents modified in the past 3 month + old_date = new Date(old_date.getFullYear(), old_date.getMonth() - 3); + configuration = { + type: "replicate", + // XXX This drop the signature lists... + query: { + query: 'portal_type:"' + portal_type + '" ', + // XX Synchonizing the whole module is too much, here is a way to start quietly + //+ 'AND local_roles: ("Owner") ' + //+ 'AND validation_state: ("draft", "released_alive", "shared_alive", "published_alive") ', + limit: [0, 1234567890] + }, + use_remote_post: false, + conflict_handling: 2, + check_local_modification: true, + check_local_creation: true, + check_local_deletion: true, + check_remote_modification: true, + check_remote_creation: true, + check_remote_deletion: true, + local_sub_storage: { + type: "mapping", + attachment_mapping_dict: { + 'data': { + get: {uri_template: 'enclosure'}, + put: {uri_template: 'enclosure'} + } + }, + sub_storage: { + type: "query", + sub_storage: { + type: "uuid", + sub_storage: { + type: "indexeddb", + database: "officejs-dav" + } + } + } + }, + remote_sub_storage: { + type: "mapping", + attachment_mapping_dict: { + 'data': { + get: {uri_template: 'enclosure'}, + put: {uri_template: 'enclosure'} + } + }, + sub_storage: { + type: "query", + sub_storage: { + type: "drivetojiomapping", + sub_storage: { + type: "mapping", + mapping_dict: { + "portal_type": { + "equal": "type", + "value": { + "switch": { + "PDF": { + "equal": "pdf" + }, + "Web Text": { + "equal": "txt" + } + } + } + } + }, + sub_storage: { + type: "dav", + url: gadget.props.element.querySelector("input[name='dav_url']").value, + basic_login: btoa(gadget.props.element.querySelector("input[name='dav_username']").value + + ':' + gadget.props.element.querySelector("input[name='dav_password']").value), + with_credentials: true + } + } + } + } + } + }; + return gadget.setSetting('jio_storage_description', configuration); + }) + .push(function () { + return gadget.setSetting('jio_storage_name', "DAV"); + }) + .push(function () { + return gadget.reload(); + }); + } + + var gadget_klass = rJS(window); + + gadget_klass + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + g.props.deferred = RSVP.defer(); + return g.getSetting('jio_storage_name'); + }) + .push(function (jio_storage_name) { + if (jio_storage_name === "DAV") { + return g.getSetting('jio_storage_description') + .push(function (jio_storage_description) { + g.props.element.querySelector("input[name='dav_url']").value = + jio_storage_description.remote_sub_storage.sub_storage.sub_storage.url; + }); + } + }); + }) + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod("redirect", "redirect") + .declareAcquiredMethod("reload", "reload") + .declareAcquiredMethod("getSetting", "getSetting") + .declareAcquiredMethod("setSetting", "setSetting") + .declareMethod("render", function () { + var gadget = this; + return gadget.updateHeader({ + title: "Connect To DAV Storage", + back_url: "#page=jio_configurator", + panel_action: false + }).push(function () { + return gadget.props.deferred.resolve(); + }); + }) + + ///////////////////////////////////////// + // Form submit + ///////////////////////////////////////// + .declareService(function () { + var gadget = this; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }) + .push(function () { + return loopEventListener( + gadget.props.element.querySelector('form'), + 'submit', + true, + function () { + return setjIODAVConfiguration(gadget); + } + ); + }); + }); + + +}(window, rJS, RSVP)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.xml new file mode 100644 index 0000000000..7184fe149b --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_dav_delete_js.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Script" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>dav_delete.js</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_dav_delete_js</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Script</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>dav_delete</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781878.74</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64653.18502.64853</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781872.54</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779356.31</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.html new file mode 100644 index 0000000000..fcfa8fbdc5 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.html @@ -0,0 +1,4608 @@ +/*! + + handlebars v4.0.5 + +Copyright (C) 2011-2015 by Yehuda Katz + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. + +@license +*/ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define([], factory); + else if(typeof exports === 'object') + exports["Handlebars"] = factory(); + else + root["Handlebars"] = factory(); +})(this, function() { +return /******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; + +/******/ // The require function +/******/ function __webpack_require__(moduleId) { + +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) +/******/ return installedModules[moduleId].exports; + +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ exports: {}, +/******/ id: moduleId, +/******/ loaded: false +/******/ }; + +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); + +/******/ // Flag the module as loaded +/******/ module.loaded = true; + +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } + + +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; + +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; + +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; + +/******/ // Load entry module and return exports +/******/ return __webpack_require__(0); +/******/ }) +/************************************************************************/ +/******/ ([ +/* 0 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _handlebarsRuntime = __webpack_require__(2); + + var _handlebarsRuntime2 = _interopRequireDefault(_handlebarsRuntime); + + // Compiler imports + + var _handlebarsCompilerAst = __webpack_require__(21); + + var _handlebarsCompilerAst2 = _interopRequireDefault(_handlebarsCompilerAst); + + var _handlebarsCompilerBase = __webpack_require__(22); + + var _handlebarsCompilerCompiler = __webpack_require__(27); + + var _handlebarsCompilerJavascriptCompiler = __webpack_require__(28); + + var _handlebarsCompilerJavascriptCompiler2 = _interopRequireDefault(_handlebarsCompilerJavascriptCompiler); + + var _handlebarsCompilerVisitor = __webpack_require__(25); + + var _handlebarsCompilerVisitor2 = _interopRequireDefault(_handlebarsCompilerVisitor); + + var _handlebarsNoConflict = __webpack_require__(20); + + var _handlebarsNoConflict2 = _interopRequireDefault(_handlebarsNoConflict); + + var _create = _handlebarsRuntime2['default'].create; + function create() { + var hb = _create(); + + hb.compile = function (input, options) { + return _handlebarsCompilerCompiler.compile(input, options, hb); + }; + hb.precompile = function (input, options) { + return _handlebarsCompilerCompiler.precompile(input, options, hb); + }; + + hb.AST = _handlebarsCompilerAst2['default']; + hb.Compiler = _handlebarsCompilerCompiler.Compiler; + hb.JavaScriptCompiler = _handlebarsCompilerJavascriptCompiler2['default']; + hb.Parser = _handlebarsCompilerBase.parser; + hb.parse = _handlebarsCompilerBase.parse; + + return hb; + } + + var inst = create(); + inst.create = create; + + _handlebarsNoConflict2['default'](inst); + + inst.Visitor = _handlebarsCompilerVisitor2['default']; + + inst['default'] = inst; + + exports['default'] = inst; + module.exports = exports['default']; + +/***/ }, +/* 1 */ +/***/ function(module, exports) { + + "use strict"; + + exports["default"] = function (obj) { + return obj && obj.__esModule ? obj : { + "default": obj + }; + }; + + exports.__esModule = true; + +/***/ }, +/* 2 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireWildcard = __webpack_require__(3)['default']; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _handlebarsBase = __webpack_require__(4); + + var base = _interopRequireWildcard(_handlebarsBase); + + // Each of these augment the Handlebars object. No need to setup here. + // (This is done to easily share code between commonjs and browse envs) + + var _handlebarsSafeString = __webpack_require__(18); + + var _handlebarsSafeString2 = _interopRequireDefault(_handlebarsSafeString); + + var _handlebarsException = __webpack_require__(6); + + var _handlebarsException2 = _interopRequireDefault(_handlebarsException); + + var _handlebarsUtils = __webpack_require__(5); + + var Utils = _interopRequireWildcard(_handlebarsUtils); + + var _handlebarsRuntime = __webpack_require__(19); + + var runtime = _interopRequireWildcard(_handlebarsRuntime); + + var _handlebarsNoConflict = __webpack_require__(20); + + var _handlebarsNoConflict2 = _interopRequireDefault(_handlebarsNoConflict); + + // For compatibility and usage outside of module systems, make the Handlebars object a namespace + function create() { + var hb = new base.HandlebarsEnvironment(); + + Utils.extend(hb, base); + hb.SafeString = _handlebarsSafeString2['default']; + hb.Exception = _handlebarsException2['default']; + hb.Utils = Utils; + hb.escapeExpression = Utils.escapeExpression; + + hb.VM = runtime; + hb.template = function (spec) { + return runtime.template(spec, hb); + }; + + return hb; + } + + var inst = create(); + inst.create = create; + + _handlebarsNoConflict2['default'](inst); + + inst['default'] = inst; + + exports['default'] = inst; + module.exports = exports['default']; + +/***/ }, +/* 3 */ +/***/ function(module, exports) { + + "use strict"; + + exports["default"] = function (obj) { + if (obj && obj.__esModule) { + return obj; + } else { + var newObj = {}; + + if (obj != null) { + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; + } + } + + newObj["default"] = obj; + return newObj; + } + }; + + exports.__esModule = true; + +/***/ }, +/* 4 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.HandlebarsEnvironment = HandlebarsEnvironment; + + var _utils = __webpack_require__(5); + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + var _helpers = __webpack_require__(7); + + var _decorators = __webpack_require__(15); + + var _logger = __webpack_require__(17); + + var _logger2 = _interopRequireDefault(_logger); + + var VERSION = '4.0.5'; + exports.VERSION = VERSION; + var COMPILER_REVISION = 7; + + exports.COMPILER_REVISION = COMPILER_REVISION; + var REVISION_CHANGES = { + 1: '<= 1.0.rc.2', // 1.0.rc.2 is actually rev2 but doesn't report it + 2: '== 1.0.0-rc.3', + 3: '== 1.0.0-rc.4', + 4: '== 1.x.x', + 5: '== 2.0.0-alpha.x', + 6: '>= 2.0.0-beta.1', + 7: '>= 4.0.0' + }; + + exports.REVISION_CHANGES = REVISION_CHANGES; + var objectType = '[object Object]'; + + function HandlebarsEnvironment(helpers, partials, decorators) { + this.helpers = helpers || {}; + this.partials = partials || {}; + this.decorators = decorators || {}; + + _helpers.registerDefaultHelpers(this); + _decorators.registerDefaultDecorators(this); + } + + HandlebarsEnvironment.prototype = { + constructor: HandlebarsEnvironment, + + logger: _logger2['default'], + log: _logger2['default'].log, + + registerHelper: function registerHelper(name, fn) { + if (_utils.toString.call(name) === objectType) { + if (fn) { + throw new _exception2['default']('Arg not supported with multiple helpers'); + } + _utils.extend(this.helpers, name); + } else { + this.helpers[name] = fn; + } + }, + unregisterHelper: function unregisterHelper(name) { + delete this.helpers[name]; + }, + + registerPartial: function registerPartial(name, partial) { + if (_utils.toString.call(name) === objectType) { + _utils.extend(this.partials, name); + } else { + if (typeof partial === 'undefined') { + throw new _exception2['default']('Attempting to register a partial called "' + name + '" as undefined'); + } + this.partials[name] = partial; + } + }, + unregisterPartial: function unregisterPartial(name) { + delete this.partials[name]; + }, + + registerDecorator: function registerDecorator(name, fn) { + if (_utils.toString.call(name) === objectType) { + if (fn) { + throw new _exception2['default']('Arg not supported with multiple decorators'); + } + _utils.extend(this.decorators, name); + } else { + this.decorators[name] = fn; + } + }, + unregisterDecorator: function unregisterDecorator(name) { + delete this.decorators[name]; + } + }; + + var log = _logger2['default'].log; + + exports.log = log; + exports.createFrame = _utils.createFrame; + exports.logger = _logger2['default']; + +/***/ }, +/* 5 */ +/***/ function(module, exports) { + + 'use strict'; + + exports.__esModule = true; + exports.extend = extend; + exports.indexOf = indexOf; + exports.escapeExpression = escapeExpression; + exports.isEmpty = isEmpty; + exports.createFrame = createFrame; + exports.blockParams = blockParams; + exports.appendContextPath = appendContextPath; + var escape = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''', + '`': '`', + '=': '=' + }; + + var badChars = /[&<>"'`=]/g, + possible = /[&<>"'`=]/; + + function escapeChar(chr) { + return escape[chr]; + } + + function extend(obj /* , ...source */) { + for (var i = 1; i < arguments.length; i++) { + for (var key in arguments[i]) { + if (Object.prototype.hasOwnProperty.call(arguments[i], key)) { + obj[key] = arguments[i][key]; + } + } + } + + return obj; + } + + var toString = Object.prototype.toString; + + exports.toString = toString; + // Sourced from lodash + // https://github.com/bestiejs/lodash/blob/master/LICENSE.txt + /* eslint-disable func-style */ + var isFunction = function isFunction(value) { + return typeof value === 'function'; + }; + // fallback for older versions of Chrome and Safari + /* istanbul ignore next */ + if (isFunction(/x/)) { + exports.isFunction = isFunction = function (value) { + return typeof value === 'function' && toString.call(value) === '[object Function]'; + }; + } + exports.isFunction = isFunction; + + /* eslint-enable func-style */ + + /* istanbul ignore next */ + var isArray = Array.isArray || function (value) { + return value && typeof value === 'object' ? toString.call(value) === '[object Array]' : false; + }; + + exports.isArray = isArray; + // Older IE versions do not directly support indexOf so we must implement our own, sadly. + + function indexOf(array, value) { + for (var i = 0, len = array.length; i < len; i++) { + if (array[i] === value) { + return i; + } + } + return -1; + } + + function escapeExpression(string) { + if (typeof string !== 'string') { + // don't escape SafeStrings, since they're already safe + if (string && string.toHTML) { + return string.toHTML(); + } else if (string == null) { + return ''; + } else if (!string) { + return string + ''; + } + + // Force a string conversion as this will be done by the append regardless and + // the regex test will do this transparently behind the scenes, causing issues if + // an object's to string has escaped characters in it. + string = '' + string; + } + + if (!possible.test(string)) { + return string; + } + return string.replace(badChars, escapeChar); + } + + function isEmpty(value) { + if (!value && value !== 0) { + return true; + } else if (isArray(value) && value.length === 0) { + return true; + } else { + return false; + } + } + + function createFrame(object) { + var frame = extend({}, object); + frame._parent = object; + return frame; + } + + function blockParams(params, ids) { + params.path = ids; + return params; + } + + function appendContextPath(contextPath, id) { + return (contextPath ? contextPath + '.' : '') + id; + } + +/***/ }, +/* 6 */ +/***/ function(module, exports) { + + 'use strict'; + + exports.__esModule = true; + + var errorProps = ['description', 'fileName', 'lineNumber', 'message', 'name', 'number', 'stack']; + + function Exception(message, node) { + var loc = node && node.loc, + line = undefined, + column = undefined; + if (loc) { + line = loc.start.line; + column = loc.start.column; + + message += ' - ' + line + ':' + column; + } + + var tmp = Error.prototype.constructor.call(this, message); + + // Unfortunately errors are not enumerable in Chrome (at least), so `for prop in tmp` doesn't work. + for (var idx = 0; idx < errorProps.length; idx++) { + this[errorProps[idx]] = tmp[errorProps[idx]]; + } + + /* istanbul ignore else */ + if (Error.captureStackTrace) { + Error.captureStackTrace(this, Exception); + } + + if (loc) { + this.lineNumber = line; + this.column = column; + } + } + + Exception.prototype = new Error(); + + exports['default'] = Exception; + module.exports = exports['default']; + +/***/ }, +/* 7 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.registerDefaultHelpers = registerDefaultHelpers; + + var _helpersBlockHelperMissing = __webpack_require__(8); + + var _helpersBlockHelperMissing2 = _interopRequireDefault(_helpersBlockHelperMissing); + + var _helpersEach = __webpack_require__(9); + + var _helpersEach2 = _interopRequireDefault(_helpersEach); + + var _helpersHelperMissing = __webpack_require__(10); + + var _helpersHelperMissing2 = _interopRequireDefault(_helpersHelperMissing); + + var _helpersIf = __webpack_require__(11); + + var _helpersIf2 = _interopRequireDefault(_helpersIf); + + var _helpersLog = __webpack_require__(12); + + var _helpersLog2 = _interopRequireDefault(_helpersLog); + + var _helpersLookup = __webpack_require__(13); + + var _helpersLookup2 = _interopRequireDefault(_helpersLookup); + + var _helpersWith = __webpack_require__(14); + + var _helpersWith2 = _interopRequireDefault(_helpersWith); + + function registerDefaultHelpers(instance) { + _helpersBlockHelperMissing2['default'](instance); + _helpersEach2['default'](instance); + _helpersHelperMissing2['default'](instance); + _helpersIf2['default'](instance); + _helpersLog2['default'](instance); + _helpersLookup2['default'](instance); + _helpersWith2['default'](instance); + } + +/***/ }, +/* 8 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + exports['default'] = function (instance) { + instance.registerHelper('blockHelperMissing', function (context, options) { + var inverse = options.inverse, + fn = options.fn; + + if (context === true) { + return fn(this); + } else if (context === false || context == null) { + return inverse(this); + } else if (_utils.isArray(context)) { + if (context.length > 0) { + if (options.ids) { + options.ids = [options.name]; + } + + return instance.helpers.each(context, options); + } else { + return inverse(this); + } + } else { + if (options.data && options.ids) { + var data = _utils.createFrame(options.data); + data.contextPath = _utils.appendContextPath(options.data.contextPath, options.name); + options = { data: data }; + } + + return fn(context, options); + } + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 9 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + exports['default'] = function (instance) { + instance.registerHelper('each', function (context, options) { + if (!options) { + throw new _exception2['default']('Must pass iterator to #each'); + } + + var fn = options.fn, + inverse = options.inverse, + i = 0, + ret = '', + data = undefined, + contextPath = undefined; + + if (options.data && options.ids) { + contextPath = _utils.appendContextPath(options.data.contextPath, options.ids[0]) + '.'; + } + + if (_utils.isFunction(context)) { + context = context.call(this); + } + + if (options.data) { + data = _utils.createFrame(options.data); + } + + function execIteration(field, index, last) { + if (data) { + data.key = field; + data.index = index; + data.first = index === 0; + data.last = !!last; + + if (contextPath) { + data.contextPath = contextPath + field; + } + } + + ret = ret + fn(context[field], { + data: data, + blockParams: _utils.blockParams([context[field], field], [contextPath + field, null]) + }); + } + + if (context && typeof context === 'object') { + if (_utils.isArray(context)) { + for (var j = context.length; i < j; i++) { + if (i in context) { + execIteration(i, i, i === context.length - 1); + } + } + } else { + var priorKey = undefined; + + for (var key in context) { + if (context.hasOwnProperty(key)) { + // We're running the iterations one step out of sync so we can detect + // the last iteration without have to scan the object twice and create + // an itermediate keys array. + if (priorKey !== undefined) { + execIteration(priorKey, i - 1); + } + priorKey = key; + i++; + } + } + if (priorKey !== undefined) { + execIteration(priorKey, i - 1, true); + } + } + } + + if (i === 0) { + ret = inverse(this); + } + + return ret; + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 10 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + exports['default'] = function (instance) { + instance.registerHelper('helperMissing', function () /* [args, ]options */{ + if (arguments.length === 1) { + // A missing field in a {{foo}} construct. + return undefined; + } else { + // Someone is actually trying to call something, blow up. + throw new _exception2['default']('Missing helper: "' + arguments[arguments.length - 1].name + '"'); + } + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 11 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + exports['default'] = function (instance) { + instance.registerHelper('if', function (conditional, options) { + if (_utils.isFunction(conditional)) { + conditional = conditional.call(this); + } + + // Default behavior is to render the positive path if the value is truthy and not empty. + // The `includeZero` option may be set to treat the condtional as purely not empty based on the + // behavior of isEmpty. Effectively this determines if 0 is handled by the positive path or negative. + if (!options.hash.includeZero && !conditional || _utils.isEmpty(conditional)) { + return options.inverse(this); + } else { + return options.fn(this); + } + }); + + instance.registerHelper('unless', function (conditional, options) { + return instance.helpers['if'].call(this, conditional, { fn: options.inverse, inverse: options.fn, hash: options.hash }); + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 12 */ +/***/ function(module, exports) { + + 'use strict'; + + exports.__esModule = true; + + exports['default'] = function (instance) { + instance.registerHelper('log', function () /* message, options */{ + var args = [undefined], + options = arguments[arguments.length - 1]; + for (var i = 0; i < arguments.length - 1; i++) { + args.push(arguments[i]); + } + + var level = 1; + if (options.hash.level != null) { + level = options.hash.level; + } else if (options.data && options.data.level != null) { + level = options.data.level; + } + args[0] = level; + + instance.log.apply(instance, args); + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 13 */ +/***/ function(module, exports) { + + 'use strict'; + + exports.__esModule = true; + + exports['default'] = function (instance) { + instance.registerHelper('lookup', function (obj, field) { + return obj && obj[field]; + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 14 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + exports['default'] = function (instance) { + instance.registerHelper('with', function (context, options) { + if (_utils.isFunction(context)) { + context = context.call(this); + } + + var fn = options.fn; + + if (!_utils.isEmpty(context)) { + var data = options.data; + if (options.data && options.ids) { + data = _utils.createFrame(options.data); + data.contextPath = _utils.appendContextPath(options.data.contextPath, options.ids[0]); + } + + return fn(context, { + data: data, + blockParams: _utils.blockParams([context], [data && data.contextPath]) + }); + } else { + return options.inverse(this); + } + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 15 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.registerDefaultDecorators = registerDefaultDecorators; + + var _decoratorsInline = __webpack_require__(16); + + var _decoratorsInline2 = _interopRequireDefault(_decoratorsInline); + + function registerDefaultDecorators(instance) { + _decoratorsInline2['default'](instance); + } + +/***/ }, +/* 16 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + exports['default'] = function (instance) { + instance.registerDecorator('inline', function (fn, props, container, options) { + var ret = fn; + if (!props.partials) { + props.partials = {}; + ret = function (context, options) { + // Create a new partials stack frame prior to exec. + var original = container.partials; + container.partials = _utils.extend({}, original, props.partials); + var ret = fn(context, options); + container.partials = original; + return ret; + }; + } + + props.partials[options.args[0]] = options.fn; + + return ret; + }); + }; + + module.exports = exports['default']; + +/***/ }, +/* 17 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + var logger = { + methodMap: ['debug', 'info', 'warn', 'error'], + level: 'info', + + // Maps a given level value to the `methodMap` indexes above. + lookupLevel: function lookupLevel(level) { + if (typeof level === 'string') { + var levelMap = _utils.indexOf(logger.methodMap, level.toLowerCase()); + if (levelMap >= 0) { + level = levelMap; + } else { + level = parseInt(level, 10); + } + } + + return level; + }, + + // Can be overridden in the host environment + log: function log(level) { + level = logger.lookupLevel(level); + + if (typeof console !== 'undefined' && logger.lookupLevel(logger.level) <= level) { + var method = logger.methodMap[level]; + if (!console[method]) { + // eslint-disable-line no-console + method = 'log'; + } + + for (var _len = arguments.length, message = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + message[_key - 1] = arguments[_key]; + } + + console[method].apply(console, message); // eslint-disable-line no-console + } + } + }; + + exports['default'] = logger; + module.exports = exports['default']; + +/***/ }, +/* 18 */ +/***/ function(module, exports) { + + // Build out our basic SafeString type + 'use strict'; + + exports.__esModule = true; + function SafeString(string) { + this.string = string; + } + + SafeString.prototype.toString = SafeString.prototype.toHTML = function () { + return '' + this.string; + }; + + exports['default'] = SafeString; + module.exports = exports['default']; + +/***/ }, +/* 19 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireWildcard = __webpack_require__(3)['default']; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.checkRevision = checkRevision; + exports.template = template; + exports.wrapProgram = wrapProgram; + exports.resolvePartial = resolvePartial; + exports.invokePartial = invokePartial; + exports.noop = noop; + + var _utils = __webpack_require__(5); + + var Utils = _interopRequireWildcard(_utils); + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + var _base = __webpack_require__(4); + + function checkRevision(compilerInfo) { + var compilerRevision = compilerInfo && compilerInfo[0] || 1, + currentRevision = _base.COMPILER_REVISION; + + if (compilerRevision !== currentRevision) { + if (compilerRevision < currentRevision) { + var runtimeVersions = _base.REVISION_CHANGES[currentRevision], + compilerVersions = _base.REVISION_CHANGES[compilerRevision]; + throw new _exception2['default']('Template was precompiled with an older version of Handlebars than the current runtime. ' + 'Please update your precompiler to a newer version (' + runtimeVersions + ') or downgrade your runtime to an older version (' + compilerVersions + ').'); + } else { + // Use the embedded version info since the runtime doesn't know about this revision yet + throw new _exception2['default']('Template was precompiled with a newer version of Handlebars than the current runtime. ' + 'Please update your runtime to a newer version (' + compilerInfo[1] + ').'); + } + } + } + + function template(templateSpec, env) { + /* istanbul ignore next */ + if (!env) { + throw new _exception2['default']('No environment passed to template'); + } + if (!templateSpec || !templateSpec.main) { + throw new _exception2['default']('Unknown template object: ' + typeof templateSpec); + } + + templateSpec.main.decorator = templateSpec.main_d; + + // Note: Using env.VM references rather than local var references throughout this section to allow + // for external users to override these as psuedo-supported APIs. + env.VM.checkRevision(templateSpec.compiler); + + function invokePartialWrapper(partial, context, options) { + if (options.hash) { + context = Utils.extend({}, context, options.hash); + if (options.ids) { + options.ids[0] = true; + } + } + + partial = env.VM.resolvePartial.call(this, partial, context, options); + var result = env.VM.invokePartial.call(this, partial, context, options); + + if (result == null && env.compile) { + options.partials[options.name] = env.compile(partial, templateSpec.compilerOptions, env); + result = options.partials[options.name](context, options); + } + if (result != null) { + if (options.indent) { + var lines = result.split('\n'); + for (var i = 0, l = lines.length; i < l; i++) { + if (!lines[i] && i + 1 === l) { + break; + } + + lines[i] = options.indent + lines[i]; + } + result = lines.join('\n'); + } + return result; + } else { + throw new _exception2['default']('The partial ' + options.name + ' could not be compiled when running in runtime-only mode'); + } + } + + // Just add water + var container = { + strict: function strict(obj, name) { + if (!(name in obj)) { + throw new _exception2['default']('"' + name + '" not defined in ' + obj); + } + return obj[name]; + }, + lookup: function lookup(depths, name) { + var len = depths.length; + for (var i = 0; i < len; i++) { + if (depths[i] && depths[i][name] != null) { + return depths[i][name]; + } + } + }, + lambda: function lambda(current, context) { + return typeof current === 'function' ? current.call(context) : current; + }, + + escapeExpression: Utils.escapeExpression, + invokePartial: invokePartialWrapper, + + fn: function fn(i) { + var ret = templateSpec[i]; + ret.decorator = templateSpec[i + '_d']; + return ret; + }, + + programs: [], + program: function program(i, data, declaredBlockParams, blockParams, depths) { + var programWrapper = this.programs[i], + fn = this.fn(i); + if (data || depths || blockParams || declaredBlockParams) { + programWrapper = wrapProgram(this, i, fn, data, declaredBlockParams, blockParams, depths); + } else if (!programWrapper) { + programWrapper = this.programs[i] = wrapProgram(this, i, fn); + } + return programWrapper; + }, + + data: function data(value, depth) { + while (value && depth--) { + value = value._parent; + } + return value; + }, + merge: function merge(param, common) { + var obj = param || common; + + if (param && common && param !== common) { + obj = Utils.extend({}, common, param); + } + + return obj; + }, + + noop: env.VM.noop, + compilerInfo: templateSpec.compiler + }; + + function ret(context) { + var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + var data = options.data; + + ret._setup(options); + if (!options.partial && templateSpec.useData) { + data = initData(context, data); + } + var depths = undefined, + blockParams = templateSpec.useBlockParams ? [] : undefined; + if (templateSpec.useDepths) { + if (options.depths) { + depths = context !== options.depths[0] ? [context].concat(options.depths) : options.depths; + } else { + depths = [context]; + } + } + + function main(context /*, options*/) { + return '' + templateSpec.main(container, context, container.helpers, container.partials, data, blockParams, depths); + } + main = executeDecorators(templateSpec.main, main, container, options.depths || [], data, blockParams); + return main(context, options); + } + ret.isTop = true; + + ret._setup = function (options) { + if (!options.partial) { + container.helpers = container.merge(options.helpers, env.helpers); + + if (templateSpec.usePartial) { + container.partials = container.merge(options.partials, env.partials); + } + if (templateSpec.usePartial || templateSpec.useDecorators) { + container.decorators = container.merge(options.decorators, env.decorators); + } + } else { + container.helpers = options.helpers; + container.partials = options.partials; + container.decorators = options.decorators; + } + }; + + ret._child = function (i, data, blockParams, depths) { + if (templateSpec.useBlockParams && !blockParams) { + throw new _exception2['default']('must pass block params'); + } + if (templateSpec.useDepths && !depths) { + throw new _exception2['default']('must pass parent depths'); + } + + return wrapProgram(container, i, templateSpec[i], data, 0, blockParams, depths); + }; + return ret; + } + + function wrapProgram(container, i, fn, data, declaredBlockParams, blockParams, depths) { + function prog(context) { + var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + var currentDepths = depths; + if (depths && context !== depths[0]) { + currentDepths = [context].concat(depths); + } + + return fn(container, context, container.helpers, container.partials, options.data || data, blockParams && [options.blockParams].concat(blockParams), currentDepths); + } + + prog = executeDecorators(fn, prog, container, depths, data, blockParams); + + prog.program = i; + prog.depth = depths ? depths.length : 0; + prog.blockParams = declaredBlockParams || 0; + return prog; + } + + function resolvePartial(partial, context, options) { + if (!partial) { + if (options.name === '@partial-block') { + partial = options.data['partial-block']; + } else { + partial = options.partials[options.name]; + } + } else if (!partial.call && !options.name) { + // This is a dynamic partial that returned a string + options.name = partial; + partial = options.partials[partial]; + } + return partial; + } + + function invokePartial(partial, context, options) { + options.partial = true; + if (options.ids) { + options.data.contextPath = options.ids[0] || options.data.contextPath; + } + + var partialBlock = undefined; + if (options.fn && options.fn !== noop) { + options.data = _base.createFrame(options.data); + partialBlock = options.data['partial-block'] = options.fn; + + if (partialBlock.partials) { + options.partials = Utils.extend({}, options.partials, partialBlock.partials); + } + } + + if (partial === undefined && partialBlock) { + partial = partialBlock; + } + + if (partial === undefined) { + throw new _exception2['default']('The partial ' + options.name + ' could not be found'); + } else if (partial instanceof Function) { + return partial(context, options); + } + } + + function noop() { + return ''; + } + + function initData(context, data) { + if (!data || !('root' in data)) { + data = data ? _base.createFrame(data) : {}; + data.root = context; + } + return data; + } + + function executeDecorators(fn, prog, container, depths, data, blockParams) { + if (fn.decorator) { + var props = {}; + prog = fn.decorator(prog, props, container, depths && depths[0], data, blockParams, depths); + Utils.extend(prog, props); + } + return prog; + } + +/***/ }, +/* 20 */ +/***/ function(module, exports) { + + /* WEBPACK VAR INJECTION */(function(global) {/* global window */ + 'use strict'; + + exports.__esModule = true; + + exports['default'] = function (Handlebars) { + /* istanbul ignore next */ + var root = typeof global !== 'undefined' ? global : window, + $Handlebars = root.Handlebars; + /* istanbul ignore next */ + Handlebars.noConflict = function () { + if (root.Handlebars === Handlebars) { + root.Handlebars = $Handlebars; + } + return Handlebars; + }; + }; + + module.exports = exports['default']; + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 21 */ +/***/ function(module, exports) { + + 'use strict'; + + exports.__esModule = true; + var AST = { + // Public API used to evaluate derived attributes regarding AST nodes + helpers: { + // a mustache is definitely a helper if: + // * it is an eligible helper, and + // * it has at least one parameter or hash segment + helperExpression: function helperExpression(node) { + return node.type === 'SubExpression' || (node.type === 'MustacheStatement' || node.type === 'BlockStatement') && !!(node.params && node.params.length || node.hash); + }, + + scopedId: function scopedId(path) { + return (/^\.|this\b/.test(path.original) + ); + }, + + // an ID is simple if it only has one part, and that part is not + // `..` or `this`. + simpleId: function simpleId(path) { + return path.parts.length === 1 && !AST.helpers.scopedId(path) && !path.depth; + } + } + }; + + // Must be exported as an object rather than the root of the module as the jison lexer + // must modify the object to operate properly. + exports['default'] = AST; + module.exports = exports['default']; + +/***/ }, +/* 22 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + var _interopRequireWildcard = __webpack_require__(3)['default']; + + exports.__esModule = true; + exports.parse = parse; + + var _parser = __webpack_require__(23); + + var _parser2 = _interopRequireDefault(_parser); + + var _whitespaceControl = __webpack_require__(24); + + var _whitespaceControl2 = _interopRequireDefault(_whitespaceControl); + + var _helpers = __webpack_require__(26); + + var Helpers = _interopRequireWildcard(_helpers); + + var _utils = __webpack_require__(5); + + exports.parser = _parser2['default']; + + var yy = {}; + _utils.extend(yy, Helpers); + + function parse(input, options) { + // Just return if an already-compiled AST was passed in. + if (input.type === 'Program') { + return input; + } + + _parser2['default'].yy = yy; + + // Altering the shared object here, but this is ok as parser is a sync operation + yy.locInfo = function (locInfo) { + return new yy.SourceLocation(options && options.srcName, locInfo); + }; + + var strip = new _whitespaceControl2['default'](options); + return strip.accept(_parser2['default'].parse(input)); + } + +/***/ }, +/* 23 */ +/***/ function(module, exports) { + + /* istanbul ignore next */ + /* Jison generated parser */ + "use strict"; + + var handlebars = (function () { + var parser = { trace: function trace() {}, + yy: {}, + symbols_: { "error": 2, "root": 3, "program": 4, "EOF": 5, "program_repetition0": 6, "statement": 7, "mustache": 8, "block": 9, "rawBlock": 10, "partial": 11, "partialBlock": 12, "content": 13, "COMMENT": 14, "CONTENT": 15, "openRawBlock": 16, "rawBlock_repetition_plus0": 17, "END_RAW_BLOCK": 18, "OPEN_RAW_BLOCK": 19, "helperName": 20, "openRawBlock_repetition0": 21, "openRawBlock_option0": 22, "CLOSE_RAW_BLOCK": 23, "openBlock": 24, "block_option0": 25, "closeBlock": 26, "openInverse": 27, "block_option1": 28, "OPEN_BLOCK": 29, "openBlock_repetition0": 30, "openBlock_option0": 31, "openBlock_option1": 32, "CLOSE": 33, "OPEN_INVERSE": 34, "openInverse_repetition0": 35, "openInverse_option0": 36, "openInverse_option1": 37, "openInverseChain": 38, "OPEN_INVERSE_CHAIN": 39, "openInverseChain_repetition0": 40, "openInverseChain_option0": 41, "openInverseChain_option1": 42, "inverseAndProgram": 43, "INVERSE": 44, "inverseChain": 45, "inverseChain_option0": 46, "OPEN_ENDBLOCK": 47, "OPEN": 48, "mustache_repetition0": 49, "mustache_option0": 50, "OPEN_UNESCAPED": 51, "mustache_repetition1": 52, "mustache_option1": 53, "CLOSE_UNESCAPED": 54, "OPEN_PARTIAL": 55, "partialName": 56, "partial_repetition0": 57, "partial_option0": 58, "openPartialBlock": 59, "OPEN_PARTIAL_BLOCK": 60, "openPartialBlock_repetition0": 61, "openPartialBlock_option0": 62, "param": 63, "sexpr": 64, "OPEN_SEXPR": 65, "sexpr_repetition0": 66, "sexpr_option0": 67, "CLOSE_SEXPR": 68, "hash": 69, "hash_repetition_plus0": 70, "hashSegment": 71, "ID": 72, "EQUALS": 73, "blockParams": 74, "OPEN_BLOCK_PARAMS": 75, "blockParams_repetition_plus0": 76, "CLOSE_BLOCK_PARAMS": 77, "path": 78, "dataName": 79, "STRING": 80, "NUMBER": 81, "BOOLEAN": 82, "UNDEFINED": 83, "NULL": 84, "DATA": 85, "pathSegments": 86, "SEP": 87, "$accept": 0, "$end": 1 }, + terminals_: { 2: "error", 5: "EOF", 14: "COMMENT", 15: "CONTENT", 18: "END_RAW_BLOCK", 19: "OPEN_RAW_BLOCK", 23: "CLOSE_RAW_BLOCK", 29: "OPEN_BLOCK", 33: "CLOSE", 34: "OPEN_INVERSE", 39: "OPEN_INVERSE_CHAIN", 44: "INVERSE", 47: "OPEN_ENDBLOCK", 48: "OPEN", 51: "OPEN_UNESCAPED", 54: "CLOSE_UNESCAPED", 55: "OPEN_PARTIAL", 60: "OPEN_PARTIAL_BLOCK", 65: "OPEN_SEXPR", 68: "CLOSE_SEXPR", 72: "ID", 73: "EQUALS", 75: "OPEN_BLOCK_PARAMS", 77: "CLOSE_BLOCK_PARAMS", 80: "STRING", 81: "NUMBER", 82: "BOOLEAN", 83: "UNDEFINED", 84: "NULL", 85: "DATA", 87: "SEP" }, + productions_: [0, [3, 2], [4, 1], [7, 1], [7, 1], [7, 1], [7, 1], [7, 1], [7, 1], [7, 1], [13, 1], [10, 3], [16, 5], [9, 4], [9, 4], [24, 6], [27, 6], [38, 6], [43, 2], [45, 3], [45, 1], [26, 3], [8, 5], [8, 5], [11, 5], [12, 3], [59, 5], [63, 1], [63, 1], [64, 5], [69, 1], [71, 3], [74, 3], [20, 1], [20, 1], [20, 1], [20, 1], [20, 1], [20, 1], [20, 1], [56, 1], [56, 1], [79, 2], [78, 1], [86, 3], [86, 1], [6, 0], [6, 2], [17, 1], [17, 2], [21, 0], [21, 2], [22, 0], [22, 1], [25, 0], [25, 1], [28, 0], [28, 1], [30, 0], [30, 2], [31, 0], [31, 1], [32, 0], [32, 1], [35, 0], [35, 2], [36, 0], [36, 1], [37, 0], [37, 1], [40, 0], [40, 2], [41, 0], [41, 1], [42, 0], [42, 1], [46, 0], [46, 1], [49, 0], [49, 2], [50, 0], [50, 1], [52, 0], [52, 2], [53, 0], [53, 1], [57, 0], [57, 2], [58, 0], [58, 1], [61, 0], [61, 2], [62, 0], [62, 1], [66, 0], [66, 2], [67, 0], [67, 1], [70, 1], [70, 2], [76, 1], [76, 2]], + performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$ + /**/) { + + var $0 = $$.length - 1; + switch (yystate) { + case 1: + return $$[$0 - 1]; + break; + case 2: + this.$ = yy.prepareProgram($$[$0]); + break; + case 3: + this.$ = $$[$0]; + break; + case 4: + this.$ = $$[$0]; + break; + case 5: + this.$ = $$[$0]; + break; + case 6: + this.$ = $$[$0]; + break; + case 7: + this.$ = $$[$0]; + break; + case 8: + this.$ = $$[$0]; + break; + case 9: + this.$ = { + type: 'CommentStatement', + value: yy.stripComment($$[$0]), + strip: yy.stripFlags($$[$0], $$[$0]), + loc: yy.locInfo(this._$) + }; + + break; + case 10: + this.$ = { + type: 'ContentStatement', + original: $$[$0], + value: $$[$0], + loc: yy.locInfo(this._$) + }; + + break; + case 11: + this.$ = yy.prepareRawBlock($$[$0 - 2], $$[$0 - 1], $$[$0], this._$); + break; + case 12: + this.$ = { path: $$[$0 - 3], params: $$[$0 - 2], hash: $$[$0 - 1] }; + break; + case 13: + this.$ = yy.prepareBlock($$[$0 - 3], $$[$0 - 2], $$[$0 - 1], $$[$0], false, this._$); + break; + case 14: + this.$ = yy.prepareBlock($$[$0 - 3], $$[$0 - 2], $$[$0 - 1], $$[$0], true, this._$); + break; + case 15: + this.$ = { open: $$[$0 - 5], path: $$[$0 - 4], params: $$[$0 - 3], hash: $$[$0 - 2], blockParams: $$[$0 - 1], strip: yy.stripFlags($$[$0 - 5], $$[$0]) }; + break; + case 16: + this.$ = { path: $$[$0 - 4], params: $$[$0 - 3], hash: $$[$0 - 2], blockParams: $$[$0 - 1], strip: yy.stripFlags($$[$0 - 5], $$[$0]) }; + break; + case 17: + this.$ = { path: $$[$0 - 4], params: $$[$0 - 3], hash: $$[$0 - 2], blockParams: $$[$0 - 1], strip: yy.stripFlags($$[$0 - 5], $$[$0]) }; + break; + case 18: + this.$ = { strip: yy.stripFlags($$[$0 - 1], $$[$0 - 1]), program: $$[$0] }; + break; + case 19: + var inverse = yy.prepareBlock($$[$0 - 2], $$[$0 - 1], $$[$0], $$[$0], false, this._$), + program = yy.prepareProgram([inverse], $$[$0 - 1].loc); + program.chained = true; + + this.$ = { strip: $$[$0 - 2].strip, program: program, chain: true }; + + break; + case 20: + this.$ = $$[$0]; + break; + case 21: + this.$ = { path: $$[$0 - 1], strip: yy.stripFlags($$[$0 - 2], $$[$0]) }; + break; + case 22: + this.$ = yy.prepareMustache($$[$0 - 3], $$[$0 - 2], $$[$0 - 1], $$[$0 - 4], yy.stripFlags($$[$0 - 4], $$[$0]), this._$); + break; + case 23: + this.$ = yy.prepareMustache($$[$0 - 3], $$[$0 - 2], $$[$0 - 1], $$[$0 - 4], yy.stripFlags($$[$0 - 4], $$[$0]), this._$); + break; + case 24: + this.$ = { + type: 'PartialStatement', + name: $$[$0 - 3], + params: $$[$0 - 2], + hash: $$[$0 - 1], + indent: '', + strip: yy.stripFlags($$[$0 - 4], $$[$0]), + loc: yy.locInfo(this._$) + }; + + break; + case 25: + this.$ = yy.preparePartialBlock($$[$0 - 2], $$[$0 - 1], $$[$0], this._$); + break; + case 26: + this.$ = { path: $$[$0 - 3], params: $$[$0 - 2], hash: $$[$0 - 1], strip: yy.stripFlags($$[$0 - 4], $$[$0]) }; + break; + case 27: + this.$ = $$[$0]; + break; + case 28: + this.$ = $$[$0]; + break; + case 29: + this.$ = { + type: 'SubExpression', + path: $$[$0 - 3], + params: $$[$0 - 2], + hash: $$[$0 - 1], + loc: yy.locInfo(this._$) + }; + + break; + case 30: + this.$ = { type: 'Hash', pairs: $$[$0], loc: yy.locInfo(this._$) }; + break; + case 31: + this.$ = { type: 'HashPair', key: yy.id($$[$0 - 2]), value: $$[$0], loc: yy.locInfo(this._$) }; + break; + case 32: + this.$ = yy.id($$[$0 - 1]); + break; + case 33: + this.$ = $$[$0]; + break; + case 34: + this.$ = $$[$0]; + break; + case 35: + this.$ = { type: 'StringLiteral', value: $$[$0], original: $$[$0], loc: yy.locInfo(this._$) }; + break; + case 36: + this.$ = { type: 'NumberLiteral', value: Number($$[$0]), original: Number($$[$0]), loc: yy.locInfo(this._$) }; + break; + case 37: + this.$ = { type: 'BooleanLiteral', value: $$[$0] === 'true', original: $$[$0] === 'true', loc: yy.locInfo(this._$) }; + break; + case 38: + this.$ = { type: 'UndefinedLiteral', original: undefined, value: undefined, loc: yy.locInfo(this._$) }; + break; + case 39: + this.$ = { type: 'NullLiteral', original: null, value: null, loc: yy.locInfo(this._$) }; + break; + case 40: + this.$ = $$[$0]; + break; + case 41: + this.$ = $$[$0]; + break; + case 42: + this.$ = yy.preparePath(true, $$[$0], this._$); + break; + case 43: + this.$ = yy.preparePath(false, $$[$0], this._$); + break; + case 44: + $$[$0 - 2].push({ part: yy.id($$[$0]), original: $$[$0], separator: $$[$0 - 1] });this.$ = $$[$0 - 2]; + break; + case 45: + this.$ = [{ part: yy.id($$[$0]), original: $$[$0] }]; + break; + case 46: + this.$ = []; + break; + case 47: + $$[$0 - 1].push($$[$0]); + break; + case 48: + this.$ = [$$[$0]]; + break; + case 49: + $$[$0 - 1].push($$[$0]); + break; + case 50: + this.$ = []; + break; + case 51: + $$[$0 - 1].push($$[$0]); + break; + case 58: + this.$ = []; + break; + case 59: + $$[$0 - 1].push($$[$0]); + break; + case 64: + this.$ = []; + break; + case 65: + $$[$0 - 1].push($$[$0]); + break; + case 70: + this.$ = []; + break; + case 71: + $$[$0 - 1].push($$[$0]); + break; + case 78: + this.$ = []; + break; + case 79: + $$[$0 - 1].push($$[$0]); + break; + case 82: + this.$ = []; + break; + case 83: + $$[$0 - 1].push($$[$0]); + break; + case 86: + this.$ = []; + break; + case 87: + $$[$0 - 1].push($$[$0]); + break; + case 90: + this.$ = []; + break; + case 91: + $$[$0 - 1].push($$[$0]); + break; + case 94: + this.$ = []; + break; + case 95: + $$[$0 - 1].push($$[$0]); + break; + case 98: + this.$ = [$$[$0]]; + break; + case 99: + $$[$0 - 1].push($$[$0]); + break; + case 100: + this.$ = [$$[$0]]; + break; + case 101: + $$[$0 - 1].push($$[$0]); + break; + } + }, + table: [{ 3: 1, 4: 2, 5: [2, 46], 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 1: [3] }, { 5: [1, 4] }, { 5: [2, 2], 7: 5, 8: 6, 9: 7, 10: 8, 11: 9, 12: 10, 13: 11, 14: [1, 12], 15: [1, 20], 16: 17, 19: [1, 23], 24: 15, 27: 16, 29: [1, 21], 34: [1, 22], 39: [2, 2], 44: [2, 2], 47: [2, 2], 48: [1, 13], 51: [1, 14], 55: [1, 18], 59: 19, 60: [1, 24] }, { 1: [2, 1] }, { 5: [2, 47], 14: [2, 47], 15: [2, 47], 19: [2, 47], 29: [2, 47], 34: [2, 47], 39: [2, 47], 44: [2, 47], 47: [2, 47], 48: [2, 47], 51: [2, 47], 55: [2, 47], 60: [2, 47] }, { 5: [2, 3], 14: [2, 3], 15: [2, 3], 19: [2, 3], 29: [2, 3], 34: [2, 3], 39: [2, 3], 44: [2, 3], 47: [2, 3], 48: [2, 3], 51: [2, 3], 55: [2, 3], 60: [2, 3] }, { 5: [2, 4], 14: [2, 4], 15: [2, 4], 19: [2, 4], 29: [2, 4], 34: [2, 4], 39: [2, 4], 44: [2, 4], 47: [2, 4], 48: [2, 4], 51: [2, 4], 55: [2, 4], 60: [2, 4] }, { 5: [2, 5], 14: [2, 5], 15: [2, 5], 19: [2, 5], 29: [2, 5], 34: [2, 5], 39: [2, 5], 44: [2, 5], 47: [2, 5], 48: [2, 5], 51: [2, 5], 55: [2, 5], 60: [2, 5] }, { 5: [2, 6], 14: [2, 6], 15: [2, 6], 19: [2, 6], 29: [2, 6], 34: [2, 6], 39: [2, 6], 44: [2, 6], 47: [2, 6], 48: [2, 6], 51: [2, 6], 55: [2, 6], 60: [2, 6] }, { 5: [2, 7], 14: [2, 7], 15: [2, 7], 19: [2, 7], 29: [2, 7], 34: [2, 7], 39: [2, 7], 44: [2, 7], 47: [2, 7], 48: [2, 7], 51: [2, 7], 55: [2, 7], 60: [2, 7] }, { 5: [2, 8], 14: [2, 8], 15: [2, 8], 19: [2, 8], 29: [2, 8], 34: [2, 8], 39: [2, 8], 44: [2, 8], 47: [2, 8], 48: [2, 8], 51: [2, 8], 55: [2, 8], 60: [2, 8] }, { 5: [2, 9], 14: [2, 9], 15: [2, 9], 19: [2, 9], 29: [2, 9], 34: [2, 9], 39: [2, 9], 44: [2, 9], 47: [2, 9], 48: [2, 9], 51: [2, 9], 55: [2, 9], 60: [2, 9] }, { 20: 25, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 36, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 4: 37, 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 39: [2, 46], 44: [2, 46], 47: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 4: 38, 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 44: [2, 46], 47: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 13: 40, 15: [1, 20], 17: 39 }, { 20: 42, 56: 41, 64: 43, 65: [1, 44], 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 4: 45, 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 47: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 5: [2, 10], 14: [2, 10], 15: [2, 10], 18: [2, 10], 19: [2, 10], 29: [2, 10], 34: [2, 10], 39: [2, 10], 44: [2, 10], 47: [2, 10], 48: [2, 10], 51: [2, 10], 55: [2, 10], 60: [2, 10] }, { 20: 46, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 47, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 48, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 42, 56: 49, 64: 43, 65: [1, 44], 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 33: [2, 78], 49: 50, 65: [2, 78], 72: [2, 78], 80: [2, 78], 81: [2, 78], 82: [2, 78], 83: [2, 78], 84: [2, 78], 85: [2, 78] }, { 23: [2, 33], 33: [2, 33], 54: [2, 33], 65: [2, 33], 68: [2, 33], 72: [2, 33], 75: [2, 33], 80: [2, 33], 81: [2, 33], 82: [2, 33], 83: [2, 33], 84: [2, 33], 85: [2, 33] }, { 23: [2, 34], 33: [2, 34], 54: [2, 34], 65: [2, 34], 68: [2, 34], 72: [2, 34], 75: [2, 34], 80: [2, 34], 81: [2, 34], 82: [2, 34], 83: [2, 34], 84: [2, 34], 85: [2, 34] }, { 23: [2, 35], 33: [2, 35], 54: [2, 35], 65: [2, 35], 68: [2, 35], 72: [2, 35], 75: [2, 35], 80: [2, 35], 81: [2, 35], 82: [2, 35], 83: [2, 35], 84: [2, 35], 85: [2, 35] }, { 23: [2, 36], 33: [2, 36], 54: [2, 36], 65: [2, 36], 68: [2, 36], 72: [2, 36], 75: [2, 36], 80: [2, 36], 81: [2, 36], 82: [2, 36], 83: [2, 36], 84: [2, 36], 85: [2, 36] }, { 23: [2, 37], 33: [2, 37], 54: [2, 37], 65: [2, 37], 68: [2, 37], 72: [2, 37], 75: [2, 37], 80: [2, 37], 81: [2, 37], 82: [2, 37], 83: [2, 37], 84: [2, 37], 85: [2, 37] }, { 23: [2, 38], 33: [2, 38], 54: [2, 38], 65: [2, 38], 68: [2, 38], 72: [2, 38], 75: [2, 38], 80: [2, 38], 81: [2, 38], 82: [2, 38], 83: [2, 38], 84: [2, 38], 85: [2, 38] }, { 23: [2, 39], 33: [2, 39], 54: [2, 39], 65: [2, 39], 68: [2, 39], 72: [2, 39], 75: [2, 39], 80: [2, 39], 81: [2, 39], 82: [2, 39], 83: [2, 39], 84: [2, 39], 85: [2, 39] }, { 23: [2, 43], 33: [2, 43], 54: [2, 43], 65: [2, 43], 68: [2, 43], 72: [2, 43], 75: [2, 43], 80: [2, 43], 81: [2, 43], 82: [2, 43], 83: [2, 43], 84: [2, 43], 85: [2, 43], 87: [1, 51] }, { 72: [1, 35], 86: 52 }, { 23: [2, 45], 33: [2, 45], 54: [2, 45], 65: [2, 45], 68: [2, 45], 72: [2, 45], 75: [2, 45], 80: [2, 45], 81: [2, 45], 82: [2, 45], 83: [2, 45], 84: [2, 45], 85: [2, 45], 87: [2, 45] }, { 52: 53, 54: [2, 82], 65: [2, 82], 72: [2, 82], 80: [2, 82], 81: [2, 82], 82: [2, 82], 83: [2, 82], 84: [2, 82], 85: [2, 82] }, { 25: 54, 38: 56, 39: [1, 58], 43: 57, 44: [1, 59], 45: 55, 47: [2, 54] }, { 28: 60, 43: 61, 44: [1, 59], 47: [2, 56] }, { 13: 63, 15: [1, 20], 18: [1, 62] }, { 15: [2, 48], 18: [2, 48] }, { 33: [2, 86], 57: 64, 65: [2, 86], 72: [2, 86], 80: [2, 86], 81: [2, 86], 82: [2, 86], 83: [2, 86], 84: [2, 86], 85: [2, 86] }, { 33: [2, 40], 65: [2, 40], 72: [2, 40], 80: [2, 40], 81: [2, 40], 82: [2, 40], 83: [2, 40], 84: [2, 40], 85: [2, 40] }, { 33: [2, 41], 65: [2, 41], 72: [2, 41], 80: [2, 41], 81: [2, 41], 82: [2, 41], 83: [2, 41], 84: [2, 41], 85: [2, 41] }, { 20: 65, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 26: 66, 47: [1, 67] }, { 30: 68, 33: [2, 58], 65: [2, 58], 72: [2, 58], 75: [2, 58], 80: [2, 58], 81: [2, 58], 82: [2, 58], 83: [2, 58], 84: [2, 58], 85: [2, 58] }, { 33: [2, 64], 35: 69, 65: [2, 64], 72: [2, 64], 75: [2, 64], 80: [2, 64], 81: [2, 64], 82: [2, 64], 83: [2, 64], 84: [2, 64], 85: [2, 64] }, { 21: 70, 23: [2, 50], 65: [2, 50], 72: [2, 50], 80: [2, 50], 81: [2, 50], 82: [2, 50], 83: [2, 50], 84: [2, 50], 85: [2, 50] }, { 33: [2, 90], 61: 71, 65: [2, 90], 72: [2, 90], 80: [2, 90], 81: [2, 90], 82: [2, 90], 83: [2, 90], 84: [2, 90], 85: [2, 90] }, { 20: 75, 33: [2, 80], 50: 72, 63: 73, 64: 76, 65: [1, 44], 69: 74, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 72: [1, 80] }, { 23: [2, 42], 33: [2, 42], 54: [2, 42], 65: [2, 42], 68: [2, 42], 72: [2, 42], 75: [2, 42], 80: [2, 42], 81: [2, 42], 82: [2, 42], 83: [2, 42], 84: [2, 42], 85: [2, 42], 87: [1, 51] }, { 20: 75, 53: 81, 54: [2, 84], 63: 82, 64: 76, 65: [1, 44], 69: 83, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 26: 84, 47: [1, 67] }, { 47: [2, 55] }, { 4: 85, 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 39: [2, 46], 44: [2, 46], 47: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 47: [2, 20] }, { 20: 86, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 4: 87, 6: 3, 14: [2, 46], 15: [2, 46], 19: [2, 46], 29: [2, 46], 34: [2, 46], 47: [2, 46], 48: [2, 46], 51: [2, 46], 55: [2, 46], 60: [2, 46] }, { 26: 88, 47: [1, 67] }, { 47: [2, 57] }, { 5: [2, 11], 14: [2, 11], 15: [2, 11], 19: [2, 11], 29: [2, 11], 34: [2, 11], 39: [2, 11], 44: [2, 11], 47: [2, 11], 48: [2, 11], 51: [2, 11], 55: [2, 11], 60: [2, 11] }, { 15: [2, 49], 18: [2, 49] }, { 20: 75, 33: [2, 88], 58: 89, 63: 90, 64: 76, 65: [1, 44], 69: 91, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 65: [2, 94], 66: 92, 68: [2, 94], 72: [2, 94], 80: [2, 94], 81: [2, 94], 82: [2, 94], 83: [2, 94], 84: [2, 94], 85: [2, 94] }, { 5: [2, 25], 14: [2, 25], 15: [2, 25], 19: [2, 25], 29: [2, 25], 34: [2, 25], 39: [2, 25], 44: [2, 25], 47: [2, 25], 48: [2, 25], 51: [2, 25], 55: [2, 25], 60: [2, 25] }, { 20: 93, 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 75, 31: 94, 33: [2, 60], 63: 95, 64: 76, 65: [1, 44], 69: 96, 70: 77, 71: 78, 72: [1, 79], 75: [2, 60], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 75, 33: [2, 66], 36: 97, 63: 98, 64: 76, 65: [1, 44], 69: 99, 70: 77, 71: 78, 72: [1, 79], 75: [2, 66], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 75, 22: 100, 23: [2, 52], 63: 101, 64: 76, 65: [1, 44], 69: 102, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 20: 75, 33: [2, 92], 62: 103, 63: 104, 64: 76, 65: [1, 44], 69: 105, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 33: [1, 106] }, { 33: [2, 79], 65: [2, 79], 72: [2, 79], 80: [2, 79], 81: [2, 79], 82: [2, 79], 83: [2, 79], 84: [2, 79], 85: [2, 79] }, { 33: [2, 81] }, { 23: [2, 27], 33: [2, 27], 54: [2, 27], 65: [2, 27], 68: [2, 27], 72: [2, 27], 75: [2, 27], 80: [2, 27], 81: [2, 27], 82: [2, 27], 83: [2, 27], 84: [2, 27], 85: [2, 27] }, { 23: [2, 28], 33: [2, 28], 54: [2, 28], 65: [2, 28], 68: [2, 28], 72: [2, 28], 75: [2, 28], 80: [2, 28], 81: [2, 28], 82: [2, 28], 83: [2, 28], 84: [2, 28], 85: [2, 28] }, { 23: [2, 30], 33: [2, 30], 54: [2, 30], 68: [2, 30], 71: 107, 72: [1, 108], 75: [2, 30] }, { 23: [2, 98], 33: [2, 98], 54: [2, 98], 68: [2, 98], 72: [2, 98], 75: [2, 98] }, { 23: [2, 45], 33: [2, 45], 54: [2, 45], 65: [2, 45], 68: [2, 45], 72: [2, 45], 73: [1, 109], 75: [2, 45], 80: [2, 45], 81: [2, 45], 82: [2, 45], 83: [2, 45], 84: [2, 45], 85: [2, 45], 87: [2, 45] }, { 23: [2, 44], 33: [2, 44], 54: [2, 44], 65: [2, 44], 68: [2, 44], 72: [2, 44], 75: [2, 44], 80: [2, 44], 81: [2, 44], 82: [2, 44], 83: [2, 44], 84: [2, 44], 85: [2, 44], 87: [2, 44] }, { 54: [1, 110] }, { 54: [2, 83], 65: [2, 83], 72: [2, 83], 80: [2, 83], 81: [2, 83], 82: [2, 83], 83: [2, 83], 84: [2, 83], 85: [2, 83] }, { 54: [2, 85] }, { 5: [2, 13], 14: [2, 13], 15: [2, 13], 19: [2, 13], 29: [2, 13], 34: [2, 13], 39: [2, 13], 44: [2, 13], 47: [2, 13], 48: [2, 13], 51: [2, 13], 55: [2, 13], 60: [2, 13] }, { 38: 56, 39: [1, 58], 43: 57, 44: [1, 59], 45: 112, 46: 111, 47: [2, 76] }, { 33: [2, 70], 40: 113, 65: [2, 70], 72: [2, 70], 75: [2, 70], 80: [2, 70], 81: [2, 70], 82: [2, 70], 83: [2, 70], 84: [2, 70], 85: [2, 70] }, { 47: [2, 18] }, { 5: [2, 14], 14: [2, 14], 15: [2, 14], 19: [2, 14], 29: [2, 14], 34: [2, 14], 39: [2, 14], 44: [2, 14], 47: [2, 14], 48: [2, 14], 51: [2, 14], 55: [2, 14], 60: [2, 14] }, { 33: [1, 114] }, { 33: [2, 87], 65: [2, 87], 72: [2, 87], 80: [2, 87], 81: [2, 87], 82: [2, 87], 83: [2, 87], 84: [2, 87], 85: [2, 87] }, { 33: [2, 89] }, { 20: 75, 63: 116, 64: 76, 65: [1, 44], 67: 115, 68: [2, 96], 69: 117, 70: 77, 71: 78, 72: [1, 79], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 33: [1, 118] }, { 32: 119, 33: [2, 62], 74: 120, 75: [1, 121] }, { 33: [2, 59], 65: [2, 59], 72: [2, 59], 75: [2, 59], 80: [2, 59], 81: [2, 59], 82: [2, 59], 83: [2, 59], 84: [2, 59], 85: [2, 59] }, { 33: [2, 61], 75: [2, 61] }, { 33: [2, 68], 37: 122, 74: 123, 75: [1, 121] }, { 33: [2, 65], 65: [2, 65], 72: [2, 65], 75: [2, 65], 80: [2, 65], 81: [2, 65], 82: [2, 65], 83: [2, 65], 84: [2, 65], 85: [2, 65] }, { 33: [2, 67], 75: [2, 67] }, { 23: [1, 124] }, { 23: [2, 51], 65: [2, 51], 72: [2, 51], 80: [2, 51], 81: [2, 51], 82: [2, 51], 83: [2, 51], 84: [2, 51], 85: [2, 51] }, { 23: [2, 53] }, { 33: [1, 125] }, { 33: [2, 91], 65: [2, 91], 72: [2, 91], 80: [2, 91], 81: [2, 91], 82: [2, 91], 83: [2, 91], 84: [2, 91], 85: [2, 91] }, { 33: [2, 93] }, { 5: [2, 22], 14: [2, 22], 15: [2, 22], 19: [2, 22], 29: [2, 22], 34: [2, 22], 39: [2, 22], 44: [2, 22], 47: [2, 22], 48: [2, 22], 51: [2, 22], 55: [2, 22], 60: [2, 22] }, { 23: [2, 99], 33: [2, 99], 54: [2, 99], 68: [2, 99], 72: [2, 99], 75: [2, 99] }, { 73: [1, 109] }, { 20: 75, 63: 126, 64: 76, 65: [1, 44], 72: [1, 35], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 5: [2, 23], 14: [2, 23], 15: [2, 23], 19: [2, 23], 29: [2, 23], 34: [2, 23], 39: [2, 23], 44: [2, 23], 47: [2, 23], 48: [2, 23], 51: [2, 23], 55: [2, 23], 60: [2, 23] }, { 47: [2, 19] }, { 47: [2, 77] }, { 20: 75, 33: [2, 72], 41: 127, 63: 128, 64: 76, 65: [1, 44], 69: 129, 70: 77, 71: 78, 72: [1, 79], 75: [2, 72], 78: 26, 79: 27, 80: [1, 28], 81: [1, 29], 82: [1, 30], 83: [1, 31], 84: [1, 32], 85: [1, 34], 86: 33 }, { 5: [2, 24], 14: [2, 24], 15: [2, 24], 19: [2, 24], 29: [2, 24], 34: [2, 24], 39: [2, 24], 44: [2, 24], 47: [2, 24], 48: [2, 24], 51: [2, 24], 55: [2, 24], 60: [2, 24] }, { 68: [1, 130] }, { 65: [2, 95], 68: [2, 95], 72: [2, 95], 80: [2, 95], 81: [2, 95], 82: [2, 95], 83: [2, 95], 84: [2, 95], 85: [2, 95] }, { 68: [2, 97] }, { 5: [2, 21], 14: [2, 21], 15: [2, 21], 19: [2, 21], 29: [2, 21], 34: [2, 21], 39: [2, 21], 44: [2, 21], 47: [2, 21], 48: [2, 21], 51: [2, 21], 55: [2, 21], 60: [2, 21] }, { 33: [1, 131] }, { 33: [2, 63] }, { 72: [1, 133], 76: 132 }, { 33: [1, 134] }, { 33: [2, 69] }, { 15: [2, 12] }, { 14: [2, 26], 15: [2, 26], 19: [2, 26], 29: [2, 26], 34: [2, 26], 47: [2, 26], 48: [2, 26], 51: [2, 26], 55: [2, 26], 60: [2, 26] }, { 23: [2, 31], 33: [2, 31], 54: [2, 31], 68: [2, 31], 72: [2, 31], 75: [2, 31] }, { 33: [2, 74], 42: 135, 74: 136, 75: [1, 121] }, { 33: [2, 71], 65: [2, 71], 72: [2, 71], 75: [2, 71], 80: [2, 71], 81: [2, 71], 82: [2, 71], 83: [2, 71], 84: [2, 71], 85: [2, 71] }, { 33: [2, 73], 75: [2, 73] }, { 23: [2, 29], 33: [2, 29], 54: [2, 29], 65: [2, 29], 68: [2, 29], 72: [2, 29], 75: [2, 29], 80: [2, 29], 81: [2, 29], 82: [2, 29], 83: [2, 29], 84: [2, 29], 85: [2, 29] }, { 14: [2, 15], 15: [2, 15], 19: [2, 15], 29: [2, 15], 34: [2, 15], 39: [2, 15], 44: [2, 15], 47: [2, 15], 48: [2, 15], 51: [2, 15], 55: [2, 15], 60: [2, 15] }, { 72: [1, 138], 77: [1, 137] }, { 72: [2, 100], 77: [2, 100] }, { 14: [2, 16], 15: [2, 16], 19: [2, 16], 29: [2, 16], 34: [2, 16], 44: [2, 16], 47: [2, 16], 48: [2, 16], 51: [2, 16], 55: [2, 16], 60: [2, 16] }, { 33: [1, 139] }, { 33: [2, 75] }, { 33: [2, 32] }, { 72: [2, 101], 77: [2, 101] }, { 14: [2, 17], 15: [2, 17], 19: [2, 17], 29: [2, 17], 34: [2, 17], 39: [2, 17], 44: [2, 17], 47: [2, 17], 48: [2, 17], 51: [2, 17], 55: [2, 17], 60: [2, 17] }], + defaultActions: { 4: [2, 1], 55: [2, 55], 57: [2, 20], 61: [2, 57], 74: [2, 81], 83: [2, 85], 87: [2, 18], 91: [2, 89], 102: [2, 53], 105: [2, 93], 111: [2, 19], 112: [2, 77], 117: [2, 97], 120: [2, 63], 123: [2, 69], 124: [2, 12], 136: [2, 75], 137: [2, 32] }, + parseError: function parseError(str, hash) { + throw new Error(str); + }, + parse: function parse(input) { + var self = this, + stack = [0], + vstack = [null], + lstack = [], + table = this.table, + yytext = "", + yylineno = 0, + yyleng = 0, + recovering = 0, + TERROR = 2, + EOF = 1; + this.lexer.setInput(input); + this.lexer.yy = this.yy; + this.yy.lexer = this.lexer; + this.yy.parser = this; + if (typeof this.lexer.yylloc == "undefined") this.lexer.yylloc = {}; + var yyloc = this.lexer.yylloc; + lstack.push(yyloc); + var ranges = this.lexer.options && this.lexer.options.ranges; + if (typeof this.yy.parseError === "function") this.parseError = this.yy.parseError; + function popStack(n) { + stack.length = stack.length - 2 * n; + vstack.length = vstack.length - n; + lstack.length = lstack.length - n; + } + function lex() { + var token; + token = self.lexer.lex() || 1; + if (typeof token !== "number") { + token = self.symbols_[token] || token; + } + return token; + } + var symbol, + preErrorSymbol, + state, + action, + a, + r, + yyval = {}, + p, + len, + newState, + expected; + while (true) { + state = stack[stack.length - 1]; + if (this.defaultActions[state]) { + action = this.defaultActions[state]; + } else { + if (symbol === null || typeof symbol == "undefined") { + symbol = lex(); + } + action = table[state] && table[state][symbol]; + } + if (typeof action === "undefined" || !action.length || !action[0]) { + var errStr = ""; + if (!recovering) { + expected = []; + for (p in table[state]) if (this.terminals_[p] && p > 2) { + expected.push("'" + this.terminals_[p] + "'"); + } + if (this.lexer.showPosition) { + errStr = "Parse error on line " + (yylineno + 1) + ":\n" + this.lexer.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'"; + } else { + errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == 1 ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'"); + } + this.parseError(errStr, { text: this.lexer.match, token: this.terminals_[symbol] || symbol, line: this.lexer.yylineno, loc: yyloc, expected: expected }); + } + } + if (action[0] instanceof Array && action.length > 1) { + throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol); + } + switch (action[0]) { + case 1: + stack.push(symbol); + vstack.push(this.lexer.yytext); + lstack.push(this.lexer.yylloc); + stack.push(action[1]); + symbol = null; + if (!preErrorSymbol) { + yyleng = this.lexer.yyleng; + yytext = this.lexer.yytext; + yylineno = this.lexer.yylineno; + yyloc = this.lexer.yylloc; + if (recovering > 0) recovering--; + } else { + symbol = preErrorSymbol; + preErrorSymbol = null; + } + break; + case 2: + len = this.productions_[action[1]][1]; + yyval.$ = vstack[vstack.length - len]; + yyval._$ = { first_line: lstack[lstack.length - (len || 1)].first_line, last_line: lstack[lstack.length - 1].last_line, first_column: lstack[lstack.length - (len || 1)].first_column, last_column: lstack[lstack.length - 1].last_column }; + if (ranges) { + yyval._$.range = [lstack[lstack.length - (len || 1)].range[0], lstack[lstack.length - 1].range[1]]; + } + r = this.performAction.call(yyval, yytext, yyleng, yylineno, this.yy, action[1], vstack, lstack); + if (typeof r !== "undefined") { + return r; + } + if (len) { + stack = stack.slice(0, -1 * len * 2); + vstack = vstack.slice(0, -1 * len); + lstack = lstack.slice(0, -1 * len); + } + stack.push(this.productions_[action[1]][0]); + vstack.push(yyval.$); + lstack.push(yyval._$); + newState = table[stack[stack.length - 2]][stack[stack.length - 1]]; + stack.push(newState); + break; + case 3: + return true; + } + } + return true; + } + }; + /* Jison generated lexer */ + var lexer = (function () { + var lexer = { EOF: 1, + parseError: function parseError(str, hash) { + if (this.yy.parser) { + this.yy.parser.parseError(str, hash); + } else { + throw new Error(str); + } + }, + setInput: function setInput(input) { + this._input = input; + this._more = this._less = this.done = false; + this.yylineno = this.yyleng = 0; + this.yytext = this.matched = this.match = ''; + this.conditionStack = ['INITIAL']; + this.yylloc = { first_line: 1, first_column: 0, last_line: 1, last_column: 0 }; + if (this.options.ranges) this.yylloc.range = [0, 0]; + this.offset = 0; + return this; + }, + input: function input() { + var ch = this._input[0]; + this.yytext += ch; + this.yyleng++; + this.offset++; + this.match += ch; + this.matched += ch; + var lines = ch.match(/(?:\r\n?|\n).*/g); + if (lines) { + this.yylineno++; + this.yylloc.last_line++; + } else { + this.yylloc.last_column++; + } + if (this.options.ranges) this.yylloc.range[1]++; + + this._input = this._input.slice(1); + return ch; + }, + unput: function unput(ch) { + var len = ch.length; + var lines = ch.split(/(?:\r\n?|\n)/g); + + this._input = ch + this._input; + this.yytext = this.yytext.substr(0, this.yytext.length - len - 1); + //this.yyleng -= len; + this.offset -= len; + var oldLines = this.match.split(/(?:\r\n?|\n)/g); + this.match = this.match.substr(0, this.match.length - 1); + this.matched = this.matched.substr(0, this.matched.length - 1); + + if (lines.length - 1) this.yylineno -= lines.length - 1; + var r = this.yylloc.range; + + this.yylloc = { first_line: this.yylloc.first_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.first_column, + last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len + }; + + if (this.options.ranges) { + this.yylloc.range = [r[0], r[0] + this.yyleng - len]; + } + return this; + }, + more: function more() { + this._more = true; + return this; + }, + less: function less(n) { + this.unput(this.match.slice(n)); + }, + pastInput: function pastInput() { + var past = this.matched.substr(0, this.matched.length - this.match.length); + return (past.length > 20 ? '...' : '') + past.substr(-20).replace(/\n/g, ""); + }, + upcomingInput: function upcomingInput() { + var next = this.match; + if (next.length < 20) { + next += this._input.substr(0, 20 - next.length); + } + return (next.substr(0, 20) + (next.length > 20 ? '...' : '')).replace(/\n/g, ""); + }, + showPosition: function showPosition() { + var pre = this.pastInput(); + var c = new Array(pre.length + 1).join("-"); + return pre + this.upcomingInput() + "\n" + c + "^"; + }, + next: function next() { + if (this.done) { + return this.EOF; + } + if (!this._input) this.done = true; + + var token, match, tempMatch, index, col, lines; + if (!this._more) { + this.yytext = ''; + this.match = ''; + } + var rules = this._currentRules(); + for (var i = 0; i < rules.length; i++) { + tempMatch = this._input.match(this.rules[rules[i]]); + if (tempMatch && (!match || tempMatch[0].length > match[0].length)) { + match = tempMatch; + index = i; + if (!this.options.flex) break; + } + } + if (match) { + lines = match[0].match(/(?:\r\n?|\n).*/g); + if (lines) this.yylineno += lines.length; + this.yylloc = { first_line: this.yylloc.last_line, + last_line: this.yylineno + 1, + first_column: this.yylloc.last_column, + last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length }; + this.yytext += match[0]; + this.match += match[0]; + this.matches = match; + this.yyleng = this.yytext.length; + if (this.options.ranges) { + this.yylloc.range = [this.offset, this.offset += this.yyleng]; + } + this._more = false; + this._input = this._input.slice(match[0].length); + this.matched += match[0]; + token = this.performAction.call(this, this.yy, this, rules[index], this.conditionStack[this.conditionStack.length - 1]); + if (this.done && this._input) this.done = false; + if (token) return token;else return; + } + if (this._input === "") { + return this.EOF; + } else { + return this.parseError('Lexical error on line ' + (this.yylineno + 1) + '. Unrecognized text.\n' + this.showPosition(), { text: "", token: null, line: this.yylineno }); + } + }, + lex: function lex() { + var r = this.next(); + if (typeof r !== 'undefined') { + return r; + } else { + return this.lex(); + } + }, + begin: function begin(condition) { + this.conditionStack.push(condition); + }, + popState: function popState() { + return this.conditionStack.pop(); + }, + _currentRules: function _currentRules() { + return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules; + }, + topState: function topState() { + return this.conditionStack[this.conditionStack.length - 2]; + }, + pushState: function begin(condition) { + this.begin(condition); + } }; + lexer.options = {}; + lexer.performAction = function anonymous(yy, yy_, $avoiding_name_collisions, YY_START + /**/) { + + function strip(start, end) { + return yy_.yytext = yy_.yytext.substr(start, yy_.yyleng - end); + } + + var YYSTATE = YY_START; + switch ($avoiding_name_collisions) { + case 0: + if (yy_.yytext.slice(-2) === "\\\\") { + strip(0, 1); + this.begin("mu"); + } else if (yy_.yytext.slice(-1) === "\\") { + strip(0, 1); + this.begin("emu"); + } else { + this.begin("mu"); + } + if (yy_.yytext) return 15; + + break; + case 1: + return 15; + break; + case 2: + this.popState(); + return 15; + + break; + case 3: + this.begin('raw');return 15; + break; + case 4: + this.popState(); + // Should be using `this.topState()` below, but it currently + // returns the second top instead of the first top. Opened an + // issue about it at https://github.com/zaach/jison/issues/291 + if (this.conditionStack[this.conditionStack.length - 1] === 'raw') { + return 15; + } else { + yy_.yytext = yy_.yytext.substr(5, yy_.yyleng - 9); + return 'END_RAW_BLOCK'; + } + + break; + case 5: + return 15; + break; + case 6: + this.popState(); + return 14; + + break; + case 7: + return 65; + break; + case 8: + return 68; + break; + case 9: + return 19; + break; + case 10: + this.popState(); + this.begin('raw'); + return 23; + + break; + case 11: + return 55; + break; + case 12: + return 60; + break; + case 13: + return 29; + break; + case 14: + return 47; + break; + case 15: + this.popState();return 44; + break; + case 16: + this.popState();return 44; + break; + case 17: + return 34; + break; + case 18: + return 39; + break; + case 19: + return 51; + break; + case 20: + return 48; + break; + case 21: + this.unput(yy_.yytext); + this.popState(); + this.begin('com'); + + break; + case 22: + this.popState(); + return 14; + + break; + case 23: + return 48; + break; + case 24: + return 73; + break; + case 25: + return 72; + break; + case 26: + return 72; + break; + case 27: + return 87; + break; + case 28: + // ignore whitespace + break; + case 29: + this.popState();return 54; + break; + case 30: + this.popState();return 33; + break; + case 31: + yy_.yytext = strip(1, 2).replace(/\\"/g, '"');return 80; + break; + case 32: + yy_.yytext = strip(1, 2).replace(/\\'/g, "'");return 80; + break; + case 33: + return 85; + break; + case 34: + return 82; + break; + case 35: + return 82; + break; + case 36: + return 83; + break; + case 37: + return 84; + break; + case 38: + return 81; + break; + case 39: + return 75; + break; + case 40: + return 77; + break; + case 41: + return 72; + break; + case 42: + yy_.yytext = yy_.yytext.replace(/\\([\\\]])/g, '$1');return 72; + break; + case 43: + return 'INVALID'; + break; + case 44: + return 5; + break; + } + }; + lexer.rules = [/^(?:[^\x00]*?(?=(\{\{)))/, /^(?:[^\x00]+)/, /^(?:[^\x00]{2,}?(?=(\{\{|\\\{\{|\\\\\{\{|$)))/, /^(?:\{\{\{\{(?=[^/]))/, /^(?:\{\{\{\{\/[^\s!"#%-,\.\/;->@\[-\^`\{-~]+(?=[=}\s\/.])\}\}\}\})/, /^(?:[^\x00]*?(?=(\{\{\{\{)))/, /^(?:[\s\S]*?--(~)?\}\})/, /^(?:\()/, /^(?:\))/, /^(?:\{\{\{\{)/, /^(?:\}\}\}\})/, /^(?:\{\{(~)?>)/, /^(?:\{\{(~)?#>)/, /^(?:\{\{(~)?#\*?)/, /^(?:\{\{(~)?\/)/, /^(?:\{\{(~)?\^\s*(~)?\}\})/, /^(?:\{\{(~)?\s*else\s*(~)?\}\})/, /^(?:\{\{(~)?\^)/, /^(?:\{\{(~)?\s*else\b)/, /^(?:\{\{(~)?\{)/, /^(?:\{\{(~)?&)/, /^(?:\{\{(~)?!--)/, /^(?:\{\{(~)?![\s\S]*?\}\})/, /^(?:\{\{(~)?\*?)/, /^(?:=)/, /^(?:\.\.)/, /^(?:\.(?=([=~}\s\/.)|])))/, /^(?:[\/.])/, /^(?:\s+)/, /^(?:\}(~)?\}\})/, /^(?:(~)?\}\})/, /^(?:"(\\["]|[^"])*")/, /^(?:'(\\[']|[^'])*')/, /^(?:@)/, /^(?:true(?=([~}\s)])))/, /^(?:false(?=([~}\s)])))/, /^(?:undefined(?=([~}\s)])))/, /^(?:null(?=([~}\s)])))/, /^(?:-?[0-9]+(?:\.[0-9]+)?(?=([~}\s)])))/, /^(?:as\s+\|)/, /^(?:\|)/, /^(?:([^\s!"#%-,\.\/;->@\[-\^`\{-~]+(?=([=~}\s\/.)|]))))/, /^(?:\[(\\\]|[^\]])*\])/, /^(?:.)/, /^(?:$)/]; + lexer.conditions = { "mu": { "rules": [7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44], "inclusive": false }, "emu": { "rules": [2], "inclusive": false }, "com": { "rules": [6], "inclusive": false }, "raw": { "rules": [3, 4, 5], "inclusive": false }, "INITIAL": { "rules": [0, 1, 44], "inclusive": true } }; + return lexer; + })(); + parser.lexer = lexer; + function Parser() { + this.yy = {}; + }Parser.prototype = parser;parser.Parser = Parser; + return new Parser(); + })();exports.__esModule = true; + exports['default'] = handlebars; + +/***/ }, +/* 24 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _visitor = __webpack_require__(25); + + var _visitor2 = _interopRequireDefault(_visitor); + + function WhitespaceControl() { + var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; + + this.options = options; + } + WhitespaceControl.prototype = new _visitor2['default'](); + + WhitespaceControl.prototype.Program = function (program) { + var doStandalone = !this.options.ignoreStandalone; + + var isRoot = !this.isRootSeen; + this.isRootSeen = true; + + var body = program.body; + for (var i = 0, l = body.length; i < l; i++) { + var current = body[i], + strip = this.accept(current); + + if (!strip) { + continue; + } + + var _isPrevWhitespace = isPrevWhitespace(body, i, isRoot), + _isNextWhitespace = isNextWhitespace(body, i, isRoot), + openStandalone = strip.openStandalone && _isPrevWhitespace, + closeStandalone = strip.closeStandalone && _isNextWhitespace, + inlineStandalone = strip.inlineStandalone && _isPrevWhitespace && _isNextWhitespace; + + if (strip.close) { + omitRight(body, i, true); + } + if (strip.open) { + omitLeft(body, i, true); + } + + if (doStandalone && inlineStandalone) { + omitRight(body, i); + + if (omitLeft(body, i)) { + // If we are on a standalone node, save the indent info for partials + if (current.type === 'PartialStatement') { + // Pull out the whitespace from the final line + current.indent = /([ \t]+$)/.exec(body[i - 1].original)[1]; + } + } + } + if (doStandalone && openStandalone) { + omitRight((current.program || current.inverse).body); + + // Strip out the previous content node if it's whitespace only + omitLeft(body, i); + } + if (doStandalone && closeStandalone) { + // Always strip the next node + omitRight(body, i); + + omitLeft((current.inverse || current.program).body); + } + } + + return program; + }; + + WhitespaceControl.prototype.BlockStatement = WhitespaceControl.prototype.DecoratorBlock = WhitespaceControl.prototype.PartialBlockStatement = function (block) { + this.accept(block.program); + this.accept(block.inverse); + + // Find the inverse program that is involed with whitespace stripping. + var program = block.program || block.inverse, + inverse = block.program && block.inverse, + firstInverse = inverse, + lastInverse = inverse; + + if (inverse && inverse.chained) { + firstInverse = inverse.body[0].program; + + // Walk the inverse chain to find the last inverse that is actually in the chain. + while (lastInverse.chained) { + lastInverse = lastInverse.body[lastInverse.body.length - 1].program; + } + } + + var strip = { + open: block.openStrip.open, + close: block.closeStrip.close, + + // Determine the standalone candiacy. Basically flag our content as being possibly standalone + // so our parent can determine if we actually are standalone + openStandalone: isNextWhitespace(program.body), + closeStandalone: isPrevWhitespace((firstInverse || program).body) + }; + + if (block.openStrip.close) { + omitRight(program.body, null, true); + } + + if (inverse) { + var inverseStrip = block.inverseStrip; + + if (inverseStrip.open) { + omitLeft(program.body, null, true); + } + + if (inverseStrip.close) { + omitRight(firstInverse.body, null, true); + } + if (block.closeStrip.open) { + omitLeft(lastInverse.body, null, true); + } + + // Find standalone else statments + if (!this.options.ignoreStandalone && isPrevWhitespace(program.body) && isNextWhitespace(firstInverse.body)) { + omitLeft(program.body); + omitRight(firstInverse.body); + } + } else if (block.closeStrip.open) { + omitLeft(program.body, null, true); + } + + return strip; + }; + + WhitespaceControl.prototype.Decorator = WhitespaceControl.prototype.MustacheStatement = function (mustache) { + return mustache.strip; + }; + + WhitespaceControl.prototype.PartialStatement = WhitespaceControl.prototype.CommentStatement = function (node) { + /* istanbul ignore next */ + var strip = node.strip || {}; + return { + inlineStandalone: true, + open: strip.open, + close: strip.close + }; + }; + + function isPrevWhitespace(body, i, isRoot) { + if (i === undefined) { + i = body.length; + } + + // Nodes that end with newlines are considered whitespace (but are special + // cased for strip operations) + var prev = body[i - 1], + sibling = body[i - 2]; + if (!prev) { + return isRoot; + } + + if (prev.type === 'ContentStatement') { + return (sibling || !isRoot ? /\r?\n\s*?$/ : /(^|\r?\n)\s*?$/).test(prev.original); + } + } + function isNextWhitespace(body, i, isRoot) { + if (i === undefined) { + i = -1; + } + + var next = body[i + 1], + sibling = body[i + 2]; + if (!next) { + return isRoot; + } + + if (next.type === 'ContentStatement') { + return (sibling || !isRoot ? /^\s*?\r?\n/ : /^\s*?(\r?\n|$)/).test(next.original); + } + } + + // Marks the node to the right of the position as omitted. + // I.e. {{foo}}' ' will mark the ' ' node as omitted. + // + // If i is undefined, then the first child will be marked as such. + // + // If mulitple is truthy then all whitespace will be stripped out until non-whitespace + // content is met. + function omitRight(body, i, multiple) { + var current = body[i == null ? 0 : i + 1]; + if (!current || current.type !== 'ContentStatement' || !multiple && current.rightStripped) { + return; + } + + var original = current.value; + current.value = current.value.replace(multiple ? /^\s+/ : /^[ \t]*\r?\n?/, ''); + current.rightStripped = current.value !== original; + } + + // Marks the node to the left of the position as omitted. + // I.e. ' '{{foo}} will mark the ' ' node as omitted. + // + // If i is undefined then the last child will be marked as such. + // + // If mulitple is truthy then all whitespace will be stripped out until non-whitespace + // content is met. + function omitLeft(body, i, multiple) { + var current = body[i == null ? body.length - 1 : i - 1]; + if (!current || current.type !== 'ContentStatement' || !multiple && current.leftStripped) { + return; + } + + // We omit the last node if it's whitespace only and not preceeded by a non-content node. + var original = current.value; + current.value = current.value.replace(multiple ? /\s+$/ : /[ \t]+$/, ''); + current.leftStripped = current.value !== original; + return current.leftStripped; + } + + exports['default'] = WhitespaceControl; + module.exports = exports['default']; + +/***/ }, +/* 25 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + function Visitor() { + this.parents = []; + } + + Visitor.prototype = { + constructor: Visitor, + mutating: false, + + // Visits a given value. If mutating, will replace the value if necessary. + acceptKey: function acceptKey(node, name) { + var value = this.accept(node[name]); + if (this.mutating) { + // Hacky sanity check: This may have a few false positives for type for the helper + // methods but will generally do the right thing without a lot of overhead. + if (value && !Visitor.prototype[value.type]) { + throw new _exception2['default']('Unexpected node type "' + value.type + '" found when accepting ' + name + ' on ' + node.type); + } + node[name] = value; + } + }, + + // Performs an accept operation with added sanity check to ensure + // required keys are not removed. + acceptRequired: function acceptRequired(node, name) { + this.acceptKey(node, name); + + if (!node[name]) { + throw new _exception2['default'](node.type + ' requires ' + name); + } + }, + + // Traverses a given array. If mutating, empty respnses will be removed + // for child elements. + acceptArray: function acceptArray(array) { + for (var i = 0, l = array.length; i < l; i++) { + this.acceptKey(array, i); + + if (!array[i]) { + array.splice(i, 1); + i--; + l--; + } + } + }, + + accept: function accept(object) { + if (!object) { + return; + } + + /* istanbul ignore next: Sanity code */ + if (!this[object.type]) { + throw new _exception2['default']('Unknown type: ' + object.type, object); + } + + if (this.current) { + this.parents.unshift(this.current); + } + this.current = object; + + var ret = this[object.type](object); + + this.current = this.parents.shift(); + + if (!this.mutating || ret) { + return ret; + } else if (ret !== false) { + return object; + } + }, + + Program: function Program(program) { + this.acceptArray(program.body); + }, + + MustacheStatement: visitSubExpression, + Decorator: visitSubExpression, + + BlockStatement: visitBlock, + DecoratorBlock: visitBlock, + + PartialStatement: visitPartial, + PartialBlockStatement: function PartialBlockStatement(partial) { + visitPartial.call(this, partial); + + this.acceptKey(partial, 'program'); + }, + + ContentStatement: function ContentStatement() /* content */{}, + CommentStatement: function CommentStatement() /* comment */{}, + + SubExpression: visitSubExpression, + + PathExpression: function PathExpression() /* path */{}, + + StringLiteral: function StringLiteral() /* string */{}, + NumberLiteral: function NumberLiteral() /* number */{}, + BooleanLiteral: function BooleanLiteral() /* bool */{}, + UndefinedLiteral: function UndefinedLiteral() /* literal */{}, + NullLiteral: function NullLiteral() /* literal */{}, + + Hash: function Hash(hash) { + this.acceptArray(hash.pairs); + }, + HashPair: function HashPair(pair) { + this.acceptRequired(pair, 'value'); + } + }; + + function visitSubExpression(mustache) { + this.acceptRequired(mustache, 'path'); + this.acceptArray(mustache.params); + this.acceptKey(mustache, 'hash'); + } + function visitBlock(block) { + visitSubExpression.call(this, block); + + this.acceptKey(block, 'program'); + this.acceptKey(block, 'inverse'); + } + function visitPartial(partial) { + this.acceptRequired(partial, 'name'); + this.acceptArray(partial.params); + this.acceptKey(partial, 'hash'); + } + + exports['default'] = Visitor; + module.exports = exports['default']; + +/***/ }, +/* 26 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.SourceLocation = SourceLocation; + exports.id = id; + exports.stripFlags = stripFlags; + exports.stripComment = stripComment; + exports.preparePath = preparePath; + exports.prepareMustache = prepareMustache; + exports.prepareRawBlock = prepareRawBlock; + exports.prepareBlock = prepareBlock; + exports.prepareProgram = prepareProgram; + exports.preparePartialBlock = preparePartialBlock; + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + function validateClose(open, close) { + close = close.path ? close.path.original : close; + + if (open.path.original !== close) { + var errorNode = { loc: open.path.loc }; + + throw new _exception2['default'](open.path.original + " doesn't match " + close, errorNode); + } + } + + function SourceLocation(source, locInfo) { + this.source = source; + this.start = { + line: locInfo.first_line, + column: locInfo.first_column + }; + this.end = { + line: locInfo.last_line, + column: locInfo.last_column + }; + } + + function id(token) { + if (/^\[.*\]$/.test(token)) { + return token.substr(1, token.length - 2); + } else { + return token; + } + } + + function stripFlags(open, close) { + return { + open: open.charAt(2) === '~', + close: close.charAt(close.length - 3) === '~' + }; + } + + function stripComment(comment) { + return comment.replace(/^\{\{~?\!-?-?/, '').replace(/-?-?~?\}\}$/, ''); + } + + function preparePath(data, parts, loc) { + loc = this.locInfo(loc); + + var original = data ? '@' : '', + dig = [], + depth = 0, + depthString = ''; + + for (var i = 0, l = parts.length; i < l; i++) { + var part = parts[i].part, + + // If we have [] syntax then we do not treat path references as operators, + // i.e. foo.[this] resolves to approximately context.foo['this'] + isLiteral = parts[i].original !== part; + original += (parts[i].separator || '') + part; + + if (!isLiteral && (part === '..' || part === '.' || part === 'this')) { + if (dig.length > 0) { + throw new _exception2['default']('Invalid path: ' + original, { loc: loc }); + } else if (part === '..') { + depth++; + depthString += '../'; + } + } else { + dig.push(part); + } + } + + return { + type: 'PathExpression', + data: data, + depth: depth, + parts: dig, + original: original, + loc: loc + }; + } + + function prepareMustache(path, params, hash, open, strip, locInfo) { + // Must use charAt to support IE pre-10 + var escapeFlag = open.charAt(3) || open.charAt(2), + escaped = escapeFlag !== '{' && escapeFlag !== '&'; + + var decorator = /\*/.test(open); + return { + type: decorator ? 'Decorator' : 'MustacheStatement', + path: path, + params: params, + hash: hash, + escaped: escaped, + strip: strip, + loc: this.locInfo(locInfo) + }; + } + + function prepareRawBlock(openRawBlock, contents, close, locInfo) { + validateClose(openRawBlock, close); + + locInfo = this.locInfo(locInfo); + var program = { + type: 'Program', + body: contents, + strip: {}, + loc: locInfo + }; + + return { + type: 'BlockStatement', + path: openRawBlock.path, + params: openRawBlock.params, + hash: openRawBlock.hash, + program: program, + openStrip: {}, + inverseStrip: {}, + closeStrip: {}, + loc: locInfo + }; + } + + function prepareBlock(openBlock, program, inverseAndProgram, close, inverted, locInfo) { + if (close && close.path) { + validateClose(openBlock, close); + } + + var decorator = /\*/.test(openBlock.open); + + program.blockParams = openBlock.blockParams; + + var inverse = undefined, + inverseStrip = undefined; + + if (inverseAndProgram) { + if (decorator) { + throw new _exception2['default']('Unexpected inverse block on decorator', inverseAndProgram); + } + + if (inverseAndProgram.chain) { + inverseAndProgram.program.body[0].closeStrip = close.strip; + } + + inverseStrip = inverseAndProgram.strip; + inverse = inverseAndProgram.program; + } + + if (inverted) { + inverted = inverse; + inverse = program; + program = inverted; + } + + return { + type: decorator ? 'DecoratorBlock' : 'BlockStatement', + path: openBlock.path, + params: openBlock.params, + hash: openBlock.hash, + program: program, + inverse: inverse, + openStrip: openBlock.strip, + inverseStrip: inverseStrip, + closeStrip: close && close.strip, + loc: this.locInfo(locInfo) + }; + } + + function prepareProgram(statements, loc) { + if (!loc && statements.length) { + var firstLoc = statements[0].loc, + lastLoc = statements[statements.length - 1].loc; + + /* istanbul ignore else */ + if (firstLoc && lastLoc) { + loc = { + source: firstLoc.source, + start: { + line: firstLoc.start.line, + column: firstLoc.start.column + }, + end: { + line: lastLoc.end.line, + column: lastLoc.end.column + } + }; + } + } + + return { + type: 'Program', + body: statements, + strip: {}, + loc: loc + }; + } + + function preparePartialBlock(open, program, close, locInfo) { + validateClose(open, close); + + return { + type: 'PartialBlockStatement', + name: open.path, + params: open.params, + hash: open.hash, + program: program, + openStrip: open.strip, + closeStrip: close && close.strip, + loc: this.locInfo(locInfo) + }; + } + +/***/ }, +/* 27 */ +/***/ function(module, exports, __webpack_require__) { + + /* eslint-disable new-cap */ + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + exports.Compiler = Compiler; + exports.precompile = precompile; + exports.compile = compile; + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + var _utils = __webpack_require__(5); + + var _ast = __webpack_require__(21); + + var _ast2 = _interopRequireDefault(_ast); + + var slice = [].slice; + + function Compiler() {} + + // the foundHelper register will disambiguate helper lookup from finding a + // function in a context. This is necessary for mustache compatibility, which + // requires that context functions in blocks are evaluated by blockHelperMissing, + // and then proceed as if the resulting value was provided to blockHelperMissing. + + Compiler.prototype = { + compiler: Compiler, + + equals: function equals(other) { + var len = this.opcodes.length; + if (other.opcodes.length !== len) { + return false; + } + + for (var i = 0; i < len; i++) { + var opcode = this.opcodes[i], + otherOpcode = other.opcodes[i]; + if (opcode.opcode !== otherOpcode.opcode || !argEquals(opcode.args, otherOpcode.args)) { + return false; + } + } + + // We know that length is the same between the two arrays because they are directly tied + // to the opcode behavior above. + len = this.children.length; + for (var i = 0; i < len; i++) { + if (!this.children[i].equals(other.children[i])) { + return false; + } + } + + return true; + }, + + guid: 0, + + compile: function compile(program, options) { + this.sourceNode = []; + this.opcodes = []; + this.children = []; + this.options = options; + this.stringParams = options.stringParams; + this.trackIds = options.trackIds; + + options.blockParams = options.blockParams || []; + + // These changes will propagate to the other compiler components + var knownHelpers = options.knownHelpers; + options.knownHelpers = { + 'helperMissing': true, + 'blockHelperMissing': true, + 'each': true, + 'if': true, + 'unless': true, + 'with': true, + 'log': true, + 'lookup': true + }; + if (knownHelpers) { + for (var _name in knownHelpers) { + /* istanbul ignore else */ + if (_name in knownHelpers) { + options.knownHelpers[_name] = knownHelpers[_name]; + } + } + } + + return this.accept(program); + }, + + compileProgram: function compileProgram(program) { + var childCompiler = new this.compiler(), + // eslint-disable-line new-cap + result = childCompiler.compile(program, this.options), + guid = this.guid++; + + this.usePartial = this.usePartial || result.usePartial; + + this.children[guid] = result; + this.useDepths = this.useDepths || result.useDepths; + + return guid; + }, + + accept: function accept(node) { + /* istanbul ignore next: Sanity code */ + if (!this[node.type]) { + throw new _exception2['default']('Unknown type: ' + node.type, node); + } + + this.sourceNode.unshift(node); + var ret = this[node.type](node); + this.sourceNode.shift(); + return ret; + }, + + Program: function Program(program) { + this.options.blockParams.unshift(program.blockParams); + + var body = program.body, + bodyLength = body.length; + for (var i = 0; i < bodyLength; i++) { + this.accept(body[i]); + } + + this.options.blockParams.shift(); + + this.isSimple = bodyLength === 1; + this.blockParams = program.blockParams ? program.blockParams.length : 0; + + return this; + }, + + BlockStatement: function BlockStatement(block) { + transformLiteralToPath(block); + + var program = block.program, + inverse = block.inverse; + + program = program && this.compileProgram(program); + inverse = inverse && this.compileProgram(inverse); + + var type = this.classifySexpr(block); + + if (type === 'helper') { + this.helperSexpr(block, program, inverse); + } else if (type === 'simple') { + this.simpleSexpr(block); + + // now that the simple mustache is resolved, we need to + // evaluate it by executing `blockHelperMissing` + this.opcode('pushProgram', program); + this.opcode('pushProgram', inverse); + this.opcode('emptyHash'); + this.opcode('blockValue', block.path.original); + } else { + this.ambiguousSexpr(block, program, inverse); + + // now that the simple mustache is resolved, we need to + // evaluate it by executing `blockHelperMissing` + this.opcode('pushProgram', program); + this.opcode('pushProgram', inverse); + this.opcode('emptyHash'); + this.opcode('ambiguousBlockValue'); + } + + this.opcode('append'); + }, + + DecoratorBlock: function DecoratorBlock(decorator) { + var program = decorator.program && this.compileProgram(decorator.program); + var params = this.setupFullMustacheParams(decorator, program, undefined), + path = decorator.path; + + this.useDecorators = true; + this.opcode('registerDecorator', params.length, path.original); + }, + + PartialStatement: function PartialStatement(partial) { + this.usePartial = true; + + var program = partial.program; + if (program) { + program = this.compileProgram(partial.program); + } + + var params = partial.params; + if (params.length > 1) { + throw new _exception2['default']('Unsupported number of partial arguments: ' + params.length, partial); + } else if (!params.length) { + if (this.options.explicitPartialContext) { + this.opcode('pushLiteral', 'undefined'); + } else { + params.push({ type: 'PathExpression', parts: [], depth: 0 }); + } + } + + var partialName = partial.name.original, + isDynamic = partial.name.type === 'SubExpression'; + if (isDynamic) { + this.accept(partial.name); + } + + this.setupFullMustacheParams(partial, program, undefined, true); + + var indent = partial.indent || ''; + if (this.options.preventIndent && indent) { + this.opcode('appendContent', indent); + indent = ''; + } + + this.opcode('invokePartial', isDynamic, partialName, indent); + this.opcode('append'); + }, + PartialBlockStatement: function PartialBlockStatement(partialBlock) { + this.PartialStatement(partialBlock); + }, + + MustacheStatement: function MustacheStatement(mustache) { + this.SubExpression(mustache); + + if (mustache.escaped && !this.options.noEscape) { + this.opcode('appendEscaped'); + } else { + this.opcode('append'); + } + }, + Decorator: function Decorator(decorator) { + this.DecoratorBlock(decorator); + }, + + ContentStatement: function ContentStatement(content) { + if (content.value) { + this.opcode('appendContent', content.value); + } + }, + + CommentStatement: function CommentStatement() {}, + + SubExpression: function SubExpression(sexpr) { + transformLiteralToPath(sexpr); + var type = this.classifySexpr(sexpr); + + if (type === 'simple') { + this.simpleSexpr(sexpr); + } else if (type === 'helper') { + this.helperSexpr(sexpr); + } else { + this.ambiguousSexpr(sexpr); + } + }, + ambiguousSexpr: function ambiguousSexpr(sexpr, program, inverse) { + var path = sexpr.path, + name = path.parts[0], + isBlock = program != null || inverse != null; + + this.opcode('getContext', path.depth); + + this.opcode('pushProgram', program); + this.opcode('pushProgram', inverse); + + path.strict = true; + this.accept(path); + + this.opcode('invokeAmbiguous', name, isBlock); + }, + + simpleSexpr: function simpleSexpr(sexpr) { + var path = sexpr.path; + path.strict = true; + this.accept(path); + this.opcode('resolvePossibleLambda'); + }, + + helperSexpr: function helperSexpr(sexpr, program, inverse) { + var params = this.setupFullMustacheParams(sexpr, program, inverse), + path = sexpr.path, + name = path.parts[0]; + + if (this.options.knownHelpers[name]) { + this.opcode('invokeKnownHelper', params.length, name); + } else if (this.options.knownHelpersOnly) { + throw new _exception2['default']('You specified knownHelpersOnly, but used the unknown helper ' + name, sexpr); + } else { + path.strict = true; + path.falsy = true; + + this.accept(path); + this.opcode('invokeHelper', params.length, path.original, _ast2['default'].helpers.simpleId(path)); + } + }, + + PathExpression: function PathExpression(path) { + this.addDepth(path.depth); + this.opcode('getContext', path.depth); + + var name = path.parts[0], + scoped = _ast2['default'].helpers.scopedId(path), + blockParamId = !path.depth && !scoped && this.blockParamIndex(name); + + if (blockParamId) { + this.opcode('lookupBlockParam', blockParamId, path.parts); + } else if (!name) { + // Context reference, i.e. `{{foo .}}` or `{{foo ..}}` + this.opcode('pushContext'); + } else if (path.data) { + this.options.data = true; + this.opcode('lookupData', path.depth, path.parts, path.strict); + } else { + this.opcode('lookupOnContext', path.parts, path.falsy, path.strict, scoped); + } + }, + + StringLiteral: function StringLiteral(string) { + this.opcode('pushString', string.value); + }, + + NumberLiteral: function NumberLiteral(number) { + this.opcode('pushLiteral', number.value); + }, + + BooleanLiteral: function BooleanLiteral(bool) { + this.opcode('pushLiteral', bool.value); + }, + + UndefinedLiteral: function UndefinedLiteral() { + this.opcode('pushLiteral', 'undefined'); + }, + + NullLiteral: function NullLiteral() { + this.opcode('pushLiteral', 'null'); + }, + + Hash: function Hash(hash) { + var pairs = hash.pairs, + i = 0, + l = pairs.length; + + this.opcode('pushHash'); + + for (; i < l; i++) { + this.pushParam(pairs[i].value); + } + while (i--) { + this.opcode('assignToHash', pairs[i].key); + } + this.opcode('popHash'); + }, + + // HELPERS + opcode: function opcode(name) { + this.opcodes.push({ opcode: name, args: slice.call(arguments, 1), loc: this.sourceNode[0].loc }); + }, + + addDepth: function addDepth(depth) { + if (!depth) { + return; + } + + this.useDepths = true; + }, + + classifySexpr: function classifySexpr(sexpr) { + var isSimple = _ast2['default'].helpers.simpleId(sexpr.path); + + var isBlockParam = isSimple && !!this.blockParamIndex(sexpr.path.parts[0]); + + // a mustache is an eligible helper if: + // * its id is simple (a single part, not `this` or `..`) + var isHelper = !isBlockParam && _ast2['default'].helpers.helperExpression(sexpr); + + // if a mustache is an eligible helper but not a definite + // helper, it is ambiguous, and will be resolved in a later + // pass or at runtime. + var isEligible = !isBlockParam && (isHelper || isSimple); + + // if ambiguous, we can possibly resolve the ambiguity now + // An eligible helper is one that does not have a complex path, i.e. `this.foo`, `../foo` etc. + if (isEligible && !isHelper) { + var _name2 = sexpr.path.parts[0], + options = this.options; + + if (options.knownHelpers[_name2]) { + isHelper = true; + } else if (options.knownHelpersOnly) { + isEligible = false; + } + } + + if (isHelper) { + return 'helper'; + } else if (isEligible) { + return 'ambiguous'; + } else { + return 'simple'; + } + }, + + pushParams: function pushParams(params) { + for (var i = 0, l = params.length; i < l; i++) { + this.pushParam(params[i]); + } + }, + + pushParam: function pushParam(val) { + var value = val.value != null ? val.value : val.original || ''; + + if (this.stringParams) { + if (value.replace) { + value = value.replace(/^(\.?\.\/)*/g, '').replace(/\//g, '.'); + } + + if (val.depth) { + this.addDepth(val.depth); + } + this.opcode('getContext', val.depth || 0); + this.opcode('pushStringParam', value, val.type); + + if (val.type === 'SubExpression') { + // SubExpressions get evaluated and passed in + // in string params mode. + this.accept(val); + } + } else { + if (this.trackIds) { + var blockParamIndex = undefined; + if (val.parts && !_ast2['default'].helpers.scopedId(val) && !val.depth) { + blockParamIndex = this.blockParamIndex(val.parts[0]); + } + if (blockParamIndex) { + var blockParamChild = val.parts.slice(1).join('.'); + this.opcode('pushId', 'BlockParam', blockParamIndex, blockParamChild); + } else { + value = val.original || value; + if (value.replace) { + value = value.replace(/^this(?:\.|$)/, '').replace(/^\.\//, '').replace(/^\.$/, ''); + } + + this.opcode('pushId', val.type, value); + } + } + this.accept(val); + } + }, + + setupFullMustacheParams: function setupFullMustacheParams(sexpr, program, inverse, omitEmpty) { + var params = sexpr.params; + this.pushParams(params); + + this.opcode('pushProgram', program); + this.opcode('pushProgram', inverse); + + if (sexpr.hash) { + this.accept(sexpr.hash); + } else { + this.opcode('emptyHash', omitEmpty); + } + + return params; + }, + + blockParamIndex: function blockParamIndex(name) { + for (var depth = 0, len = this.options.blockParams.length; depth < len; depth++) { + var blockParams = this.options.blockParams[depth], + param = blockParams && _utils.indexOf(blockParams, name); + if (blockParams && param >= 0) { + return [depth, param]; + } + } + } + }; + + function precompile(input, options, env) { + if (input == null || typeof input !== 'string' && input.type !== 'Program') { + throw new _exception2['default']('You must pass a string or Handlebars AST to Handlebars.precompile. You passed ' + input); + } + + options = options || {}; + if (!('data' in options)) { + options.data = true; + } + if (options.compat) { + options.useDepths = true; + } + + var ast = env.parse(input, options), + environment = new env.Compiler().compile(ast, options); + return new env.JavaScriptCompiler().compile(environment, options); + } + + function compile(input, options, env) { + if (options === undefined) options = {}; + + if (input == null || typeof input !== 'string' && input.type !== 'Program') { + throw new _exception2['default']('You must pass a string or Handlebars AST to Handlebars.compile. You passed ' + input); + } + + if (!('data' in options)) { + options.data = true; + } + if (options.compat) { + options.useDepths = true; + } + + var compiled = undefined; + + function compileInput() { + var ast = env.parse(input, options), + environment = new env.Compiler().compile(ast, options), + templateSpec = new env.JavaScriptCompiler().compile(environment, options, undefined, true); + return env.template(templateSpec); + } + + // Template is only compiled on first use and cached after that point. + function ret(context, execOptions) { + if (!compiled) { + compiled = compileInput(); + } + return compiled.call(this, context, execOptions); + } + ret._setup = function (setupOptions) { + if (!compiled) { + compiled = compileInput(); + } + return compiled._setup(setupOptions); + }; + ret._child = function (i, data, blockParams, depths) { + if (!compiled) { + compiled = compileInput(); + } + return compiled._child(i, data, blockParams, depths); + }; + return ret; + } + + function argEquals(a, b) { + if (a === b) { + return true; + } + + if (_utils.isArray(a) && _utils.isArray(b) && a.length === b.length) { + for (var i = 0; i < a.length; i++) { + if (!argEquals(a[i], b[i])) { + return false; + } + } + return true; + } + } + + function transformLiteralToPath(sexpr) { + if (!sexpr.path.parts) { + var literal = sexpr.path; + // Casting to string here to make false and 0 literal values play nicely with the rest + // of the system. + sexpr.path = { + type: 'PathExpression', + data: false, + depth: 0, + parts: [literal.original + ''], + original: literal.original + '', + loc: literal.loc + }; + } + } + +/***/ }, +/* 28 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var _interopRequireDefault = __webpack_require__(1)['default']; + + exports.__esModule = true; + + var _base = __webpack_require__(4); + + var _exception = __webpack_require__(6); + + var _exception2 = _interopRequireDefault(_exception); + + var _utils = __webpack_require__(5); + + var _codeGen = __webpack_require__(29); + + var _codeGen2 = _interopRequireDefault(_codeGen); + + function Literal(value) { + this.value = value; + } + + function JavaScriptCompiler() {} + + JavaScriptCompiler.prototype = { + // PUBLIC API: You can override these methods in a subclass to provide + // alternative compiled forms for name lookup and buffering semantics + nameLookup: function nameLookup(parent, name /* , type*/) { + if (JavaScriptCompiler.isValidJavaScriptVariableName(name)) { + return [parent, '.', name]; + } else { + return [parent, '[', JSON.stringify(name), ']']; + } + }, + depthedLookup: function depthedLookup(name) { + return [this.aliasable('container.lookup'), '(depths, "', name, '")']; + }, + + compilerInfo: function compilerInfo() { + var revision = _base.COMPILER_REVISION, + versions = _base.REVISION_CHANGES[revision]; + return [revision, versions]; + }, + + appendToBuffer: function appendToBuffer(source, location, explicit) { + // Force a source as this simplifies the merge logic. + if (!_utils.isArray(source)) { + source = [source]; + } + source = this.source.wrap(source, location); + + if (this.environment.isSimple) { + return ['return ', source, ';']; + } else if (explicit) { + // This is a case where the buffer operation occurs as a child of another + // construct, generally braces. We have to explicitly output these buffer + // operations to ensure that the emitted code goes in the correct location. + return ['buffer += ', source, ';']; + } else { + source.appendToBuffer = true; + return source; + } + }, + + initializeBuffer: function initializeBuffer() { + return this.quotedString(''); + }, + // END PUBLIC API + + compile: function compile(environment, options, context, asObject) { + this.environment = environment; + this.options = options; + this.stringParams = this.options.stringParams; + this.trackIds = this.options.trackIds; + this.precompile = !asObject; + + this.name = this.environment.name; + this.isChild = !!context; + this.context = context || { + decorators: [], + programs: [], + environments: [] + }; + + this.preamble(); + + this.stackSlot = 0; + this.stackVars = []; + this.aliases = {}; + this.registers = { list: [] }; + this.hashes = []; + this.compileStack = []; + this.inlineStack = []; + this.blockParams = []; + + this.compileChildren(environment, options); + + this.useDepths = this.useDepths || environment.useDepths || environment.useDecorators || this.options.compat; + this.useBlockParams = this.useBlockParams || environment.useBlockParams; + + var opcodes = environment.opcodes, + opcode = undefined, + firstLoc = undefined, + i = undefined, + l = undefined; + + for (i = 0, l = opcodes.length; i < l; i++) { + opcode = opcodes[i]; + + this.source.currentLocation = opcode.loc; + firstLoc = firstLoc || opcode.loc; + this[opcode.opcode].apply(this, opcode.args); + } + + // Flush any trailing content that might be pending. + this.source.currentLocation = firstLoc; + this.pushSource(''); + + /* istanbul ignore next */ + if (this.stackSlot || this.inlineStack.length || this.compileStack.length) { + throw new _exception2['default']('Compile completed with content left on stack'); + } + + if (!this.decorators.isEmpty()) { + this.useDecorators = true; + + this.decorators.prepend('var decorators = container.decorators;\n'); + this.decorators.push('return fn;'); + + if (asObject) { + this.decorators = Function.apply(this, ['fn', 'props', 'container', 'depth0', 'data', 'blockParams', 'depths', this.decorators.merge()]); + } else { + this.decorators.prepend('function(fn, props, container, depth0, data, blockParams, depths) {\n'); + this.decorators.push('}\n'); + this.decorators = this.decorators.merge(); + } + } else { + this.decorators = undefined; + } + + var fn = this.createFunctionContext(asObject); + if (!this.isChild) { + var ret = { + compiler: this.compilerInfo(), + main: fn + }; + + if (this.decorators) { + ret.main_d = this.decorators; // eslint-disable-line camelcase + ret.useDecorators = true; + } + + var _context = this.context; + var programs = _context.programs; + var decorators = _context.decorators; + + for (i = 0, l = programs.length; i < l; i++) { + if (programs[i]) { + ret[i] = programs[i]; + if (decorators[i]) { + ret[i + '_d'] = decorators[i]; + ret.useDecorators = true; + } + } + } + + if (this.environment.usePartial) { + ret.usePartial = true; + } + if (this.options.data) { + ret.useData = true; + } + if (this.useDepths) { + ret.useDepths = true; + } + if (this.useBlockParams) { + ret.useBlockParams = true; + } + if (this.options.compat) { + ret.compat = true; + } + + if (!asObject) { + ret.compiler = JSON.stringify(ret.compiler); + + this.source.currentLocation = { start: { line: 1, column: 0 } }; + ret = this.objectLiteral(ret); + + if (options.srcName) { + ret = ret.toStringWithSourceMap({ file: options.destName }); + ret.map = ret.map && ret.map.toString(); + } else { + ret = ret.toString(); + } + } else { + ret.compilerOptions = this.options; + } + + return ret; + } else { + return fn; + } + }, + + preamble: function preamble() { + // track the last context pushed into place to allow skipping the + // getContext opcode when it would be a noop + this.lastContext = 0; + this.source = new _codeGen2['default'](this.options.srcName); + this.decorators = new _codeGen2['default'](this.options.srcName); + }, + + createFunctionContext: function createFunctionContext(asObject) { + var varDeclarations = ''; + + var locals = this.stackVars.concat(this.registers.list); + if (locals.length > 0) { + varDeclarations += ', ' + locals.join(', '); + } + + // Generate minimizer alias mappings + // + // When using true SourceNodes, this will update all references to the given alias + // as the source nodes are reused in situ. For the non-source node compilation mode, + // aliases will not be used, but this case is already being run on the client and + // we aren't concern about minimizing the template size. + var aliasCount = 0; + for (var alias in this.aliases) { + // eslint-disable-line guard-for-in + var node = this.aliases[alias]; + + if (this.aliases.hasOwnProperty(alias) && node.children && node.referenceCount > 1) { + varDeclarations += ', alias' + ++aliasCount + '=' + alias; + node.children[0] = 'alias' + aliasCount; + } + } + + var params = ['container', 'depth0', 'helpers', 'partials', 'data']; + + if (this.useBlockParams || this.useDepths) { + params.push('blockParams'); + } + if (this.useDepths) { + params.push('depths'); + } + + // Perform a second pass over the output to merge content when possible + var source = this.mergeSource(varDeclarations); + + if (asObject) { + params.push(source); + + return Function.apply(this, params); + } else { + return this.source.wrap(['function(', params.join(','), ') {\n ', source, '}']); + } + }, + mergeSource: function mergeSource(varDeclarations) { + var isSimple = this.environment.isSimple, + appendOnly = !this.forceBuffer, + appendFirst = undefined, + sourceSeen = undefined, + bufferStart = undefined, + bufferEnd = undefined; + this.source.each(function (line) { + if (line.appendToBuffer) { + if (bufferStart) { + line.prepend(' + '); + } else { + bufferStart = line; + } + bufferEnd = line; + } else { + if (bufferStart) { + if (!sourceSeen) { + appendFirst = true; + } else { + bufferStart.prepend('buffer += '); + } + bufferEnd.add(';'); + bufferStart = bufferEnd = undefined; + } + + sourceSeen = true; + if (!isSimple) { + appendOnly = false; + } + } + }); + + if (appendOnly) { + if (bufferStart) { + bufferStart.prepend('return '); + bufferEnd.add(';'); + } else if (!sourceSeen) { + this.source.push('return "";'); + } + } else { + varDeclarations += ', buffer = ' + (appendFirst ? '' : this.initializeBuffer()); + + if (bufferStart) { + bufferStart.prepend('return buffer + '); + bufferEnd.add(';'); + } else { + this.source.push('return buffer;'); + } + } + + if (varDeclarations) { + this.source.prepend('var ' + varDeclarations.substring(2) + (appendFirst ? '' : ';\n')); + } + + return this.source.merge(); + }, + + // [blockValue] + // + // On stack, before: hash, inverse, program, value + // On stack, after: return value of blockHelperMissing + // + // The purpose of this opcode is to take a block of the form + // `{{#this.foo}}...{{/this.foo}}`, resolve the value of `foo`, and + // replace it on the stack with the result of properly + // invoking blockHelperMissing. + blockValue: function blockValue(name) { + var blockHelperMissing = this.aliasable('helpers.blockHelperMissing'), + params = [this.contextName(0)]; + this.setupHelperArgs(name, 0, params); + + var blockName = this.popStack(); + params.splice(1, 0, blockName); + + this.push(this.source.functionCall(blockHelperMissing, 'call', params)); + }, + + // [ambiguousBlockValue] + // + // On stack, before: hash, inverse, program, value + // Compiler value, before: lastHelper=value of last found helper, if any + // On stack, after, if no lastHelper: same as [blockValue] + // On stack, after, if lastHelper: value + ambiguousBlockValue: function ambiguousBlockValue() { + // We're being a bit cheeky and reusing the options value from the prior exec + var blockHelperMissing = this.aliasable('helpers.blockHelperMissing'), + params = [this.contextName(0)]; + this.setupHelperArgs('', 0, params, true); + + this.flushInline(); + + var current = this.topStack(); + params.splice(1, 0, current); + + this.pushSource(['if (!', this.lastHelper, ') { ', current, ' = ', this.source.functionCall(blockHelperMissing, 'call', params), '}']); + }, + + // [appendContent] + // + // On stack, before: ... + // On stack, after: ... + // + // Appends the string value of `content` to the current buffer + appendContent: function appendContent(content) { + if (this.pendingContent) { + content = this.pendingContent + content; + } else { + this.pendingLocation = this.source.currentLocation; + } + + this.pendingContent = content; + }, + + // [append] + // + // On stack, before: value, ... + // On stack, after: ... + // + // Coerces `value` to a String and appends it to the current buffer. + // + // If `value` is truthy, or 0, it is coerced into a string and appended + // Otherwise, the empty string is appended + append: function append() { + if (this.isInline()) { + this.replaceStack(function (current) { + return [' != null ? ', current, ' : ""']; + }); + + this.pushSource(this.appendToBuffer(this.popStack())); + } else { + var local = this.popStack(); + this.pushSource(['if (', local, ' != null) { ', this.appendToBuffer(local, undefined, true), ' }']); + if (this.environment.isSimple) { + this.pushSource(['else { ', this.appendToBuffer("''", undefined, true), ' }']); + } + } + }, + + // [appendEscaped] + // + // On stack, before: value, ... + // On stack, after: ... + // + // Escape `value` and append it to the buffer + appendEscaped: function appendEscaped() { + this.pushSource(this.appendToBuffer([this.aliasable('container.escapeExpression'), '(', this.popStack(), ')'])); + }, + + // [getContext] + // + // On stack, before: ... + // On stack, after: ... + // Compiler value, after: lastContext=depth + // + // Set the value of the `lastContext` compiler value to the depth + getContext: function getContext(depth) { + this.lastContext = depth; + }, + + // [pushContext] + // + // On stack, before: ... + // On stack, after: currentContext, ... + // + // Pushes the value of the current context onto the stack. + pushContext: function pushContext() { + this.pushStackLiteral(this.contextName(this.lastContext)); + }, + + // [lookupOnContext] + // + // On stack, before: ... + // On stack, after: currentContext[name], ... + // + // Looks up the value of `name` on the current context and pushes + // it onto the stack. + lookupOnContext: function lookupOnContext(parts, falsy, strict, scoped) { + var i = 0; + + if (!scoped && this.options.compat && !this.lastContext) { + // The depthed query is expected to handle the undefined logic for the root level that + // is implemented below, so we evaluate that directly in compat mode + this.push(this.depthedLookup(parts[i++])); + } else { + this.pushContext(); + } + + this.resolvePath('context', parts, i, falsy, strict); + }, + + // [lookupBlockParam] + // + // On stack, before: ... + // On stack, after: blockParam[name], ... + // + // Looks up the value of `parts` on the given block param and pushes + // it onto the stack. + lookupBlockParam: function lookupBlockParam(blockParamId, parts) { + this.useBlockParams = true; + + this.push(['blockParams[', blockParamId[0], '][', blockParamId[1], ']']); + this.resolvePath('context', parts, 1); + }, + + // [lookupData] + // + // On stack, before: ... + // On stack, after: data, ... + // + // Push the data lookup operator + lookupData: function lookupData(depth, parts, strict) { + if (!depth) { + this.pushStackLiteral('data'); + } else { + this.pushStackLiteral('container.data(data, ' + depth + ')'); + } + + this.resolvePath('data', parts, 0, true, strict); + }, + + resolvePath: function resolvePath(type, parts, i, falsy, strict) { + // istanbul ignore next + + var _this = this; + + if (this.options.strict || this.options.assumeObjects) { + this.push(strictLookup(this.options.strict && strict, this, parts, type)); + return; + } + + var len = parts.length; + for (; i < len; i++) { + /* eslint-disable no-loop-func */ + this.replaceStack(function (current) { + var lookup = _this.nameLookup(current, parts[i], type); + // We want to ensure that zero and false are handled properly if the context (falsy flag) + // needs to have the special handling for these values. + if (!falsy) { + return [' != null ? ', lookup, ' : ', current]; + } else { + // Otherwise we can use generic falsy handling + return [' && ', lookup]; + } + }); + /* eslint-enable no-loop-func */ + } + }, + + // [resolvePossibleLambda] + // + // On stack, before: value, ... + // On stack, after: resolved value, ... + // + // If the `value` is a lambda, replace it on the stack by + // the return value of the lambda + resolvePossibleLambda: function resolvePossibleLambda() { + this.push([this.aliasable('container.lambda'), '(', this.popStack(), ', ', this.contextName(0), ')']); + }, + + // [pushStringParam] + // + // On stack, before: ... + // On stack, after: string, currentContext, ... + // + // This opcode is designed for use in string mode, which + // provides the string value of a parameter along with its + // depth rather than resolving it immediately. + pushStringParam: function pushStringParam(string, type) { + this.pushContext(); + this.pushString(type); + + // If it's a subexpression, the string result + // will be pushed after this opcode. + if (type !== 'SubExpression') { + if (typeof string === 'string') { + this.pushString(string); + } else { + this.pushStackLiteral(string); + } + } + }, + + emptyHash: function emptyHash(omitEmpty) { + if (this.trackIds) { + this.push('{}'); // hashIds + } + if (this.stringParams) { + this.push('{}'); // hashContexts + this.push('{}'); // hashTypes + } + this.pushStackLiteral(omitEmpty ? 'undefined' : '{}'); + }, + pushHash: function pushHash() { + if (this.hash) { + this.hashes.push(this.hash); + } + this.hash = { values: [], types: [], contexts: [], ids: [] }; + }, + popHash: function popHash() { + var hash = this.hash; + this.hash = this.hashes.pop(); + + if (this.trackIds) { + this.push(this.objectLiteral(hash.ids)); + } + if (this.stringParams) { + this.push(this.objectLiteral(hash.contexts)); + this.push(this.objectLiteral(hash.types)); + } + + this.push(this.objectLiteral(hash.values)); + }, + + // [pushString] + // + // On stack, before: ... + // On stack, after: quotedString(string), ... + // + // Push a quoted version of `string` onto the stack + pushString: function pushString(string) { + this.pushStackLiteral(this.quotedString(string)); + }, + + // [pushLiteral] + // + // On stack, before: ... + // On stack, after: value, ... + // + // Pushes a value onto the stack. This operation prevents + // the compiler from creating a temporary variable to hold + // it. + pushLiteral: function pushLiteral(value) { + this.pushStackLiteral(value); + }, + + // [pushProgram] + // + // On stack, before: ... + // On stack, after: program(guid), ... + // + // Push a program expression onto the stack. This takes + // a compile-time guid and converts it into a runtime-accessible + // expression. + pushProgram: function pushProgram(guid) { + if (guid != null) { + this.pushStackLiteral(this.programExpression(guid)); + } else { + this.pushStackLiteral(null); + } + }, + + // [registerDecorator] + // + // On stack, before: hash, program, params..., ... + // On stack, after: ... + // + // Pops off the decorator's parameters, invokes the decorator, + // and inserts the decorator into the decorators list. + registerDecorator: function registerDecorator(paramSize, name) { + var foundDecorator = this.nameLookup('decorators', name, 'decorator'), + options = this.setupHelperArgs(name, paramSize); + + this.decorators.push(['fn = ', this.decorators.functionCall(foundDecorator, '', ['fn', 'props', 'container', options]), ' || fn;']); + }, + + // [invokeHelper] + // + // On stack, before: hash, inverse, program, params..., ... + // On stack, after: result of helper invocation + // + // Pops off the helper's parameters, invokes the helper, + // and pushes the helper's return value onto the stack. + // + // If the helper is not found, `helperMissing` is called. + invokeHelper: function invokeHelper(paramSize, name, isSimple) { + var nonHelper = this.popStack(), + helper = this.setupHelper(paramSize, name), + simple = isSimple ? [helper.name, ' || '] : ''; + + var lookup = ['('].concat(simple, nonHelper); + if (!this.options.strict) { + lookup.push(' || ', this.aliasable('helpers.helperMissing')); + } + lookup.push(')'); + + this.push(this.source.functionCall(lookup, 'call', helper.callParams)); + }, + + // [invokeKnownHelper] + // + // On stack, before: hash, inverse, program, params..., ... + // On stack, after: result of helper invocation + // + // This operation is used when the helper is known to exist, + // so a `helperMissing` fallback is not required. + invokeKnownHelper: function invokeKnownHelper(paramSize, name) { + var helper = this.setupHelper(paramSize, name); + this.push(this.source.functionCall(helper.name, 'call', helper.callParams)); + }, + + // [invokeAmbiguous] + // + // On stack, before: hash, inverse, program, params..., ... + // On stack, after: result of disambiguation + // + // This operation is used when an expression like `{{foo}}` + // is provided, but we don't know at compile-time whether it + // is a helper or a path. + // + // This operation emits more code than the other options, + // and can be avoided by passing the `knownHelpers` and + // `knownHelpersOnly` flags at compile-time. + invokeAmbiguous: function invokeAmbiguous(name, helperCall) { + this.useRegister('helper'); + + var nonHelper = this.popStack(); + + this.emptyHash(); + var helper = this.setupHelper(0, name, helperCall); + + var helperName = this.lastHelper = this.nameLookup('helpers', name, 'helper'); + + var lookup = ['(', '(helper = ', helperName, ' || ', nonHelper, ')']; + if (!this.options.strict) { + lookup[0] = '(helper = '; + lookup.push(' != null ? helper : ', this.aliasable('helpers.helperMissing')); + } + + this.push(['(', lookup, helper.paramsInit ? ['),(', helper.paramsInit] : [], '),', '(typeof helper === ', this.aliasable('"function"'), ' ? ', this.source.functionCall('helper', 'call', helper.callParams), ' : helper))']); + }, + + // [invokePartial] + // + // On stack, before: context, ... + // On stack after: result of partial invocation + // + // This operation pops off a context, invokes a partial with that context, + // and pushes the result of the invocation back. + invokePartial: function invokePartial(isDynamic, name, indent) { + var params = [], + options = this.setupParams(name, 1, params); + + if (isDynamic) { + name = this.popStack(); + delete options.name; + } + + if (indent) { + options.indent = JSON.stringify(indent); + } + options.helpers = 'helpers'; + options.partials = 'partials'; + options.decorators = 'container.decorators'; + + if (!isDynamic) { + params.unshift(this.nameLookup('partials', name, 'partial')); + } else { + params.unshift(name); + } + + if (this.options.compat) { + options.depths = 'depths'; + } + options = this.objectLiteral(options); + params.push(options); + + this.push(this.source.functionCall('container.invokePartial', '', params)); + }, + + // [assignToHash] + // + // On stack, before: value, ..., hash, ... + // On stack, after: ..., hash, ... + // + // Pops a value off the stack and assigns it to the current hash + assignToHash: function assignToHash(key) { + var value = this.popStack(), + context = undefined, + type = undefined, + id = undefined; + + if (this.trackIds) { + id = this.popStack(); + } + if (this.stringParams) { + type = this.popStack(); + context = this.popStack(); + } + + var hash = this.hash; + if (context) { + hash.contexts[key] = context; + } + if (type) { + hash.types[key] = type; + } + if (id) { + hash.ids[key] = id; + } + hash.values[key] = value; + }, + + pushId: function pushId(type, name, child) { + if (type === 'BlockParam') { + this.pushStackLiteral('blockParams[' + name[0] + '].path[' + name[1] + ']' + (child ? ' + ' + JSON.stringify('.' + child) : '')); + } else if (type === 'PathExpression') { + this.pushString(name); + } else if (type === 'SubExpression') { + this.pushStackLiteral('true'); + } else { + this.pushStackLiteral('null'); + } + }, + + // HELPERS + + compiler: JavaScriptCompiler, + + compileChildren: function compileChildren(environment, options) { + var children = environment.children, + child = undefined, + compiler = undefined; + + for (var i = 0, l = children.length; i < l; i++) { + child = children[i]; + compiler = new this.compiler(); // eslint-disable-line new-cap + + var index = this.matchExistingProgram(child); + + if (index == null) { + this.context.programs.push(''); // Placeholder to prevent name conflicts for nested children + index = this.context.programs.length; + child.index = index; + child.name = 'program' + index; + this.context.programs[index] = compiler.compile(child, options, this.context, !this.precompile); + this.context.decorators[index] = compiler.decorators; + this.context.environments[index] = child; + + this.useDepths = this.useDepths || compiler.useDepths; + this.useBlockParams = this.useBlockParams || compiler.useBlockParams; + } else { + child.index = index; + child.name = 'program' + index; + + this.useDepths = this.useDepths || child.useDepths; + this.useBlockParams = this.useBlockParams || child.useBlockParams; + } + } + }, + matchExistingProgram: function matchExistingProgram(child) { + for (var i = 0, len = this.context.environments.length; i < len; i++) { + var environment = this.context.environments[i]; + if (environment && environment.equals(child)) { + return i; + } + } + }, + + programExpression: function programExpression(guid) { + var child = this.environment.children[guid], + programParams = [child.index, 'data', child.blockParams]; + + if (this.useBlockParams || this.useDepths) { + programParams.push('blockParams'); + } + if (this.useDepths) { + programParams.push('depths'); + } + + return 'container.program(' + programParams.join(', ') + ')'; + }, + + useRegister: function useRegister(name) { + if (!this.registers[name]) { + this.registers[name] = true; + this.registers.list.push(name); + } + }, + + push: function push(expr) { + if (!(expr instanceof Literal)) { + expr = this.source.wrap(expr); + } + + this.inlineStack.push(expr); + return expr; + }, + + pushStackLiteral: function pushStackLiteral(item) { + this.push(new Literal(item)); + }, + + pushSource: function pushSource(source) { + if (this.pendingContent) { + this.source.push(this.appendToBuffer(this.source.quotedString(this.pendingContent), this.pendingLocation)); + this.pendingContent = undefined; + } + + if (source) { + this.source.push(source); + } + }, + + replaceStack: function replaceStack(callback) { + var prefix = ['('], + stack = undefined, + createdStack = undefined, + usedLiteral = undefined; + + /* istanbul ignore next */ + if (!this.isInline()) { + throw new _exception2['default']('replaceStack on non-inline'); + } + + // We want to merge the inline statement into the replacement statement via ',' + var top = this.popStack(true); + + if (top instanceof Literal) { + // Literals do not need to be inlined + stack = [top.value]; + prefix = ['(', stack]; + usedLiteral = true; + } else { + // Get or create the current stack name for use by the inline + createdStack = true; + var _name = this.incrStack(); + + prefix = ['((', this.push(_name), ' = ', top, ')']; + stack = this.topStack(); + } + + var item = callback.call(this, stack); + + if (!usedLiteral) { + this.popStack(); + } + if (createdStack) { + this.stackSlot--; + } + this.push(prefix.concat(item, ')')); + }, + + incrStack: function incrStack() { + this.stackSlot++; + if (this.stackSlot > this.stackVars.length) { + this.stackVars.push('stack' + this.stackSlot); + } + return this.topStackName(); + }, + topStackName: function topStackName() { + return 'stack' + this.stackSlot; + }, + flushInline: function flushInline() { + var inlineStack = this.inlineStack; + this.inlineStack = []; + for (var i = 0, len = inlineStack.length; i < len; i++) { + var entry = inlineStack[i]; + /* istanbul ignore if */ + if (entry instanceof Literal) { + this.compileStack.push(entry); + } else { + var stack = this.incrStack(); + this.pushSource([stack, ' = ', entry, ';']); + this.compileStack.push(stack); + } + } + }, + isInline: function isInline() { + return this.inlineStack.length; + }, + + popStack: function popStack(wrapped) { + var inline = this.isInline(), + item = (inline ? this.inlineStack : this.compileStack).pop(); + + if (!wrapped && item instanceof Literal) { + return item.value; + } else { + if (!inline) { + /* istanbul ignore next */ + if (!this.stackSlot) { + throw new _exception2['default']('Invalid stack pop'); + } + this.stackSlot--; + } + return item; + } + }, + + topStack: function topStack() { + var stack = this.isInline() ? this.inlineStack : this.compileStack, + item = stack[stack.length - 1]; + + /* istanbul ignore if */ + if (item instanceof Literal) { + return item.value; + } else { + return item; + } + }, + + contextName: function contextName(context) { + if (this.useDepths && context) { + return 'depths[' + context + ']'; + } else { + return 'depth' + context; + } + }, + + quotedString: function quotedString(str) { + return this.source.quotedString(str); + }, + + objectLiteral: function objectLiteral(obj) { + return this.source.objectLiteral(obj); + }, + + aliasable: function aliasable(name) { + var ret = this.aliases[name]; + if (ret) { + ret.referenceCount++; + return ret; + } + + ret = this.aliases[name] = this.source.wrap(name); + ret.aliasable = true; + ret.referenceCount = 1; + + return ret; + }, + + setupHelper: function setupHelper(paramSize, name, blockHelper) { + var params = [], + paramsInit = this.setupHelperArgs(name, paramSize, params, blockHelper); + var foundHelper = this.nameLookup('helpers', name, 'helper'), + callContext = this.aliasable(this.contextName(0) + ' != null ? ' + this.contextName(0) + ' : {}'); + + return { + params: params, + paramsInit: paramsInit, + name: foundHelper, + callParams: [callContext].concat(params) + }; + }, + + setupParams: function setupParams(helper, paramSize, params) { + var options = {}, + contexts = [], + types = [], + ids = [], + objectArgs = !params, + param = undefined; + + if (objectArgs) { + params = []; + } + + options.name = this.quotedString(helper); + options.hash = this.popStack(); + + if (this.trackIds) { + options.hashIds = this.popStack(); + } + if (this.stringParams) { + options.hashTypes = this.popStack(); + options.hashContexts = this.popStack(); + } + + var inverse = this.popStack(), + program = this.popStack(); + + // Avoid setting fn and inverse if neither are set. This allows + // helpers to do a check for `if (options.fn)` + if (program || inverse) { + options.fn = program || 'container.noop'; + options.inverse = inverse || 'container.noop'; + } + + // The parameters go on to the stack in order (making sure that they are evaluated in order) + // so we need to pop them off the stack in reverse order + var i = paramSize; + while (i--) { + param = this.popStack(); + params[i] = param; + + if (this.trackIds) { + ids[i] = this.popStack(); + } + if (this.stringParams) { + types[i] = this.popStack(); + contexts[i] = this.popStack(); + } + } + + if (objectArgs) { + options.args = this.source.generateArray(params); + } + + if (this.trackIds) { + options.ids = this.source.generateArray(ids); + } + if (this.stringParams) { + options.types = this.source.generateArray(types); + options.contexts = this.source.generateArray(contexts); + } + + if (this.options.data) { + options.data = 'data'; + } + if (this.useBlockParams) { + options.blockParams = 'blockParams'; + } + return options; + }, + + setupHelperArgs: function setupHelperArgs(helper, paramSize, params, useRegister) { + var options = this.setupParams(helper, paramSize, params); + options = this.objectLiteral(options); + if (useRegister) { + this.useRegister('options'); + params.push('options'); + return ['options=', options]; + } else if (params) { + params.push(options); + return ''; + } else { + return options; + } + } + }; + + (function () { + var reservedWords = ('break else new var' + ' case finally return void' + ' catch for switch while' + ' continue function this with' + ' default if throw' + ' delete in try' + ' do instanceof typeof' + ' abstract enum int short' + ' boolean export interface static' + ' byte extends long super' + ' char final native synchronized' + ' class float package throws' + ' const goto private transient' + ' debugger implements protected volatile' + ' double import public let yield await' + ' null true false').split(' '); + + var compilerWords = JavaScriptCompiler.RESERVED_WORDS = {}; + + for (var i = 0, l = reservedWords.length; i < l; i++) { + compilerWords[reservedWords[i]] = true; + } + })(); + + JavaScriptCompiler.isValidJavaScriptVariableName = function (name) { + return !JavaScriptCompiler.RESERVED_WORDS[name] && /^[a-zA-Z_$][0-9a-zA-Z_$]*$/.test(name); + }; + + function strictLookup(requireTerminal, compiler, parts, type) { + var stack = compiler.popStack(), + i = 0, + len = parts.length; + if (requireTerminal) { + len--; + } + + for (; i < len; i++) { + stack = compiler.nameLookup(stack, parts[i], type); + } + + if (requireTerminal) { + return [compiler.aliasable('container.strict'), '(', stack, ', ', compiler.quotedString(parts[i]), ')']; + } else { + return stack; + } + } + + exports['default'] = JavaScriptCompiler; + module.exports = exports['default']; + +/***/ }, +/* 29 */ +/***/ function(module, exports, __webpack_require__) { + + /* global define */ + 'use strict'; + + exports.__esModule = true; + + var _utils = __webpack_require__(5); + + var SourceNode = undefined; + + try { + /* istanbul ignore next */ + if (false) { + // We don't support this in AMD environments. For these environments, we asusme that + // they are running on the browser and thus have no need for the source-map library. + var SourceMap = require('source-map'); + SourceNode = SourceMap.SourceNode; + } + } catch (err) {} + /* NOP */ + + /* istanbul ignore if: tested but not covered in istanbul due to dist build */ + if (!SourceNode) { + SourceNode = function (line, column, srcFile, chunks) { + this.src = ''; + if (chunks) { + this.add(chunks); + } + }; + /* istanbul ignore next */ + SourceNode.prototype = { + add: function add(chunks) { + if (_utils.isArray(chunks)) { + chunks = chunks.join(''); + } + this.src += chunks; + }, + prepend: function prepend(chunks) { + if (_utils.isArray(chunks)) { + chunks = chunks.join(''); + } + this.src = chunks + this.src; + }, + toStringWithSourceMap: function toStringWithSourceMap() { + return { code: this.toString() }; + }, + toString: function toString() { + return this.src; + } + }; + } + + function castChunk(chunk, codeGen, loc) { + if (_utils.isArray(chunk)) { + var ret = []; + + for (var i = 0, len = chunk.length; i < len; i++) { + ret.push(codeGen.wrap(chunk[i], loc)); + } + return ret; + } else if (typeof chunk === 'boolean' || typeof chunk === 'number') { + // Handle primitives that the SourceNode will throw up on + return chunk + ''; + } + return chunk; + } + + function CodeGen(srcFile) { + this.srcFile = srcFile; + this.source = []; + } + + CodeGen.prototype = { + isEmpty: function isEmpty() { + return !this.source.length; + }, + prepend: function prepend(source, loc) { + this.source.unshift(this.wrap(source, loc)); + }, + push: function push(source, loc) { + this.source.push(this.wrap(source, loc)); + }, + + merge: function merge() { + var source = this.empty(); + this.each(function (line) { + source.add([' ', line, '\n']); + }); + return source; + }, + + each: function each(iter) { + for (var i = 0, len = this.source.length; i < len; i++) { + iter(this.source[i]); + } + }, + + empty: function empty() { + var loc = this.currentLocation || { start: {} }; + return new SourceNode(loc.start.line, loc.start.column, this.srcFile); + }, + wrap: function wrap(chunk) { + var loc = arguments.length <= 1 || arguments[1] === undefined ? this.currentLocation || { start: {} } : arguments[1]; + + if (chunk instanceof SourceNode) { + return chunk; + } + + chunk = castChunk(chunk, this, loc); + + return new SourceNode(loc.start.line, loc.start.column, this.srcFile, chunk); + }, + + functionCall: function functionCall(fn, type, params) { + params = this.generateList(params); + return this.wrap([fn, type ? '.' + type + '(' : '(', params, ')']); + }, + + quotedString: function quotedString(str) { + return '"' + (str + '').replace(/\\/g, '\\\\').replace(/"/g, '\\"').replace(/\n/g, '\\n').replace(/\r/g, '\\r').replace(/\u2028/g, '\\u2028') // Per Ecma-262 7.3 + 7.8.4 + .replace(/\u2029/g, '\\u2029') + '"'; + }, + + objectLiteral: function objectLiteral(obj) { + var pairs = []; + + for (var key in obj) { + if (obj.hasOwnProperty(key)) { + var value = castChunk(obj[key], this); + if (value !== 'undefined') { + pairs.push([this.quotedString(key), ':', value]); + } + } + } + + var ret = this.generateList(pairs); + ret.prepend('{'); + ret.add('}'); + return ret; + }, + + generateList: function generateList(entries) { + var ret = this.empty(); + + for (var i = 0, len = entries.length; i < len; i++) { + if (i) { + ret.add(','); + } + + ret.add(castChunk(entries[i], this)); + } + + return ret; + }, + + generateArray: function generateArray(entries) { + var ret = this.generateList(entries); + ret.prepend('['); + ret.add(']'); + + return ret; + } + }; + + exports['default'] = CodeGen; + module.exports = exports['default']; + +/***/ } +/******/ ]) +}); +; \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.xml new file mode 100644 index 0000000000..f3f05dfca4 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_handlebars_js.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Page" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/html</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>handlebars.js</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_handlebars_js</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Page</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>handlebars JS</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779992.59</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64658.11040.49834</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779668.98</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779255.66</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.html new file mode 100644 index 0000000000..b11754cd5a --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.html @@ -0,0 +1,47 @@ +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Jio Web Page View</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="handlebars.js"></script> + + <script class="view-web-page-template" type="text/x-handlebars-template"> + <a href="{{url_string}}" style="display: block; text-align: center; font-size: 1.7em;">{{url_string}}</a> + + <form class="view-web-page-form"> + <div class="center"> + <div class="ui-field-contain"> + <label data-i18n="Title:">Title:</label> + <input type="text" name="title" value="{{title}}"> + </div> + + <div class="ui-field-contain"> + <label data-i18n="Url:">Url:</label> + <input type="text" name="url_string" value="{{url_string}}"> + </div> + + <div class="ui-field-contain"> + <label data-i18n="Description:">Description:</label> + <textarea name="description">{{description}}</textarea> + </div> + + <div> + <button type="submit" data-i18n="Save" style="display:none;">Save</button> + </div> + </div> + </form> + + </script> + + <script src="gadget_officejs_jio_bookmark_view.js"></script> + + </head> + + <body> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.xml new file mode 100644 index 0000000000..ccabc8eabc --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_html.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Page" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/html</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_jio_bookmark_view.html</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_jio_bookmark_view_html</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Page</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>OfficeJS Jio Bookmark View</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781391.48</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64652.65377.29115</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781383.01</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779339.13</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.js new file mode 100644 index 0000000000..f8ce83e512 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.js @@ -0,0 +1,142 @@ +/*globals window, rJS, Handlebars, RSVP, loopEventListener, console*/ +/*jslint indent: 2, nomen: true, maxlen: 80*/ +(function (window, RSVP, rJS, Handlebars, loopEventListener) { + "use strict"; + + function saveContent(gadget, submit_event) { + var i, + doc = gadget.options.doc, + now = new Date(); + doc.parent_relative_url = "bookmark_module"; + doc.portal_type = "Bookmark"; + doc.modification_date = now.toISOString(); + for (i = 0; i < submit_event.target.length; i += 1) { + // XXX Should check input type instead + if (submit_event.target[i].name) { + doc[submit_event.target[i].name] = submit_event.target[i].value; + } + } + return new RSVP.Queue() + .push(function () { + return gadget.put(gadget.options.jio_key, doc); + }); + } + + function maximize(gadget) { + var iframe = gadget.props.element.querySelector('iframe'), + iframe_class_string = iframe.getAttribute('class') || "", + class_name = "ui-content-maximize", + class_index = iframe_class_string.indexOf(class_name); + if (class_index === -1) { + iframe_class_string += ' ' + class_name; + iframe.setAttribute('style', ''); + iframe.setAttribute('class', iframe_class_string); + return; + } + iframe_class_string = iframe_class_string.substring(0, class_index) + + iframe_class_string.substring(class_index + class_name.length); + iframe.setAttribute('style', 'width:100%; border: 0 none; height: 600px'); + iframe.setAttribute('class', iframe_class_string); + return; + } + + var gadget_klass = rJS(window), + source = gadget_klass.__template_element + .querySelector(".view-web-page-template") + .innerHTML, + template = Handlebars.compile(source); + + + gadget_klass + .ready(function (g) { + g.props = {}; + g.options = null; + return g.getElement() + .push(function (element) { + g.props.element = element; + g.props.deferred = RSVP.defer(); + }); + }) + + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod("get", "jio_get") + .declareAcquiredMethod("translateHtml", "translateHtml") + .declareAcquiredMethod("put", "jio_put") + .declareAcquiredMethod('allDocs', 'jio_allDocs') + .declareAcquiredMethod("redirect", "redirect") + + .allowPublicAcquisition('triggerMaximize', function () { + var gadget = this; + return RSVP.Queue() + .push(function () { + return maximize(gadget); + }) + .fail(function (e) { + console.log(e); + }); + }) + + .allowPublicAcquisition('triggerSubmit', function () { + return this.props.element.querySelector('button').click(); + }) + + .declareMethod('triggerSubmit', function () { + return this.props.element.querySelector('button').click(); + }) + + .declareMethod("render", function (options) { + var gadget = this; + gadget.options = options; + gadget.options.doc.title = gadget.options.doc.title || ""; + return new RSVP.Queue() + .push(function () { + return gadget.translateHtml(template(options.doc)); + }) + .push(function (html) { + gadget.props.element.innerHTML = html; + return gadget.updateHeader({ + title: options.doc.title + " | Bookmark", + save_action: true + }); + }) + .push(function () { + return gadget.props.deferred.resolve(); + }); + }) + + ///////////////////////////////////////// + // Render text content gadget + ///////////////////////////////////////// + .declareService(function () { + var gadget = this, + text_gadget = null; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }); + }) + + ///////////////////////////////////////// + // Form submit + ///////////////////////////////////////// + .declareService(function () { + var gadget = this; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }) + .push(function () { + return loopEventListener( + gadget.props.element.querySelector('form'), + 'submit', + true, + function (event) { + return saveContent(gadget, event); + } + ); + }); + }); + +}(window, RSVP, rJS, Handlebars, loopEventListener)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.xml new file mode 100644 index 0000000000..8ce9072aa6 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_bookmark_view_js.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Script" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_jio_bookmark_view.js</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_jio_bookmark_view_js</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Script</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>OfficeJS Jio Bookmark view JS</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781322.76</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64652.63438.53777</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781314.69</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779337.2</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.html index 9c7aaa60b7..938ba6717e 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.html @@ -1,47 +1,47 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS Jio Web Page View</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - <script src="handlebars.js"></script> - - <script class="view-web-page-template" type="text/x-handlebars-template"> - <a href="{{url_string}}" style="display: block; text-align: center; font-size: 1.7em;">{{url_string}}</a> - - <form class="view-web-page-form"> - <div class="center"> - <div class="ui-field-contain"> - <label data-i18n="Title:">Title:</label> - <input type="text" name="title" value="{{title}}"> - </div> - - <div class="ui-field-contain"> - <label data-i18n="Url:">Url:</label> - <input type="text" name="url_string" value="{{url_string}}"> - </div> - - <div class="ui-field-contain"> - <label data-i18n="Description:">Description:</label> - <textarea name="description">{{description}}</textarea> - </div> - - <div> - <button type="submit" data-i18n="Save" style="display:none;">Save</button> - </div> - </div> - </form> - - </script> - - <script src="gadget_officejs_jio_url_view.js"></script> - - </head> - - <body> - </body> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Jio Web Page View</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="handlebars.js"></script> + + <script class="view-web-page-template" type="text/x-handlebars-template"> + <a href="{{url_string}}" style="display: block; text-align: center; font-size: 1.7em;">{{url_string}}</a> + + <form class="view-web-page-form"> + <div class="center"> + <div class="ui-field-contain"> + <label data-i18n="Title:">Title:</label> + <input type="text" name="title" value="{{title}}"> + </div> + + <div class="ui-field-contain"> + <label data-i18n="Url:">Url:</label> + <input type="text" name="url_string" value="{{url_string}}"> + </div> + + <div class="ui-field-contain"> + <label data-i18n="Description:">Description:</label> + <textarea name="description">{{description}}</textarea> + </div> + + <div> + <button type="submit" data-i18n="Save" style="display:none;">Save</button> + </div> + </div> + </form> + + </script> + + <script src="gadget_officejs_jio_url_view.js"></script> + + </head> + + <body> + </body> </html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.xml index 6ae707bf11..ed859bab02 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_html.xml @@ -105,13 +105,11 @@ </item> <item> <key> <string>title</string> </key> - <value> <string>OfficeJS Jio Bookmark View</string> </value> + <value> <string>OfficeJS Bookmark List</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -193,7 +191,7 @@ </tuple> <state> <tuple> - <float>1468958515.0</float> + <float>1485781210.11</float> <string>UTC</string> </tuple> </state> @@ -238,7 +236,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.49823.4948.58316</string> </value> + <value> <string>956.64689.57793.57070</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +254,7 @@ </tuple> <state> <tuple> - <float>1480959906.78</float> + <float>1485781570.45</float> <string>UTC</string> </tuple> </state> @@ -279,7 +277,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -295,7 +295,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -313,7 +313,7 @@ </tuple> <state> <tuple> - <float>1468958471.49</float> + <float>1485779333.22</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.js index 64ede43f86..107f33668d 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.js @@ -1,125 +1,125 @@ -/*globals window, rJS, Handlebars, RSVP, loopEventListener, console*/ -/*jslint indent: 2, nomen: true, maxlen: 80*/ -(function (window, RSVP, rJS, Handlebars, loopEventListener) { - "use strict"; - - function saveContent(gadget, submit_event) { - var i, - doc = gadget.options.doc, - now = new Date(); - return new RSVP.Queue() - .push(function () { - return RSVP.all([ - gadget.getSetting("portal_type"), - gadget.getSetting("parent_relative_url") - ]); - }) - .push(function (answer_list) { - doc.portal_type = answer_list[0]; - doc.parent_relative_url = answer_list[1]; - doc.modification_date = now.toISOString(); - - for (i = 0; i < submit_event.target.length; i += 1) { - // XXX Should check input type instead - if (submit_event.target[i].name) { - doc[submit_event.target[i].name] = submit_event.target[i].value; - } - } - - return gadget.put(gadget.options.jio_key, doc); - }); - } - - var gadget_klass = rJS(window), - source = gadget_klass.__template_element - .querySelector(".view-web-page-template") - .innerHTML, - template = Handlebars.compile(source); - - - gadget_klass - .ready(function (g) { - g.props = {}; - g.options = null; - return g.getElement() - .push(function (element) { - g.props.element = element; - g.props.deferred = RSVP.defer(); - }); - }) - - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod('getSetting', 'getSetting') - .declareAcquiredMethod("get", "jio_get") - .declareAcquiredMethod("translateHtml", "translateHtml") - .declareAcquiredMethod("put", "jio_put") - .declareAcquiredMethod('allDocs', 'jio_allDocs') - .declareAcquiredMethod("redirect", "redirect") - - .allowPublicAcquisition('triggerSubmit', function () { - return this.props.element.querySelector('button').click(); - }) - - .declareMethod('triggerSubmit', function () { - return this.props.element.querySelector('button').click(); - }) - - .declareMethod("render", function (options) { - var gadget = this; - gadget.options = options; - gadget.options.doc.title = gadget.options.doc.title || ""; - return new RSVP.Queue() - .push(function () { - return gadget.translateHtml(template(options.doc)); - }) - .push(function (html) { - gadget.props.element.innerHTML = html; - return gadget.updateHeader({ - title: options.doc.title + " | Bookmark", - save_action: true - }); - }) - .push(function () { - return gadget.props.deferred.resolve(); - }); - }) - - ///////////////////////////////////////// - // Render text content gadget - ///////////////////////////////////////// - .declareService(function () { - var gadget = this, - text_gadget = null; - - return new RSVP.Queue() - .push(function () { - return gadget.props.deferred.promise; - }); - }) - - ///////////////////////////////////////// - // Form submit - ///////////////////////////////////////// - .declareService(function () { - var gadget = this; - - return new RSVP.Queue() - .push(function () { - return gadget.props.deferred.promise; - }) - .push(function () { - return loopEventListener( - gadget.props.element.querySelector('form'), - 'submit', - true, - function (event) { - return saveContent(gadget, event) - .push(function () { - return gadget.redirect({page: "bookmark_list"}); - }); - } - ); - }); - }); - +/*globals window, rJS, Handlebars, RSVP, loopEventListener, console*/ +/*jslint indent: 2, nomen: true, maxlen: 80*/ +(function (window, RSVP, rJS, Handlebars, loopEventListener) { + "use strict"; + + function saveContent(gadget, submit_event) { + var i, + doc = gadget.options.doc, + now = new Date(); + return new RSVP.Queue() + .push(function () { + return RSVP.all([ + gadget.getSetting("portal_type"), + gadget.getSetting("parent_relative_url") + ]); + }) + .push(function (answer_list) { + doc.portal_type = answer_list[0]; + doc.parent_relative_url = answer_list[1]; + doc.modification_date = now.toISOString(); + + for (i = 0; i < submit_event.target.length; i += 1) { + // XXX Should check input type instead + if (submit_event.target[i].name) { + doc[submit_event.target[i].name] = submit_event.target[i].value; + } + } + + return gadget.put(gadget.options.jio_key, doc); + }); + } + + var gadget_klass = rJS(window), + source = gadget_klass.__template_element + .querySelector(".view-web-page-template") + .innerHTML, + template = Handlebars.compile(source); + + + gadget_klass + .ready(function (g) { + g.props = {}; + g.options = null; + return g.getElement() + .push(function (element) { + g.props.element = element; + g.props.deferred = RSVP.defer(); + }); + }) + + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod('getSetting', 'getSetting') + .declareAcquiredMethod("get", "jio_get") + .declareAcquiredMethod("translateHtml", "translateHtml") + .declareAcquiredMethod("put", "jio_put") + .declareAcquiredMethod('allDocs', 'jio_allDocs') + .declareAcquiredMethod("redirect", "redirect") + + .allowPublicAcquisition('triggerSubmit', function () { + return this.props.element.querySelector('button').click(); + }) + + .declareMethod('triggerSubmit', function () { + return this.props.element.querySelector('button').click(); + }) + + .declareMethod("render", function (options) { + var gadget = this; + gadget.options = options; + gadget.options.doc.title = gadget.options.doc.title || ""; + return new RSVP.Queue() + .push(function () { + return gadget.translateHtml(template(options.doc)); + }) + .push(function (html) { + gadget.props.element.innerHTML = html; + return gadget.updateHeader({ + title: options.doc.title + " | Bookmark", + save_action: true + }); + }) + .push(function () { + return gadget.props.deferred.resolve(); + }); + }) + + ///////////////////////////////////////// + // Render text content gadget + ///////////////////////////////////////// + .declareService(function () { + var gadget = this, + text_gadget = null; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }); + }) + + ///////////////////////////////////////// + // Form submit + ///////////////////////////////////////// + .declareService(function () { + var gadget = this; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }) + .push(function () { + return loopEventListener( + gadget.props.element.querySelector('form'), + 'submit', + true, + function (event) { + return saveContent(gadget, event) + .push(function () { + return gadget.redirect({page: "bookmark_list"}); + }); + } + ); + }); + }); + }(window, RSVP, rJS, Handlebars, loopEventListener)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.xml index 9b98c538e7..58ea9fecbe 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_url_view_js.xml @@ -69,6 +69,10 @@ <none/> </value> </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_jio_url_view.js</string> </value> @@ -93,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> - <value> <string>OfficeJS Jio Bookmark view JS</string> </value> + <value> <string>OfficeJS Bookmark List JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -189,7 +185,7 @@ </tuple> <state> <tuple> - <float>1468958553.47</float> + <float>1485781151.76</float> <string>UTC</string> </tuple> </state> @@ -234,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.49845.11611.51046</string> </value> + <value> <string>956.64652.56936.54408</string> </value> </item> <item> <key> <string>state</string> </key> @@ -252,7 +248,7 @@ </tuple> <state> <tuple> - <float>1480959915.54</float> + <float>1485781142.8</float> <string>UTC</string> </tuple> </state> @@ -275,7 +271,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -291,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -309,7 +307,7 @@ </tuple> <state> <tuple> - <float>1468958530.09</float> + <float>1485779331.34</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_html.xml index 78c9e1a08a..e98effd1e2 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_html.xml @@ -144,9 +144,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -259,7 +257,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>supercedriclen</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -273,7 +271,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>951.29240.27236.54562</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -291,7 +289,7 @@ </tuple> <state> <tuple> - <float>1464253011.4</float> + <float>1485781082.56</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_js.xml index 5c8b5512bd..ed03b92f26 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_illustration_view_js.xml @@ -140,9 +140,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -269,7 +267,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>954.15924.25382.7799</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -287,7 +285,7 @@ </tuple> <state> <tuple> - <float>1475164165.45</float> + <float>1485781045.04</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_html.xml index 7cdb140757..12495fcfb7 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_html.xml @@ -109,9 +109,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -232,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>954.38520.8745.1109</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -250,7 +248,7 @@ </tuple> <state> <tuple> - <float>1476433509.51</float> + <float>1485781000.66</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_js.xml index b9e94b80b4..35d22ba6ff 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_jio_web_page_view_js.xml @@ -105,9 +105,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -228,7 +226,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>954.15935.39380.57002</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -246,7 +244,7 @@ </tuple> <state> <tuple> - <float>1475164868.59</float> + <float>1485780967.55</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.html new file mode 100644 index 0000000000..8abce25ca3 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.html @@ -0,0 +1,20 @@ +<!DOCTYPE html> +<html> + <head> + <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> + <meta name="viewport" content="width=device-width, user-scalable=no" /> + <title>Jio Gadget</title> + + <!-- renderjs --> + <script src="rsvp.js" type="text/javascript"></script> + <script src="renderjs.js" type="text/javascript"></script> + + <script src="jiodev.js" type="text/javascript"></script> + + <!-- custom script --> + <script src="gadget_crib_bridge.js" type="text/javascript"></script> + + </head> + <body> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.xml new file mode 100644 index 0000000000..943804a84c --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_html.xml @@ -0,0 +1,326 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Page" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/html</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_liberator.html</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> <string>Jio access</string> </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_liberator_html</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Page</string> </value> + </item> + <item> + <key> <string>short_title</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>Liberator Gadget</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781795.26</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64693.60428.35840</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781800.12</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779372.4</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.js new file mode 100644 index 0000000000..483d568ae3 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.js @@ -0,0 +1,98 @@ +/*global window, rJS, jIO, FormData, RSVP, MessageChannel */ +/*jslint indent: 2, maxerr: 3 */ +(function (window, rJS, jIO, MessageChannel, RSVP) { + "use strict"; + + rJS(window) + + .ready(function (gadget) { + gadget.state_parameter_dict = {}; + }) + + .declareMethod('createStorage', function (erp5_url) { + this.state_parameter_dict.jio_storage = jIO.createJIO({ + use_remote_post: false, + conflict_handling: 1, + check_local_modification: true, + check_local_creation: true, + check_local_deletion: false, + check_remote_modification: false, + check_remote_creation: false, + check_remote_deletion: false, + type: "replicate", + query: {query: 'content_type: "text%"'}, + signature_storage: { + type: "indexeddb", + database: "sync_hash" + }, + local_sub_storage: { + type: "uuid", + sub_storage: { + type: "query", + sub_storage: { + type: "indexeddb", + database: window.location.origin + + window.location.pathname.replace( + "gadget_officejs_liberator.html", + "" + ) + } + } + }, + remote_sub_storage: { + type: "mapping", + id: ["equalSubProperty", "url_string"], + property: { + "relative_url": ["ignore"], + "version": ["ignore"] + }, + sub_storage: { + type: "erp5", + url: erp5_url + "/hateoas", + default_view_reference: "jio_view" + } + } + }); + }) + .declareMethod('allDocs', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.allDocs.apply(storage, arguments); + }) + .declareMethod('allAttachments', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.allAttachments.apply(storage, arguments); + }) + .declareMethod('get', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.get.apply(storage, arguments); + }) + .declareMethod('put', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.put.apply(storage, arguments); + }) + .declareMethod('post', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.post.apply(storage, arguments); + }) + .declareMethod('remove', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.remove.apply(storage, arguments); + }) + .declareMethod('getAttachment', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.getAttachment.apply(storage, arguments); + }) + .declareMethod('putAttachment', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.putAttachment.apply(storage, arguments); + }) + .declareMethod('removeAttachment', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.removeAttachment.apply(storage, arguments); + }) + .declareMethod('repair', function () { + var storage = this.state_parameter_dict.jio_storage; + return storage.repair.apply(storage, arguments); + }); + +}(window, rJS, jIO, MessageChannel, RSVP)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.xml new file mode 100644 index 0000000000..912a4df4b1 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_liberator_js.xml @@ -0,0 +1,328 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Script" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>application/javascript</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_liberator.js</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_liberator_js</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Script</string> </value> + </item> + <item> + <key> <string>short_title</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>Liberator Gadget JS</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781694.71</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64692.55224.61132</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485781806.83</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779370.64</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_logo_bookmark.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_logo_bookmark.xml new file mode 100644 index 0000000000..86eac5644e --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_logo_bookmark.xml @@ -0,0 +1,437 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Illustration" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>image/svg+xml</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>OSP-25-Web.Bookmark.Editor.Logo</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_logo_bookmark</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Illustration</string> </value> + </item> + <item> + <key> <string>text_content</string> </key> + <value> <string encoding="cdata"><![CDATA[ + +<svg width="700" height="860" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\r\n + <defs>\r\n + <linearGradient id="linearGradient5866">\r\n + <stop id="stop5868" offset="0" stop-color="#000000"/>\r\n + <stop id="stop5870" offset="1" stop-opacity="0" stop-color="#000000"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient2598">\r\n + <stop id="stop2600" offset="0" stop-color="#729fcf"/>\r\n + <stop id="stop2602" offset="1" stop-color="#3465a4"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient4404">\r\n + <stop id="stop4406" offset="0" stop-color="#ffffff"/>\r\n + <stop id="stop4408" offset="1" stop-opacity="0" stop-color="#ffffff"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient2590">\r\n + <stop id="stop2592" offset="0" stop-color="#ffffff"/>\r\n + <stop id="stop2594" offset="1" stop-opacity="0" stop-color="#ffffff"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient2906">\r\n + <stop id="stop2908" offset="0" stop-color="#ffffff"/>\r\n + <stop id="stop2910" offset="1" stop-opacity="0" stop-color="#ffffff"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient2896">\r\n + <stop id="stop2898" offset="0" stop-color="#000000"/>\r\n + <stop id="stop2900" offset="1" stop-opacity="0" stop-color="#000000"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient5048">\r\n + <stop id="stop5050" offset="0" stop-opacity="0" stop-color="black"/>\r\n + <stop id="stop5056" offset="0.5" stop-color="black"/>\r\n + <stop id="stop5052" offset="1" stop-opacity="0" stop-color="black"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient5060">\r\n + <stop id="stop5062" offset="0" stop-color="black"/>\r\n + <stop id="stop5064" offset="1" stop-opacity="0" stop-color="black"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient259">\r\n + <stop id="stop260" offset="0" stop-color="#ffffff"/>\r\n + <stop id="stop261" offset="1" stop-opacity="0" stop-color="#babdb6"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient269">\r\n + <stop id="stop270" offset="0" stop-color="#888a85"/>\r\n + <stop id="stop271" offset="1" stop-color="#555753"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient15662">\r\n + <stop id="stop15664" offset="0" stop-color="#ffffff"/>\r\n + <stop id="stop15666" offset="1" stop-color="#f8f8f8"/>\r\n + </linearGradient>\r\n + <linearGradient id="linearGradient10353" x1="0.73508" x2="0.72067" xlink:href="#linearGradient2896" y1="-0.00079" y2="0.64182"/>\r\n + <linearGradient id="linearGradient10356" x1="0.16681" x2="0.5" xlink:href="#linearGradient2906" y1="0" y2="0.37325"/>\r\n + <linearGradient id="linearGradient10359" x1="0.49689" x2="0.49689" xlink:href="#linearGradient2590" y1="0.23203" y2="0.0506"/>\r\n + <linearGradient id="linearGradient10362" x1="0.39616" x2="0.39616" xlink:href="#linearGradient4404" y1="0.12556" y2="0.53363"/>\r\n + <linearGradient id="linearGradient10365" x1="0.62089" x2="0.6182" xlink:href="#linearGradient2598" y1="0.78682" y2="0.12674"/>\r\n + <linearGradient id="linearGradient10368" x1="0.70493" x2="0.72423" xlink:href="#linearGradient5866" y1="0.48247" y2="1.13444"/>\r\n + <radialGradient cx="8.14356" cy="7.2679" fx="8.14356" fy="7.2679" gradientTransform="matrix(16.510192,0,0,17.560565,6.9297437,160.30189)" gradientUnits="userSpaceOnUse" id="radialGradient10388" r="38.1587" xlink:href="#linearGradient15662"/>\r\n + <radialGradient cx="33.96668" cy="35.73692" fx="33.96668" fy="35.73692" gradientTransform="matrix(16.297417,0,0,17.727392,-48.594034,148.17911)" gradientUnits="userSpaceOnUse" id="radialGradient10391" r="86.70845" xlink:href="#linearGradient259"/>\r\n + <radialGradient cx="8.82442" cy="3.75613" fx="8.82442" fy="3.75613" gradientTransform="matrix(16.429426,0,0,17.584947,8.3082047,159.18626)" gradientUnits="userSpaceOnUse" id="radialGradient10393" r="37.75171" xlink:href="#linearGradient269"/>\r\n + <radialGradient cx="605.71429" cy="486.64789" fx="605.71429" fy="486.64789" gradientTransform="matrix(-1.0192489,0,0,0.4965576,724.33207,655.10373)" gradientUnits="userSpaceOnUse" id="radialGradient10420" r="117.14286" xlink:href="#linearGradient5060"/>\r\n + <radialGradient cx="605.71429" cy="486.64789" fx="605.71429" fy="486.64789" gradientTransform="matrix(1.0192489,0,0,0.4965576,-12.03827,655.10373)" gradientUnits="userSpaceOnUse" id="radialGradient10423" r="117.14286" xlink:href="#linearGradient5060"/>\r\n + <linearGradient id="linearGradient10426" x1="0.3787" x2="0.3787" xlink:href="#linearGradient5048" y1="0" y2="1"/>\r\n + </defs>\r\n + <metadata id="metadata7">image/svg+xmlbookmarkJuly 2008Beate KasparBeate KasparRRZEbook markfavoritereminderplacemarkerHendrik Eggers, Franziska Sponselbased on <http://webcvs.freedesktop.org/tango/tango-icon-theme/scalable/actions/bookmark-new.svg></metadata>\r\n + <g>\r\n + <title>background</title>\r\n + <rect x="-1" y="-1" width="702" height="862" id="canvas_background" fill="none"/>\r\n + </g>\r\n + <g>\r\n + <title>Layer 1</title>\r\n + <g id="layer1">\r\n + <g id="g10428">\r\n + <rect height="850" id="rect2300" width="850" x="-63.54646" y="10.51821" fill="none"/>\r\n + <rect height="120.59255" id="rect4173" width="492.15161" x="111.4044" y="731.82806" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linecap="round" fill-rule="nonzero" fill="url(#linearGradient10426)" opacity="0.40206"/>\r\n + <path d="m603.55603,731.83219c0,0 0,120.5859 0,120.5859c52.4888,0.227 126.89238,-27.01718 126.89235,-60.30071c0,-33.28353 -58.57355,-60.28518 -126.89235,-60.28519z" id="path5058" stroke-dashoffset="0" stroke-miterlimit="4" marker-end="none" marker-mid="none" marker-start="none" stroke-linecap="round" fill-rule="nonzero" fill="url(#radialGradient10423)" opacity="0.40206"/>\r\n + <path d="m111.40441,731.83219c0,0 0,120.5859 0,120.5859c-52.48881,0.227 -126.89237,-27.01718 -126.89237,-60.30071c0,-33.28353 58.57355,-60.28518 126.89237,-60.28519z" id="path5018" stroke-dashoffset="0" stroke-miterlimit="4" marker-end="none" marker-mid="none" marker-start="none" stroke-linecap="round" fill-rule="nonzero" fill="url(#radialGradient10420)" opacity="0.40206"/>\r\n + <rect height="696.75452" id="rect15391" rx="19.49678" ry="19.49677" width="591.75067" x="64.78682" y="104.92996" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" stroke-width="16.96776" stroke="url(#radialGradient10393)" fill-rule="nonzero" fill="url(#radialGradient10391)"/>\r\n + <rect height="662.22137" id="rect15660" rx="2.52902" ry="2.52902" width="558.86737" x="81.79627" y="121.91532" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" stroke-width="16.96775" stroke="url(#radialGradient10388)" fill-rule="nonzero" fill="none"/>\r\n + <path d="m149.72286,138.76824l0,643.19017" id="path15672" stroke-opacity="0.01754" stroke-miterlimit="4" stroke-width="16.77353" stroke="#000000" fill-rule="evenodd" fill-opacity="0.75" fill="none"/>\r\n + <path d="m166.5934,130.72959l0,645.07546" id="path15674" stroke-opacity="0.20468" stroke-miterlimit="4" stroke-width="16.96776" stroke="#ffffff" fill-rule="evenodd" fill-opacity="0.75" fill="none"/>\r\n + <rect height="16.96776" id="rect15686" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="198.25262" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15688" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="232.18816" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15690" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="266.12368" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15692" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="300.0592" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15694" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="333.99471" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15696" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="367.93026" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15698" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="401.86578" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15700" rx="2.33793" ry="1.10954" width="339.35535" x="225.98047" y="435.80132" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15732" rx="1.05207" ry="1.10954" width="152.70996" x="225.98032" y="469.73681" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15736" rx="2.33793" ry="1.10954" width="339.35535" x="225.98032" y="537.60784" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15738" rx="2.33793" ry="1.10954" width="339.35535" x="225.98032" y="571.54339" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15740" rx="2.33793" ry="1.10954" width="339.35535" x="225.98032" y="605.47894" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15742" rx="2.33793" ry="1.10954" width="339.35535" x="225.98032" y="639.41442" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <rect height="16.96776" id="rect15744" rx="1.63655" ry="1.10954" width="237.5489" x="225.98032" y="673.34997" stroke-opacity="0.08187" stroke-dashoffset="0" stroke-miterlimit="4" stroke-linejoin="round" stroke-linecap="round" fill-rule="nonzero" fill="#babdb6"/>\r\n + <path d="m433.7654,577.05622l-120.437,-71.11528l-116.06459,63.6308l-9.25947,-457.04771l250.91485,0l-5.15379,464.53219z" id="path5138" stroke-width="0.25pt" fill-rule="evenodd" fill="url(#linearGradient10368)" opacity="0.28022"/>\r\n + <path d="m165.36052,105.2357c0,0 -3.17806,-49.42404 45.48259,-50.48452l169.87242,-0.601c19.64765,0 24.81603,11.60137 24.81603,27.18694l0,468.65569l-102.42522,-88.16534l-99.61909,88.16534l-1.40307,-444.72979l-36.72366,-0.02732z" id="path2204" stroke-miterlimit="4" stroke-width="16.96776" stroke="#204a87" fill-rule="evenodd" fill="url(#linearGradient10365)"/>\r\n + <path d="m175.59072,96.64611c-0.32595,-13.34396 4.79611,-32.77595 39.79212,-33.83643l163.78115,-0.29914c10.40158,0 18.02401,2.84091 18.02401,13.56538l-0.49478,147.49007l-182.29977,0l-2.12097,-127.13147c0,0 -36.68176,0.21159 -36.68176,0.21159z" id="path3668" stroke-width="0.25pt" fill-rule="evenodd" fill="url(#linearGradient10362)" opacity="0.44505"/>\r\n + <path d="m369.81357,83.03389l18.64248,15.3319l-0.47662,413.99252l-85.68687,-73.09983l-81.33293,71.45888l-0.08484,-418.52071l148.93878,-9.16276z" id="path5969" stroke-opacity="0.19126" stroke-miterlimit="4" stroke-width="16.96776" stroke="url(#linearGradient10359)" fill-rule="evenodd" fill="none"/>\r\n + <path d="m211.70406,112.36861l-0.74998,-49.28948c-36.14981,0 -35.99405,32.82515 -35.99405,49.28948l36.74403,0z" id="path2894" stroke-dashoffset="0" stroke-miterlimit="4" marker-end="none" marker-mid="none" marker-start="none" stroke-width="1.10534" fill-rule="nonzero" fill="url(#linearGradient10356)" opacity="0.48295"/>\r\n + <path d="m211.70406,112.36861l-0.74998,-35.86374c-38.99361,0.30423 -35.99405,35.86374 -35.99405,35.86374l36.74403,0z" id="path2904" stroke-dashoffset="0" stroke-miterlimit="4" marker-end="none" marker-mid="none" marker-start="none" stroke-width="1.10534" fill-rule="nonzero" fill="url(#linearGradient10353)" opacity="0.35795"/>\r\n + </g>\r\n + </g>\r\n + <g id="svg_14" stroke="null">\r\n + <polygon fill="#E44D26" points="479.44830322265625,818.51025390625 457.3672180175781,570.84033203125 700,570.84033203125 677.8956298828125,818.4713745117188 578.5354614257812,846.017822265625 " id="svg_4" stroke="null"/>\r\n + <polygon fill="#F16529" points="578.6839599609375,824.9625244140625 658.9718017578125,802.7031860351562 677.8614501953125,591.0909423828125 578.6839599609375,591.0909423828125 " id="svg_5" stroke="null"/>\r\n + <polygon fill="#EBEBEB" points="578.6839599609375,682.9483032226562 538.4895629882812,682.9483032226562 535.713623046875,651.8430786132812 578.6839599609375,651.8430786132812 578.6839599609375,621.467041015625 578.5789794921875,621.467041015625 502.5171813964844,621.467041015625 503.2442626953125,629.6163940429688 510.7099304199219,713.3236694335938 578.6839599609375,713.3236694335938 " id="svg_6" stroke="null"/>\r\n + <polygon fill="#EBEBEB" points="578.6839599609375,761.8372192382812 578.5508422851562,761.8726196289062 544.7218017578125,752.73779296875 542.5592651367188,728.5120849609375 526.1206665039062,728.5120849609375 512.0670776367188,728.5120849609375 516.3226013183594,776.2061157226562 578.5441284179688,793.4794311523438 578.6839599609375,793.4405517578125 " id="svg_7" stroke="null"/>\r\n + <polygon fill="#FFFFFF" points="578.5789794921875,682.9483032226562 578.5789794921875,713.3236694335938 615.9823608398438,713.3236694335938 612.4566040039062,752.7185668945312 578.5789794921875,761.8626708984375 578.5789794921875,793.46484375 640.8494262695312,776.2061157226562 641.30615234375,771.0741577148438 648.4440307617188,691.1048583984375 649.1851196289062,682.9483032226562 640.9998168945312,682.9483032226562 " id="svg_12" stroke="null"/>\r\n + <polygon fill="#FFFFFF" points="578.5789794921875,621.467041015625 578.5789794921875,640.3329467773438 578.5789794921875,651.7687377929688 578.5789794921875,651.8430786132812 651.8513793945312,651.8430786132812 651.8513793945312,651.8430786132812 651.9490966796875,651.8430786132812 652.5584106445312,645.0154418945312 653.9423217773438,629.6163940429688 654.6688232421875,621.467041015625 " id="svg_13" stroke="null"/>\r\n + </g>\r\n + <image xlink:href="" id="svg_1" height="240" width="240" y="30" x="460"/>\r\n + </g>\r\n +</svg> + +]]></string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>Web Bookmark Editor Logo</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779185.07</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>draft</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64650.35091.33928</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485782040.77</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779185.07</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.html index 52c82aff6f..3e48b50103 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.html @@ -1,19 +1,19 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS Add Bookmark</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - <script src="handlebars.js"></script> - <script src="gadget_officejs_page_add_bookmark.js"></script> - - - </head> - - <body> - </body> -</html> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Add Bookmark</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="handlebars.js"></script> + <script src="gadget_officejs_page_add_bookmark.js"></script> + + + </head> + + <body> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.xml index 5bf833f47c..8185439871 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_html.xml @@ -63,14 +63,6 @@ </tuple> </value> </item> - <item> - <key> <string>categories</string> </key> - <value> - <tuple> - <string>contributor/person_module/1</string> - </tuple> - </value> - </item> <item> <key> <string>content_md5</string> </key> <value> @@ -81,14 +73,6 @@ <key> <string>content_type</string> </key> <value> <string>text/html</string> </value> </item> - <item> - <key> <string>creators</string> </key> - <value> - <tuple> - <string>cedric.le.ninivin</string> - </tuple> - </value> - </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_page_add_bookmark.html</string> </value> @@ -109,44 +93,17 @@ <none/> </value> </item> - <item> - <key> <string>modification_date</string> </key> - <value> - <object> - <klass> - <global name="DateTime" module="DateTime.DateTime"/> - </klass> - <tuple> - <none/> - </tuple> - <state> - <tuple> - <float>1455284351.46</float> - <string>UTC</string> - </tuple> - </state> - </object> - </value> - </item> <item> <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Add Bookmark</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -228,7 +185,7 @@ </tuple> <state> <tuple> - <float>1471549670.93</float> + <float>1485780873.2</float> <string>UTC</string> </tuple> </state> @@ -273,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>953.21235.57104.50295</string> </value> + <value> <string>956.64678.36333.6946</string> </value> </item> <item> <key> <string>state</string> </key> @@ -291,7 +248,7 @@ </tuple> <state> <tuple> - <float>1474013662.65</float> + <float>1485780894.37</float> <string>UTC</string> </tuple> </state> @@ -314,7 +271,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -330,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -348,7 +307,7 @@ </tuple> <state> <tuple> - <float>1471549602.17</float> + <float>1485779320.09</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.js index e465a3e7ea..bc1dac0f04 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.js @@ -1,70 +1,70 @@ -/*globals window, RSVP, rJS*/ -/*jslint indent: 2, nomen: true, maxlen: 80*/ -(function (window, RSVP, rJS) { - "use strict"; - - var gadget_klass = rJS(window); - - gadget_klass - .ready(function (g) { - g.props = {}; - return g.getElement() - .push(function (element) { - g.props.element = element; - g.props.deferred = RSVP.defer(); - }); - }) - - .declareAcquiredMethod("post", "jio_post") - .declareAcquiredMethod("redirect", "redirect") - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod('getSetting', 'getSetting') - - .declareMethod("render", function (options) { - var gadget = this; - gadget.props.options = options; - return new RSVP.Queue() - .push(function () { - return RSVP.all([ - gadget.getSetting("portal_type"), - gadget.getSetting("document_title"), - gadget.getSetting("parent_relative_url") - ]); - }).push(function (answer_list) { - gadget.props.portal_type = answer_list[0]; - gadget.props.document_title = answer_list[1]; - gadget.props.parent_relative_url = answer_list[2]; - return gadget.updateHeader({ - title: "New " + gadget.props.document_title - }); - }) - .push(function () { - gadget.props.deferred.resolve(); - }); - }) - - .declareService(function () { - var gadget = this; - - return new RSVP.Queue() - .push(function () { - return gadget.props.deferred.promise; - }) - .push(function () { - var doc = { - // XXX Hardcoded - parent_relative_url: gadget.props.parent_relative_url, - portal_type: gadget.props.portal_type - }; - return gadget.post(doc); - }) - .push(function (data) { - return gadget.redirect({ - jio_key: data, - page: "view" - }); - }); - - }); - +/*globals window, RSVP, rJS*/ +/*jslint indent: 2, nomen: true, maxlen: 80*/ +(function (window, RSVP, rJS) { + "use strict"; + + var gadget_klass = rJS(window); + + gadget_klass + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + g.props.deferred = RSVP.defer(); + }); + }) + + .declareAcquiredMethod("post", "jio_post") + .declareAcquiredMethod("redirect", "redirect") + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod('getSetting', 'getSetting') + + .declareMethod("render", function (options) { + var gadget = this; + gadget.props.options = options; + return new RSVP.Queue() + .push(function () { + return RSVP.all([ + gadget.getSetting("portal_type"), + gadget.getSetting("document_title"), + gadget.getSetting("parent_relative_url") + ]); + }).push(function (answer_list) { + gadget.props.portal_type = answer_list[0]; + gadget.props.document_title = answer_list[1]; + gadget.props.parent_relative_url = answer_list[2]; + return gadget.updateHeader({ + title: "New " + gadget.props.document_title + }); + }) + .push(function () { + gadget.props.deferred.resolve(); + }); + }) + + .declareService(function () { + var gadget = this; + + return new RSVP.Queue() + .push(function () { + return gadget.props.deferred.promise; + }) + .push(function () { + var doc = { + // XXX Hardcoded + parent_relative_url: gadget.props.parent_relative_url, + portal_type: gadget.props.portal_type + }; + return gadget.post(doc); + }) + .push(function (data) { + return gadget.redirect({ + jio_key: data, + page: "view" + }); + }); + + }); + }(window, RSVP, rJS)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.xml index eb4c782837..0187ec6136 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_add_bookmark_js.xml @@ -63,14 +63,6 @@ </tuple> </value> </item> - <item> - <key> <string>categories</string> </key> - <value> - <tuple> - <string>contributor/person_module/1</string> - </tuple> - </value> - </item> <item> <key> <string>content_md5</string> </key> <value> @@ -78,12 +70,8 @@ </value> </item> <item> - <key> <string>creators</string> </key> - <value> - <tuple> - <string>cedric.le.ninivin</string> - </tuple> - </value> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> </item> <item> <key> <string>default_reference</string> </key> @@ -105,44 +93,17 @@ <none/> </value> </item> - <item> - <key> <string>modification_date</string> </key> - <value> - <object> - <klass> - <global name="DateTime" module="DateTime.DateTime"/> - </klass> - <tuple> - <none/> - </tuple> - <state> - <tuple> - <float>1455284351.49</float> - <string>UTC</string> - </tuple> - </state> - </object> - </value> - </item> <item> <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Add Bookmark JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -224,7 +185,7 @@ </tuple> <state> <tuple> - <float>1471549673.52</float> + <float>1485780820.98</float> <string>UTC</string> </tuple> </state> @@ -269,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>953.21219.58513.54579</string> </value> + <value> <string>956.64652.42771.37444</string> </value> </item> <item> <key> <string>state</string> </key> @@ -287,7 +248,7 @@ </tuple> <state> <tuple> - <float>1474013855.64</float> + <float>1485780817.22</float> <string>UTC</string> </tuple> </state> @@ -310,7 +271,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -326,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -344,7 +307,7 @@ </tuple> <state> <tuple> - <float>1471549600.18</float> + <float>1485779318.49</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.html index 26562f4629..63b6488d1a 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.html @@ -26,4 +26,4 @@ </form> </body> -</html> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.xml index 63cc7c47d0..da9c2c75cd 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_html.xml @@ -144,9 +144,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -273,7 +271,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.22589.46402.6092</string> </value> + <value> <string>956.64677.1467.64529</string> </value> </item> <item> <key> <string>state</string> </key> @@ -291,7 +289,7 @@ </tuple> <state> <tuple> - <float>1479469812.2</float> + <float>1485780792.24</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.js index bd3d7bb14e..83ce46ce8c 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.js @@ -1,111 +1,110 @@ -/*globals window, RSVP, rJS*/ -/*jslint indent: 2, nomen: true, maxlen: 80*/ -(function (window, RSVP, rJS) { - "use strict"; - - function getSearchedString() { - var regex = new RegExp("[\\#?&]search=([^&]*)"), - results = regex.exec(window.location.hash); - return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " ")); - } - - function updateSearchUrl(event) { - var gadget = this; - makeOptionDict(gadget) - .push(function() { - return gadget.getSetting("option"); - }) - .push(function(option) { - return gadget.getUrlFor(option); - }) - .push(function(url) { - url = window.location.href + url; - gadget.props.element.getElementsByClassName("search-engine-url")[0].innerHTML = url; - }); - } - - rJS(window) - .ready(function (g) { - g.props = {}; - return g.getElement() - .push(function (element) { - g.props.element = element; - }); - }) - .declareAcquiredMethod("translate", "translate") - .declareAcquiredMethod("getUrlFor", "getUrlFor") - .declareAcquiredMethod("redirect", "redirect") - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod('getSetting', 'getSetting') - .declareAcquiredMethod("jio_allDocs", "jio_allDocs") - .declareAcquiredMethod("getSetting", "getSetting") - .declareAcquiredMethod("setSetting", "setSetting") - .declareMethod("render", function (options) { - var gadget = this, - portal_type = null, - gadget_option_dict = options, - option = { - auto_redirect: false, - search_engine: "" - }; - - return new RSVP.Queue() - .push(gadget.updateHeader({title: 'Search in Bookmarks'})) - .push(function () { - return gadget.getSetting("portal_type") - .push(function(result) { - portal_type = result; - }); - }) - .push(function (){ - return gadget.getSetting("option") - .push(function(result) { - if (result) { - option = result; - } - }); - }) - .push(function () { - var search = gadget_option_dict.search, - query = ""; - if (search) { - query = { - query: '(title:"%' + search + '%" OR url_string:"%' + search + '%" OR description:"%' + search + '%") AND portal_type:"' + portal_type + '"', - select_list: ['title', 'url_string', 'description'], - }; - return gadget.jio_allDocs(query) - .push(function (query_result) { - var result_list_length = query_result.data.rows.length; - - // if 0 result, let's search with a real search engine - if (result_list_length === 0 && option.search_engine !== '') { - window.location.href = option.search_engine + window.encodeURIComponent(search); - } - // if 1 result, we go there - else if (result_list_length === 1 && option.auto_redirect === true) { - window.location.href = query_result.data.rows[0].value.url_string; - } - else { - return gadget.getUrlFor({page: "bookmark_list", search: window.encodeURIComponent(search)}) - .push(function (url) { - window.location.href = url; - }); - } - }); - } - }); - }) - .onEvent("submit", function () { - var gadget = this; - //var option_parameter = gadget.getSetting("option"); - var option_parameter = { - search: window.encodeURIComponent(gadget.props.element.getElementsByTagName('input')[0].value), - page: 'bookmark_dispatcher' - }; - return gadget.getUrlFor(option_parameter) - .push(function (url) { - window.location.href = url; - }); - }); - +/*globals window, RSVP, rJS*/ +/*jslint indent: 2, nomen: true, maxlen: 80*/ +(function (window, RSVP, rJS) { + "use strict"; + + function getSearchedString() { + var regex = new RegExp("[\\#?&]search=([^&]*)"), + results = regex.exec(window.location.hash); + return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " ")); + } + + function updateSearchUrl(event) { + var gadget = this; + makeOptionDict(gadget) + .push(function() { + return gadget.getSetting("option"); + }) + .push(function(option) { + return gadget.getUrlFor(option); + }) + .push(function(url) { + url = window.location.href + url; + gadget.props.element.getElementsByClassName("search-engine-url")[0].innerHTML = url; + }); + } + + rJS(window) + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + }); + }) + .declareAcquiredMethod("translate", "translate") + .declareAcquiredMethod("getUrlFor", "getUrlFor") + .declareAcquiredMethod("redirect", "redirect") + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod('getSetting', 'getSetting') + .declareAcquiredMethod("jio_allDocs", "jio_allDocs") + .declareAcquiredMethod("getSetting", "getSetting") + .declareAcquiredMethod("setSetting", "setSetting") + .declareMethod("render", function (options) { + var gadget = this, + portal_type = null, + option = { + auto_redirect: false, + search_engine: "" + }; + + return new RSVP.Queue() + .push(gadget.updateHeader({title: 'Search in Bookmarks'})) + .push(function () { + return gadget.getSetting("portal_type") + .push(function(result) { + portal_type = result; + }); + }) + .push(function (){ + return gadget.getSetting("option") + .push(function(result) { + if (result) { + option = result; + } + }); + }) + .push(function () { + var search = window.decodeURIComponent(getSearchedString()), + query = ""; + if (search) { + query = { + query: '(title:"%' + search + '%" OR url_string:"%' + search + '%" OR description:"%' + search + '%") AND portal_type:"' + portal_type + '"', + select_list: ['title', 'url_string', 'description'], + }; + return gadget.jio_allDocs(query) + .push(function (query_result) { + var result_list_length = query_result.data.rows.length; + + // if 0 result, let's search with a real search engine + if (result_list_length === 0 && option.search_engine !== '') { + window.location.href = option.search_engine + window.encodeURIComponent(search); + } + // if 1 result, we go there + else if (result_list_length === 1 && option.auto_redirect === true) { + window.location.href = query_result.data.rows[0].value.url_string; + } + else { + return gadget.getUrlFor({page: "bookmark_list", search: window.encodeURIComponent(search)}) + .push(function (url) { + window.location.href = url; + }); + } + }); + } + }); + }) + .onEvent("submit", function () { + var gadget = this; + //var option_parameter = gadget.getSetting("option"); + var option_parameter = { + search: window.encodeURIComponent(gadget.props.element.getElementsByTagName('input')[0].value), + page: 'bookmark_dispatcher' + }; + return gadget.getUrlFor(option_parameter) + .push(function (url) { + window.location.href = url; + }); + }); + }(window, RSVP, rJS)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.xml index 7fb0b82633..a6bf986f1a 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_dispatcher_js.xml @@ -63,14 +63,6 @@ </tuple> </value> </item> - <item> - <key> <string>categories</string> </key> - <value> - <tuple> - <string>contributor/person_module/1</string> - </tuple> - </value> - </item> <item> <key> <string>content_md5</string> </key> <value> @@ -78,12 +70,8 @@ </value> </item> <item> - <key> <string>creators</string> </key> - <value> - <tuple> - <string>cedric.le.ninivin</string> - </tuple> - </value> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> </item> <item> <key> <string>default_reference</string> </key> @@ -105,44 +93,17 @@ <none/> </value> </item> - <item> - <key> <string>modification_date</string> </key> - <value> - <object> - <klass> - <global name="DateTime" module="DateTime.DateTime"/> - </klass> - <tuple> - <none/> - </tuple> - <state> - <tuple> - <float>1455284352.18</float> - <string>UTC</string> - </tuple> - </state> - </object> - </value> - </item> <item> <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Bookmark Dispatcher JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -224,7 +185,7 @@ </tuple> <state> <tuple> - <float>1478605449.85</float> + <float>1485780752.49</float> <string>UTC</string> </tuple> </state> @@ -269,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.49852.11197.39970</string> </value> + <value> <string>956.64652.37486.36010</string> </value> </item> <item> <key> <string>state</string> </key> @@ -287,7 +248,7 @@ </tuple> <state> <tuple> - <float>1480959188.76</float> + <float>1485780744.68</float> <string>UTC</string> </tuple> </state> @@ -310,7 +271,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -326,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -344,7 +307,7 @@ </tuple> <state> <tuple> - <float>1478605233.57</float> + <float>1485779312.96</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_html.xml index 7977520089..4b2b66bf2d 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_html.xml @@ -144,9 +144,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -273,7 +271,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.8037.23694.47974</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -291,7 +289,7 @@ </tuple> <state> <tuple> - <float>1478536688.15</float> + <float>1485780721.46</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.js index 9d3bdc7770..73eebc2d39 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.js @@ -1,107 +1,107 @@ -/*globals window, RSVP, rJS*/ -/*jslint indent: 2, nomen: true, maxlen: 80*/ -(function (window, RSVP, rJS) { - "use strict"; - - rJS(window) - .ready(function (g) { - g.props = {}; - return g.getElement() - .push(function (element) { - g.props.element = element; - }); - }) - .ready(function (g) { - return new RSVP.Queue() - .push(function () { - return RSVP.all([ - g.translate("validated"), - g.translate("invalidated"), - g.translate("Not synced!"), - g.translate("Waiting for approval") - ]); - }) - .push(function (result_list) { - g.props.translation_dict = { - "validated": result_list[0], - "invalidated": result_list[1], - "Not synced!": result_list[2], - "Waiting for approval": result_list[3] - }; - }); - }) - .declareAcquiredMethod("translate", "translate") - .declareAcquiredMethod("getUrlFor", "getUrlFor") - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod('getSetting', 'getSetting') - .declareAcquiredMethod("jio_allDocs", "jio_allDocs") - .allowPublicAcquisition("jio_allDocs", function (param_list) { - var gadget = this; - return this.jio_allDocs.apply(this, param_list) - .push(function (result) { - var i, - len; - for (i = 0, len = result.data.total_rows; i < len; i += 1) { - // XXX jIO does not create UUID with module inside - if (result.data.rows[i].id.indexOf("module") === -1) { - result.data.rows[i].value.state = - gadget.props.translation_dict["Not synced!"]; - } else { - result.data.rows[i].value.state = - gadget.props.translation_dict[ - result.data.rows[i].value.local_state || - "Waiting for approval" - ]; - } - } - return result; - }); - }) - .declareMethod("render", function (options) { - var gadget = this; - return new RSVP.Queue() - .push(function () { - return RSVP.all([ - gadget.getSetting("portal_type"), - gadget.getSetting("bookmark_title_plural") - ]); - }) - .push(function (answer_list) { - gadget.props.portal_type = answer_list[0]; - gadget.props.bookmark_title_plural = answer_list[1]; - return gadget.getUrlFor({page: "add_bookmark"}); - }) - .push(function (url) { - return gadget.updateHeader({ - title: gadget.props.bookmark_title_plural, - add_url: url - }); - }) - .push(function () { - return gadget.getDeclaredGadget("listbox"); - }) - .push(function (listbox) { - return listbox.render({ - search_page: 'bookmark_list', - search: options.search, - column_list: [{ - select: 'title', - title: 'Title' - }, { - select: 'url_string', - title: 'URL' - }, { - select: 'description', - title: 'Description' - }], - query: { - query: 'portal_type:("' + gadget.props.portal_type + '")', - select_list: ['title', 'url_string', 'description'], - limit: [0, 30], - sort_on: [["modification_date", "descending"]] - } - }); - }); - }); - +/*globals window, RSVP, rJS*/ +/*jslint indent: 2, nomen: true, maxlen: 80*/ +(function (window, RSVP, rJS) { + "use strict"; + + rJS(window) + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + }); + }) + .ready(function (g) { + return new RSVP.Queue() + .push(function () { + return RSVP.all([ + g.translate("validated"), + g.translate("invalidated"), + g.translate("Not synced!"), + g.translate("Waiting for approval") + ]); + }) + .push(function (result_list) { + g.props.translation_dict = { + "validated": result_list[0], + "invalidated": result_list[1], + "Not synced!": result_list[2], + "Waiting for approval": result_list[3] + }; + }); + }) + .declareAcquiredMethod("translate", "translate") + .declareAcquiredMethod("getUrlFor", "getUrlFor") + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod('getSetting', 'getSetting') + .declareAcquiredMethod("jio_allDocs", "jio_allDocs") + .allowPublicAcquisition("jio_allDocs", function (param_list) { + var gadget = this; + return this.jio_allDocs.apply(this, param_list) + .push(function (result) { + var i, + len; + for (i = 0, len = result.data.total_rows; i < len; i += 1) { + // XXX jIO does not create UUID with module inside + if (result.data.rows[i].id.indexOf("module") === -1) { + result.data.rows[i].value.state = + gadget.props.translation_dict["Not synced!"]; + } else { + result.data.rows[i].value.state = + gadget.props.translation_dict[ + result.data.rows[i].value.local_state || + "Waiting for approval" + ]; + } + } + return result; + }); + }) + .declareMethod("render", function (options) { + var gadget = this; + return new RSVP.Queue() + .push(function () { + return RSVP.all([ + gadget.getSetting("portal_type"), + gadget.getSetting("document_title_plural") + ]); + }) + .push(function (answer_list) { + gadget.props.portal_type = answer_list[0]; + gadget.props.bookmark_title_plural = answer_list[1]; + return gadget.getUrlFor({page: "add_bookmark"}); + }) + .push(function (url) { + return gadget.updateHeader({ + title: gadget.props.bookmark_title_plural, + add_url: url + }); + }) + .push(function () { + return gadget.getDeclaredGadget("listbox"); + }) + .push(function (listbox) { + return listbox.render({ + search_page: 'bookmark_list', + search: options.search, + column_list: [{ + select: 'title', + title: 'Title' + }, { + select: 'url_string', + title: 'URL' + }, { + select: 'description', + title: 'Description' + }], + query: { + query: 'portal_type:("' + gadget.props.portal_type + '")', + select_list: ['title', 'url_string', 'description'], + limit: [0, 30], + sort_on: [["modification_date", "descending"]] + } + }); + }); + }); + }(window, RSVP, rJS)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.xml index e2f71d6966..62b76c0b73 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_list_js.xml @@ -63,14 +63,6 @@ </tuple> </value> </item> - <item> - <key> <string>categories</string> </key> - <value> - <tuple> - <string>contributor/person_module/1</string> - </tuple> - </value> - </item> <item> <key> <string>content_md5</string> </key> <value> @@ -78,12 +70,8 @@ </value> </item> <item> - <key> <string>creators</string> </key> - <value> - <tuple> - <string>cedric.le.ninivin</string> - </tuple> - </value> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> </item> <item> <key> <string>default_reference</string> </key> @@ -105,44 +93,17 @@ <none/> </value> </item> - <item> - <key> <string>modification_date</string> </key> - <value> - <object> - <klass> - <global name="DateTime" module="DateTime.DateTime"/> - </klass> - <tuple> - <none/> - </tuple> - <state> - <tuple> - <float>1455284352.18</float> - <string>UTC</string> - </tuple> - </state> - </object> - </value> - </item> <item> <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Bookmark List JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -224,7 +185,7 @@ </tuple> <state> <tuple> - <float>1468955568.76</float> + <float>1485780679.17</float> <string>UTC</string> </tuple> </state> @@ -269,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>953.62286.195.51114</string> </value> + <value> <string>956.64652.30281.58163</string> </value> </item> <item> <key> <string>state</string> </key> @@ -287,7 +248,7 @@ </tuple> <state> <tuple> - <float>1478609077.97</float> + <float>1485780674.63</float> <string>UTC</string> </tuple> </state> @@ -310,7 +271,9 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> @@ -326,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -344,7 +307,7 @@ </tuple> <state> <tuple> - <float>1468955459.16</float> + <float>1485779306.52</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_html.xml index bced8bfd0f..0961da88a2 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_html.xml @@ -109,9 +109,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -238,7 +236,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.26757.64302.42649</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +254,7 @@ </tuple> <state> <tuple> - <float>1483369683.96</float> + <float>1485780641.43</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_js.xml index 0f9d99cdd6..9b679de0a8 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_bookmark_preference_js.xml @@ -109,9 +109,7 @@ </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -238,7 +236,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.61034.43590.15752</string> </value> + <value> <string>956.64450.52709.9386</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +254,7 @@ </tuple> <state> <tuple> - <float>1483369693.2</float> + <float>1485780623.37</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.html index 5f53f9f749..e30213ac38 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.html @@ -1,75 +1,76 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS jIO DAV Configurator Page</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - - <script src="gadget_officejs_page_jio_dav_configurator.js"></script> - - </head> - - <body> - <article class="ui-content ui-body-c"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-database"> </span> - Your WebDAV Connection parameters - </h3> - </section> - <section class="ui-body-c ui-content-section"> - <form class="dav-configuration-form"> - - <div class="ui-form"> - <div class="ui-field-contain"> - <label data-i18n="Connection URL:">Connection URL:</label> - <input type="url" name="dav_url" required value=""/> - </div> - <div class="ui-field-contain"> - <label data-i18n="Username:">Username:</label> - <input type="text" name="dav_username" value=""/> - </div> - <div class="ui-field-contain"> - <label data-i18n="Password:">Password:</label> - <input type="password" name="dav_password" value=""/> - </div> - </div> - <div class="select-storage ui-controlgroup ui-controlgroup-horizontal"> - <div class="ui-grid-b ui-responsive"> - <div class="ui-block-a"></div> - <div class="ui-block-b"></div> - <div class="ui-block-c"> - <button type="submit" data-i18n="Connect" class="ui-btn-btn-right">Connect</button> - </div> - </div> - </div> - </form> - </section> - </article> - <article class="ui-content ui-body-c document-access"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-file-text-o"> </span> - Your Documents - </h3> - </section> - <section class="ui-body-c ui-content-section"> - <p style="color: red">Continue by <b>synchronizing</b> with your remote storage or <b>accessing</b> your documents</p> - <div class="ui-controlgroup ui-controlgroup-horizontal"> - <div class="ui-grid-a ui-responsive"> - <div class="ui-block-a"> - <a class="ui-btn" href="#page=sync" data-i18n="Synchronize">Synchronize</a> - </div> - <div class="ui-block-b"> - <a class="ui-btn" href="#page=document_list" data-i18n="Go to document List">Access document List</a> - </div> - </div> - </div> - </section> - </article> - </body> -</html> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS jIO DAV Configurator Page</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + + <script src="gadget_officejs_page_jio_dav_configurator.js"></script> + + </head> + + <body> + <article class="ui-content ui-body-c"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-database"> </span> + Your WebDAV Connection parameters + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <form class="dav-configuration-form"> + + <div class="ui-form"> + <div class="ui-field-contain"> + <label data-i18n="Connection URL:">Connection URL:</label> + <input type="url" name="dav_url" required value=""/> + </div> + <div class="ui-field-contain"> + <label data-i18n="Username:">Username:</label> + <input type="text" name="dav_username" value=""/> + </div> + <div class="ui-field-contain"> + <label data-i18n="Password:">Password:</label> + <input type="password" name="dav_password" value=""/> + </div> + </div> + <div class="select-storage ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-b ui-responsive"> + <div class="ui-block-a"></div> + <div class="ui-block-b"></div> + <div class="ui-block-c"> + <button type="submit" data-i18n="Connect" class="ui-btn-btn-right">Connect</button> + </div> + </div> + </div> + </form> + </section> + </article> + <article class="ui-content ui-body-c document-access"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-file-text-o"> </span> + Your Documents + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <p style="color: red">Continue by <b>synchronizing</b> with your remote storage or <b>accessing</b> your documents</p> + <div class="ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-a ui-responsive"> + <div class="ui-block-a"> + <a class="ui-btn" href="#page=sync&auto_repair=true" data-i18n="Synchronize">Synchronize</a> + </div> + <div class="ui-block-b"> + <a class="ui-btn" href="#page=document_list" data-i18n="Go to document List">Access document List</a> + </div> + </div> + </div> + </section> + </article> + <div class="global_setting_gadget" style="display: none;"></div> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.xml index 1d8fe31014..de533d11e3 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dav_configurator_html.xml @@ -97,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS jIO DAV Configurator Page</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -171,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -193,7 +185,7 @@ </tuple> <state> <tuple> - <float>1442831613.46</float> + <float>1485780580.2</float> <string>UTC</string> </tuple> </state> @@ -238,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>946.59102.61985.50653</string> </value> + <value> <string>956.64652.20228.58760</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +248,7 @@ </tuple> <state> <tuple> - <float>1446741062.96</float> + <float>1485780575.5</float> <string>UTC</string> </tuple> </state> @@ -279,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -295,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -313,7 +307,7 @@ </tuple> <state> <tuple> - <float>1442830550.27</float> + <float>1485779297.53</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.html new file mode 100644 index 0000000000..849f18142e --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.html @@ -0,0 +1,52 @@ +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS jIO Dropbox Configurator Page</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + + <script src="gadget_officejs_page_jio_dropbox_configurator.js"></script> + + </head> + + <body> + <article class="ui-content ui-body-c"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-database"> </span> + Your Dropbox Connection parameters + </h3> + </section> + <section class="ui-content-header-plain"> + <p>Connecting to Dropbox</p> + </section> + </article> + <article class="ui-content ui-body-c document-access"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-file-text-o"> </span> + Your Documents + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <p style="color: red">Continue by <b>synchronizing</b> with your remote storage or <b>accessing</b> your documents</p> + <div class="ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-a ui-responsive"> + <div class="ui-block-a"> + <a class="ui-btn" href="#page=sync" data-i18n="Synchronize">Synchronize</a> + </div> + <div class="ui-block-b"> + <a class="ui-btn" href="#page=document_list" data-i18n="Go to document List">Access document List</a> + </div> + </div> + </div> + </section> + </article> + + <div class="global_setting_gadget" style="display: none;"></div> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.xml new file mode 100644 index 0000000000..fa56bc0640 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_html.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Page" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/html</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_page_jio_dropbox_configurator.html</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_page_jio_dropbox_configurator_html</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Page</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>OfficeJS jIO Dropbox Configurator Page</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485780483.1</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64672.3552.2918</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485780527.48</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779368.87</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.txt b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.txt new file mode 100644 index 0000000000..ec625e23ec --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.txt @@ -0,0 +1,138 @@ +/*global window, rJS, RSVP, URI, location, + loopEventListener, btoa */ +/*jslint nomen: true, indent: 2, maxerr: 3*/ +(function (window, rJS, RSVP) { + "use strict"; + + function setDropboxConfiguration(gadget) { + return gadget.getSetting("portal_type") + .push(function (portal_type) { + var old_date = new Date(), + configuration = {}; + // We are looking for documents modified in the past 3 month + old_date = new Date(old_date.getFullYear(), old_date.getMonth() - 3); + configuration = { + type: "replicate", + // XXX This drop the signature lists... + query: { + query: 'portal_type:"' + portal_type + '" ', + // XX Synchonizing the whole module is too much, here is a way to start quietly + // Supsended until modification_date is handled for synchronization + limit: [0, 1234567890] + }, + use_remote_post: false, + conflict_handling: 2, + check_local_modification: true, + check_local_creation: true, + check_local_deletion: false, + check_remote_modification: true, + check_remote_creation: true, + check_remote_deletion: true, + local_sub_storage: { + type: "mapping", + attachment: { + 'data': { + get: {uri_template: 'enclosure'}, + put: {uri_template: 'enclosure'} + } + }, + sub_storage: { + type: "query", + sub_storage: { + type: "uuid", + sub_storage: { + type: "indexeddb", + database: "officejs-dropbox" + } + } + } + }, + remote_sub_storage: { + type: "mapping", + attachment: { + 'data': { + get: {uri_template: 'enclosure'}, + put: {uri_template: 'enclosure'} + } + }, + mapping_dict: { + "portal_type": ["equalSubProperty", "type"] + }, + sub_storage: { + type: "query", + sub_storage: { + type: "drivetojiomapping", + sub_storage: { + type: "dropbox", + access_token: gadget.props.access_token, + root: "sandbox" + } + } + } + } + }; + return gadget.setSetting('jio_storage_description', configuration); + }) + .push(function () { + return gadget.setSetting('jio_storage_name', "DROPBOX"); + }) + .push(function () { + return gadget.setSetting('sync_reload', true); + }) + .push(function () { + return gadget.redirect({page: 'sync', auto_repair: 'true'}); + }); + } + + var gadget_klass = rJS(window); + + gadget_klass + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + g.props.deferred = RSVP.defer(); + }); + }) + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod("redirect", "redirect") + .declareAcquiredMethod("reload", "reload") + .declareAcquiredMethod("getSetting", "getSetting") + .declareAcquiredMethod("setSetting", "setSetting") + .declareMethod("getGlobalSetting", function (key) { + var gadget = this; + return gadget.getDeclaredGadget("global_setting_gadget") + .push(function (global_setting_gadget) { + return global_setting_gadget.getSetting(key); + }); + }) + .declareMethod("setGlobalSetting", function (key, value) { + var gadget = this; + return gadget.getDeclaredGadget("global_setting_gadget") + .push(function (global_setting_gadget) { + return global_setting_gadget.setSetting(key, value); + }); + }) + .declareMethod("render", function (options) { + var gadget = this; + return gadget.updateHeader({ + title: "Connect To Drobox Storage", + back_url: "#page=jio_configurator", + panel_action: false + }) + .push(function (options) { + return gadget.getSetting('jio_storage_name'); + }) + .push(function (jio_storage_name) { + if (!jio_storage_name) { + gadget.props.element.querySelector(".document-access").setAttribute("style", "display: none;"); + } + }) + .push(function () { + gadget.props.access_token = options.token; + return setDropboxConfiguration(gadget); + }); + }); + +}(window, rJS, RSVP)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.xml new file mode 100644 index 0000000000..082f0708c9 --- /dev/null +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_dropbox_configurator_js.xml @@ -0,0 +1,322 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="Web Script" module="erp5.portal_type"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>_Access_contents_information_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Add_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Change_local_roles_Permission</string> </key> + <value> + <tuple> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_Modify_portal_content_Permission</string> </key> + <value> + <tuple> + <string>Assignee</string> + <string>Assignor</string> + <string>Manager</string> + </tuple> + </value> + </item> + <item> + <key> <string>_View_Permission</string> </key> + <value> + <tuple> + <string>Anonymous</string> + <string>Assignee</string> + <string>Assignor</string> + <string>Associate</string> + <string>Auditor</string> + <string>Manager</string> + <string>Owner</string> + </tuple> + </value> + </item> + <item> + <key> <string>content_md5</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/plain</string> </value> + </item> + <item> + <key> <string>default_reference</string> </key> + <value> <string>gadget_officejs_page_jio_dropbox_configurator.js</string> </value> + </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>gadget_officejs_page_jio_dropbox_configurator_js</string> </value> + </item> + <item> + <key> <string>language</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>portal_type</string> </key> + <value> <string>Web Script</string> </value> + </item> + <item> + <key> <string>title</string> </key> + <value> <string>OfficeJS jIO Dropbox Configurator Page JS</string> </value> + </item> + <item> + <key> <string>version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>workflow_history</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary> + <item> + <key> <string>document_publication_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + </value> + </item> + <item> + <key> <string>edit_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> + </value> + </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>publish_alive</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485780470.2</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + <item> + <key> <string>validation_state</string> </key> + <value> <string>published_alive</string> </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="4" aka="AAAAAAAAAAQ="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> <string>edit</string> </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>956.64671.54901.45909</string> </value> + </item> + <item> + <key> <string>state</string> </key> + <value> <string>current</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485780514.28</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779366.79</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> +</ZopeData> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.html index e5b6354b12..31a08e2e31 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.html @@ -1,71 +1,73 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS jIO ERP5 Configurator Page</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - - <script src="gadget_officejs_page_jio_erp5_configurator.js"></script> - - </head> - - <body> - <article class="ui-content ui-body-c"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-database"> </span> - Your ERP5 Connection parameters - </h3> - </section> - <section class="ui-content-header-plain"> - <p>You have to be logged in this ERP5 prior to synchronising</p> - </section> - <section class="ui-body-c ui-content-section"> - <form class="erp5-configuration-form"> - - <div class="ui-form"> - <div class="ui-field-contain"> - <label data-i18n="Connection URL:">Connection URL:</label> - <input type="url" name="erp5_url" class="ui-focus" required disabled/> - </div> - <div class="select-storage ui-controlgroup ui-controlgroup-horizontal"> - <div class="ui-grid-b ui-responsive"> - <div class="ui-block-a"></div> - <div class="ui-block-b"></div> - <div class="ui-block-c"> - <button type="submit" data-i18n="Connect" class="ui-btn-btn-right">Connect</button> - </div> - </div> - </div> - </form> - </section> - </article> - <article class="ui-content ui-body-c document-access"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-file-text-o"> </span> - Your Documents - </h3> - </section> - <section class="ui-body-c ui-content-section"> - <p style="color: red">Continue by <b>synchronizing</b> with your remote storage or <b>accessing</b> your documents</p> - <div class="ui-controlgroup ui-controlgroup-horizontal"> - <div class="ui-grid-a ui-responsive"> - <div class="ui-block-a"> - <a class="ui-btn" href="#page=sync&auto_repair=true" data-i18n="Synchronize">Synchronize</a> - </div> - <div class="ui-block-b"> - <a class="ui-btn" href="#page=document_list" data-i18n="Go to document List">Access document List</a> - </div> - </div> - </div> - </section> - </article> - - <div class="global_setting_gadget" style="display: none;"></div> - </body> -</html> +<!doctype html> +<html> + <head> +<base href="https://texteditor.app.officejs.com/1.0.4/gadget_officejs_page_jio_erp5_configurator.html/" /> + + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS jIO ERP5 Configurator Page</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + + <script src="gadget_officejs_page_jio_erp5_configurator.js"></script> + + </head> + + <body> + <article class="ui-content ui-body-c"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-database"> </span> + Your ERP5 Connection parameters + </h3> + </section> + <section class="ui-content-header-plain"> + <p>You have to be logged in this ERP5 prior to synchronising</p> + </section> + <section class="ui-body-c ui-content-section"> + <form class="erp5-configuration-form"> + + <div class="ui-form"> + <div class="ui-field-contain"> + <label data-i18n="Connection URL:">Connection URL:</label> + <input type="url" name="erp5_url" class="ui-focus" required disabled/> + </div> + <div class="select-storage ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-b ui-responsive"> + <div class="ui-block-a"></div> + <div class="ui-block-b"></div> + <div class="ui-block-c"> + <button type="submit" data-i18n="Connect" class="ui-btn-btn-right">Connect</button> + </div> + </div> + </div> + </form> + </section> + </article> + <article class="ui-content ui-body-c document-access"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-file-text-o"> </span> + Your Documents + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <p style="color: red">Continue by <b>synchronizing</b> with your remote storage or <b>accessing</b> your documents</p> + <div class="ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-a ui-responsive"> + <div class="ui-block-a"> + <a class="ui-btn" href="#page=sync&auto_repair=true" data-i18n="Synchronize">Synchronize</a> + </div> + <div class="ui-block-b"> + <a class="ui-btn" href="#page=document_list" data-i18n="Go to document List">Access document List</a> + </div> + </div> + </div> + </section> + </article> + + <div class="global_setting_gadget" style="display: none;"></div> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.xml index 17056da06d..9a2e317531 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_jio_erp5_configurator_html.xml @@ -63,14 +63,6 @@ </tuple> </value> </item> - <item> - <key> <string>categories</string> </key> - <value> - <tuple> - <string>contributor/person_module/1</string> - </tuple> - </value> - </item> <item> <key> <string>content_md5</string> </key> <value> @@ -81,14 +73,6 @@ <key> <string>content_type</string> </key> <value> <string>text/html</string> </value> </item> - <item> - <key> <string>creators</string> </key> - <value> - <tuple> - <string>cedric.le.ninivin</string> - </tuple> - </value> - </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_page_jio_erp5_configurator.html</string> </value> @@ -109,44 +93,17 @@ <none/> </value> </item> - <item> - <key> <string>modification_date</string> </key> - <value> - <object> - <klass> - <global name="DateTime" module="DateTime.DateTime"/> - </klass> - <tuple> - <none/> - </tuple> - <state> - <tuple> - <float>1455284351.6</float> - <string>UTC</string> - </tuple> - </state> - </object> - </value> - </item> <item> <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS jIO ERP5 Configurator Page</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -206,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>supercedriclen</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -228,7 +185,7 @@ </tuple> <state> <tuple> - <float>1466088843.02</float> + <float>1485780407.13</float> <string>UTC</string> </tuple> </state> @@ -273,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>954.38565.29657.34116</string> </value> + <value> <string>956.64653.28215.17971</string> </value> </item> <item> <key> <string>state</string> </key> @@ -291,7 +248,7 @@ </tuple> <state> <tuple> - <float>1476436854.76</float> + <float>1485780401.63</float> <string>UTC</string> </tuple> </state> @@ -314,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>supercedriclen</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -330,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -348,7 +307,7 @@ </tuple> <state> <tuple> - <float>1466085053.26</float> + <float>1485779365.09</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.html index cbae60ce8b..b2f1898f44 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.html @@ -1,47 +1,47 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS Login Page </title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - <script src="gadget_global.js" ></script> - - <script src="gadget_officejs_page_login.js"></script> - </head> - - <body> - <article class="ui-content ui-body-c"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-user"> </span> - Login - </h3> - </section> - <section class="ui-body-c ui-content-section"> - <form class="login-form"> - <div class="ui-field-contain"> - <label data-i18n="Login">Login</label> - <input type="text" name="jid" placeholder="Ex: john" value="" required> - </div> - <div class="ui-field-contain"> - <label data-i18n="Password">Password</label> - <input type="password" name="passwd" placeholder="Ex: A1bcF$99" value="" required> - </div> - <div class="ui-grid-b ui-responsive"> - <div class="ui-block-a"> - </div> - <div class="ui-block-b"> - </div> - <div class="ui-block-c"> - <button class="ui-btn ui-btn-b" type="submit" data-i18n="Log In">Log In</button> - </div> - </div> - </form> - </section> - </article> - </body> -</html> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Login Page </title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="gadget_global.js" ></script> + + <script src="gadget_officejs_page_login.js"></script> + </head> + + <body> + <article class="ui-content ui-body-c"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-user"> </span> + Login + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <form class="login-form"> + <div class="ui-field-contain"> + <label data-i18n="Login">Login</label> + <input type="text" name="jid" placeholder="Ex: john" value="" required> + </div> + <div class="ui-field-contain"> + <label data-i18n="Password">Password</label> + <input type="password" name="passwd" placeholder="Ex: A1bcF$99" value="" required> + </div> + <div class="ui-grid-b ui-responsive"> + <div class="ui-block-a"> + </div> + <div class="ui-block-b"> + </div> + <div class="ui-block-c"> + <button class="ui-btn ui-btn-b" type="submit" data-i18n="Log In">Log In</button> + </div> + </div> + </form> + </section> + </article> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.xml index 234fd3d47c..a1ea8c7740 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_html.xml @@ -97,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Login Page</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -171,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -193,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438011335.54</float> + <float>1485780377.99</float> <string>UTC</string> </tuple> </state> @@ -224,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -238,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>945.62650.43414.46660</string> </value> + <value> <string>956.64652.16930.8601</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +248,7 @@ </tuple> <state> <tuple> - <float>1443096971.41</float> + <float>1485780371.75</float> <string>UTC</string> </tuple> </state> @@ -279,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -295,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -313,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438011232.72</float> + <float>1485779294.46</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.js index 3dda99da14..9216887f63 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.js @@ -1,51 +1,51 @@ -/*globals window, document, RSVP, rJS, promiseEventListener*/ -/*jslint indent: 2, maxlen: 80, nomen: true*/ -(function (window, document, RSVP, rJS, promiseEventListener) { - "use strict"; - - ///////////////////////////////////////////////////////////////// - // templates - ///////////////////////////////////////////////////////////////// - rJS(window) - .ready(function (g) { - g.props = {}; - return g.getElement() - .push(function (element) { - g.props.element = element; - }); - }) - - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod("translateHtml", "translateHtml") - .declareMethod("render", function () { - var gadget = this; - return gadget.updateHeader({ - title: "Connect" - }); - }) - - .declareAcquiredMethod("redirect", "redirect") - .declareService(function () { - var gadget = this; - return new RSVP.Queue() - .push(function () { - gadget.props.element.querySelector("input[type=text]") - .focus(); - return promiseEventListener( - gadget.props.element.querySelector('form.login-form'), - 'submit', - false - ); - }) - .push(function (evt) { - gadget.props.element.querySelector("button") - .disabled = true; - var login = evt.target.elements[0].value, - passwd = evt.target.elements[1].value; - document.cookie = "__ac=" + window.btoa(login + ":" + passwd) + - "; path=/"; - return gadget.redirect({page:"sync"}); - }); - }); - +/*globals window, document, RSVP, rJS, promiseEventListener*/ +/*jslint indent: 2, maxlen: 80, nomen: true*/ +(function (window, document, RSVP, rJS, promiseEventListener) { + "use strict"; + + ///////////////////////////////////////////////////////////////// + // templates + ///////////////////////////////////////////////////////////////// + rJS(window) + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + }); + }) + + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod("translateHtml", "translateHtml") + .declareMethod("render", function () { + var gadget = this; + return gadget.updateHeader({ + title: "Connect" + }); + }) + + .declareAcquiredMethod("redirect", "redirect") + .declareService(function () { + var gadget = this; + return new RSVP.Queue() + .push(function () { + gadget.props.element.querySelector("input[type=text]") + .focus(); + return promiseEventListener( + gadget.props.element.querySelector('form.login-form'), + 'submit', + false + ); + }) + .push(function (evt) { + gadget.props.element.querySelector("button") + .disabled = true; + var login = evt.target.elements[0].value, + passwd = evt.target.elements[1].value; + document.cookie = "__ac=" + window.btoa(login + ":" + passwd) + + "; path=/"; + return gadget.redirect({page:"sync"}); + }); + }); + }(window, document, RSVP, rJS, promiseEventListener)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.xml index 72b5da7005..3579bb6d18 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_login_js.xml @@ -69,6 +69,10 @@ <none/> </value> </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_page_login.js</string> </value> @@ -93,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Login Page JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -167,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -189,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438011356.37</float> + <float>1485780342.24</float> <string>UTC</string> </tuple> </state> @@ -220,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -234,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>945.62644.11371.29525</string> </value> + <value> <string>956.64652.14224.43383</string> </value> </item> <item> <key> <string>state</string> </key> @@ -252,7 +248,7 @@ </tuple> <state> <tuple> - <float>1443096382.27</float> + <float>1485780123.89</float> <string>UTC</string> </tuple> </state> @@ -275,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -291,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -309,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438011231.09</float> + <float>1485779291.98</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.html index 6b61724516..e3c500affe 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.html @@ -1,32 +1,32 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS Logout Page</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - <script src="handlebars.js"></script> - <script src="gadget_global.js" ></script> - - <script id="page-template" type="text/x-handlebars-template"> - <div class="ui-grid-b ui-responsive"> - <div class="ui-block-a"></div> - <div class="ui-block-b"> - <form class="logout-form"> - <input data-inline="true" type="submit" data-i18n="[value]Confirm" value="Confirm" data-theme="b"> - </form> - </div> - <div class="ui-block-c"></div> - </div> - </script> - - <script src="gadget_officejs_page_logout.js"></script> - - </head> - - <body> - </body> -</html> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Logout Page</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="handlebars.js"></script> + <script src="gadget_global.js" ></script> + + <script id="page-template" type="text/x-handlebars-template"> + <div class="ui-grid-b ui-responsive"> + <div class="ui-block-a"></div> + <div class="ui-block-b"> + <form class="logout-form"> + <input data-inline="true" type="submit" data-i18n="[value]Confirm" value="Confirm" data-theme="b"> + </form> + </div> + <div class="ui-block-c"></div> + </div> + </script> + + <script src="gadget_officejs_page_logout.js"></script> + + </head> + + <body> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.xml index 71bbfb9173..87be1fc6c8 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_html.xml @@ -97,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Logout Page</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -171,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -193,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438011477.47</float> + <float>1485780056.47</float> <string>UTC</string> </tuple> </state> @@ -224,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -238,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>945.18325.52875.45858</string> </value> + <value> <string>956.64652.10976.32921</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +248,7 @@ </tuple> <state> <tuple> - <float>1440439770.0</float> + <float>1485780049.93</float> <string>UTC</string> </tuple> </state> @@ -279,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -295,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -313,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438011364.67</float> + <float>1485779288.82</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.js index c30910425a..4e2edd3e58 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.js @@ -1,60 +1,60 @@ -/*globals window, RSVP, rJS, promiseEventListener, document, Handlebars*/ -/*jslint indent: 2, maxlen: 80, nomen: true*/ -(function (window, RSVP, rJS, promiseEventListener, document, Handlebars) { - "use strict"; - - ///////////////////////////////////////////////////////////////// - // templates - ///////////////////////////////////////////////////////////////// - var gadget_klass = rJS(window), - templater = gadget_klass.__template_element, - - template = Handlebars.compile( - templater.getElementById("page-template").innerHTML - ); - - gadget_klass - .ready(function (g) { - g.props = {}; - return g.getElement() - .push(function (element) { - g.props.element = element; - }); - }) - - .declareAcquiredMethod("updateHeader", "updateHeader") - .declareAcquiredMethod("translateHtml", "translateHtml") - - .declareMethod("render", function () { - var gadget = this; - return gadget.updateHeader({ - title: "Logout" - }) - .push(function () { - return gadget.translateHtml(template()); - }) - .push(function (html) { - gadget.props.element.innerHTML = html; - }); - }) - - .declareAcquiredMethod("redirect", "redirect") - .declareService(function () { - var gadget = this; - return new RSVP.Queue() - .push(function () { - return promiseEventListener( - gadget.props.element.querySelector('form.logout-form'), - 'submit', - false - ); - }) - .push(function () { - gadget.props.element.querySelector("input[type=submit]") - .disabled = true; - document.cookie = "__ac=; path=/"; - return gadget.redirect({}); - }); - }); - +/*globals window, RSVP, rJS, promiseEventListener, document, Handlebars*/ +/*jslint indent: 2, maxlen: 80, nomen: true*/ +(function (window, RSVP, rJS, promiseEventListener, document, Handlebars) { + "use strict"; + + ///////////////////////////////////////////////////////////////// + // templates + ///////////////////////////////////////////////////////////////// + var gadget_klass = rJS(window), + templater = gadget_klass.__template_element, + + template = Handlebars.compile( + templater.getElementById("page-template").innerHTML + ); + + gadget_klass + .ready(function (g) { + g.props = {}; + return g.getElement() + .push(function (element) { + g.props.element = element; + }); + }) + + .declareAcquiredMethod("updateHeader", "updateHeader") + .declareAcquiredMethod("translateHtml", "translateHtml") + + .declareMethod("render", function () { + var gadget = this; + return gadget.updateHeader({ + title: "Logout" + }) + .push(function () { + return gadget.translateHtml(template()); + }) + .push(function (html) { + gadget.props.element.innerHTML = html; + }); + }) + + .declareAcquiredMethod("redirect", "redirect") + .declareService(function () { + var gadget = this; + return new RSVP.Queue() + .push(function () { + return promiseEventListener( + gadget.props.element.querySelector('form.logout-form'), + 'submit', + false + ); + }) + .push(function () { + gadget.props.element.querySelector("input[type=submit]") + .disabled = true; + document.cookie = "__ac=; path=/"; + return gadget.redirect({}); + }); + }); + }(window, RSVP, rJS, promiseEventListener, document, Handlebars)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.xml index 854457708d..08a12c490b 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_logout_js.xml @@ -69,6 +69,10 @@ <none/> </value> </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_page_logout.js</string> </value> @@ -93,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Logout Page JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -167,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -189,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438011427.35</float> + <float>1485780028.72</float> <string>UTC</string> </tuple> </state> @@ -220,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -234,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>944.43433.8046.27699</string> </value> + <value> <string>956.64652.7554.6263</string> </value> </item> <item> <key> <string>state</string> </key> @@ -252,7 +248,7 @@ </tuple> <state> <tuple> - <float>1440437142.4</float> + <float>1485780024.23</float> <string>UTC</string> </tuple> </state> @@ -275,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -291,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -309,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438011362.53</float> + <float>1485779286.12</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.html index cb2806b76c..fc0f32f7af 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.html @@ -1,44 +1,44 @@ -<!doctype html> -<html> - <head> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <title>OfficeJS Sync Page</title> - - <script src="rsvp.js"></script> - <script src="renderjs.js"></script> - <script src="handlebars.js"></script> - <script src="gadget_global.js" ></script> - - <script id="page-template" type="text/x-handlebars-template"> - <article class="ui-content ui-body-c"> - <section class="ui-content-header-plain"> - <h3 class="ui-content-title ui-body-c"> - <span class="ui-icon ui-icon-custom ui-icon-refresh"> </span> - Synchronize your data - </h3> - </section> - <section class="ui-body-c ui-content-section"> - <div class="ui-controlgroup ui-controlgroup-horizontal"> - <div class="ui-grid-b ui-responsive"> - <div class="ui-block-a"></div> - <div class="ui-block-b"> - <form class="synchro-form view-web-page-form"> - <button type="submit" data-i18n="Launch Synchronization" data-theme="b">Launch Synchronization</button> - </form> - </div> - <div class="ui-block-c"></div> - </div> - </div> - </section> - </article> - </script> - - <script src="gadget_officejs_page_sync.js"></script> - - </head> - - <body> - </body> -</html> +<!doctype html> +<html> + <head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + + <title>OfficeJS Sync Page</title> + + <script src="rsvp.js"></script> + <script src="renderjs.js"></script> + <script src="handlebars.js"></script> + <script src="gadget_global.js" ></script> + + <script id="page-template" type="text/x-handlebars-template"> + <article class="ui-content ui-body-c"> + <section class="ui-content-header-plain"> + <h3 class="ui-content-title ui-body-c"> + <span class="ui-icon ui-icon-custom ui-icon-refresh"> </span> + Synchronize your data + </h3> + </section> + <section class="ui-body-c ui-content-section"> + <div class="ui-controlgroup ui-controlgroup-horizontal"> + <div class="ui-grid-b ui-responsive"> + <div class="ui-block-a"></div> + <div class="ui-block-b"> + <form class="synchro-form view-web-page-form"> + <button type="submit" data-i18n="Launch Synchronization" data-theme="b">Launch Synchronization</button> + </form> + </div> + <div class="ui-block-c"></div> + </div> + </div> + </section> + </article> + </script> + + <script src="gadget_officejs_page_sync.js"></script> + + </head> + + <body> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.xml index 6230da39d6..86724f6109 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_page_sync_html.xml @@ -97,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Sync Page</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -144,6 +136,12 @@ <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> + <item> + <key> <string>processing_status_workflow</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAU=</string> </persistent> + </value> + </item> </dictionary> </value> </item> @@ -165,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -187,7 +185,7 @@ </tuple> <state> <tuple> - <float>1442854019.1</float> + <float>1485779928.61</float> <string>UTC</string> </tuple> </state> @@ -218,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -232,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>945.58606.64610.54852</string> </value> + <value> <string>956.64652.3093.26982</string> </value> </item> <item> <key> <string>state</string> </key> @@ -250,7 +248,66 @@ </tuple> <state> <tuple> - <float>1443012064.85</float> + <float>1485779922.53</float> + <string>UTC</string> + </tuple> + </state> + </object> + </value> + </item> + </dictionary> + </list> + </tuple> + </pickle> + </record> + <record id="5" aka="AAAAAAAAAAU="> + <pickle> + <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> + </pickle> + <pickle> + <tuple> + <none/> + <list> + <dictionary> + <item> + <key> <string>action</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>actor</string> </key> + <value> <string>zope</string> </value> + </item> + <item> + <key> <string>comment</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>error_message</string> </key> + <value> <string></string> </value> + </item> + <item> + <key> <string>external_processing_state</string> </key> + <value> <string>empty</string> </value> + </item> + <item> + <key> <string>serial</string> </key> + <value> <string>0.0.0.0</string> </value> + </item> + <item> + <key> <string>time</string> </key> + <value> + <object> + <klass> + <global name="DateTime" module="DateTime.DateTime"/> + </klass> + <tuple> + <none/> + </tuple> + <state> + <tuple> + <float>1485779281.24</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.html b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.html index 6b3c6fe6d9..89e4008168 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.html +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.html @@ -1,60 +1,60 @@ -<!DOCTYPE html> -<html> - <head> - <meta charset="utf-8" /> - <meta name="viewport" content="width=device-width, user-scalable=no" /> - <title>OfficeJS Widget Listbox</title> - - <!-- renderjs --> - <script src="rsvp.js" type="text/javascript"></script> - <script src="renderjs.js" type="text/javascript"></script> - <script src="handlebars.js"></script> - - <script id="listbox-widget-table" type="text/x-handlebars-template"> - <form><div class="center"> - <div class="ui-field-contain"> - <div class="ui-input-text ui-body-{{widget_theme}} ui-corner-all ui-shadow-inset ui-input-has-clear {{widget_status_class}}"> - <input type="text" data-enhanced="true" value="{{search}}" name="search" {{widget_status_attribute}} /> - <div class="ui-btn ui-input-clear ui-input-btn ui-corner-all ui-icon-search ui-btn-icon-notext" data-i18n="[node]header-submit"> - Submit<input data-enhanced="true" type="submit" data-i18n="[value]header-submit" value="Submit" {{widget_status_attribute}} /> - </div> - </div> - </div> - </div></form> - <table class="ui-responsive ui-body-c ui-table-inset custom-force-list"> - <thead class="ui-bar-inherit"> - <tr> - {{#each column_list}} - <th>{{this}}</th> - {{/each}} - </tr> - </thead> - {{> listbox-widget-table-partial}} - <tfoot class="ui-bar-inherit"></tfoot> - </table> - </script> - - <script id="listbox-widget-table-partial" type="text/x-handlebars-template"> - <tbody> - {{#each row_list}} - <tr> - {{#each cell_list}} - <td><a class="ui-link" href="{{href}}">{{value}}</a></td> - {{/each}} - </tr> - {{/each}} - </tbody> - </script> - - <!-- custom script --> - <script src="gadget_officejs_widget_listbox.js" type="text/javascript"></script> - - </head> - <body> - <div class="custom-grid-wrap"> - <div class="custom-grid ui-corner-all ui-body-inherit ui-shadow ui-corner-all"> - <div class="ui-body-c ui-corner-all"></div> - </div> - </div> - </body> -</html> +<!DOCTYPE html> +<html> + <head> + <meta charset="utf-8" /> + <meta name="viewport" content="width=device-width, user-scalable=no" /> + <title>OfficeJS Widget Listbox</title> + + <!-- renderjs --> + <script src="rsvp.js" type="text/javascript"></script> + <script src="renderjs.js" type="text/javascript"></script> + <script src="handlebars.js"></script> + + <script id="listbox-widget-table" type="text/x-handlebars-template"> + <form><div class="center"> + <div class="ui-field-contain"> + <div class="ui-input-text ui-body-{{widget_theme}} ui-corner-all ui-shadow-inset ui-input-has-clear {{widget_status_class}}"> + <input type="text" data-enhanced="true" value="{{search}}" name="search" {{widget_status_attribute}} /> + <div class="ui-btn ui-input-clear ui-input-btn ui-corner-all ui-icon-search ui-btn-icon-notext" data-i18n="[node]header-submit"> + Submit<input data-enhanced="true" type="submit" data-i18n="[value]header-submit" value="Submit" {{widget_status_attribute}} /> + </div> + </div> + </div> + </div></form> + <table class="ui-responsive ui-body-c ui-table-inset custom-force-list"> + <thead class="ui-bar-inherit"> + <tr> + {{#each column_list}} + <th>{{this}}</th> + {{/each}} + </tr> + </thead> + {{> listbox-widget-table-partial}} + <tfoot class="ui-bar-inherit"></tfoot> + </table> + </script> + + <script id="listbox-widget-table-partial" type="text/x-handlebars-template"> + <tbody> + {{#each row_list}} + <tr> + {{#each cell_list}} + <td><a class="ui-link" href="{{href}}">{{value}}</a></td> + {{/each}} + </tr> + {{/each}} + </tbody> + </script> + + <!-- custom script --> + <script src="gadget_officejs_widget_listbox.js" type="text/javascript"></script> + + </head> + <body> + <div class="custom-grid-wrap"> + <div class="custom-grid ui-corner-all ui-body-inherit ui-shadow ui-corner-all"> + <div class="ui-body-c ui-corner-all"></div> + </div> + </div> + </body> +</html> \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.xml index 0aff0a7757..2666406c1a 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_html.xml @@ -97,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Page</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Widget Listbox</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -171,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -193,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438012253.92</float> + <float>1485779878.36</float> <string>UTC</string> </tuple> </state> @@ -224,7 +216,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -238,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>945.18321.41236.45056</string> </value> + <value> <string>956.64651.62129.51660</string> </value> </item> <item> <key> <string>state</string> </key> @@ -256,7 +248,7 @@ </tuple> <state> <tuple> - <float>1440439658.47</float> + <float>1485779826.21</float> <string>UTC</string> </tuple> </state> @@ -279,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -295,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -313,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438012182.81</float> + <float>1485779276.02</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.js b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.js index eced69a70e..5430ccd690 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.js +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.js @@ -1,161 +1,156 @@ -/*global window, rJS, RSVP, Handlebars, loopEventListener */ -/*jslint nomen: true, indent: 2 */ -(function (window, rJS, RSVP, Handlebars, loopEventListener) { - "use strict"; - - ///////////////////////////////////////////////////////////////// - // templates - ///////////////////////////////////////////////////////////////// - var gadget_klass = rJS(window), - templater = gadget_klass.__template_element, - - listbox_widget_table = Handlebars.compile( - templater.getElementById("listbox-widget-table").innerHTML - ); - Handlebars.registerPartial( - "listbox-widget-table-partial", - templater.getElementById("listbox-widget-table-partial").innerHTML - ); - - ///////////////////////////////////////////////////////////////// - // some methods - ///////////////////////////////////////////////////////////////// - - gadget_klass - - ///////////////////////////////////////////////////////////////// - // ready - ///////////////////////////////////////////////////////////////// - .ready(function (gadget) { - gadget.property_dict = { - render_deferred: RSVP.defer() - }; - }) - - .ready(function (gadget) { - return gadget.getElement() - .push(function (element) { - gadget.property_dict.element = element; - }); - }) - - ///////////////////////////////////////////////////////////////// - // published methods - ///////////////////////////////////////////////////////////////// - - ///////////////////////////////////////////////////////////////// - // acquired methods - ///////////////////////////////////////////////////////////////// - .declareAcquiredMethod("jio_allDocs", "jio_allDocs") - .declareAcquiredMethod("getUrlFor", "getUrlFor") - .declareAcquiredMethod("translate", "translate") - .declareAcquiredMethod("redirect", "redirect") - - ///////////////////////////////////////////////////////////////// - // declared methods - ///////////////////////////////////////////////////////////////// - .declareMethod('render', function (option_dict) { - var gadget = this, - content = '', - k, - k_len, - search_list = [], - translated_column_list = [], - all_docs_result; - - // store initial configuration - gadget.property_dict.option_dict = option_dict; - - // Create the search query - if (option_dict.search) { - for (k = 0, k_len = option_dict.column_list.length; k < k_len; k += 1) { - search_list.push(option_dict.column_list[k].select + ':"%' + option_dict.search + '%"'); - } - option_dict.query.query = '(' + search_list.join(' OR ') + ') AND ' + option_dict.query.query; - } - return gadget.jio_allDocs(option_dict.query) - .push(function (result) { - var promise_list = [], - i_len, - i; - all_docs_result = result; - for (i = 0, i_len = result.data.total_rows; i < i_len; i += 1) { - if (option_dict.came_from_jio_key) { - promise_list.push(gadget.getUrlFor({jio_key: option_dict.came_from_jio_key, page: 'view', came_from_jio_key: result.data.rows[i].id})); - } else { - promise_list.push(gadget.getUrlFor({jio_key: result.data.rows[i].id, page: 'view'})); - } - } - - return RSVP.all(promise_list); - }) - .push(function (link_list) { - var row_list = [], - cell_list, - i_len, - i, - j_len, - j; - - // build handlebars object - - for (j = 0, j_len = all_docs_result.data.total_rows; j < j_len; j += 1) { - cell_list = []; - for (i = 0, i_len = option_dict.column_list.length; i < i_len; i += 1) { - cell_list.push({ - "href": link_list[j], - "value": all_docs_result.data.rows[j].value[option_dict.column_list[i].select] - }); - } - row_list.push({"cell_list": cell_list}); - } - - for (i = 0; i < option_dict.column_list.length; i += 1) { - translated_column_list.push(gadget.translate(option_dict.column_list[i].title)); - } - return RSVP.all([ - row_list, - RSVP.all(translated_column_list) - ]); - }) - .push(function (result_list) { - content += listbox_widget_table({ - widget_theme : option_dict.widget_theme, - search: option_dict.search, - column_list: result_list[1], - row_list: result_list[0] - }); - - gadget.property_dict.element.querySelector(".custom-grid .ui-body-c") - .innerHTML = content; - gadget.property_dict.render_deferred.resolve(); - }); - }) - - ///////////////////////////////////////////////////////////////// - // declared service - ///////////////////////////////////////////////////////////////// - .declareService(function () { - var gadget = this; - return new RSVP.Queue() - .push(function () { - return gadget.property_dict.render_deferred.promise; - }) - .push(function () { - return loopEventListener( - gadget.property_dict.element.querySelector('form'), - 'submit', - false, - function (evt) { - return gadget.redirect({ - jio_key: gadget.property_dict.option_dict.jio_key || '', - page: gadget.property_dict.option_dict.search_page || '', - search: evt.target[0].value, - came_from_jio_key: gadget.property_dict.option_dict.came_from_jio_key - }); - } - ); - }); - }); - -}(window, rJS, RSVP, Handlebars, loopEventListener)); +/*global window, rJS, RSVP, Handlebars, loopEventListener */ +/*jslint nomen: true, indent: 2 */ +(function (window, rJS, RSVP, Handlebars, loopEventListener) { + "use strict"; + + ///////////////////////////////////////////////////////////////// + // templates + ///////////////////////////////////////////////////////////////// + var gadget_klass = rJS(window), + templater = gadget_klass.__template_element, + + listbox_widget_table = Handlebars.compile( + templater.getElementById("listbox-widget-table").innerHTML + ); + Handlebars.registerPartial( + "listbox-widget-table-partial", + templater.getElementById("listbox-widget-table-partial").innerHTML + ); + + ///////////////////////////////////////////////////////////////// + // some methods + ///////////////////////////////////////////////////////////////// + + gadget_klass + + ///////////////////////////////////////////////////////////////// + // ready + ///////////////////////////////////////////////////////////////// + .ready(function (gadget) { + gadget.property_dict = { + render_deferred: RSVP.defer() + }; + }) + + .ready(function (gadget) { + return gadget.getElement() + .push(function (element) { + gadget.property_dict.element = element; + }); + }) + + ///////////////////////////////////////////////////////////////// + // published methods + ///////////////////////////////////////////////////////////////// + + ///////////////////////////////////////////////////////////////// + // acquired methods + ///////////////////////////////////////////////////////////////// + .declareAcquiredMethod("jio_allDocs", "jio_allDocs") + .declareAcquiredMethod("getUrlFor", "getUrlFor") + .declareAcquiredMethod("translate", "translate") + .declareAcquiredMethod("redirect", "redirect") + + ///////////////////////////////////////////////////////////////// + // declared methods + ///////////////////////////////////////////////////////////////// + .declareMethod('render', function (option_dict) { + var gadget = this, + content = '', + k, + k_len, + search_list = [], + translated_column_list = [], + all_docs_result; + + // store initial configuration + gadget.property_dict.option_dict = option_dict; + + // Create the search query + if (option_dict.search) { + for (k = 0, k_len = option_dict.column_list.length; k < k_len; k += 1) { + search_list.push(option_dict.column_list[k].select + ':"%' + option_dict.search + '%"'); + } + option_dict.query.query = '(' + search_list.join(' OR ') + ') AND ' + option_dict.query.query; + } + return gadget.jio_allDocs(option_dict.query) + .push(function (result) { + var promise_list = [], + i_len, + i; + all_docs_result = result; + for (i = 0, i_len = result.data.total_rows; i < i_len; i += 1) { + promise_list.push(gadget.getUrlFor({jio_key: result.data.rows[i].id, page: 'view'})); + } + + return RSVP.all(promise_list); + }) + .push(function (link_list) { + var row_list = [], + cell_list, + i_len, + i, + j_len, + j; + + // build handlebars object + + for (j = 0, j_len = all_docs_result.data.total_rows; j < j_len; j += 1) { + cell_list = []; + for (i = 0, i_len = option_dict.column_list.length; i < i_len; i += 1) { + cell_list.push({ + "href": link_list[j], + "value": all_docs_result.data.rows[j].value[option_dict.column_list[i].select] + }); + } + row_list.push({"cell_list": cell_list}); + } + + for (i = 0; i < option_dict.column_list.length; i += 1) { + translated_column_list.push(gadget.translate(option_dict.column_list[i].title)); + } + return RSVP.all([ + row_list, + RSVP.all(translated_column_list) + ]); + }) + .push(function (result_list) { + content += listbox_widget_table({ + widget_theme : option_dict.widget_theme, + search: option_dict.search, + column_list: result_list[1], + row_list: result_list[0] + }); + + gadget.property_dict.element.querySelector(".custom-grid .ui-body-c") + .innerHTML = content; + gadget.property_dict.render_deferred.resolve(); + }); + }) + + ///////////////////////////////////////////////////////////////// + // declared service + ///////////////////////////////////////////////////////////////// + .declareService(function () { + var gadget = this; + return new RSVP.Queue() + .push(function () { + return gadget.property_dict.render_deferred.promise; + }) + .push(function () { + return loopEventListener( + gadget.property_dict.element.querySelector('form'), + 'submit', + false, + function (evt) { + return gadget.redirect({ + jio_key: gadget.property_dict.option_dict.jio_key || '', + page: gadget.property_dict.option_dict.search_page || '', + search: evt.target[0].value + }); + } + ); + }); + }); + +}(window, rJS, RSVP, Handlebars, loopEventListener)); \ No newline at end of file diff --git a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.xml b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.xml index ab08716948..3cfc4159bb 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_widget_listbox_js.xml @@ -69,6 +69,10 @@ <none/> </value> </item> + <item> + <key> <string>content_type</string> </key> + <value> <string>text/javascript</string> </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>gadget_officejs_widget_listbox.js</string> </value> @@ -93,21 +97,13 @@ <key> <string>portal_type</string> </key> <value> <string>Web Script</string> </value> </item> - <item> - <key> <string>short_title</string> </key> - <value> - <none/> - </value> - </item> <item> <key> <string>title</string> </key> <value> <string>OfficeJS Widget Listbox JS</string> </value> </item> <item> <key> <string>version</string> </key> - <value> - <none/> - </value> + <value> <string>001</string> </value> </item> <item> <key> <string>workflow_history</string> </key> @@ -167,7 +163,7 @@ </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -189,7 +185,7 @@ </tuple> <state> <tuple> - <float>1438012300.3</float> + <float>1485779801.92</float> <string>UTC</string> </tuple> </state> @@ -234,7 +230,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>956.14016.52782.35993</string> </value> + <value> <string>956.64651.59655.13977</string> </value> </item> <item> <key> <string>state</string> </key> @@ -252,7 +248,7 @@ </tuple> <state> <tuple> - <float>1482742612.5</float> + <float>1485779785.44</float> <string>UTC</string> </tuple> </state> @@ -275,11 +271,13 @@ <dictionary> <item> <key> <string>action</string> </key> - <value> <string>detect_converted_file</string> </value> + <value> + <none/> + </value> </item> <item> <key> <string>actor</string> </key> - <value> <string>cedric.le.ninivin</string> </value> + <value> <string>zope</string> </value> </item> <item> <key> <string>comment</string> </key> @@ -291,7 +289,7 @@ </item> <item> <key> <string>external_processing_state</string> </key> - <value> <string>converted</string> </value> + <value> <string>empty</string> </value> </item> <item> <key> <string>serial</string> </key> @@ -309,7 +307,7 @@ </tuple> <state> <tuple> - <float>1438012180.81</float> + <float>1485779273.78</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager.xml b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager.xml index d69b4ad06d..c1f3959312 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager.xml @@ -289,6 +289,46 @@ <value> <string>string</string> </value> </item> </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_latest_document_version</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_latest_version</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_cache_file</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_x_frame_options</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> </tuple> </value> </item> @@ -323,7 +363,7 @@ <value> <tuple> <string>caching_policy/no-cache</string> - <string>aggregate/web_page_module/rjs_gadget_erp5_html</string> + <string>aggregate/web_page_module/gadget_officejs_bootloader.html</string> </tuple> </value> </item> @@ -331,9 +371,13 @@ <key> <string>configuration_application_title</string> </key> <value> <string>Bookmark Manager</string> </value> </item> + <item> + <key> <string>configuration_cache_file</string> </key> + <value> <string>gadget_officejs_bookmark_manager.appcache</string> </value> + </item> <item> <key> <string>configuration_content_security_policy</string> </key> - <value> <string>default-src \'none\'; img-src \'self\' data:; media-src \'self\' blob:; connect-src \'self\' https://localhost:5000 mail.tiolive.com data:; script-src \'self\' \'unsafe-eval\'; font-src netdna.bootstrapcdn.com; style-src \'self\' netdna.bootstrapcdn.com \'unsafe-inline\' data:; frame-src \'self\' data:</string> </value> + <value> <string>default-src \'self\'; img-src \'self\' data:; media-src \'self\' blob:; connect-src \'self\' https://content.dropboxapi.com https://api.dropboxapi.com https://localhost:5000 mail.tiolive.com data: *.host.vifib.net *.node.vifib.com *.erp5.net; script-src \'self\' \'unsafe-eval\' \'unsafe-inline\'; font-src \'self\' netdna.bootstrapcdn.com; style-src \'self\' netdna.bootstrapcdn.com \'unsafe-inline\' data:; frame-src \'self\' data:</string> </value> </item> <item> <key> <string>configuration_default_view_action_reference</string> </key> @@ -359,6 +403,14 @@ <key> <string>configuration_jio_gadget_url</string> </key> <value> <string>gadget_officejs_jio.html</string> </value> </item> + <item> + <key> <string>configuration_latest_document_version</string> </key> + <value> <string>001</string> </value> + </item> + <item> + <key> <string>configuration_latest_version</string> </key> + <value> <string>development</string> </value> + </item> <item> <key> <string>configuration_manifest_url</string> </key> <value> <string>gadget_officejs_bookmark_manager.appcache</string> </value> @@ -381,17 +433,21 @@ <none/> </value> </item> + <item> + <key> <string>configuration_x_frame_options</string> </key> + <value> <string>ALLOW-FROM-ALL</string> </value> + </item> <item> <key> <string>container_layout</string> </key> - <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + <value> <string>WebSection_renderOfficeJSApplicationPage</string> </value> </item> <item> <key> <string>content_layout</string> </key> - <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + <value> <string>WebSection_renderOfficeJSApplicationPage</string> </value> </item> <item> <key> <string>custom_render_method_id</string> </key> - <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + <value> <string>WebSection_renderOfficeJSApplicationPage</string> </value> </item> <item> <key> <string>description</string> </key> @@ -409,7 +465,7 @@ </item> <item> <key> <string>layout_configuration_form_id</string> </key> - <value> <string>WebSection_viewRenderJSPreference</string> </value> + <value> <string>WebSection_viewOfficeJSApplicationPreference</string> </value> </item> <item> <key> <string>portal_type</string> </key> @@ -423,7 +479,7 @@ </item> <item> <key> <string>skin_selection_name</string> </key> - <value> <string>RJS</string> </value> + <value> <string>RJSVersionning</string> </value> </item> <item> <key> <string>static_language_selection</string> </key> @@ -616,7 +672,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>955.33994.14381.45824</string> </value> + <value> <string>956.64547.1035.31863</string> </value> </item> <item> <key> <string>state</string> </key> @@ -634,7 +690,7 @@ </tuple> <state> <tuple> - <float>1480323894.28</float> + <float>1485773650.59</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/rjsunsafe.xml b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/development.xml similarity index 60% rename from bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/rjsunsafe.xml rename to bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/development.xml index ac2e94437d..5713cf1c53 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/rjsunsafe.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/development.xml @@ -98,7 +98,7 @@ <key> <tuple> <int>99</int> - <string>ERP5 Web Section/rjsunsafe</string> + <string>ERP5 Web Section/development</string> </tuple> </key> <value> @@ -120,6 +120,103 @@ <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> + <item> + <key> <string>_local_properties</string> </key> + <value> + <tuple> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_router_gadget_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_jio_gadget_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_panel_gadget_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_translation_gadget_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_header_gadget_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_hateoas_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_x_frame_options</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_manifest_url</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_content_security_policy</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + </tuple> + </value> + </item> <item> <key> <string>_range_criterion</string> </key> <value> @@ -131,9 +228,58 @@ <value> <tuple> <string>caching_policy/must-revalidate</string> + <string>aggregate/web_page_module/rjs_gadget_erp5_html</string> </tuple> </value> </item> + <item> + <key> <string>configuration_content_security_policy</string> </key> + <value> <string>default-src \'self\'; img-src \'self\' data:; media-src \'self\' blob:; connect-src \'self\' https://content.dropboxapi.com https://api.dropboxapi.com https://localhost:5000 mail.tiolive.com data: *.host.vifib.net *.node.vifib.com *.erp5.net; script-src \'self\' \'unsafe-eval\' \'unsafe-inline\'; font-src \'self\' netdna.bootstrapcdn.com; style-src \'self\' netdna.bootstrapcdn.com \'unsafe-inline\' data:; frame-src \'self\' data:</string> </value> + </item> + <item> + <key> <string>configuration_hateoas_url</string> </key> + <value> <string>hateoasnoauth</string> </value> + </item> + <item> + <key> <string>configuration_header_gadget_url</string> </key> + <value> <string>gadget_officejs_header.html</string> </value> + </item> + <item> + <key> <string>configuration_jio_gadget_url</string> </key> + <value> <string>gadget_officejs_jio.html</string> </value> + </item> + <item> + <key> <string>configuration_manifest_url</string> </key> + <value> <string>gadget_officejs_bookmark_manager.appcache</string> </value> + </item> + <item> + <key> <string>configuration_panel_gadget_url</string> </key> + <value> <string>gadget_officejs_bookmark_manager_panel.html</string> </value> + </item> + <item> + <key> <string>configuration_router_gadget_url</string> </key> + <value> <string>gadget_officejs_bookmark_manager_router.html</string> </value> + </item> + <item> + <key> <string>configuration_translation_gadget_url</string> </key> + <value> <string>gadget_translation.html</string> </value> + </item> + <item> + <key> <string>configuration_x_frame_options</string> </key> + <value> <string>ALLOW-FROM-ALL</string> </value> + </item> + <item> + <key> <string>container_layout</string> </key> + <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + </item> + <item> + <key> <string>content_layout</string> </key> + <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + </item> + <item> + <key> <string>custom_render_method_id</string> </key> + <value> <string>WebSection_renderDefaultPageAsGadget</string> </value> + </item> <item> <key> <string>description</string> </key> <value> @@ -146,7 +292,11 @@ </item> <item> <key> <string>id</string> </key> - <value> <string>rjsunsafe</string> </value> + <value> <string>development</string> </value> + </item> + <item> + <key> <string>layout_configuration_form_id</string> </key> + <value> <string>WebSection_viewRenderJSPreference</string> </value> </item> <item> <key> <string>portal_type</string> </key> @@ -160,11 +310,11 @@ </item> <item> <key> <string>skin_selection_name</string> </key> - <value> <string>RJSUnsafe</string> </value> + <value> <string>RJS</string> </value> </item> <item> <key> <string>title</string> </key> - <value> <string>RJS Unsafe</string> </value> + <value> <string>Bookmark Manager Development</string> </value> </item> <item> <key> <string>visible</string> </key> @@ -329,7 +479,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>952.28990.12586.6929</string> </value> + <value> <string>956.64558.37525.61166</string> </value> </item> <item> <key> <string>state</string> </key> @@ -347,7 +497,7 @@ </tuple> <state> <tuple> - <float>1478604794.1</float> + <float>1485773692.55</float> <string>UTC</string> </tuple> </state> diff --git a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoas.xml b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoasnoauth.xml similarity index 85% rename from bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoas.xml rename to bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoasnoauth.xml index bc4ebe1af6..9058e076fa 100644 --- a/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoas.xml +++ b/bt5/erp5_officejs/PathTemplateItem/web_site_module/officejs_bookmark_manager/hateoasnoauth.xml @@ -98,7 +98,7 @@ <key> <tuple> <int>99</int> - <string>ERP5 Web Section/hateoas</string> + <string>ERP5 Web Section/hateoasnoauth</string> </tuple> </key> <value> @@ -194,6 +194,46 @@ <value> <string>string</string> </value> </item> </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_latest_document_version</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_latest_version</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_cache_file</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> + <dictionary> + <item> + <key> <string>id</string> </key> + <value> <string>configuration_x_frame_options</string> </value> + </item> + <item> + <key> <string>type</string> </key> + <value> <string>string</string> </value> + </item> + </dictionary> </tuple> </value> </item> @@ -217,6 +257,12 @@ <none/> </value> </item> + <item> + <key> <string>configuration_cache_file</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>configuration_content_security_policy</string> </key> <value> @@ -229,6 +275,22 @@ <none/> </value> </item> + <item> + <key> <string>configuration_latest_document_version</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>configuration_latest_version</string> </key> + <value> + <none/> + </value> + </item> + <item> + <key> <string>configuration_x_frame_options</string> </key> + <value> <string>ALLOW-FROM-ALL</string> </value> + </item> <item> <key> <string>container_layout</string> </key> <value> <string>ERP5Document_getHateoas</string> </value> @@ -265,7 +327,7 @@ </item> <item> <key> <string>id</string> </key> - <value> <string>hateoas</string> </value> + <value> <string>hateoasnoauth</string> </value> </item> <item> <key> <string>layout_configuration_form_id</string> </key> @@ -285,11 +347,11 @@ </item> <item> <key> <string>skin_selection_name</string> </key> - <value> <string>HalRestricted</string> </value> + <value> <string>Hal</string> </value> </item> <item> <key> <string>title</string> </key> - <value> <string>Restricted Hateoas</string> </value> + <value> <string>UnRestricted Hateoas</string> </value> </item> <item> <key> <string>view_action_category</string> </key> @@ -458,7 +520,7 @@ </item> <item> <key> <string>serial</string> </key> - <value> <string>952.28990.12586.6929</string> </value> + <value> <string>956.64550.37569.27579</string> </value> </item> <item> <key> <string>state</string> </key> @@ -476,7 +538,7 @@ </tuple> <state> <tuple> - <float>1478604794.11</float> + <float>1485773256.97</float> <string>UTC</string> </tuple> </state> -- 2.30.9