-var _infscroll_disable = 0;
-var _infscroll_request_sent = 0;
-var _search_query = false;
-var _viewfeed_last = 0;
+let _infscroll_disable = 0;
+let _infscroll_request_sent = 0;
-var counters_last_request = 0;
+let _search_query = false;
+let _viewfeed_last = 0;
+let _viewfeed_timeout = false;
-function viewCategory(cat) {
- viewfeed(cat, '', true);
- return false;
+let counters_last_request = 0;
+let _counters_prev = [];
+
+function resetCounterCache() {
+ _counters_prev = [];
}
function loadMoreHeadlines() {
- try {
- console.log("loadMoreHeadlines");
-
- var offset = 0;
-
- var view_mode = document.forms["main_toolbar_form"].view_mode.value;
- var unread_in_buffer = $$("#headlines-frame > div[id*=RROW][class*=Unread]").length;
- var num_all = $$("#headlines-frame > div[id*=RROW]").length;
- var num_unread = getFeedUnread(getActiveFeedId(), activeFeedIsCat());
-
- // TODO implement marked & published
-
- if (view_mode == "marked") {
- console.warn("loadMoreHeadlines: marked is not implemented, falling back.");
- offset = num_all;
- } else if (view_mode == "published") {
- console.warn("loadMoreHeadlines: published is not implemented, falling back.");
- offset = num_all;
- } else if (view_mode == "unread") {
- offset = unread_in_buffer;
- } else if (_search_query) {
- offset = num_all;
- } else if (view_mode == "adaptive") {
- if (num_unread > 0)
- offset = unread_in_buffer;
- else
- offset = num_all;
- } else {
- offset = num_all;
- }
-
- console.log("offset: " + offset);
-
- viewfeed(getActiveFeedId(), '', activeFeedIsCat(), offset, false, true);
-
- } catch (e) {
- exception_error("viewNextFeedPage", e);
+ console.log("loadMoreHeadlines");
+
+ let offset = 0;
+
+ const view_mode = document.forms["main_toolbar_form"].view_mode.value;
+ const unread_in_buffer = $$("#headlines-frame > div[id*=RROW][class*=Unread]").length;
+ const num_all = $$("#headlines-frame > div[id*=RROW]").length;
+ const num_unread = getFeedUnread(getActiveFeedId(), activeFeedIsCat());
+
+ // TODO implement marked & published
+
+ if (view_mode == "marked") {
+ console.warn("loadMoreHeadlines: marked is not implemented, falling back.");
+ offset = num_all;
+ } else if (view_mode == "published") {
+ console.warn("loadMoreHeadlines: published is not implemented, falling back.");
+ offset = num_all;
+ } else if (view_mode == "unread") {
+ offset = unread_in_buffer;
+ } else if (_search_query) {
+ offset = num_all;
+ } else if (view_mode == "adaptive" && !(getActiveFeedId() == -1 && !activeFeedIsCat())) {
+ // ^ starred feed shows both unread & read articles in adaptive mode
+ offset = num_unread > 0 ? unread_in_buffer : num_all;
+ } else {
+ offset = num_all;
}
-}
+ console.log("offset: " + offset);
-function viewfeed(feed, method, is_cat, offset, background, infscroll_req) {
- try {
- if (is_cat == undefined)
- is_cat = false;
- else
- is_cat = !!is_cat;
-
- if (method == undefined) method = '';
- if (offset == undefined) offset = 0;
- if (background == undefined) background = false;
- if (infscroll_req == undefined) infscroll_req = false;
-
- last_requested_article = 0;
-
- var cached_headlines = false;
+ viewfeed({feed: getActiveFeedId(), is_cat: activeFeedIsCat(), offset: offset, infscroll_req: true});
- if (feed == getActiveFeedId() && activeFeedIsCat() == is_cat) {
- cache_delete("feed:" + feed + ":" + is_cat);
- } else {
- cached_headlines = cache_get("feed:" + feed + ":" + is_cat);
+}
- if (!background && _search_query) _search_query = false;
+function cleanup_memory(root) {
+ const dijits = dojo.query("[widgetid]", dijit.byId(root).domNode).map(dijit.byNode);
- // switching to a different feed, we might as well catchup stuff visible
- // in headlines buffer (if any)
- // disabled for now because this behavior is considered confusing -fox
- /* if (!background && isCdmMode() && getInitParam("cdm_auto_catchup") == 1 && parseInt(getActiveFeedId()) > 0) {
+ dijits.each(function (d) {
+ dojo.destroy(d.domNode);
+ });
- $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
- function(child) {
- var hf = $("headlines-frame");
+ $$("#" + root + " *").each(function (i) {
+ i.parentNode ? i.parentNode.removeChild(i) : true;
+ });
+}
- if (hf.scrollTop + hf.offsetHeight >=
- child.offsetTop + child.offsetHeight) {
+function viewfeed(params) {
+ const feed = params.feed;
+ let is_cat = !!params.is_cat || false;
+ let offset = params.offset || 0;
+ let background = params.background || false;
+ let infscroll_req = params.infscroll_req || false;
+ const can_wait = params.can_wait;
+ const viewfeed_debug = params.viewfeed_debug;
+ const method = params.method;
- var id = child.id.replace("RROW-", "");
+ if (infscroll_req == undefined) infscroll_req = false;
- if (catchup_id_batch.indexOf(id) == -1)
- catchup_id_batch.push(id);
+ last_requested_article = 0;
- }
+ if (feed != getActiveFeedId() || activeFeedIsCat() != is_cat) {
+ if (!background && _search_query) _search_query = false;
+ }
- if (catchup_id_batch.length > 0) {
- window.clearTimeout(catchup_timeout_id);
+ if (!background) {
+ _viewfeed_last = get_timestamp();
- if (!_infscroll_request_sent) {
- catchup_timeout_id = window.setTimeout('catchupBatchedArticles()',
- 2000);
- }
- }
+ if (getActiveFeedId() != feed || !infscroll_req) {
+ setActiveArticleId(0);
+ _infscroll_disable = 0;
- });
- } */
+ cleanup_memory("headlines-frame");
+ _headlines_scroll_offset = 0;
}
- if (!background) {
- _viewfeed_last = get_timestamp();
+ if (infscroll_req) {
+ const timestamp = get_timestamp();
- if (getActiveFeedId() != feed || offset == 0) {
- active_post_id = 0;
- _infscroll_disable = 0;
+ if (_infscroll_request_sent && _infscroll_request_sent + 30 > timestamp) {
+ //console.log("infscroll request in progress, aborting");
+ return;
}
- if (!offset && !method && cached_headlines && !background) {
- try {
- render_local_headlines(feed, is_cat, JSON.parse(cached_headlines));
- return;
- } catch (e) {
- console.warn("render_local_headlines failed: " + e);
- }
- }
+ _infscroll_request_sent = timestamp;
+ }
+ }
- if (offset != 0 && !method) {
- var timestamp = get_timestamp();
+ Form.enable("main_toolbar_form");
- if (_infscroll_request_sent && _infscroll_request_sent + 30 > timestamp) {
- //console.log("infscroll request in progress, aborting");
- return;
- }
+ const toolbar_query = Form.serialize("main_toolbar_form");
- _infscroll_request_sent = timestamp;
- }
+ let query = "?op=feeds&method=view&feed=" + param_escape(feed) + "&" +
+ toolbar_query;
- hideAuxDlg();
+ if (method) query += "&m=" + param_escape(method);
+
+ if (offset > 0) {
+ if (current_first_id) {
+ query = query + "&fid=" + param_escape(current_first_id);
}
+ }
- Form.enable("main_toolbar_form");
+ if (!background) {
+ if (_search_query) {
+ query = query + "&" + _search_query;
+ //_search_query = false;
+ }
- var toolbar_query = Form.serialize("main_toolbar_form");
+ if (offset != 0) {
+ query = query + "&skip=" + offset;
- var query = "?op=feeds&method=view&feed=" + feed + "&" +
- toolbar_query;
+ // to prevent duplicate feed titles when showing grouped vfeeds
+ if (vgroup_last_feed) {
+ query = query + "&vgrlf=" + param_escape(vgroup_last_feed);
+ }
+ } else if (!is_cat && feed == getActiveFeedId() && !params.method) {
+ query = query + "&m=ForceUpdate";
+ }
- if (method) {
- query = query + "&m=" + param_escape(method);
- }
+ Form.enable("main_toolbar_form");
- if (!background) {
- if (_search_query) {
- force_nocache = true;
- query = query + "&" + _search_query;
- //_search_query = false;
- }
+ if (!setFeedExpandoIcon(feed, is_cat,
+ (is_cat) ? 'images/indicator_tiny.gif' : 'images/indicator_white.gif'))
+ notify_progress("Loading, please wait...", true);
+ }
- if (offset != 0) {
- query = query + "&skip=" + offset;
+ query += "&cat=" + is_cat;
- // to prevent duplicate feed titles when showing grouped vfeeds
- if (vgroup_last_feed) {
- query = query + "&vgrlf=" + param_escape(vgroup_last_feed);
- }
- } else {
- if (!method && !is_cat && feed == getActiveFeedId()) {
- query = query + "&m=ForceUpdate";
- }
- }
+ if (can_wait && _viewfeed_timeout) {
+ setFeedExpandoIcon(getActiveFeedId(), activeFeedIsCat(), 'images/blank_icon.gif');
+ clearTimeout(_viewfeed_timeout);
+ }
- Form.enable("main_toolbar_form");
+ setActiveFeedId(feed, is_cat);
- if (!offset)
- if (!is_cat) {
- if (!setFeedExpandoIcon(feed, is_cat, 'images/indicator_white.gif'))
- notify_progress("Loading, please wait...", true);
- } else {
- notify_progress("Loading, please wait...", true);
- }
- }
+ if (viewfeed_debug) {
+ window.open("backend.php" + query + "&debug=1&csrf_token=" + getInitParam("csrf_token"));
+ }
- query += "&cat=" + is_cat;
+ const timeout_ms = can_wait ? 250 : 0;
+ _viewfeed_timeout = setTimeout(() => {
- console.log(query);
+ xhrPost("backend.php", query, (transport) => {
+ try {
+ setFeedExpandoIcon(feed, is_cat, 'images/blank_icon.gif');
+ headlines_callback2(transport, offset, background, infscroll_req);
+ PluginHost.run(PluginHost.HOOK_FEED_LOADED, [feed, is_cat]);
+ } catch (e) {
+ exception_error(e);
+ }
+ });
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- setFeedExpandoIcon(feed, is_cat, 'images/blank_icon.gif');
- headlines_callback2(transport, offset, background, infscroll_req);
- } });
+ }, timeout_ms); // Wait 250ms
- } catch (e) {
- exception_error("viewfeed", e);
- }
}
function feedlist_init() {
- try {
- console.log("in feedlist init");
+ console.log("in feedlist init");
- hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
- document.onkeydown = hotkey_handler;
- setTimeout("hotkey_prefix_timeout()", 5*1000);
+ loading_set_progress(50);
- if (!getActiveFeedId())
- viewfeed(-3);
+ document.onkeydown = hotkey_handler;
+ setTimeout(hotkey_prefix_timeout, 5*1000);
- console.log("T:" +
- getInitParam("cdm_auto_catchup") + " " + getFeedUnread(-3));
-
- hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
+ if (!getActiveFeedId()) {
+ viewfeed({feed: -3});
+ } else {
+ viewfeed({feed: getActiveFeedId(), is_cat: activeFeedIsCat()});
+ }
- request_counters(true);
- timeout();
- setTimeout("precache_headlines_idle()", 15000);
+ hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
+
+ if (getInitParam("is_default_pw")) {
+ console.warn("user password is at default value");
+
+ const dialog = new dijit.Dialog({
+ title: __("Your password is at default value"),
+ href: "backend.php?op=dlg&method=defaultpasswordwarning",
+ id: 'infoBox',
+ style: "width: 600px",
+ onCancel: function() {
+ return true;
+ },
+ onExecute: function() {
+ return true;
+ },
+ onClose: function() {
+ return true;
+ }
+ });
- } catch (e) {
- exception_error("feedlist/init", e);
+ dialog.show();
}
+
+ // bw_limit disables timeout() so we request initial counters separately
+ if (getInitParam("bw_limit") == "1") {
+ request_counters(true);
+ } else {
+ setTimeout(timeout, 250);
+ }
}
function request_counters(force) {
- try {
- var date = new Date();
- var timestamp = Math.round(date.getTime() / 1000);
+ const date = new Date();
+ const timestamp = Math.round(date.getTime() / 1000);
- if (force || timestamp - counters_last_request > 5) {
- console.log("scheduling request of counters...");
+ if (force || timestamp - counters_last_request > 5) {
+ console.log("scheduling request of counters...");
- counters_last_request = timestamp;
+ counters_last_request = timestamp;
- var query = "?op=rpc&method=getAllCounters&seq=" + next_seq();
+ let query = {op: "rpc", method: "getAllCounters", seq: next_seq()};
- if (!force)
- query = query + "&last_article_id=" + getInitParam("last_article_id");
+ if (!force)
+ query.last_article_id = getInitParam("last_article_id");
- console.log(query);
+ xhrPost("backend.php", query, (transport) => {
+ handle_rpc_json(transport);
+ });
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- try {
- handle_rpc_json(transport);
- } catch (e) {
- exception_error("request_counters", e);
- }
- } });
-
- } else {
- console.log("request_counters: rate limit reached: " + (timestamp - counters_last_request));
- }
-
- } catch (e) {
- exception_error("request_counters", e);
+ } else {
+ console.log("request_counters: rate limit reached: " + (timestamp - counters_last_request));
}
}
-function displayNewContentPrompt(id) {
- try {
+// NOTE: this implementation is incomplete
+// for general objects but good enough for counters
+// http://adripofjavascript.com/blog/drips/object-equality-in-javascript.html
+function counter_is_equal(a, b) {
+ // Create arrays of property names
+ const aProps = Object.getOwnPropertyNames(a);
+ const bProps = Object.getOwnPropertyNames(b);
+
+ // If number of properties is different,
+ // objects are not equivalent
+ if (aProps.length != bProps.length) {
+ return false;
+ }
- var msg = "<a href='#' onclick='viewCurrentFeed()'>" +
- __("New articles available in this feed (click to show)") + "</a>";
+ for (let i = 0; i < aProps.length; i++) {
+ const propName = aProps[i];
- msg = msg.replace("%s", getFeedName(id));
+ // If values of same property are not equal,
+ // objects are not equivalent
+ if (a[propName] !== b[propName]) {
+ return false;
+ }
+ }
- $('auxDlg').innerHTML = msg;
+ // If we made it this far, objects
+ // are considered equivalent
+ return true;
+}
- new Effect.Appear('auxDlg', {duration : 0.5});
- } catch (e) {
- exception_error("displayNewContentPrompt", e);
- }
-}
+function parse_counters(elems) {
+ for (let l = 0; l < elems.length; l++) {
-function parse_counters(elems, scheduled_call) {
- try {
- for (var l = 0; l < elems.length; l++) {
-
- var id = elems[l].id;
- var kind = elems[l].kind;
- var ctr = parseInt(elems[l].counter);
- var error = elems[l].error;
- var has_img = elems[l].has_img;
- var updated = elems[l].updated;
-
- if (id == "global-unread") {
- global_unread = ctr;
- updateTitle();
- continue;
- }
+ if (_counters_prev[l] && counter_is_equal(elems[l], _counters_prev[l])) {
+ continue;
+ }
- if (id == "subscribed-feeds") {
- feeds_found = ctr;
- continue;
- }
+ const id = elems[l].id;
+ const kind = elems[l].kind;
+ const ctr = parseInt(elems[l].counter);
+ const error = elems[l].error;
+ const has_img = elems[l].has_img;
+ const updated = elems[l].updated;
+ const auxctr = parseInt(elems[l].auxcounter);
- if (id == getActiveFeedId() && ctr > getFeedUnread(id) && scheduled_call) {
- displayNewContentPrompt(id);
- }
+ if (id == "global-unread") {
+ global_unread = ctr;
+ updateTitle();
+ continue;
+ }
- if (getFeedUnread(id, (kind == "cat")) != ctr ||
- (kind == "cat")) {
+ if (id == "subscribed-feeds") {
+ /* feeds_found = ctr; */
+ continue;
+ }
- cache_delete("feed:" + id + ":" + (kind == "cat"));
- }
+ /*if (getFeedUnread(id, (kind == "cat")) != ctr ||
+ (kind == "cat")) {
+ }*/
- setFeedUnread(id, (kind == "cat"), ctr);
+ setFeedUnread(id, (kind == "cat"), ctr);
+ setFeedValue(id, (kind == "cat"), 'auxcounter', auxctr);
- if (kind != "cat") {
- setFeedValue(id, false, 'error', error);
- setFeedValue(id, false, 'updated', updated);
+ if (kind != "cat") {
+ setFeedValue(id, false, 'error', error);
+ setFeedValue(id, false, 'updated', updated);
- if (id > 0) {
- if (has_img) {
- setFeedIcon(id, false,
- getInitParam("icons_url") + "/" + id + ".ico");
- } else {
- setFeedIcon(id, false, 'images/blank_icon.gif');
- }
+ if (id > 0) {
+ if (has_img) {
+ setFeedIcon(id, false,
+ getInitParam("icons_url") + "/" + id + ".ico?" + has_img);
+ } else {
+ setFeedIcon(id, false, 'images/blank_icon.gif');
}
}
}
+ }
- hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
+ hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
- } catch (e) {
- exception_error("parse_counters", e);
- }
+ _counters_prev = elems;
}
function getFeedUnread(feed, is_cat) {
try {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
if (tree && tree.model)
return tree.model.getFeedUnread(feed, is_cat);
function getFeedCategory(feed) {
try {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
if (tree && tree.model)
return tree.getFeedCategory(feed);
}
function hideOrShowFeeds(hide) {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
if (tree)
return tree.hideRead(hide, getInitParam("hide_read_shows_special"));
}
function getFeedName(feed, is_cat) {
- var tree = dijit.byId("feedTree");
+
+ if (isNaN(feed)) return feed; // it's a tag
+
+ const tree = dijit.byId("feedTree");
if (tree && tree.model)
return tree.model.getFeedValue(feed, is_cat, 'name');
function getFeedValue(feed, is_cat, key) {
try {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
if (tree && tree.model)
return tree.model.getFeedValue(feed, is_cat, key);
}
function setFeedUnread(feed, is_cat, unread) {
- try {
- var tree = dijit.byId("feedTree");
-
- if (tree && tree.model)
- return tree.model.setFeedUnread(feed, is_cat, unread);
+ const tree = dijit.byId("feedTree");
- } catch (e) {
- exception_error("setFeedUnread", e);
- }
+ if (tree && tree.model)
+ return tree.model.setFeedUnread(feed, is_cat, unread);
}
function setFeedValue(feed, is_cat, key, value) {
try {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
if (tree && tree.model)
return tree.model.setFeedValue(feed, is_cat, key, value);
}
function selectFeed(feed, is_cat) {
- try {
- var tree = dijit.byId("feedTree");
-
- if (tree) return tree.selectFeed(feed, is_cat);
+ const tree = dijit.byId("feedTree");
- } catch (e) {
- exception_error("selectFeed", e);
- }
+ if (tree) return tree.selectFeed(feed, is_cat);
}
function setFeedIcon(feed, is_cat, src) {
- try {
- var tree = dijit.byId("feedTree");
-
- if (tree) return tree.setFeedIcon(feed, is_cat, src);
+ const tree = dijit.byId("feedTree");
- } catch (e) {
- exception_error("setFeedIcon", e);
- }
+ if (tree) return tree.setFeedIcon(feed, is_cat, src);
}
function setFeedExpandoIcon(feed, is_cat, src) {
- try {
- var tree = dijit.byId("feedTree");
+ const tree = dijit.byId("feedTree");
- if (tree) return tree.setFeedExpandoIcon(feed, is_cat, src);
+ if (tree) return tree.setFeedExpandoIcon(feed, is_cat, src);
- } catch (e) {
- exception_error("setFeedIcon", e);
- }
return false;
}
function getNextUnreadFeed(feed, is_cat) {
- try {
- var tree = dijit.byId("feedTree");
- var nuf = tree.model.getNextUnreadFeed(feed, is_cat);
+ const tree = dijit.byId("feedTree");
+ const nuf = tree.model.getNextUnreadFeed(feed, is_cat);
- if (nuf)
- return tree.model.store.getValue(nuf, 'bare_id');
-
- } catch (e) {
- exception_error("getNextUnreadFeed", e);
- }
+ if (nuf)
+ return tree.model.store.getValue(nuf, 'bare_id');
}
-function catchupCurrentFeed() {
- return catchupFeed(getActiveFeedId(), activeFeedIsCat());
+function catchupCurrentFeed(mode) {
+ catchupFeed(getActiveFeedId(), activeFeedIsCat(), mode);
}
function catchupFeedInGroup(id) {
- try {
+ const title = getFeedName(id);
- var title = getFeedName(id);
+ const str = __("Mark all articles in %s as read?").replace("%s", title);
- var str = __("Mark all articles in %s as read?").replace("%s", title);
+ if (getInitParam("confirm_feed_catchup") != 1 || confirm(str)) {
- if (getInitParam("confirm_feed_catchup") != 1 || confirm(str)) {
- return viewCurrentFeed('MarkAllReadGR:' + id);
- }
+ const rows = $$("#headlines-frame > div[id*=RROW][data-orig-feed-id='"+id+"']");
- } catch (e) {
- exception_error("catchupFeedInGroup", e);
- }
-}
+ if (rows.length > 0) {
-function catchupFeed(feed, is_cat) {
- try {
- if (is_cat == undefined) is_cat = false;
+ rows.each(function (row) {
+ row.removeClassName("Unread");
- var str = __("Mark all articles in %s as read?");
- var fn = getFeedName(feed, is_cat);
+ if (row.getAttribute("data-article-id") != getActiveArticleId()) {
+ new Effect.Fade(row, {duration: 0.5});
+ }
- str = str.replace("%s", fn);
+ });
- if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str)) {
- return;
- }
+ const feedTitles = $$("#headlines-frame > div[class='cdmFeedTitle']");
- var max_id = 0;
+ for (let i = 0; i < feedTitles.length; i++) {
+ if (feedTitles[i].getAttribute("data-feed-id") == id) {
- if (feed == getActiveFeedId() && is_cat == activeFeedIsCat()) {
- $$("#headlines-frame > div[id*=RROW]").each(
- function(child) {
- var id = parseInt(child.id.replace("RROW-", ""));
+ if (i < feedTitles.length - 1) {
+ new Effect.Fade(feedTitles[i], {duration: 0.5});
+ }
- if (id > max_id) max_id = id;
+ break;
}
- );
+ }
+
+ updateFloatingTitle(true);
}
- var catchup_query = "?op=rpc&method=catchupFeed&feed_id=" +
- feed + "&is_cat=" + is_cat + "&max_id=" + max_id;
+ notify_progress("Loading, please wait...", true);
- console.log(catchup_query);
+ xhrPost("backend.php", { op: "rpc", method: "catchupFeed", feed_id: id, is_cat: false}, (transport) => {
+ handle_rpc_json(transport);
+ });
+ }
+}
- notify_progress("Loading, please wait...", true);
+function catchupFeed(feed, is_cat, mode) {
+ if (is_cat == undefined) is_cat = false;
+
+ let str = false;
+
+ switch (mode) {
+ case "1day":
+ str = __("Mark %w in %s older than 1 day as read?");
+ break;
+ case "1week":
+ str = __("Mark %w in %s older than 1 week as read?");
+ break;
+ case "2week":
+ str = __("Mark %w in %s older than 2 weeks as read?");
+ break;
+ default:
+ str = __("Mark %w in %s as read?");
+ }
- new Ajax.Request("backend.php", {
- parameters: catchup_query,
- onComplete: function(transport) {
- handle_rpc_json(transport);
+ const mark_what = last_search_query && last_search_query[0] ? __("search results") : __("all articles");
+ const fn = getFeedName(feed, is_cat);
- if (feed == getActiveFeedId() && is_cat == activeFeedIsCat()) {
+ str = str.replace("%s", fn)
+ .replace("%w", mark_what);
- $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
- function(child) {
- child.removeClassName("Unread");
- }
- );
- }
+ if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str)) {
+ return;
+ }
- var show_next_feed = getInitParam("on_catchup_show_next_feed") == "1";
+ const catchup_query = {op: 'rpc', method: 'catchupFeed', feed_id: feed,
+ is_cat: is_cat, mode: mode, search_query: last_search_query[0],
+ search_lang: last_search_query[1]};
- if (show_next_feed) {
- var nuf = getNextUnreadFeed(feed, is_cat);
+ notify_progress("Loading, please wait...", true);
- if (nuf) {
- viewfeed(nuf, '', is_cat);
- }
- }
+ xhrPost("backend.php", catchup_query, (transport) => {
+ handle_rpc_json(transport);
- notify("");
- } });
+ const show_next_feed = getInitParam("on_catchup_show_next_feed") == "1";
- } catch (e) {
- exception_error("catchupFeed", e);
- }
+ if (show_next_feed) {
+ const nuf = getNextUnreadFeed(feed, is_cat);
+
+ if (nuf) {
+ viewfeed({feed: nuf, is_cat: is_cat});
+ }
+ } else if (feed == getActiveFeedId() && is_cat == activeFeedIsCat()) {
+ viewCurrentFeed();
+ }
+
+ notify("");
+ });
}
function decrementFeedCounter(feed, is_cat) {
- try {
- var ctr = getFeedUnread(feed, is_cat);
+ let ctr = getFeedUnread(feed, is_cat);
- if (ctr > 0) {
- setFeedUnread(feed, is_cat, ctr - 1);
- global_unread = global_unread - 1;
- updateTitle();
+ if (ctr > 0) {
+ setFeedUnread(feed, is_cat, ctr - 1);
+ global_unread = global_unread - 1;
+ updateTitle();
- if (!is_cat) {
- var cat = parseInt(getFeedCategory(feed));
+ if (!is_cat) {
+ const cat = parseInt(getFeedCategory(feed));
- if (!isNaN(cat)) {
- ctr = getFeedUnread(cat, true);
+ if (!isNaN(cat)) {
+ ctr = getFeedUnread(cat, true);
- if (ctr > 0) {
- setFeedUnread(cat, true, ctr - 1);
- }
+ if (ctr > 0) {
+ setFeedUnread(cat, true, ctr - 1);
}
}
}
-
- cache_delete("feed:" + feed + ":" + is_cat);
-
- } catch (e) {
- exception_error("decrement_feed_counter", e);
}
+
}
+
+