Commit 510cf1a7 authored by Eugene Shen's avatar Eugene Shen

Refactor and JSLint configurator files

Store only text content in jIO instead of the full stringified message,
rename message properties and recolour old messages to deal with that,
move jIO and MappingStorage scripts around in chat box and room HTML,
use room in queries because room is in the TextPost property sheet,
make the chat box redirect to chat connect if user_email is falsy,
completely refactor configurator files to delete custom settings,
remove requireSetting, and pass JSLint on all of them; finally,
store ID in mapping_id property in preparation for more fun.
parent da50ea6d
...@@ -6,7 +6,9 @@ ...@@ -6,7 +6,9 @@
<title>>Chat Room Gadget</title> <title>>Chat Room Gadget</title>
<script src="rsvp.js"></script> <script src="rsvp.js"></script>
<script src="renderjs.js"></script> <script src="renderjs.js"></script>
<script src="jiodev.js"></script>
<script src="handlebars.js"></script> <script src="handlebars.js"></script>
<script src="jio_mappingstorage.js"></script>
<script src="gadget_erp5_chat_room.js"></script> <script src="gadget_erp5_chat_room.js"></script>
<script class="connect-form-template" type="text/x-handlebars-template"> <script class="connect-form-template" type="text/x-handlebars-template">
<label> <label>
......
...@@ -147,6 +147,12 @@ ...@@ -147,6 +147,12 @@
<persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent>
</value> </value>
</item> </item>
<item>
<key> <string>edit_workflow</string> </key>
<value>
<persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent>
</value>
</item>
</dictionary> </dictionary>
</value> </value>
</item> </item>
...@@ -206,4 +212,63 @@ ...@@ -206,4 +212,63 @@
</tuple> </tuple>
</pickle> </pickle>
</record> </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>eyqs</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>958.41620.48534.44868</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>1492008152.73</float>
<string>UTC</string>
</tuple>
</state>
</object>
</value>
</item>
</dictionary>
</list>
</tuple>
</pickle>
</record>
</ZopeData> </ZopeData>
...@@ -8,11 +8,12 @@ ...@@ -8,11 +8,12 @@
// State is set in erp5_page_chat_box. // State is set in erp5_page_chat_box.
// The following function is acquired from erp5_page_chat_box. // The following function is acquired from erp5_page_chat_box.js
.declareAcquiredMethod("joinNewRoom", "joinNewRoom") .declareAcquiredMethod("joinNewRoom", "joinNewRoom")
// The following functions are all acquired from erp5_page_launcher. // The following functions are all acquired from erp5_launcher_nojqm.js.
.declareAcquiredMethod("jio_put", "jio_put") .declareAcquiredMethod("jio_put", "jio_put")
.declareAcquiredMethod("jio_get", "jio_get") .declareAcquiredMethod("jio_get", "jio_get")
.declareAcquiredMethod("jio_repair", "jio_repair") .declareAcquiredMethod("jio_repair", "jio_repair")
......
...@@ -143,6 +143,12 @@ ...@@ -143,6 +143,12 @@
<persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent>
</value> </value>
</item> </item>
<item>
<key> <string>edit_workflow</string> </key>
<value>
<persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent>
</value>
</item>
</dictionary> </dictionary>
</value> </value>
</item> </item>
...@@ -202,4 +208,63 @@ ...@@ -202,4 +208,63 @@
</tuple> </tuple>
</pickle> </pickle>
</record> </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>eyqs</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>958.41781.6927.63641</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>1492012150.54</float>
<string>UTC</string>
</tuple>
</state>
</object>
</value>
</item>
</dictionary>
</list>
</tuple>
</pickle>
</record>
</ZopeData> </ZopeData>
...@@ -6,7 +6,6 @@ ...@@ -6,7 +6,6 @@
<title>OfficeJS Chat</title> <title>OfficeJS Chat</title>
<script src="rsvp.js"></script> <script src="rsvp.js"></script>
<script src="renderjs.js"></script> <script src="renderjs.js"></script>
<script src="jiodev.js"></script>
<script src="handlebars.js"></script> <script src="handlebars.js"></script>
<script src="gadget_global.js"></script> <script src="gadget_global.js"></script>
<script src="gadget_erp5_page_chat_box.js"></script> <script src="gadget_erp5_page_chat_box.js"></script>
......
...@@ -147,6 +147,12 @@ ...@@ -147,6 +147,12 @@
<persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent>
</value> </value>
</item> </item>
<item>
<key> <string>edit_workflow</string> </key>
<value>
<persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent>
</value>
</item>
</dictionary> </dictionary>
</value> </value>
</item> </item>
...@@ -206,4 +212,63 @@ ...@@ -206,4 +212,63 @@
</tuple> </tuple>
</pickle> </pickle>
</record> </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>eyqs</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>958.41714.1894.49698</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>1492008152.15</float>
<string>UTC</string>
</tuple>
</state>
</object>
</value>
</item>
</dictionary>
</list>
</tuple>
</pickle>
</record>
</ZopeData> </ZopeData>
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* Settings required: /* Settings required:
* - jio_storage_description, or be redirected * - jio_storage_description, or be redirected
* - user-email * - user_email, or be redirected
* Settings used: * Settings used:
* - default_jio_type, default: "" * - default_jio_type, default: ""
* - default_erp5_url, default: "" * - default_erp5_url, default: ""
...@@ -70,7 +70,7 @@ ...@@ -70,7 +70,7 @@
*/ */
function getTime(message) { function getTime(message) {
return new Date(message.time).getTime(); return new Date(message.date_ms).getTime();
} }
...@@ -89,9 +89,10 @@ ...@@ -89,9 +89,10 @@
/* Create a new JSON message. /* Create a new JSON message.
* Parameters: * Parameters:
* - name: the name of the sender of the message * - type: the type of message, either "notification" or "message"
* - author: the name of the sender of the message
* - room: the room from where the message is sent * - room: the room from where the message is sent
* - time: the epoch time at which the message is sent * - date_ms: the epoch time at which the message is sent
* - content: the content of the message * - content: the content of the message
* - color: the colour of the message in the chat * - color: the colour of the message in the chat
* Effects: nothing * Effects: nothing
...@@ -101,11 +102,11 @@ ...@@ -101,11 +102,11 @@
function createMessage(param_dict) { function createMessage(param_dict) {
return { return {
type: param_dict.type || "message", type: param_dict.type || "message",
name: param_dict.name, author: param_dict.author,
room: param_dict.room, room: param_dict.room,
time: param_dict.time || new Date(), date_ms: param_dict.date_ms || new Date(),
content: param_dict.content || "", content: param_dict.content || "",
color: param_dict.color || "black" color: param_dict.color || "grey"
}; };
} }
...@@ -130,8 +131,8 @@ ...@@ -130,8 +131,8 @@
} else if (message.type === "message") { } else if (message.type === "message") {
// Put message in the format "[3/24/2017, 11:30:52 AM] user: message" // Put message in the format "[3/24/2017, 11:30:52 AM] user: message"
chat.html = "[" + new Date(message.time).toLocaleString() chat.html = "[" + new Date(message.date_ms).toLocaleString()
+ "] " + message.name + ": "; + "] " + message.author + ": ";
// Loop through all potential URLs in the message // Loop through all potential URLs in the message
// matches[i] is the non-link content, matches[i + 1] is the actual link // matches[i] is the non-link content, matches[i + 1] is the actual link
...@@ -235,11 +236,11 @@ ...@@ -235,11 +236,11 @@
}) })
// The following functions are all acquired from erp5_page_launcher. // The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod("updateHeader", "updateHeader") .declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("requireSetting", "requireSetting")
.declareAcquiredMethod("getSetting", "getSetting") .declareAcquiredMethod("getSetting", "getSetting")
.declareAcquiredMethod("redirect", "redirect")
.declareAcquiredMethod("jio_post", "jio_post") .declareAcquiredMethod("jio_post", "jio_post")
.declareAcquiredMethod("jio_allDocs", "jio_allDocs") .declareAcquiredMethod("jio_allDocs", "jio_allDocs")
...@@ -259,7 +260,7 @@ ...@@ -259,7 +260,7 @@
return gadget.changeState({room: param_list[0], is_chat: true}) return gadget.changeState({room: param_list[0], is_chat: true})
.push(function () { .push(function () {
gadget.deployMessage({ gadget.deployMessage({
name: gadget.state.name, author: gadget.state.name,
room: param_list[0], room: param_list[0],
content: gadget.state.name + " has joined.", content: gadget.state.name + " has joined.",
color: "orange" color: "orange"
...@@ -368,10 +369,11 @@ ...@@ -368,10 +369,11 @@
* - getSetting: user_email, jio_storage_description, * - getSetting: user_email, jio_storage_description,
* default_jio_type, default_erp5_url, default_dav_url * default_jio_type, default_erp5_url, default_dav_url
* Effects: * Effects:
* - update header, page_title to "OfficeJS Chat" * - updateHeader: "OfficeJS Chat"
* - compile Handlebars templates * - redirect to jio_configurator if in getSetting,
* no jIO storage available or no user email given
* - update state with default parameters * - update state with default parameters
* - redirect if no jIO storage available * - compile Handlebars templates
* - declare a new room gadget for each contact in jIO storage * - declare a new room gadget for each contact in jIO storage
* - create the user contact if not present, whose name is the user name * - create the user contact if not present, whose name is the user name
* - change to the user contact panel * - change to the user contact panel
...@@ -381,14 +383,24 @@ ...@@ -381,14 +383,24 @@
var gadget = this, var gadget = this,
user_email, user_email,
has_own_contact = false; has_own_contact = false;
return gadget.requireSetting( return gadget.updateHeader({page_title: "OfficeJS Chat"})
"jio_storage_description",
"jio_configurator",
new RSVP.Queue()
.push(function () { .push(function () {
return gadget.updateHeader({page_title: "OfficeJS Chat"}); return RSVP.all([
gadget.getSetting("user_email"),
gadget.getSetting("jio_storage_description"),
gadget.getSetting("default_jio_type"),
gadget.getSetting("default_erp5_url"),
gadget.getSetting("default_dav_url")
]);
}) })
.push(function () { .push(function (setting_list) {
user_email = setting_list[0];
if (!user_email || !setting_list[1]) {
throw gadget.redirect({
command: "display",
options: {page: "chat_connect"}
});
}
gadget.state.chat_list_template = Handlebars.compile( gadget.state.chat_list_template = Handlebars.compile(
Object.getPrototypeOf(gadget).constructor.__template_element Object.getPrototypeOf(gadget).constructor.__template_element
.querySelector(".chat-list-template").innerHTML .querySelector(".chat-list-template").innerHTML
...@@ -401,25 +413,12 @@ ...@@ -401,25 +413,12 @@
.querySelector(".chat-title"); .querySelector(".chat-title");
gadget.state.chat_box_element = gadget.element gadget.state.chat_box_element = gadget.element
.querySelector(".chat-right-panel-chat"); .querySelector(".chat-right-panel-chat");
return RSVP.all([
gadget.getSetting("user_email"),
gadget.getSetting("jio_storage_description"),
gadget.getSetting("default_jio_type", "none"),
gadget.getSetting("default_erp5_url", "none"),
gadget.getSetting("default_dav_url", "none")
]);
})
.push(function (setting_list) {
user_email = setting_list[0];
return gadget.changeState({ return gadget.changeState({
name: user_email, name: user_email,
local_sub_storage: setting_list[1], local_sub_storage: setting_list[1],
default_jio_type: setting_list[2] === "none" ? default_jio_type: setting_list[2],
null : setting_list[2], default_erp5_url: setting_list[3],
default_erp5_url: setting_list[3] === "none" ? default_dav_url: setting_list[4]
null : setting_list[3],
default_dav_url: setting_list[4] === "none" ?
null : setting_list[4]
}); });
}) })
.push(function () { .push(function () {
...@@ -471,8 +470,7 @@ ...@@ -471,8 +470,7 @@
return gadget.createRoom(user_email); return gadget.createRoom(user_email);
} }
return gadget.changeState({room: user_email, is_chat: false}); return gadget.changeState({room: user_email, is_chat: false});
}) });
);
}) })
...@@ -514,10 +512,8 @@ ...@@ -514,10 +512,8 @@
default_jio_type: gadget.state.default_jio_type, default_jio_type: gadget.state.default_jio_type,
default_erp5_url: gadget.state.default_erp5_url, default_erp5_url: gadget.state.default_erp5_url,
default_dav_url: gadget.state.default_dav_url, default_dav_url: gadget.state.default_dav_url,
// XXX store room in description because description is
// indexed in ERP5, and only indexed properties can be queried
query: { query: {
query: 'portal_type: "Text Post" AND description: "' + room + '"', query: 'portal_type: "Text Post" AND room: "' + room + '"',
limit: [0, JIO_QUERY_MAX_LIMIT], limit: [0, JIO_QUERY_MAX_LIMIT],
select_list: ["content"], select_list: ["content"],
sort_on: [ sort_on: [
...@@ -648,19 +644,18 @@ ...@@ -648,19 +644,18 @@
.declareMethod("storeArchive", function (message) { .declareMethod("storeArchive", function (message) {
var gadget = this, var gadget = this,
id = message.room + "_" + message.name + "_" id = message.room + "_" + message.author
+ getTime(message).toString(); + "_" + getTime(message).toString();
return gadget.getDeclaredGadget("room-gadget-" + gadget.state.room) return gadget.getDeclaredGadget("room-gadget-" + gadget.state.room)
.push(function (room_gadget) { .push(function (room_gadget) {
return room_gadget.wrapJioCall("put", [id, { return room_gadget.wrapJioCall("put", [id, {
portal_type: "Text Post", portal_type: "Text Post",
parent_relative_url: "post_text_module", parent_relative_url: "text_post_module",
reference: id, author: message.author,
author: message.name,
date_ms: getTime(message),
room: message.room, room: message.room,
description: message.room, date_ms: getTime(message),
content: JSON.stringify(message) content: message.content,
mapping_id: id
}]); }]);
}); });
}) })
...@@ -778,7 +773,7 @@ ...@@ -778,7 +773,7 @@
return room_gadget.wrapJioCall("allDocs", [{ return room_gadget.wrapJioCall("allDocs", [{
query: 'portal_type: "Text Post" AND room: "' + room + '"', query: 'portal_type: "Text Post" AND room: "' + room + '"',
limit: [0, JIO_QUERY_MAX_LIMIT], limit: [0, JIO_QUERY_MAX_LIMIT],
select_list: ["content"], select_list: ["author", "room", "date_ms", "content"],
sort_on: [ sort_on: [
["date_ms", "ascending"], ["date_ms", "ascending"],
["content", "ascending"] ["content", "ascending"]
...@@ -799,18 +794,23 @@ ...@@ -799,18 +794,23 @@
// merge two sorted lists of unique messages together // merge two sorted lists of unique messages together
j = 0; j = 0;
for (i = 0; i < result_list.data.total_rows; i += 1) { for (i = 0; i < result_list.data.total_rows; i += 1) {
message = JSON.parse(result_list.data.rows[i].value.content); message = createMessage(result_list.data.rows[i].value);
if (typeof message === "object") { // add old messages sent before the current message
while (j < old_list.length while (j < old_list.length
&& getTime(old_list[j]) < getTime(message)) { && getTime(old_list[j]) < getTime(message)) {
new_list.push(old_list[j]); new_list.push(old_list[j]);
j += 1; j += 1;
} }
// ignore duplicates between the lists // add the old message if it's the same as the current message
if (j < old_list.length && isSameMessage(old_list[j], message)) {
new_list.push(old_list[j]);
// ignore all other duplicate old messages
while (j < old_list.length while (j < old_list.length
&& isSameMessage(old_list[j], message)) { && isSameMessage(old_list[j], message)) {
j += 1; j += 1;
} }
} else {
// otherwise add the current message
new_list.push(message); new_list.push(message);
} }
} }
...@@ -866,7 +866,7 @@ ...@@ -866,7 +866,7 @@
return gadget.changeRoom(argument); return gadget.changeRoom(argument);
} }
return gadget.deployNotification({ return gadget.deployNotification({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: "You must first add '" + argument + "' as a contact!", content: "You must first add '" + argument + "' as a contact!",
color: "red" color: "red"
...@@ -878,7 +878,7 @@ ...@@ -878,7 +878,7 @@
.push(function () { .push(function () {
if (gadget.state.room === gadget.state.name) { if (gadget.state.room === gadget.state.name) {
return gadget.deployNotification({ return gadget.deployNotification({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: "You cannot leave your own room!", content: "You cannot leave your own room!",
color: "red" color: "red"
...@@ -886,7 +886,7 @@ ...@@ -886,7 +886,7 @@
} }
delete gadget.state.message_list_dict[gadget.state.room]; delete gadget.state.message_list_dict[gadget.state.room];
return gadget.deployMessage({ return gadget.deployMessage({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: gadget.state.name + " has quit.", content: gadget.state.name + " has quit.",
color: "orange" color: "orange"
...@@ -904,7 +904,7 @@ ...@@ -904,7 +904,7 @@
case "help": case "help":
for (i = 0; i < help_list.length; i += 1) { for (i = 0; i < help_list.length; i += 1) {
promise_list.push(gadget.deployNotification({ promise_list.push(gadget.deployNotification({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: help_list[i], content: help_list[i],
color: "green" color: "green"
...@@ -914,7 +914,7 @@ ...@@ -914,7 +914,7 @@
default: default:
return gadget.deployNotification({ return gadget.deployNotification({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: "'" + argument + "' is not a valid command.", content: "'" + argument + "' is not a valid command.",
color: "red" color: "red"
...@@ -956,9 +956,10 @@ ...@@ -956,9 +956,10 @@
return gadget.parseCommand(content); return gadget.parseCommand(content);
} }
return gadget.deployMessage({ return gadget.deployMessage({
name: gadget.state.name, author: gadget.state.name,
room: gadget.state.room, room: gadget.state.room,
content: content content: content,
color: "black"
}); });
} }
}) })
...@@ -981,7 +982,7 @@ ...@@ -981,7 +982,7 @@
if (gadget.state.message_list_dict.hasOwnProperty(room) if (gadget.state.message_list_dict.hasOwnProperty(room)
&& gadget.state.message_count_dict[room] > 0) { && gadget.state.message_count_dict[room] > 0) {
promise_list.push(gadget.deployMessage({ promise_list.push(gadget.deployMessage({
name: gadget.state.name, author: gadget.state.name,
room: room, room: room,
content: gadget.state.name + " has quit.", content: gadget.state.name + " has quit.",
color: "orange" color: "orange"
......
...@@ -237,7 +237,7 @@ ...@@ -237,7 +237,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41680.17002.58555</string> </value> <value> <string>958.41791.24067.34747</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -255,7 +255,7 @@ ...@@ -255,7 +255,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1492006100.28</float> <float>1492013661.62</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
...@@ -142,6 +142,12 @@ ...@@ -142,6 +142,12 @@
<persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent>
</value> </value>
</item> </item>
<item>
<key> <string>edit_workflow</string> </key>
<value>
<persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent>
</value>
</item>
</dictionary> </dictionary>
</value> </value>
</item> </item>
...@@ -201,4 +207,63 @@ ...@@ -201,4 +207,63 @@
</tuple> </tuple>
</pickle> </pickle>
</record> </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>eyqs</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>958.41727.25173.10461</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>1492008933.86</float>
<string>UTC</string>
</tuple>
</state>
</object>
</value>
</item>
</dictionary>
</list>
</tuple>
</pickle>
</record>
</ZopeData> </ZopeData>
...@@ -11,23 +11,46 @@ ...@@ -11,23 +11,46 @@
*/ */
rJS(window)
// Neither state to set nor ready to initialize.
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("redirect", "redirect")
.declareAcquiredMethod("setSetting", "setSetting")
// Update header, page_title to "Connect to Chat".
.declareMethod("render", function () {
var gadget = this;
return gadget.updateHeader({
page_title: "Connect to Chat",
submit_action: true
});
})
/* Store the given connection settings. /* Store the given connection settings.
* Parameters: all from the connect form, * Parameters: all from the connect form,
* - user_email: an email, which acts as a username, example: eugene@abc.xyz * - user_email: an email, which acts as a username, example: eyqs@abc.xyz
* - default_jio_type: the type of storage to select by default * - default_jio_type: the type of storage to select by default
* for sharing chat messages, example: erp5 * for sharing chat messages, example: erp5
* - default_erp5_url: the ERP5 URL to select by default, example: * - default_erp5_url: the ERP5 URL to select by default, example:
* https://softinst75770.host.vifib.net/erp5/web_site_module/hateoas * https://softinst75770.host.vifib.net/erp5/web_site_module/hateoas
* - default_dav_url: the WebDAV URL to select by default for sharing, * - default_dav_url: the WebDAV URL to select by default, example:
* example: https://softinst75722.host.vifib.net/share * https://softinst75722.host.vifib.net/share
* Effects: * Effects:
* - setSetting: user_email, default_jio_type, * - setSetting: user_email, default_jio_type,
* default_erp5_url, default_dav_url * default_erp5_url, default_dav_url
* - redirect to the front page * - redirect to the front page
*/ */
function setConnectConfiguration(gadget, event) { .declareMethod("setConnectConfiguration", function (event) {
var i, field, queue = new RSVP.Queue(), var i, field, gadget = this,
queue = new RSVP.Queue(),
fields = ["user_email", "default_jio_type", fields = ["user_email", "default_jio_type",
"default_erp5_url", "default_dav_url"], "default_erp5_url", "default_dav_url"],
callSetting = function (setting) { callSetting = function (setting) {
...@@ -45,31 +68,7 @@ ...@@ -45,31 +68,7 @@
} }
return queue return queue
.push(function () { .push(function () {
return gadget.redirect(); return gadget.redirect({command: "display"});
});
}
rJS(window)
// Neither state to set nor ready to initialize.
// The following functions are all acquired from erp5_page_launcher.
.declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("redirect", "redirect")
.declareAcquiredMethod("setSetting", "setSetting")
/* Render the gadget.
* Effects: update header, page_title to "Connect to Chat"
*/
.declareMethod("render", function () {
var gadget = this;
return gadget.updateHeader({
page_title: "Connect to Chat",
submit_action: true
}); });
}) })
...@@ -87,7 +86,7 @@ ...@@ -87,7 +86,7 @@
.onEvent("submit", function (event) { .onEvent("submit", function (event) {
var gadget = this; var gadget = this;
return setConnectConfiguration(gadget, event); return gadget.setConnectConfiguration(event);
}); });
}(window, RSVP, rJS)); }(window, RSVP, rJS));
\ No newline at end of file
...@@ -232,7 +232,7 @@ ...@@ -232,7 +232,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41616.27300.46916</string> </value> <value> <string>958.41780.54327.47889</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -250,7 +250,7 @@ ...@@ -250,7 +250,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1492002551.39</float> <float>1492012847.47</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/* jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */ /*jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */
/* global window, document, RSVP, rJS */ /*global window, RSVP, rJS */
(function (window, document, RSVP, rJS) { (function (window, RSVP, rJS) {
'use strict'; "use strict";
/* How does redirection work in OfficeJS? /* How does redirection work in OfficeJS Chat?
* - most gadgets redirect to the front page * - most gadgets redirect to the front page
* - when storage is not configured, all non-configurator gadgets * - when jio_storage_description is falsy, gadget_officejs_jio.html
* automatically redirect to jio_configurator * redirects all pages that declare it to page_jio_configurator.html
* - when user is not logged in, all gadgets redirect to connect_page * - when user_email is falsy, gadget_erp5_chat_box.html
* - most -> front page, non-configurator -> jio_configurator -> connect_page * redirects users to page_chat_connect.html
* - most -> front page, falsy jio -> jio_configurator -> connect_page
*/ */
/* Settings required: /* Settings required:
* - application_title * - application_title
* - dropbox_app_key, iff setting Dropbox configuration * - dropbox_app_key, iff setting Dropbox configuration
* - user_email, or be redirected
* Settings used: * Settings used:
* - connect_page, default: '' * - indexeddb_database_name, default: "officejs"
* - indexeddb_database_name, default: 'jio'
* - dropbox_redirect_uri, default: window.location.origin * - dropbox_redirect_uri, default: window.location.origin
* - dropbox_authentication_uri, default: 'https://www.dropbox.com/1/oauth2' * - dropbox_authentication_uri, default: "https://www.dropbox.com/1/oauth2"
* + '/authorize?client_id={0}&response_type=token&redirect_uri={1}' * + "/authorize?client_id={0}&response_type=token&redirect_uri={1}"
* Settings modified: * Settings modified:
* - jio_storage_name, example: 'local' * - jio_storage_name, example: "local"
* - jio_storage_description, example: {type: 'indexeddb', database: 'foo'} * - jio_storage_description, example: {type: "indexeddb", database: "foo"}
* - redirect_after_reload, to: {command: 'display', options: {page: 'sync'}} * - redirect_after_reload, to: {command: "display", options: {page: "sync"}}
*/ */
/* The following setFooConfiguration functions generate jIO configurations
rJS(window)
.setState({
// Map between short names and their displayed value in storage_message
storage_name_dict: {
erp5: "ERP5",
local: "nothing. You are only using local storage",
dav: "WebDAV storage",
dropbox: "Dropbox"
}
})
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("redirect", "redirect")
.declareAcquiredMethod("reload", "reload")
.declareAcquiredMethod("setSetting", "setSetting")
.declareAcquiredMethod("getSetting", "getSetting")
/* Render the gadget
* Parameters: * Parameters:
* - setLocalConfiguration, get setting: indexeddb_database_name * - getSetting: jio_storage_name
* - setDropboxConfiguration, get setting: * Effects:
* - hide document_configurator gadget based on jio_storage_name
* - style configurator buttons based on jio_storage_name
* - updateHeader: "Storage Configurator"
*/
.declareMethod("render", function () {
var gadget = this;
return gadget.getSetting("redirect_after_reload")
.push(function (redirect) {
if (redirect) {
return gadget.setSetting("redirect_after_reload", null)
.push(function () {
return gadget.redirect(redirect);
});
}
return gadget.updateHeader({page_title: "Storage Configurator"})
.push(function () {
gadget.element.querySelector(".configurator-welcome")
.style.display = "none";
return RSVP.all([
gadget.getSetting("application_title"),
gadget.getSetting("jio_storage_name")
]);
})
.push(function (setting_list) {
gadget.element.querySelector(".configurator-document p")
.innerHTML = "Your current remote storage is "
+ gadget.state.storage_name_dict[setting_list[1]] + ".";
switch (setting_list[1]) {
case "erp5":
gadget.element.querySelector("form.select-erp5-form button")
.classList.add("ui-btn-active");
break;
case "local":
gadget.element.querySelector("form.select-local-form button")
.classList.add("ui-btn-active");
break;
case "dav":
gadget.element.querySelector("form.select-dav-form button")
.classList.add("ui-btn-active");
break;
case "dropbox":
gadget.element.querySelector("form.select-dropbox-form button")
.classList.add("active");
break;
default:
gadget.element.querySelector(".configurator-welcome h3")
.innerHTML = "Welcome to " + setting_list[0]
+ ". Please start by choosing a storage.";
gadget.element.querySelector(".configurator-welcome")
.style.display = "unset";
gadget.element.querySelector("div[data-gadget-scope="
+ "document_configurator").style.display = "none";
break;
}
});
});
})
/* The following setFooConfiguration functions generate jIO configurations.
* Parameters:
* - setLocalConfiguration, getSetting: indexeddb_database_name
* - setDropboxConfiguration, getSetting:
* dropbox_app_key, dropbox_redirect_uri, dropbox_authentication_uri * dropbox_app_key, dropbox_redirect_uri, dropbox_authentication_uri
* Effects: * Effects:
* - set setting: * - setSetting:
* jio_storage_name, jio_storage_description, redirect_after_reload * jio_storage_name, jio_storage_description, redirect_after_reload
* - reload, then redirect to sync * - reload, then redirect to sync
*/ */
function setErp5Configuration(gadget) {
.declareMethod("setErp5Configuration", function () {
var gadget = this;
return gadget.redirect({ return gadget.redirect({
command: 'display', command: "display",
options: {page: 'jio_erp5_configurator'}, options: {page: "jio_erp5_configurator"}
}); });
}
function setLocalConfiguration(gadget) {
return new RSVP.Queue()
.push(function () {
return gadget.setSetting('jio_storage_name', 'local');
}) })
.declareMethod("setLocalConfiguration", function () {
var gadget = this;
return gadget.setSetting("jio_storage_name", "local")
.push(function () { .push(function () {
return gadget.getSetting('indexeddb_database_name', 'jio'); return gadget.getSetting("indexeddb_database_name", "officejs");
}) })
.push(function (indexeddb_database) { .push(function (indexeddb_database) {
const configuration = { var configuration = {
type: 'query', type: "query",
sub_storage: { sub_storage: {
type: 'uuid', type: "uuid",
sub_storage: { sub_storage: {
type: 'indexeddb', type: "indexeddb",
database: indexeddb_database, database: indexeddb_database
}, }
}, }
}; };
return gadget.setSetting('jio_storage_description', configuration); return gadget.setSetting("jio_storage_description", configuration);
}) })
.push(function () { .push(function () {
return gadget.setSetting('redirect_after_reload', { return gadget.setSetting("redirect_after_reload", {
command: 'display', command: "display",
options: {page: 'sync'}, options: {page: "sync"}
}); });
}) })
.push(function (res) { .push(function () {
return gadget.reload(); return gadget.reload();
}); });
} })
function setDavConfiguration(gadget) { .declareMethod("setDavConfiguration", function () {
var gadget = this;
return gadget.redirect({ return gadget.redirect({
command: 'display', command: "display",
options: {page: 'jio_dav_configurator'}, options: {page: "jio_dav_configurator"}
}); });
} })
function setDropboxConfiguration(gadget) { .declareMethod("setDropboxConfiguration", function () {
var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
.push(function () { .push(function () {
return RSVP.all([ return RSVP.all([
gadget.getSetting('dropbox_app_key'), gadget.getSetting("dropbox_app_key"),
gadget.getSetting('dropbox_redirect_uri', window.location.origin), gadget.getSetting("dropbox_redirect_uri", window.location.origin),
gadget.getSetting('dropbox_authentication_uri', gadget.getSetting("dropbox_authentication_uri",
'https://www.dropbox.com/1/oauth2/authorize?' "https://www.dropbox.com/1/oauth2/authorize?"
+ 'client_id={0}&response_type=token&redirect_uri={1}'), + "client_id={0}&response_type=token&redirect_uri={1}")
]); ]);
}) })
.push(function (setting_list) { .push(function (setting_list) {
window.location = setting_list[2] window.location = setting_list[2]
.replace('{0}', setting_list[0]).replace('{1}', setting_list[1]); .replace("{0}", setting_list[0]).replace("{1}", setting_list[1]);
return;
}); });
}
rJS(window)
.setState({
// Map between short names and their displayed value in storage_message
storage_name_dict: {
erp5: 'ERP5',
local: 'nothing. You are only using local storage',
dav: 'WebDAV storage',
dropbox: 'Dropbox',
},
}) })
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('translateHtml', 'translateHtml')
.declareAcquiredMethod('redirect', 'redirect')
.declareAcquiredMethod('reload', 'reload')
.declareAcquiredMethod('setSetting', 'setSetting')
.declareAcquiredMethod('getSetting', 'getSetting')
.declareAcquiredMethod('requireSetting', 'requireSetting')
/* Render the gadget
* Parameters:
* - getSetting: jio_storage_name, user_email
* Effects:
* - hide document_configurator gadget based on jio_storage_name
* - style configurator buttons based on jio_storage_name
* - update header, page title to 'Storage Configurator'
* - redirect if user not logged in
*/
.declareMethod('render', function () {
const gadget = this;
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('redirect_after_reload', 'none');
})
.push(function (redirect) {
if (redirect !== 'none') {
return new RSVP.Queue()
.push(function () {
return gadget.setSetting('redirect_after_reload', null);
})
.push(function () {
return gadget.redirect(redirect);
});
} else {
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('connect_page', 'none');
})
.push(function (connect_page) {
return gadget.requireSetting(
'user_email',
connect_page,
new RSVP.Queue()
.push(function () {
gadget.element.querySelector('.configurator-welcome')
.style.display = 'none';
return gadget.updateHeader({page_title: 'Storage Configurator'})
})
.push(function () {
return RSVP.all([
gadget.getSetting('application_title'),
gadget.getSetting('jio_storage_name', 'none'),
])
}).push(function (setting_list) {
gadget.element.querySelector('.configurator-document p')
.innerHTML = 'Your current remote storage is '
+ gadget.state.storage_name_dict[setting_list[1]] + '.';
switch (setting_list[1]) {
case 'erp5':
gadget.element.querySelector('form.select-erp5-form button')
.classList.add('ui-btn-active');
break;
case 'local':
gadget.element.querySelector('form.select-local-form button')
.classList.add('ui-btn-active');
break;
case 'dav':
gadget.element.querySelector('form.select-dav-form button')
.classList.add('ui-btn-active');
break;
case 'dropbox':
gadget.element.querySelector('form.select-dropbox-form '
+ 'button').classList.add('active');
break;
default:
gadget.element.querySelector('.configurator-welcome h3')
.innerHTML = 'Welcome to ' + setting_list[0]
+ '. Please start by choosing a storage.';
gadget.element.querySelector('.configurator-welcome')
.style.display = 'unset';
gadget.element.querySelector('div[data-gadget-scope='
+ 'document_configurator').style.display = 'none';
break;
}
return;
})
);
});
}
});
})
// Call a setFooConfiguration function based on the form submitted // Call a setFooConfiguration function based on the form submitted
.onEvent('submit', function (event) { .onEvent("submit", function (event) {
const gadget = this; var gadget = this;
switch (event.target.className) { switch (event.target.className) {
case 'grid-box select-erp5-form': case "grid-box select-erp5-form":
return setErp5Configuration(gadget); return gadget.setErp5Configuration(gadget);
case 'grid-box select-local-form': case "grid-box select-local-form":
return setLocalConfiguration(gadget); return gadget.setLocalConfiguration(gadget);
case 'grid-box select-dav-form': case "grid-box select-dav-form":
return setDavConfiguration(gadget); return gadget.setDavConfiguration(gadget);
case 'grid-box select-dropbox-form': case "grid-box select-dropbox-form":
return setDropboxConfiguration(gadget); return gadget.setDropboxConfiguration(gadget);
} }
}); });
}(window, document, RSVP, rJS)); }(window, RSVP, rJS));
\ No newline at end of file \ No newline at end of file
...@@ -232,7 +232,7 @@ ...@@ -232,7 +232,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41673.52064.42257</string> </value> <value> <string>958.41805.52664.20462</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -250,7 +250,7 @@ ...@@ -250,7 +250,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1492005762.42</float> <float>1492013630.58</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/* global window, RSVP, rJS, btoa */ /*jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */
/* jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */ /*global window, RSVP, rJS, btoa */
(function (window, RSVP, rJS, btoa) { (function (window, RSVP, rJS, btoa) {
'use strict'; "use strict";
/* Settings required: /* Settings used:
* - jio_general_query * - jio_query, default: ""
* - user_email, or be redirected * - indexeddb_database_name, default: "officejs"
* Settings used:
* - connect_page, default: ''
* - indexeddb_database_name, default: 'jio'
* Settings modified: * Settings modified:
* - jio_storage_name, to: 'dav' * - jio_storage_name, to: "dav"
* - jio_storage_description * - jio_storage_description
* - redirect_after_reload, to: {command: 'display', options: {page: 'sync'}} * - redirect_after_reload, to: {command: "display", options: {page: "sync"}}
*/ */
/* Generate a generic jIO configuration for WebDAV storage
rJS(window)
// Neither state to set nor ready to initialize
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("reload", "reload")
.declareAcquiredMethod("setSetting", "setSetting")
.declareAcquiredMethod("getSetting", "getSetting")
/* Render the gadget
* Parameters:
* - getSetting: jio_storage_name, jio_storage_description
* Effects:
* - updateHeader: "Configure WebDAV Storage"
* - hide document_configurator gadget based on jio_storage_name
* - pre-fill input field if jio_storage_description already defined
*/
.declareMethod("render", function () {
var gadget = this;
return gadget.updateHeader({
page_title: "Configure WebDAV Storage",
back_url: "#!display?n.page=jio_configurator"
})
.push(function () {
return gadget.getSetting("jio_storage_name");
})
.push(function (storage_name) {
if (storage_name === "dav") {
return gadget.getSetting("jio_storage_description")
.push(function (configuration) {
gadget.element.querySelector("input[name='dav_url']")
.value = configuration.remote_sub_storage
.sub_storage.sub_storage.url;
});
}
gadget.element.querySelector("div[data-gadget-scope="
+ "document_configurator").style.display = "none";
});
})
/* Generate a generic jIO configuration for WebDAV storage.
* Parameters: * Parameters:
* - dav_url: the WebDAV URL from the configuration form, * - dav_url: the WebDAV URL from the configuration form,
* example: https://softinst75722.host.vifib.net/share * example: https://softinst75722.host.vifib.net/share
* - dav_user: the WebDAV username, example: eyqs * - dav_user: the WebDAV username, example: eyqs
* - dav_pass: the WebDAV password, example: correct horse battery staple * - dav_pass: the WebDAV password, example: correct horse battery staple
* - get setting: jio_general_query, indexeddb_database_name * - getSetting: jio_query, indexeddb_database_name
* Effects: * Effects:
* - set setting: * - setSetting:
* jio_storage_name, jio_storage_description, redirect_after_reload * jio_storage_name, jio_storage_description, redirect_after_reload
* - reload, then redirect to sync * - reload, then redirect to sync
*/ */
function setDavConfiguration(gadget, event) {
return new RSVP.Queue() .declareMethod("setDavConfiguration", function (event) {
.push(function () { var gadget = this;
return gadget.setSetting('jio_storage_name', 'dav'); return gadget.setSetting("jio_storage_name", "dav")
})
.push(function () { .push(function () {
return RSVP.all([ return RSVP.all([
gadget.getSetting('jio_general_query'), gadget.getSetting("jio_query", ""),
gadget.getSetting('indexeddb_database_name', 'jio'), gadget.getSetting("indexeddb_database_name", "officejs")
]); ]);
}) })
.push(function (setting_list) { .push(function (setting_list) {
const dav_url = event.target.dav_url.value; var dav_url = event.target.dav_url.value,
const dav_user = event.target.dav_user.value; dav_user = event.target.dav_user.value,
const dav_pass = event.target.dav_pass.value; dav_pass = event.target.dav_pass.value,
const configuration = { configuration = {
type: 'replicate', type: "replicate",
query: { query: {
query: setting_list[0], query: setting_list[0],
limit: [0, 16777215], limit: [0, 16777215]
}, },
use_remote_post: true, use_remote_post: true,
conflict_handling: 2, conflict_handling: 2,
check_local_deletion: false, check_local_deletion: false,
local_sub_storage: { local_sub_storage: {
type: 'query', type: "query",
sub_storage: { sub_storage: {
type: 'uuid', type: "uuid",
sub_storage: { sub_storage: {
type: 'indexeddb', type: "indexeddb",
database: setting_list[1], database: setting_list[1]
}, }
}, }
}, },
remote_sub_storage: { remote_sub_storage: {
type: 'query', type: "query",
sub_storage: { sub_storage: {
type: 'drivetojiomapping', type: "drivetojiomapping",
sub_storage: { sub_storage: {
type: 'dav', type: "dav",
url: dav_url, url: dav_url,
basic_login: btoa(dav_user + ':' + dav_pass), basic_login: btoa(dav_user + ":" + dav_pass),
with_credentials: true, with_credentials: true
}, }
}, }
}, }
}; };
return gadget.setSetting('jio_storage_description', configuration); return gadget.setSetting("jio_storage_description", configuration);
}) })
.push(function () { .push(function () {
return gadget.setSetting('redirect_after_reload', { return gadget.setSetting("redirect_after_reload", {
command: 'display', command: "display",
options: {page: 'sync'}, options: {page: "sync"}
}); });
}) })
.push(function () { .push(function () {
return gadget.reload(); return gadget.reload();
})
}
rJS(window)
// Neither state to set nor ready to initialize
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('redirect', 'redirect')
.declareAcquiredMethod('reload', 'reload')
.declareAcquiredMethod('setSetting', 'setSetting')
.declareAcquiredMethod('getSetting', 'getSetting')
.declareAcquiredMethod('requireSetting', 'requireSetting')
/* Render the gadget
* Parameters:
* - get setting: jio_storage_name, jio_storage_description, user_email
* Effects:
* - update header, page title to 'Configure WebDAV Storage'
* - hide document_configurator gadget based on jio_storage_name
* - pre-fill input field if jio_storage_description already defined
* - redirect if user not logged in
*/
.declareMethod('render', function () {
const gadget = this;
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('connect_page', 'none');
})
.push(function (connect_page) {
return gadget.requireSetting(
'user_email',
connect_page,
new RSVP.Queue()
.push(function () {
return gadget.updateHeader({
page_title: 'Configure WebDAV Storage',
back_url: '#!display?n.page=jio_configurator',
});
})
.push(function () {
return gadget.getSetting('jio_storage_name', 'none');
})
.push(function (storage_name) {
if (storage_name === 'dav') {
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('jio_storage_description');
})
.push(function (configuration) {
gadget.element.querySelector('input[name="dav_url"]')
.value = configuration.remote_sub_storage
.sub_storage.sub_storage.url;
return;
});
} else {
gadget.element.querySelector('div[data-gadget-scope='
+ 'document_configurator').style.display = 'none';
}
return;
})
);
}); });
}) })
// Call setDavConfiguration when the form is submitted // Call setDavConfiguration when the form is submitted
.onEvent('submit', function (event) {
const gadget = this; .onEvent("submit", function (event) {
return setDavConfiguration(gadget, event); var gadget = this;
return gadget.setDavConfiguration(event);
}); });
}(window, RSVP, rJS, btoa)); }(window, RSVP, rJS, btoa));
\ No newline at end of file
...@@ -236,7 +236,7 @@ ...@@ -236,7 +236,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41431.40897.24064</string> </value> <value> <string>958.41793.3712.46284</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -254,7 +254,7 @@ ...@@ -254,7 +254,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1491999885.02</float> <float>1492013640.63</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/* global window, RSVP, rJS */ /*jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */
/* jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */ /*global window, RSVP, rJS */
(function (window, RSVP, rJS) { (function (window, RSVP, rJS) {
'use strict'; "use strict";
/* Settings required: /* Settings used:
* - either erp5_jio_query or jio_general_query * - jio_query, default: ""
* - user_email, or be redirected * - indexeddb_database_name, default: "officejs"
* Settings used:
* - connect_page, default: ''
* - indexeddb_database_name, default: 'jio'
* Settings modified: * Settings modified:
* - jio_storage_name, to: 'erp5' * - jio_storage_name, to: "erp5"
* - jio_storage_description * - jio_storage_description
* - redirect_after_reload, to: {command: 'display', options: {page: 'sync'}} * - redirect_after_reload, to: {command: "display", options: {page: "sync"}}
*/ */
/* Generate a generic jIO configuration for ERP5 storage
rJS(window)
// Neither state to set nor ready to initialize
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("reload", "reload")
.declareAcquiredMethod("setSetting", "setSetting")
.declareAcquiredMethod("getSetting", "getSetting")
/* Render the gadget.
* Parameters:
* - getSetting: jio_storage_name, jio_storage_description
* Effects:
* - updateHeader: "Configure ERP5 Storage"
* - hide document_configurator gadget based on jio_storage_name
* - pre-fill input field if jio_storage_description already defined
*/
.declareMethod("render", function () {
var gadget = this;
return gadget.updateHeader({
page_title: "Configure ERP5 Storage",
back_url: "#!display?n.page=jio_configurator"
})
.push(function () {
return gadget.getSetting("jio_storage_name");
})
.push(function (storage_name) {
if (storage_name === "erp5") {
return gadget.getSetting("jio_storage_description")
.push(function (configuration) {
gadget.element.querySelector("input[name='erp5_url']")
.value = configuration.remote_sub_storage.url;
});
}
gadget.element.querySelector("div[data-gadget-scope="
+ "document_configurator").style.display = "none";
});
})
/* Generate a generic jIO configuration for ERP5 storage.
* Parameters: * Parameters:
* - erp5_url: the ERP5 URL from the configuration form, * - erp5_url: the ERP5 URL from the configuration form,
* example: https://softinst75770.host.vifib.net/web_page_module/ * example: https://softinst75770.host.vifib.net/web_page_module/
* - get setting: jio_erp5_query, jio_general_query, indexeddb_database_name * - getSetting: jio_query, indexeddb_database_name
* Effects: * Effects:
* - set setting: * - setSetting:
* jio_storage_name, jio_storage_description, redirect_after_reload * jio_storage_name, jio_storage_description, redirect_after_reload
* - reload, then redirect to sync * - reload, then redirect to sync
*/ */
function setErp5Configuration(gadget, event) {
return new RSVP.Queue() .declareMethod("setErp5Configuration", function (event) {
.push(function () { var gadget = this;
return gadget.setSetting('jio_storage_name', 'erp5'); return gadget.setSetting("jio_storage_name", "erp5")
})
.push(function () { .push(function () {
return gadget.getSetting('jio_general_query', 'none');
})
.push(function (general_query) {
if (general_query === 'none') {
general_query = null;
}
return RSVP.all([ return RSVP.all([
gadget.getSetting('jio_erp5_query', general_query), gadget.getSetting("jio_query", ""),
gadget.getSetting('indexeddb_database_name', 'jio'), gadget.getSetting("indexeddb_database_name", "officejs")
]); ]);
}) })
.push(function (setting_list) { .push(function (setting_list) {
const erp5_url = event.target.erp5_url.value; var erp5_url = event.target.erp5_url.value,
const configuration = { configuration = {
type: 'replicate', type: "replicate",
query: { query: {
query: setting_list[0], query: setting_list[0],
limit: [0, 16777215], limit: [0, 16777215]
}, },
use_remote_post: true, use_remote_post: true,
conflict_handling: 2, conflict_handling: 2,
check_local_deletion: false, check_local_deletion: false,
local_sub_storage: { local_sub_storage: {
type: 'query', type: "query",
sub_storage: { sub_storage: {
type: 'uuid', type: "uuid",
sub_storage: { sub_storage: {
type: 'indexeddb', type: "indexeddb",
database: setting_list[1], database: setting_list[1]
}, }
}, }
}, },
remote_sub_storage: { remote_sub_storage: {
type: 'erp5', type: "erp5",
url: erp5_url, url: erp5_url,
default_view_reference: 'jio_view', default_view_reference: "jio_view"
}, }
}; };
return gadget.setSetting('jio_storage_description', configuration); return gadget.setSetting("jio_storage_description", configuration);
}) })
.push(function () { .push(function () {
return gadget.setSetting('redirect_after_reload', { return gadget.setSetting("redirect_after_reload", {
command: 'display', command: "display",
options: {page: 'sync'}, options: {page: "sync"}
}); });
}) })
.push(function () { .push(function () {
return gadget.reload(); return gadget.reload();
})
}
rJS(window)
// Neither state to set nor ready to initialize
// The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('redirect', 'redirect')
.declareAcquiredMethod('reload', 'reload')
.declareAcquiredMethod('setSetting', 'setSetting')
.declareAcquiredMethod('getSetting', 'getSetting')
.declareAcquiredMethod('requireSetting', 'requireSetting')
/* Render the gadget
* Parameters:
* - get setting: jio_storage_name, jio_storage_description, user_email
* Effects:
* - update header, page title to 'Configure ERP5 Storage'
* - hide document_configurator gadget based on jio_storage_name
* - pre-fill input field if jio_storage_description already defined
* - redirect if user not logged in
*/
.declareMethod('render', function () {
const gadget = this;
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('connect_page', 'none');
})
.push(function (connect_page) {
return gadget.requireSetting(
'user_email',
connect_page,
new RSVP.Queue()
.push(function () {
return gadget.updateHeader({
page_title: 'Configure ERP5 Storage',
back_url: '#!display?n.page=jio_configurator',
});
})
.push(function () {
return gadget.getSetting('jio_storage_name', 'none');
})
.push(function (storage_name) {
if (storage_name === 'erp5') {
return new RSVP.Queue()
.push(function () {
return gadget.getSetting('jio_storage_description');
})
.push(function (configuration) {
gadget.element.querySelector('input[name="erp5_url"]')
.value = configuration.remote_sub_storage.url;
return;
});
} else {
gadget.element.querySelector('div[data-gadget-scope='
+ 'document_configurator').style.display = 'none';
}
return;
})
);
}); });
}) })
// Call setErp5Configuration when the form is submitted // Call setErp5Configuration when the form is submitted
.onEvent('submit', function (event) {
const gadget = this; .onEvent("submit", function (event) {
return setErp5Configuration(gadget, event); var gadget = this;
return gadget.setErp5Configuration(event);
}); });
}(window, RSVP, rJS)); }(window, RSVP, rJS));
\ No newline at end of file
...@@ -232,7 +232,7 @@ ...@@ -232,7 +232,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41431.39363.46114</string> </value> <value> <string>958.41792.65211.10615</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -250,7 +250,7 @@ ...@@ -250,7 +250,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1491999921.03</float> <float>1492013653.71</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/* global window, RSVP, rJS */ /*jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */
/* jslint nomen: true, indent: 2, maxerr: 3, maxlen: 80 */ /*global window, rJS */
(function (window, RSVP, rJS) { (function (window, rJS) {
'use strict'; "use strict";
/* Settings required:
* - jio_storage_description, or be redirected
*/
/* Synchronize between the local and remote storages in replicate storage
* Parameters: nothing
* Returns: nothing
* Effects:
* - repair replicate storage
* - redirect to sync
*/
function launchSynchronization(gadget, event) {
return new RSVP.Queue()
.push(function () {
event.target.elements[0].disabled = true;
return gadget.jio_repair();
})
.push(function (result_dict) {
if (result_dict && result_dict.hasOwnProperty('redirect')) {
return gadget.redirect({
command: 'display',
options: {page: result_dict.redirect},
});
} else {
return gadget.redirect();
}
});
}
rJS(window) rJS(window)
// Neither state to set nor ready to initialize // Neither state to set nor ready to initialize
// The following functions are all acquired from erp5_launcher_nojqm.js // The following functions are all acquired from erp5_launcher_nojqm.js
.declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('redirect', 'redirect')
.declareAcquiredMethod('jio_repair', 'jio_repair')
.declareAcquiredMethod('requireSetting', 'requireSetting')
/* Render the gadget .declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("redirect", "redirect")
.declareAcquiredMethod("jio_repair", "jio_repair")
// updateHeader: "Synchronize".
.declareMethod("render", function () {
var gadget = this;
return gadget.updateHeader({page_title: "Synchronize"});
})
/* Synchronize between the local and remote storages in replicate storage.
* Parameters: * Parameters:
* - get setting: jio_storage_description * - event: the event from the form element, caught by the event listener
* Effects: * Effects:
* - update header, page_title to 'Synchronize' * - repair replicate storage
* - redirect if no jIO storage available * - redirect to the front page
*/ */
.declareMethod('render', function () {
const gadget = this; .declareMethod("launchSynchronization", function (event) {
return gadget.requireSetting( var gadget = this;
'jio_storage_description', event.target.elements[0].disabled = true;
'jio_configurator', return gadget.jio_repair()
new RSVP.Queue()
.push(function () { .push(function () {
return gadget.updateHeader({page_title: 'Synchronize'}); return gadget.redirect({command: "display"});
}) });
);
}) })
// Call launchSynchronization when the form is submitted // Call launchSynchronization when the form is submitted
.onEvent('submit', function (event) {
const gadget = this; .onEvent("submit", function (event) {
return launchSynchronization(gadget, event); var gadget = this;
return gadget.launchSynchronization(event);
}); });
}(window, RSVP, rJS)); }(window, rJS));
\ No newline at end of file \ No newline at end of file
...@@ -236,7 +236,7 @@ ...@@ -236,7 +236,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41607.62274.10973</string> </value> <value> <string>958.41780.56818.15274</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -254,7 +254,7 @@ ...@@ -254,7 +254,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1492001776.17</float> <float>1492013599.99</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
<!DOCTYPE html> <!DOCTYPE html>
<html><!-- manifest="${manifest_url}"--> <html><!-- manifest="${manifest_url}"-->
<head> <head>
<!-- all ${parameters} are based on the Layout Configuration in Web Site Module, and are set by /erp5/portal_skins/erp5_web_renderjs_ui/WebSection_renderDefaultPageAsGadget -->
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1"> <meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="shortcut icon" href="favicon.ico"> <link rel="shortcut icon" href="favicon.ico">
...@@ -21,6 +20,8 @@ ...@@ -21,6 +20,8 @@
<script data-renderjs-configuration="language_map" type="text/x-renderjs-configuration">${language_map}</script> <script data-renderjs-configuration="language_map" type="text/x-renderjs-configuration">${language_map}</script>
<script data-renderjs-configuration="default_selected_language" type="text/x-renderjs-configuration">${default_selected_language}</script> <script data-renderjs-configuration="default_selected_language" type="text/x-renderjs-configuration">${default_selected_language}</script>
<script data-renderjs-configuration="website_url_set" type="text/x-renderjs-configuration">${website_url_set}</script> <script data-renderjs-configuration="website_url_set" type="text/x-renderjs-configuration">${website_url_set}</script>
<script data-renderjs-configuration="indexeddb_database_name" type="text/x-renderjs-configuration">officejs-chat</script>
<script data-renderjs-configuration="jio_query" type="text/x-renderjs-configuration">portal_type: "Text Post" OR portal_type: "Person"</script>
<script src="rsvp.js"></script> <script src="rsvp.js"></script>
<script src="renderjs.js"></script> <script src="renderjs.js"></script>
......
...@@ -238,7 +238,7 @@ ...@@ -238,7 +238,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>958.41669.34238.56968</string> </value> <value> <string>958.41752.36104.19524</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -256,7 +256,7 @@ ...@@ -256,7 +256,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1492005464.73</float> <float>1492010721.49</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment