sync marked and published states to server via mutation observer
This commit is contained in:
parent
6616c7cf67
commit
e5efde26ac
100
js/Headlines.js
100
js/Headlines.js
|
@ -8,6 +8,8 @@ define(["dojo/_base/declare"], function (declare) {
|
||||||
current_first_id: 0,
|
current_first_id: 0,
|
||||||
catchup_id_batch: [],
|
catchup_id_batch: [],
|
||||||
row_observer: new MutationObserver((mutations) => {
|
row_observer: new MutationObserver((mutations) => {
|
||||||
|
const modified = [];
|
||||||
|
|
||||||
mutations.each((m) => {
|
mutations.each((m) => {
|
||||||
if (m.type == 'attributes' && m.attributeName == 'class') {
|
if (m.type == 'attributes' && m.attributeName == 'class') {
|
||||||
|
|
||||||
|
@ -18,6 +20,8 @@ define(["dojo/_base/declare"], function (declare) {
|
||||||
const hl = Headlines.headlines[id];
|
const hl = Headlines.headlines[id];
|
||||||
|
|
||||||
if (hl) {
|
if (hl) {
|
||||||
|
const hl_old = Object.extend({}, hl);
|
||||||
|
|
||||||
hl.unread = row.hasClassName("Unread");
|
hl.unread = row.hasClassName("Unread");
|
||||||
hl.marked = row.hasClassName("marked");
|
hl.marked = row.hasClassName("marked");
|
||||||
hl.published = row.hasClassName("published");
|
hl.published = row.hasClassName("published");
|
||||||
|
@ -25,14 +29,45 @@ define(["dojo/_base/declare"], function (declare) {
|
||||||
// not sent by backend
|
// not sent by backend
|
||||||
hl.selected = row.hasClassName("Selected");
|
hl.selected = row.hasClassName("Selected");
|
||||||
hl.active = row.hasClassName("active");
|
hl.active = row.hasClassName("active");
|
||||||
|
|
||||||
|
modified.push({id: hl.id, new: hl, old: hl_old});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
|
|
||||||
Headlines.updateSelectedPrompt();
|
Headlines.updateSelectedPrompt();
|
||||||
Headlines.updateFloatingTitle(true);
|
Headlines.updateFloatingTitle(true);
|
||||||
|
|
||||||
|
Headlines.syncModified(modified);
|
||||||
}),
|
}),
|
||||||
|
syncModified: function(modified) {
|
||||||
|
const ops = {
|
||||||
|
tmark: [],
|
||||||
|
tpub: [],
|
||||||
|
};
|
||||||
|
|
||||||
|
modified.each(function(m) {
|
||||||
|
if (m.old.marked != m.new.marked)
|
||||||
|
ops.tmark.push(m.id);
|
||||||
|
|
||||||
|
if (m.old.published != m.new.published)
|
||||||
|
ops.tpub.push(m.id);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (ops.tmark.length != 0)
|
||||||
|
xhrPost("backend.php",
|
||||||
|
{ op: "rpc", method: "markSelected", ids: ops.tmark.toString(), cmode: 2}, (transport) => {
|
||||||
|
App.handleRpcJson(transport);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (ops.tpub.length != 0)
|
||||||
|
xhrPost("backend.php",
|
||||||
|
{ op: "rpc", method: "publishSelected", ids: ops.tpub.toString(), cmode: 2}, (transport) => {
|
||||||
|
App.handleRpcJson(transport);
|
||||||
|
});
|
||||||
|
|
||||||
|
},
|
||||||
click: function (event, id, in_body) {
|
click: function (event, id, in_body) {
|
||||||
in_body = in_body || false;
|
in_body = in_body || false;
|
||||||
|
|
||||||
|
@ -630,78 +665,41 @@ define(["dojo/_base/declare"], function (declare) {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
selectionToggleMarked: function (ids) {
|
selectionToggleMarked: function (ids) {
|
||||||
const rows = ids || Headlines.getSelected();
|
ids = ids || Headlines.getSelected();
|
||||||
|
|
||||||
if (rows.length == 0) {
|
if (ids.length == 0) {
|
||||||
alert(__("No articles selected."));
|
alert(__("No articles selected."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < rows.length; i++) {
|
ids.each((id) => {
|
||||||
this.toggleMark(rows[i], true, true);
|
this.toggleMark(id);
|
||||||
}
|
|
||||||
|
|
||||||
const query = {
|
|
||||||
op: "rpc", method: "markSelected",
|
|
||||||
ids: rows.toString(), cmode: 2
|
|
||||||
};
|
|
||||||
|
|
||||||
xhrPost("backend.php", query, (transport) => {
|
|
||||||
App.handleRpcJson(transport);
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
selectionTogglePublished: function (ids) {
|
selectionTogglePublished: function (ids) {
|
||||||
const rows = ids || Headlines.getSelected();
|
ids = ids || Headlines.getSelected();
|
||||||
|
|
||||||
if (rows.length == 0) {
|
if (ids.length == 0) {
|
||||||
alert(__("No articles selected."));
|
alert(__("No articles selected."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < rows.length; i++) {
|
ids.each((id) => {
|
||||||
this.togglePub(rows[i], true);
|
this.toggleMark(id);
|
||||||
}
|
});
|
||||||
|
|
||||||
if (rows.length > 0) {
|
|
||||||
const query = {
|
|
||||||
op: "rpc", method: "publishSelected",
|
|
||||||
ids: rows.toString(), cmode: 2
|
|
||||||
};
|
|
||||||
|
|
||||||
xhrPost("backend.php", query, (transport) => {
|
|
||||||
App.handleRpcJson(transport);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
toggleMark: function (id, client_only) {
|
toggleMark: function (id) {
|
||||||
const query = {op: "rpc", id: id, method: "mark"};
|
|
||||||
const row = $("RROW-" + id);
|
const row = $("RROW-" + id);
|
||||||
|
|
||||||
if (row) {
|
if (row)
|
||||||
row.toggleClassName("marked");
|
row.toggleClassName("marked");
|
||||||
query.mark = row.hasClassName("marked") ? 1 : 0;
|
|
||||||
|
|
||||||
if (!client_only)
|
|
||||||
xhrPost("backend.php", query, (transport) => {
|
|
||||||
App.handleRpcJson(transport);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
togglePub: function (id, client_only) {
|
togglePub: function (id) {
|
||||||
const row = $("RROW-" + id);
|
const row = $("RROW-" + id);
|
||||||
|
|
||||||
if (row) {
|
if (row)
|
||||||
const query = {op: "rpc", id: id, method: "publ"};
|
|
||||||
|
|
||||||
row.toggleClassName("published");
|
row.toggleClassName("published");
|
||||||
query.pub = row.hasClassName("published") ? 1 : 0;
|
|
||||||
|
|
||||||
if (!client_only)
|
|
||||||
xhrPost("backend.php", query, (transport) => {
|
|
||||||
App.handleRpcJson(transport);
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
move: function (mode, noscroll, noexpand) {
|
move: function (mode, noscroll, noexpand) {
|
||||||
const rows = Headlines.getLoaded();
|
const rows = Headlines.getLoaded();
|
||||||
|
|
Loading…
Reference in New Issue