Commit eb00daaf authored by Romain Courteaud's avatar Romain Courteaud

[erp5_officejs_afs_directory] JSLint

parent 25fa912f
/*global window, rJS, RSVP, UriTemplate, URI, Query, SimpleQuery, ComplexQuery, /*global window, rJS, RSVP,
jIO, DOMParser */ jIO, DOMParser */
/*jslint indent: 2, maxerr: 3, nomen: true, DOMParser */ /*jslint indent: 2, maxerr: 3, nomen: true */
(function (window, rJS, RSVP, UriTemplate, URI, Query, SimpleQuery, (function (window, rJS, RSVP) {
ComplexQuery, jIO, DOMParser) {
"use strict"; "use strict";
var DIRTY_OLOH_LOOKUP_UNTIL_API_WORKS = { var DIRTY_OLOH_LOOKUP_UNTIL_API_WORKS = {
...@@ -34,7 +33,7 @@ ...@@ -34,7 +33,7 @@
// XXX... lord have mercy // XXX... lord have mercy
function mockupQueryParam(param, select_list) { function mockupQueryParam(param, select_list) {
var wild_param = param.replace(/[()]/g,"%").replace(/ /g,''), var wild_param = param.replace(/[()]/g, "%").replace(/ /g, ''),
return_list = [], return_list = [],
len, len,
i; i;
...@@ -52,12 +51,12 @@ ...@@ -52,12 +51,12 @@
i; i;
for (i = 0, len = query_param_list.length; i < len; i += 1) { for (i = 0, len = query_param_list.length; i < len; i += 1) {
param = query_param_list[i]; param = query_param_list[i];
// search // search
if (param.split(":").length !== 2) { if (param.split(":").length !== 2) {
return query.replace(param, mockupQueryParam(param, select_list)); return query.replace(param, mockupQueryParam(param, select_list));
} }
// hide rows // hide rows
if (param.indexOf("catalog.uid") > 0) { if (param.indexOf("catalog.uid") > 0) {
return query.replace("catalog.", ""); return query.replace("catalog.", "");
...@@ -65,7 +64,7 @@ ...@@ -65,7 +64,7 @@
} }
return query; return query;
} }
function createDataSheets(gadget) { function createDataSheets(gadget) {
gadget.jio_allDocs = gadget.state_parameter_dict.jio_storage.allDocs; gadget.jio_allDocs = gadget.state_parameter_dict.jio_storage.allDocs;
gadget.jio_get = gadget.state_parameter_dict.jio_storage.get; gadget.jio_get = gadget.state_parameter_dict.jio_storage.get;
...@@ -77,26 +76,29 @@ ...@@ -77,26 +76,29 @@
// Make Publisher datasheets // Make Publisher datasheets
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
.push(function (data) { .push(function (data) {
var uid = 0; var uid = 0,
publisher_id_list,
promise_list;
/*
function isReplicate(el) { function isReplicate(el) {
return (el.id.indexOf("_replicate_") < 0); return (el.id.indexOf("_replicate_") < 0);
} }
*/
function setPortalTypeOnPublisher (el) { function setPortalTypeOnPublisher(el) {
return gadget.jio_get(el.id) return gadget.jio_get(el.id)
.push(function (publisher_object) { .push(function (publisher_object) {
publisher_object.portal_type = "publisher"; publisher_object.portal_type = "publisher";
//publisher_object.url = publisher_object.website; //publisher_object.url = publisher_object.website;
publisher_object.uid = (uid++).toString(); uid += 1;
publisher_object.uid = uid.toString();
return gadget.jio_put(publisher_object.uid, publisher_object);
}); return gadget.jio_put(publisher_object.uid, publisher_object);
});
} }
var publisher_id_list = data.data.rows, publisher_id_list = data.data.rows;
promise_list = publisher_id_list.map(setPortalTypeOnPublisher); promise_list = publisher_id_list.map(setPortalTypeOnPublisher);
return RSVP.all(promise_list); return RSVP.all(promise_list);
}) })
...@@ -110,8 +112,7 @@ ...@@ -110,8 +112,7 @@
// Create Statistic Sheets // Create Statistic Sheets
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
.push(function (result_list) { .push(function (result_list) {
var uid = 1000, var publisher_list = result_list.data.rows,
publisher_list = result_list.data.rows,
statistic_list = [], statistic_list = [],
i_len = publisher_list.length, i_len = publisher_list.length,
i; i;
...@@ -120,13 +121,12 @@ ...@@ -120,13 +121,12 @@
// curl https://www.openhub.net/projects/{project_id}/analyses/latest.xml // curl https://www.openhub.net/projects/{project_id}/analyses/latest.xml
function createStatisticSheet(my_publisher_row) { function createStatisticSheet(my_publisher_row) {
var publisher = my_publisher_row.value.title, var software_list = my_publisher_row.value.free_software_list,
software_list = my_publisher_row.value.free_software_list, j_len = software_list.length,
j_len = software_list.length, profile_url,
profile_url, software_analysis,
software_analysis, software_analysis_list = [],
software_analysis_list = [], j;
j;
for (j = 0; j < j_len; j += 1) { for (j = 0; j < j_len; j += 1) {
profile_url = software_list[j].source_code_profile; profile_url = software_list[j].source_code_profile;
...@@ -149,9 +149,7 @@ ...@@ -149,9 +149,7 @@
return RSVP.all(software_analysis_list); return RSVP.all(software_analysis_list);
}) })
.push(function (my_stat_list) { .push(function (my_stat_list) {
var parser = new DOMParser(), var line_total = 0,
line_total = 0,
xml,
k_len = my_stat_list.length, k_len = my_stat_list.length,
k; k;
for (k = 0; k < k_len; k += 1) { for (k = 0; k < k_len; k += 1) {
...@@ -180,7 +178,7 @@ ...@@ -180,7 +178,7 @@
} }
return new RSVP.Queue() return new RSVP.Queue()
.push(function() { .push(function () {
return RSVP.all(statistic_list); return RSVP.all(statistic_list);
}) })
.push(function () { .push(function () {
...@@ -191,30 +189,34 @@ ...@@ -191,30 +189,34 @@
// Make Software datasheets // Make Software datasheets
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
.push(function (publisher_list) { .push(function (publisher_list) {
var uid = 2000; var uid = 2000,
save_software_promise_list,
function saveSoftwareListFromPublisher (j) { publishers,
promise_list;
function saveSoftwareListFromPublisher(j) {
var publisher = j.value.title, var publisher = j.value.title,
software_list = j.value.free_software_list, software_list = j.value.free_software_list,
website = j.value.website; website = j.value.website;
function saveSoftwareDocument (software) { function saveSoftwareDocument(software) {
software.portal_type = "software"; software.portal_type = "software";
software.publisher = publisher; software.publisher = publisher;
software.publisher_website = website; software.publisher_website = website;
software.uid = (uid++).toString(); uid += 1;
software.uid = uid.toString();
return gadget.jio_put(software.uid, software); return gadget.jio_put(software.uid, software);
} }
var save_software_promise_list = software_list.map(saveSoftwareDocument); save_software_promise_list = software_list.map(saveSoftwareDocument);
return RSVP.all(save_software_promise_list); return RSVP.all(save_software_promise_list);
} }
var publishers = publisher_list.data.rows, publishers = publisher_list.data.rows;
promise_list = publishers.map(saveSoftwareListFromPublisher); promise_list = publishers.map(saveSoftwareListFromPublisher);
return RSVP.all(promise_list); return RSVP.all(promise_list);
}) })
.push(function () { .push(function () {
...@@ -224,7 +226,7 @@ ...@@ -224,7 +226,7 @@
'website', 'website',
'success_case_list', 'success_case_list',
'publisher', 'publisher',
'category_list', 'category_list'
], ],
query: 'portal_type: "software"' query: 'portal_type: "software"'
}); });
...@@ -233,50 +235,56 @@ ...@@ -233,50 +235,56 @@
// Make Success Case datasheets // Make Success Case datasheets
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
.push(function (software_list) { .push(function (software_list) {
var uid = 3000; var uid = 3000,
softwares,
function saveSuccessCaseListFromSoftware (softwareObject) { promise_list;
function saveSuccessCaseListFromSoftware(softwareObject) {
var software = softwareObject.value, var software = softwareObject.value,
publisher = softwareObject.value.publisher, publisher = softwareObject.value.publisher,
website = softwareObject.value.website, website = softwareObject.value.website,
success_case_list = softwareObject.value.success_case_list; success_case_list = softwareObject.value.success_case_list,
save_success_case_promise_list;
function isValid (success_case) {
function isValid(success_case) {
return (success_case !== "N/A" && return (success_case !== "N/A" &&
success_case.title !== "" && success_case.title !== "" &&
success_case.title !== "N/A"); success_case.title !== "N/A");
} }
function addProperties (success_case) { function addProperties(success_case) {
success_case.portal_type = "success_case"; success_case.portal_type = "success_case";
success_case.software = software.title; success_case.software = software.title;
success_case.software_website = software.website; success_case.software_website = software.website;
success_case.publisher = publisher; success_case.publisher = publisher;
success_case.publisher_website = website; success_case.publisher_website = website;
success_case.category_list = software.category_list; success_case.category_list = software.category_list;
success_case.uid = (uid++).toString(); uid += 1;
success_case.uid = uid.toString();
return gadget.jio_put(success_case.uid, success_case); return gadget.jio_put(success_case.uid, success_case);
} }
var save_success_case_promise_list = save_success_case_promise_list =
success_case_list.filter(isValid) success_case_list.filter(isValid)
.map(addProperties); .map(addProperties);
return RSVP.all(save_success_case_promise_list); return RSVP.all(save_success_case_promise_list);
} }
var softwares = software_list.data.rows.filter(function (sw) { softwares = software_list.data.rows.filter(function (sw) {
return (sw.value.success_case_list !== "N/A"); return (sw.value.success_case_list !== "N/A");
}), });
promise_list = softwares.map(saveSuccessCaseListFromSoftware); promise_list = softwares.map(saveSuccessCaseListFromSoftware);
return RSVP.all(promise_list); return RSVP.all(promise_list);
/*
}) })
.push(undefined, function (error) { .push(undefined, function (error) {
console.log(error); console.log(error);
*/
}); });
} }
rJS(window) rJS(window)
.ready(function (gadget) { .ready(function (gadget) {
...@@ -294,7 +302,7 @@ ...@@ -294,7 +302,7 @@
.declareMethod('createJio', function () { .declareMethod('createJio', function () {
var gadget = this; var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
.push(function (setting_list) { .push(function () {
return gadget.state_parameter_dict.jio_storage.createJio({ return gadget.state_parameter_dict.jio_storage.createJio({
check_local_modification: false, check_local_modification: false,
check_local_creation: false, check_local_creation: false,
...@@ -303,7 +311,7 @@ ...@@ -303,7 +311,7 @@
local_sub_storage : { local_sub_storage : {
type: "query", type: "query",
sub_storage: { sub_storage: {
type: "memory", type: "memory"
} }
}, },
remote_sub_storage : { remote_sub_storage : {
...@@ -312,14 +320,14 @@ ...@@ -312,14 +320,14 @@
type: "publisher_storage", type: "publisher_storage",
url: "/" url: "/"
} }
}, }
})
.push(function (data) {
return gadget.state_parameter_dict.jio_storage.repair();
}) })
.push(function () { .push(function () {
return createDataSheets(gadget); return gadget.state_parameter_dict.jio_storage.repair();
}); })
.push(function () {
return createDataSheets(gadget);
});
}); });
}) })
...@@ -339,5 +347,4 @@ ...@@ -339,5 +347,4 @@
.declareMethod('repair', function () { .declareMethod('repair', function () {
return this.state_parameter_dict.jio_storage.repair(); return this.state_parameter_dict.jio_storage.repair();
}); });
}(window, rJS, RSVP, UriTemplate, URI, Query, SimpleQuery, ComplexQuery, jIO, }(window, rJS, RSVP));
DOMParser)); \ No newline at end of file
\ No newline at end of file
...@@ -214,7 +214,7 @@ ...@@ -214,7 +214,7 @@
</item> </item>
<item> <item>
<key> <string>actor</string> </key> <key> <string>actor</string> </key>
<value> <string>3</string> </value> <value> <string>zope</string> </value>
</item> </item>
<item> <item>
<key> <string>comment</string> </key> <key> <string>comment</string> </key>
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>959.36864.12643.63829</string> </value> <value> <string>959.45138.33426.26555</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1495564514.77</float> <float>1496059373.63</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*jslint nomen: true, indent: 2, maxerr: 3 */ /*jslint nomen: true, indent: 2, maxerr: 3 */
/*global window, rJS, Handlebars, RSVP, loopEventListener */ /*global document, window, rJS, Handlebars, RSVP, loopEventListener, Node */
(function (window, rJS, Handlebars, RSVP, loopEventListener) { (function (document, window, rJS, Handlebars, RSVP, loopEventListener, Node) {
"use strict"; "use strict";
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
}) })
.setState({ .setState({
visible: false, visible: false,
desktop: false desktop: false
...@@ -93,11 +93,6 @@ ...@@ -93,11 +93,6 @@
.onStateChange(function (modification_dict) { .onStateChange(function (modification_dict) {
var context = this,
gadget = this,
queue = new RSVP.Queue(),
tmp_element;
if (modification_dict.hasOwnProperty("visible")) { if (modification_dict.hasOwnProperty("visible")) {
if (this.state.visible) { if (this.state.visible) {
if (!this.element.classList.contains('visible')) { if (!this.element.classList.contains('visible')) {
...@@ -154,7 +149,7 @@ ...@@ -154,7 +149,7 @@
} }
}, true, false); }, true, false);
}(window, rJS, Handlebars, RSVP, loopEventListener)); }(document, window, rJS, Handlebars, RSVP, loopEventListener, Node));
......
...@@ -214,7 +214,7 @@ ...@@ -214,7 +214,7 @@
</item> </item>
<item> <item>
<key> <string>actor</string> </key> <key> <string>actor</string> </key>
<value> <string>3</string> </value> <value> <string>zope</string> </value>
</item> </item>
<item> <item>
<key> <string>comment</string> </key> <key> <string>comment</string> </key>
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>959.35236.20346.42359</string> </value> <value> <string>959.45016.12856.26658</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1495466909.62</float> <float>1496052034.32</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*jslint nomen: true, indent: 2, maxerr: 3 */ /*jslint nomen: true, indent: 2, maxerr: 3 */
/*global window, rJS, RSVP */ /*global window, rJS */
(function (window, rJS, RSVP) { (function (window, rJS) {
"use strict"; "use strict";
rJS(window) rJS(window)
...@@ -69,8 +69,5 @@ ...@@ -69,8 +69,5 @@
return router.redirect.apply(router, argument_list); return router.redirect.apply(router, argument_list);
}); });
}); });
}(window, rJS));
}(window, rJS, RSVP)); \ No newline at end of file
\ No newline at end of file
...@@ -234,7 +234,7 @@ ...@@ -234,7 +234,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>953.59443.50628.58811</string> </value> <value> <string>959.45015.31491.22801</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -252,7 +252,7 @@ ...@@ -252,7 +252,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1473843119.57</float> <float>1496052069.31</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*jslint nomen: true*/ /*jslint indent: 2, nomen: true, maxlen: 120*/
/*global jIO, RSVP, JSON */ /*global jIO, RSVP, JSON */
(function (jIO, RSVP, JSON) { (function (jIO, RSVP, JSON) {
"use strict"; "use strict";
function PublisherStorage(spec) { function PublisherStorage(spec) {
// NOTE: requires Website Layout Configuration CSP modification // NOTE: requires Website Layout Configuration CSP modification
// => connect-src 'self' https://raw.githubusercontent.com https://api.github.com data:; // => connect-src 'self' https://raw.githubusercontent.com https://api.github.com data:;
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
//https://api.github.com/repos/Nexedi/awesome-free-software/contents/?ref=master //https://api.github.com/repos/Nexedi/awesome-free-software/contents/?ref=master
//https://api.github.com/repos/Nexedi/awesome-free-software/contents/alfresco.json //https://api.github.com/repos/Nexedi/awesome-free-software/contents/alfresco.json
//https://raw.githubusercontent.com/Nexedi/awesome-free-software/master/alfresco.json //https://raw.githubusercontent.com/Nexedi/awesome-free-software/master/alfresco.json
this._href = spec.href || 'https://api.github.com/repos/'; this._href = spec.href || 'https://api.github.com/repos/';
this._user = spec.user || 'Nexedi'; this._user = spec.user || 'Nexedi';
this._repo = spec.repo || 'awesome-free-software'; this._repo = spec.repo || 'awesome-free-software';
...@@ -41,7 +41,7 @@ ...@@ -41,7 +41,7 @@
return (name === "list"); return (name === "list");
}; };
PublisherStorage.prototype.buildQuery = function (options) { PublisherStorage.prototype.buildQuery = function () {
var url = this._href + this._user + '/' + this._repo + '/contents/?ref=master'; var url = this._href + this._user + '/' + this._repo + '/contents/?ref=master';
return new RSVP.Queue() return new RSVP.Queue()
...@@ -54,7 +54,7 @@ ...@@ -54,7 +54,7 @@
data_entry, data_entry,
len, len,
i; i;
for (i = 0, len = data_list.length; i < len; i += 1) { for (i = 0, len = data_list.length; i < len; i += 1) {
data_entry = data_list[i]; data_entry = data_list[i];
if (data_entry.path.indexOf(".json") > -1) { if (data_entry.path.indexOf(".json") > -1) {
...@@ -64,7 +64,7 @@ ...@@ -64,7 +64,7 @@
}); });
} }
} }
return result_list; return result_list;
}); });
}; };
......
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>954.54677.7080.40823</string> </value> <value> <string>959.45095.9318.10888</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1477403595.09</float> <float>1496056764.06</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
...@@ -34,7 +34,6 @@ ...@@ -34,7 +34,6 @@
console.log(error); console.log(error);
}); });
}) })
.declareAcquiredMethod("updateHeader", "updateHeader") .declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("jio_allDocs", "jio_allDocs") .declareAcquiredMethod("jio_allDocs", "jio_allDocs")
...@@ -55,66 +54,68 @@ ...@@ -55,66 +54,68 @@
page_title: 'Free Software Publisher Directory' page_title: 'Free Software Publisher Directory'
}) })
]); ]);
}) })
.push(function (my_response_list) { .push(function () {
return RSVP.all([ return RSVP.all([
gadget.jio_allDocs({ gadget.jio_allDocs({
select_list: ['category_list'], select_list: ['category_list'],
query: 'portal_type:"software"' query: 'portal_type:"software"'
}) })
// my_response_list[0].render() // my_response_list[0].render()
]); ]);
}) })
.push(function (my_response_list) { .push(function (my_response_list) {
var softwares = my_response_list[0].data.rows, var softwares = my_response_list[0].data.rows,
obj,
// get categories and flatten array of category arrays
categories = softwares.map( (obj) => obj.value.category_list )
.reduce( (cur, prev) => cur.concat(prev) ),
// remove duplicates (case sensitive!) // get categories and flatten array of category arrays
unique_categories = Array.from(new Set(categories)), categories = softwares
.map((obj) => obj.value.category_list)
.reduce((cur, prev) => cur.concat(prev)),
// kudos: https://davidwalsh.name/convert-html-stings-dom-nodes // remove duplicates (case sensitive!)
banner = document.createRange() unique_categories = Array.from(new Set(categories)),
.createContextualFragment(my_response_list[1] || "");
// kudos: https://davidwalsh.name/convert-html-stings-dom-nodes
gadget.element.insertBefore(banner, masonry_container); banner = document.createRange()
.createContextualFragment(my_response_list[1] || "");
return RSVP.all(unique_categories); gadget.element.insertBefore(banner, masonry_container);
})
.push(function (categories) { return RSVP.all(unique_categories);
var softwares_by_category = categories.map(function (category) { })
return gadget.jio_allDocs({ .push(function (categories) {
select_list: [ var softwares_by_category = categories.map(function (category) {
'title', return gadget.jio_allDocs({
'publisher', select_list: [
'logo' 'title',
], 'publisher',
query: 'category_list:"%' + category + '%" AND portal_type:"software"' 'logo'
}) ],
.push(function (softwares) { query: 'category_list:"%' + category + '%" AND portal_type:"software"'
softwares.data.rows.map(function (sw) { })
// XXX hardcoded page and view .push(function (softwares) {
sw.value.href = "#/" + sw.id + "?page=afs_software&view=view"; softwares.data.rows.map(function (sw) {
// XXX hardcoded page and view
sw.value.href = "#/" + sw.id + "?page=afs_software&view=view";
});
return {
category: category,
softwares: softwares.data.rows
};
}); });
return {
category: category,
softwares: softwares.data.rows
};
}); });
});
return RSVP.all(softwares_by_category); return RSVP.all(softwares_by_category);
}) })
.push(function (result) { .push(function (result) {
var content; var content;
// reverse sort categories by number of softwares // reverse sort categories by number of softwares
result.sort( (a, b) => b.softwares.length - a.softwares.length ); result.sort( (a, b) => b.softwares.length - a.softwares.length );
content = template(result); content = template(result);
masonry_container.innerHTML = content; masonry_container.innerHTML = content;
}); });
}); });
}(window, rJS, RSVP, Handlebars, URI, document)); }(window, rJS, RSVP, Handlebars, URI, document));
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>959.44990.18794.59562</string> </value> <value> <string>959.45141.9554.30549</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1496050512.15</float> <float>1496059536.49</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*globals window, RSVP, rJS, Handlebars, jIO*/ /*globals window, RSVP, rJS, Handlebars, jIO*/
/*jslint indent: 2, nomen: true, maxlen: 80*/ /*jslint indent: 2, nomen: true, maxlen: 100*/
(function (window, RSVP, rJS, Handlebars, jIO) { (function (window, RSVP, rJS, Handlebars, jIO) {
"use strict"; "use strict";
var PLACEHOLDER = ""; var PLACEHOLDER = "",
var gadget_klass = rJS(window), gadget_klass = rJS(window),
templater = gadget_klass.__template_element, templater = gadget_klass.__template_element,
display_widget_table = Handlebars.compile( display_widget_table = Handlebars.compile(
templater.getElementById("display-template").innerHTML templater.getElementById("display-template").innerHTML
...@@ -23,20 +23,20 @@ ...@@ -23,20 +23,20 @@
} }
} }
return case_list; return case_list;
} }
rJS(window) rJS(window)
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod('updateHeader', 'updateHeader') .declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('jio_get', 'jio_get') .declareAcquiredMethod('jio_get', 'jio_get')
.declareMethod('render', function (options) { .declareMethod('render', function (options) {
var gadget = this; var gadget = this;
...@@ -47,7 +47,8 @@ ...@@ -47,7 +47,8 @@
.push(function (publisher) { .push(function (publisher) {
// https://en.wikipedia.org/api/rest_v1/ // https://en.wikipedia.org/api/rest_v1/
// only works in for english // only works in for english
var wikipedia_api_url = 'https://en.wikipedia.org/api/rest_v1/page/summary/', var wikipedia_api_url =
'https://en.wikipedia.org/api/rest_v1/page/summary/',
wiki_list = []; wiki_list = [];
publisher.free_software_list.map(function (software) { publisher.free_software_list.map(function (software) {
...@@ -65,7 +66,7 @@ ...@@ -65,7 +66,7 @@
} else { } else {
software.success_case_list = clean(software.success_case_list); software.success_case_list = clean(software.success_case_list);
} }
if (software.wikipedia_url == "N/A") { if (software.wikipedia_url === "N/A") {
delete software.wikipedia_url; delete software.wikipedia_url;
} else { } else {
wiki_list.push( wiki_list.push(
...@@ -77,16 +78,14 @@ ...@@ -77,16 +78,14 @@
url: wikipedia_api_url + software.wikipedia_url.split("/").pop() url: wikipedia_api_url + software.wikipedia_url.split("/").pop()
}); });
}) })
.push( .push(function (my_content) {
function (my_content) { var response = my_content.target.response || my_content.target.responseText;
var response = my_content.target.respons || my_content.target.responseText; return JSON.parse(response).extract;
return JSON.parse(response).extract; }, function () {
}, function (my_error) { return undefined;
return undefined; })
} );
) }
);
}
}); });
return new RSVP.Queue() return new RSVP.Queue()
......
...@@ -214,7 +214,7 @@ ...@@ -214,7 +214,7 @@
</item> </item>
<item> <item>
<key> <string>actor</string> </key> <key> <string>actor</string> </key>
<value> <string>3</string> </value> <value> <string>zope</string> </value>
</item> </item>
<item> <item>
<key> <string>comment</string> </key> <key> <string>comment</string> </key>
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>954.58958.53154.13363</string> </value> <value> <string>959.45146.21261.49186</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1495468512.28</float> <float>1496059863.46</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*globals window, RSVP, rJS*/ /*globals window, RSVP, rJS*/
/*jslint indent: 2, nomen: true, maxlen: 80*/ /*jslint indent: 2, nomen: true, maxlen: 80*/
(function (window, RSVP, rJS) { (function (window, RSVP, rJS) {
"use strict"; "use strict";
rJS(window) rJS(window)
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod("translate", "translate") .declareAcquiredMethod("translate", "translate")
.declareAcquiredMethod("getUrlFor", "getUrlFor") .declareAcquiredMethod("getUrlFor", "getUrlFor")
...@@ -17,24 +17,25 @@ ...@@ -17,24 +17,25 @@
.declareAcquiredMethod("updateHeader", "updateHeader") .declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("jio_allDocs", "jio_allDocs") .declareAcquiredMethod("jio_allDocs", "jio_allDocs")
.allowPublicAcquisition('updateHeader', function () { .allowPublicAcquisition('updateHeader', function () {
return; return;
}) })
.allowPublicAcquisition('getUrlParameter', function (argument_list) { .allowPublicAcquisition('getUrlParameter', function (argument_list) {
return this.getUrlParameter(argument_list) return this.getUrlParameter(argument_list)
.push(function (result) { .push(function (result) {
if ((result === undefined) && (argument_list[0] === 'field_listbox_sort_list:json')) { if ((result === undefined) &&
(argument_list[0] === 'field_listbox_sort_list:json')) {
return [['title', 'ascending']]; return [['title', 'ascending']];
} }
return result; return result;
}); });
}) })
.declareMethod("render", function (options) { .declareMethod("render", function () {
var gadget = this; var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
.push(function () { .push(function () {
return gadget.updateHeader({ return gadget.updateHeader({
page_title: "Publisher List", page_title: "Publisher List"
}); });
}) })
.push(function () { .push(function () {
...@@ -48,7 +49,7 @@ ...@@ -48,7 +49,7 @@
['founded_year', 'Founded'], ['founded_year', 'Founded'],
['presence', 'Presence'] ['presence', 'Presence']
]; ];
return form_gadget.render({ return form_gadget.render({
erp5_document: {"_embedded": {"_view": { erp5_document: {"_embedded": {"_view": {
"listbox": { "listbox": {
...@@ -59,36 +60,36 @@ ...@@ -59,36 +60,36 @@
"key": "field_listbox", "key": "field_listbox",
"lines": 20, "lines": 20,
"list_method": "portal_catalog", "list_method": "portal_catalog",
"query": 'urn:jio:allDocs?query=' + 'portal_type:' + '"publisher"', "query": 'urn:jio:allDocs?query=' + 'portal_type:' +
'"publisher"',
"portal_type": [], "portal_type": [],
"search_column_list": column_list, "search_column_list": column_list,
"sort_column_list": column_list, "sort_column_list": column_list,
"sort_on": ["title", "ascending"], "sort_on": ["title", "ascending"],
"title": "Documents", "title": "Documents",
"type": "ListBox" "type": "ListBox"
} }
}}, }},
"_links": { "_links": {
"type": { "type": {
// form_list display portal_type in header // form_list display portal_type in header
name: "" name: ""
}
} }
} },
}, form_definition: {
form_definition: { group_list: [
group_list: [ [
[ "bottom",
"bottom", [["listbox"]]
[["listbox"]] ],
], [
[ "hidden",
"hidden", ["listbox_modification_date"]
["listbox_modification_date"] ]
] ]
] }
} });
}); });
});
}); });
}(window, RSVP, rJS)); }(window, RSVP, rJS));
\ No newline at end of file
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>953.40656.41521.35942</string> </value> <value> <string>959.45150.63557.44714</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1473843194.9</float> <float>1496060137.94</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*globals window, RSVP, rJS, Handlebars, jIO*/ /*globals window, RSVP, rJS, Handlebars, jIO*/
/*jslint indent: 2, nomen: true, maxlen: 80*/ /*jslint indent: 2, nomen: true, maxlen: 100*/
(function (window, RSVP, rJS, Handlebars, jIO) { (function (window, RSVP, rJS, Handlebars, jIO) {
"use strict"; "use strict";
var PLACEHOLDER = ""; var PLACEHOLDER = "",
var gadget_klass = rJS(window), gadget_klass = rJS(window),
templater = gadget_klass.__template_element, templater = gadget_klass.__template_element,
display_widget_table = Handlebars.compile( display_widget_table = Handlebars.compile(
templater.getElementById("display-template").innerHTML templater.getElementById("display-template").innerHTML
); );
function clean(case_list, software_website, software_title, publisher_website, publisher_title) { function clean(case_list, software_website, software_title, publisher_website, publisher_title) {
var emptry_string = "", var emptry_string = "",
i, i,
...@@ -34,14 +34,14 @@ ...@@ -34,14 +34,14 @@
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod('updateHeader', 'updateHeader') .declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('jio_get', 'jio_get') .declareAcquiredMethod('jio_get', 'jio_get')
.declareMethod('render', function (options) { .declareMethod('render', function (options) {
var gadget = this; var gadget = this;
...@@ -50,15 +50,15 @@ ...@@ -50,15 +50,15 @@
return gadget.jio_get(options.jio_key); return gadget.jio_get(options.jio_key);
}) })
.push(function (software) { .push(function (software) {
// https://en.wikipedia.org/api/rest_v1/ // https://en.wikipedia.org/api/rest_v1/
// only works in for english // only works in for english
var wikipedia_api_url = 'https://en.wikipedia.org/api/rest_v1/page/summary/'; var wikipedia_api_url = 'https://en.wikipedia.org/api/rest_v1/page/summary/';
if (software.logo === "N/A" || software.logo === "") { if (software.logo === "N/A" || software.logo === "") {
software.logo = PLACEHOLDER; software.logo = PLACEHOLDER;
} }
if (software.commercial_support == "N/A") { if (software.commercial_support === "N/A") {
delete software.commercial_support; delete software.commercial_support;
} }
if (software.success_case_list.length === 0 || if (software.success_case_list.length === 0 ||
...@@ -68,14 +68,14 @@ ...@@ -68,14 +68,14 @@
delete software.success_case_list; delete software.success_case_list;
} else { } else {
software.success_case_list = clean( software.success_case_list = clean(
software.success_case_list, software.success_case_list,
software.website, software.website,
software.title, software.title,
software.publisher_website, software.publisher_website,
software.publisher software.publisher
); );
} }
if (software.wikipedia_url == "N/A") { if (software.wikipedia_url === "N/A") {
delete software.wikipedia_url; delete software.wikipedia_url;
return software; return software;
} }
...@@ -88,22 +88,21 @@ ...@@ -88,22 +88,21 @@
url: wikipedia_api_url + software.wikipedia_url.split("/").pop() url: wikipedia_api_url + software.wikipedia_url.split("/").pop()
}); });
}) })
.push( .push(function (my_content) {
function (my_content) { var response = my_content.target.response || my_content.target.responseText;
var response = my_content.target.response || my_content.target.responseText; software.wikipedia_description = JSON.parse(response).extract;
software.wikipedia_description = JSON.parse(response).extract; return software;
return software; }, function () {
}, function (my_error) { // console.log(my_error)
// console.log(my_error) // 404 or not allowed, swallow
// 404 or not allowed, swallow return software;
return software; });
});
}) })
.push(function (my_software) { .push(function (my_software) {
gadget.props.element.querySelector(".display-widget") gadget.props.element.querySelector(".display-widget")
.innerHTML = display_widget_table(my_software); .innerHTML = display_widget_table(my_software);
return gadget.updateHeader({page_title: my_software.title}); return gadget.updateHeader({page_title: my_software.title});
}); });
}); });
......
...@@ -214,7 +214,7 @@ ...@@ -214,7 +214,7 @@
</item> </item>
<item> <item>
<key> <string>actor</string> </key> <key> <string>actor</string> </key>
<value> <string>3</string> </value> <value> <string>zope</string> </value>
</item> </item>
<item> <item>
<key> <string>comment</string> </key> <key> <string>comment</string> </key>
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>955.20627.16103.45619</string> </value> <value> <string>959.45155.11639.33945</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1495202159.37</float> <float>1496060365.27</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*globals window, RSVP, rJS*/ /*globals window, RSVP, rJS*/
/*jslint indent: 2, nomen: true, maxlen: 80*/ /*jslint indent: 2, nomen: true, maxlen: 80*/
(function (window, RSVP, rJS) { (function (window, RSVP, rJS) {
"use strict"; "use strict";
rJS(window) rJS(window)
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod("translate", "translate") .declareAcquiredMethod("translate", "translate")
.declareAcquiredMethod("getUrlFor", "getUrlFor") .declareAcquiredMethod("getUrlFor", "getUrlFor")
...@@ -17,24 +17,25 @@ ...@@ -17,24 +17,25 @@
.declareAcquiredMethod("updateHeader", "updateHeader") .declareAcquiredMethod("updateHeader", "updateHeader")
.declareAcquiredMethod("jio_allDocs", "jio_allDocs") .declareAcquiredMethod("jio_allDocs", "jio_allDocs")
.allowPublicAcquisition('updateHeader', function () { .allowPublicAcquisition('updateHeader', function () {
return; return;
}) })
.allowPublicAcquisition('getUrlParameter', function (argument_list) { .allowPublicAcquisition('getUrlParameter', function (argument_list) {
return this.getUrlParameter(argument_list) return this.getUrlParameter(argument_list)
.push(function (result) { .push(function (result) {
if ((result === undefined) && (argument_list[0] === 'field_listbox_sort_list:json')) { if ((result === undefined) &&
(argument_list[0] === 'field_listbox_sort_list:json')) {
return [['title', 'ascending']]; return [['title', 'ascending']];
} }
return result; return result;
}); });
}) })
.declareMethod("render", function (options) { .declareMethod("render", function () {
var gadget = this; var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
.push(function () { .push(function () {
return gadget.updateHeader({ return gadget.updateHeader({
page_title: "Software List", page_title: "Software List"
}); });
}) })
.push(function () { .push(function () {
...@@ -47,7 +48,7 @@ ...@@ -47,7 +48,7 @@
['publisher', 'Publisher'], ['publisher', 'Publisher'],
['category_list', 'Category'] ['category_list', 'Category']
]; ];
return form_gadget.render({ return form_gadget.render({
erp5_document: {"_embedded": {"_view": { erp5_document: {"_embedded": {"_view": {
"listbox": { "listbox": {
...@@ -58,34 +59,35 @@ ...@@ -58,34 +59,35 @@
"key": "field_listbox", "key": "field_listbox",
"lines": 20, "lines": 20,
"list_method": "portal_catalog", "list_method": "portal_catalog",
"query": 'urn:jio:allDocs?query=' + 'portal_type:' + '"software"', "query": 'urn:jio:allDocs?query=' + 'portal_type:' +
'"software"',
"portal_type": [], "portal_type": [],
"search_column_list": column_list, "search_column_list": column_list,
"sort_column_list": column_list, "sort_column_list": column_list,
"title": "Documents", "title": "Documents",
"type": "ListBox" "type": "ListBox"
} }
}}, }},
"_links": { "_links": {
"type": { "type": {
// form_list display portal_type in header // form_list display portal_type in header
name: "" name: ""
}
} }
} },
}, form_definition: {
form_definition: { group_list: [
group_list: [ [
[ "bottom",
"bottom", [["listbox"]]
[["listbox"]] ],
], [
[ "hidden",
"hidden", ["listbox_modification_date"]
["listbox_modification_date"] ]
] ]
] }
} });
}); });
});
}); });
}(window, RSVP, rJS)); }(window, RSVP, rJS));
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>953.40675.35974.65450</string> </value> <value> <string>959.45114.28192.42308</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1473842742.9</float> <float>1496057919.27</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
...@@ -2,27 +2,26 @@ ...@@ -2,27 +2,26 @@
/*jslint indent: 2, nomen: true, maxlen: 80*/ /*jslint indent: 2, nomen: true, maxlen: 80*/
(function (window, RSVP, rJS, Handlebars) { (function (window, RSVP, rJS, Handlebars) {
"use strict"; "use strict";
var PLACEHOLDER = "";
var gadget_klass = rJS(window), var PLACEHOLDER = "",
gadget_klass = rJS(window),
templater = gadget_klass.__template_element, templater = gadget_klass.__template_element,
display_widget_table = Handlebars.compile( display_widget_table = Handlebars.compile(
templater.getElementById("display-template").innerHTML templater.getElementById("display-template").innerHTML
); );
rJS(window) rJS(window)
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod('updateHeader', 'updateHeader') .declareAcquiredMethod('updateHeader', 'updateHeader')
.declareAcquiredMethod('jio_get', 'jio_get') .declareAcquiredMethod('jio_get', 'jio_get')
.declareMethod('render', function (options) { .declareMethod('render', function (options) {
var gadget = this; var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
......
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>954.58711.46291.45073</string> </value> <value> <string>959.45116.37210.34542</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1479291364.95</float> <float>1496058053.94</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
...@@ -6,9 +6,9 @@ ...@@ -6,9 +6,9 @@
.ready(function (g) { .ready(function (g) {
g.props = {}; g.props = {};
return g.getElement() return g.getElement()
.push(function (element) { .push(function (element) {
g.props.element = element; g.props.element = element;
}); });
}) })
.declareAcquiredMethod("translate", "translate") .declareAcquiredMethod("translate", "translate")
.declareAcquiredMethod("getUrlFor", "getUrlFor") .declareAcquiredMethod("getUrlFor", "getUrlFor")
...@@ -22,70 +22,70 @@ ...@@ -22,70 +22,70 @@
return this.getUrlParameter(argument_list) return this.getUrlParameter(argument_list)
.push(function (result) { .push(function (result) {
if ((result === undefined) && if ((result === undefined) &&
(argument_list[0] === 'field_listbox_sort_list:json')) { (argument_list[0] === 'field_listbox_sort_list:json')) {
return [['title', 'ascending']]; return [['title', 'ascending']];
} }
return result; return result;
}); });
}) })
.declareMethod("render", function (options) { .declareMethod("render", function () {
var gadget = this; var gadget = this;
return new RSVP.Queue() return new RSVP.Queue()
.push(function () { .push(function () {
return gadget.updateHeader({ return gadget.updateHeader({
page_title: "Success Story List", page_title: "Success Story List"
}); });
}) })
.push(function () { .push(function () {
return gadget.getDeclaredGadget("form_list"); return gadget.getDeclaredGadget("form_list");
}) })
.push(function (form_gadget) { .push(function (form_gadget) {
var column_list = [ var column_list = [
['title', 'Title'], ['title', 'Title'],
['software', 'Software'], ['software', 'Software'],
['publisher', 'Publisher'], ['publisher', 'Publisher'],
['industry', 'Industry'], ['industry', 'Industry'],
['category_list', 'Software Categories'], ['category_list', 'Software Categories'],
['customer', 'Customer'], ['customer', 'Customer'],
['country', 'Country'], ['country', 'Country'],
['language', 'Language'] ['language', 'Language']
]; ];
return form_gadget.render({ return form_gadget.render({
erp5_document: {"_embedded": {"_view": { erp5_document: {"_embedded": {"_view": {
"listbox": { "listbox": {
"column_list": column_list, "column_list": column_list,
"show_anchor": 0, "show_anchor": 0,
"default_params": {}, "default_params": {},
"editable": 1, "editable": 1,
"editable_column_list": [], "editable_column_list": [],
"key": "field_listbox", "key": "field_listbox",
"lines": 20, "lines": 20,
"list_method": "portal_catalog", "list_method": "portal_catalog",
"query": 'urn:jio:allDocs?query=portal_type:"success_case"', "query": 'urn:jio:allDocs?query=portal_type:"success_case"',
"portal_type": [], "portal_type": [],
"search_column_list": column_list, "search_column_list": column_list,
"sort_column_list": column_list, "sort_column_list": column_list,
"title": "", "title": "",
"type": "ListBox" "type": "ListBox"
} }
}}, }},
"_links": { "_links": {
"type": { "type": {
// form_list display portal_type in header // form_list display portal_type in header
name: "" name: ""
} }
} }
}, },
form_definition: { form_definition: {
group_list: [[ group_list: [[
"bottom", "bottom",
[["listbox"]] [["listbox"]]
], ],
["hidden", ["listbox_modification_date"]]] ["hidden", ["listbox_modification_date"]]]
} }
}); });
}); });
......
...@@ -214,7 +214,7 @@ ...@@ -214,7 +214,7 @@
</item> </item>
<item> <item>
<key> <string>actor</string> </key> <key> <string>actor</string> </key>
<value> <string>3</string> </value> <value> <string>zope</string> </value>
</item> </item>
<item> <item>
<key> <string>comment</string> </key> <key> <string>comment</string> </key>
...@@ -228,7 +228,7 @@ ...@@ -228,7 +228,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>953.59497.55273.5171</string> </value> <value> <string>959.45121.21336.33467</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -246,7 +246,7 @@ ...@@ -246,7 +246,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1495468000.96</float> <float>1496058364.96</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