summaryrefslogtreecommitdiff
path: root/digest.js
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2010-09-12 11:05:03 +0400
committerAndrew Dolgov <[email protected]>2010-09-12 11:05:03 +0400
commitc1b5cd23e068d269a2736ac4759fbaa09243f4dd (patch)
tree65f734f97a39fd5a36489ad518183ab767cf3c99 /digest.js
parente0cebf2a81f8ce20656c210c97b6751f3166b554 (diff)
digest: support feed catchup
Diffstat (limited to 'digest.js')
-rw-r--r--digest.js194
1 files changed, 120 insertions, 74 deletions
diff --git a/digest.js b/digest.js
index fffdf16ea..a3cbb4879 100644
--- a/digest.js
+++ b/digest.js
@@ -3,6 +3,36 @@ var last_feeds = [];
var _active_feed_id = false;
var _active_feed_offset = false;
var _update_timeout = false;
+var _feedlist_expanded = false;
+
+function catchup_feed(feed_id, callback) {
+ try {
+
+ var fn = find_feed(last_feeds, feed_id).title;
+
+ if (confirm(__("Mark all articles in %s as read?").replace("%s", fn))) {
+
+ var is_cat = "";
+
+ if (feed_id == -4) is_cat = "true";
+
+ var query = "?op=rpc&subop=catchupFeed&feed_id=" +
+ feed_id + "&is_cat=" + is_cat;
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ if (callback) callback(transport);
+
+ update();
+ } });
+ }
+
+ } catch (e) {
+ exception_error("catchup_article", e);
+ }
+}
+
function catchup_article(article_id, callback) {
try {
@@ -205,10 +235,14 @@ function add_feed_entry(feed) {
icon_part = "<img src='" + get_feed_icon(feed) + "'/>";
- var tmp_html = "<li id=\"F-"+feed.id+"\">" +
+ var tmp_html = "<li id=\"F-"+feed.id+"\" " +
+ "onmouseover=\"feed_mi(this)\" onmouseout=\"feed_mo(this)\">" +
icon_part +
- "<a href=\"#\" onclick=\"viewfeed("+feed.id+")\">" + feed.title +
- "<div class='unread-ctr'>" + feed.unread + "</div>" +
+ "<a href=\"#\" onclick=\"viewfeed("+feed.id+")\">" + feed.title + "</a>" +
+ "<div class='unread-ctr'>" +
+ "<img onclick=\"catchup_feed("+feed.id+")\" title=\"Dismiss\" class=\"dismiss\" style='display : none' src=\"images/digest_checkbox.png\">" +
+ "<span class=\"unread\">" + feed.unread + "</span>" +
+ "</div>" +
"</li>";
$("feeds-content").innerHTML += tmp_html;
@@ -252,9 +286,48 @@ function add_headline_entry(article, feed) {
}
}
+function expand_feeds() {
+ try {
+ _feedlist_expanded = true;
+
+ redraw_feedlist(last_feeds);
+
+ } catch (e) {
+ exception_error("expand_feeds", e);
+ }
+}
+
+function redraw_feedlist(feeds) {
+ try {
+
+ $('feeds-content').innerHTML = "";
+
+ var limit = 10;
+
+ if (_feedlist_expanded) limit = feeds.length;
+
+ for (var i = 0; i < Math.min(limit, feeds.length); i++) {
+ add_feed_entry(feeds[i]);
+ }
+
+ if (feeds.length > limit) {
+ $('feeds-content').innerHTML += "<li id='F-MORE-PROMPT'>" +
+ "<img src='images/blank_icon.gif'>" +
+ "<a href=\"#\" onclick=\"expand_feeds()\">" +
+ __("%d more...").replace("%d", feeds.length-10) +
+ "</a>" + "</li>";
+ }
+
+ } catch (e) {
+ exception_error("redraw_feedlist", e);
+ }
+}
+
function parse_feeds(transport) {
try {
+ if (!transport.responseXML) return;
+
var feeds = transport.responseXML.getElementsByTagName('feeds')[0];
if (feeds) {
@@ -275,11 +348,7 @@ function parse_feeds(transport) {
last_feeds = feeds;
- $('feeds-content').innerHTML = "";
-
- for (var i = 0; i < feeds.length; i++) {
- add_feed_entry(feeds[i]);
- }
+ redraw_feedlist(feeds);
}
} catch (e) {
@@ -289,6 +358,8 @@ function parse_feeds(transport) {
function parse_headlines(transport, replace) {
try {
+ if (!transport.responseXML) return;
+
var headlines = transport.responseXML.getElementsByTagName('headlines')[0];
if (headlines) {
@@ -296,7 +367,7 @@ function parse_headlines(transport, replace) {
if (replace) $('headlines-content').innerHTML = '';
- var pr = $('MORE-PROMPT');
+ var pr = $('H-MORE-PROMPT');
if (pr) pr.parentNode.removeChild(pr);
@@ -311,7 +382,7 @@ function parse_headlines(transport, replace) {
if (pr) {
$('headlines-content').appendChild(pr);
} else {
- $('headlines-content').innerHTML += "<li id='MORE-PROMPT'>" +
+ $('headlines-content').innerHTML += "<li id='H-MORE-PROMPT'>" +
"<div class='body'><a href=\"javascript:load_more()\">" +
__("More articles...") + "</a></div></li>";
}
@@ -324,70 +395,6 @@ function parse_headlines(transport, replace) {
}
}
-/*function digest_update(transport, feed_id, offset) {
- try {
- var feeds = transport.responseXML.getElementsByTagName('feeds')[0];
- var headlines = transport.responseXML.getElementsByTagName('headlines')[0];
-
- if (feeds) {
- feeds = eval("(" + feeds.firstChild.nodeValue + ")");
-
- last_feeds = feeds;
-
- $('feeds-content').innerHTML = "";
-
- for (var i = 0; i < feeds.length; i++) {
- add_feed_entry(feeds[i]);
- }
- } else {
- feeds = last_feeds;
- }
-
- if (headlines) {
- headlines = eval("(" + headlines.firstChild.nodeValue + ")");
-
- if (_active_feed_id != feed_id || !offset)
- $('headlines-content').innerHTML = "";
-
- var pr = $('MORE-PROMPT');
-
- if (pr) {
- pr.id = '';
- Element.hide(pr);
- }
-
- for (var i = 0; i < headlines.length; i++) {
- var elem = $('A-' + headlines[i].id);
-
- if (elem && Element.visible(elem)) {
- if (!headlines[i].unread)
- remove_headline_entry(headlines[i].id);
-
- } else {
- add_headline_entry(headlines[i], find_feed(feeds, headlines[i].feed_id));
- }
- }
-
- $('headlines-content').innerHTML += "<li id='MORE-PROMPT'>" +
- "<div class='body'><a href=\"#\" onclick=\"load_more()\">" +
- __("More articles...") + "</a></div></li>";
-
- new Effect.Appear('headlines-content');
- }
-
- if (feed_id != undefined) {
- _active_feed_id = feed_id;
- }
-
- if (offset != undefined) _active_feed_offset = offset;
-
- mark_selected_feed(_active_feed_id);
-
- } catch (e) {
- exception_error("digest_update", e);
- }
-} */
-
function init() {
try {
@@ -555,4 +562,43 @@ function fatal_error_check(transport) {
return true;
}
+function feed_mi(elem) {
+ try {
+ var imgs = elem.getElementsByTagName('IMG');
+ var spans = elem.getElementsByTagName('SPAN');
+
+ for (var i = 0; i < imgs.length; i++) {
+ if (imgs[i].className == "dismiss")
+ Element.show(imgs[i]);
+ }
+
+ for (var i = 0; i < spans.length; i++) {
+ if (spans[i].className == "unread")
+ Element.hide(spans[i]);
+ }
+
+
+ } catch (e) {
+ exception_error("feed_mi", e);
+ }
+}
+
+function feed_mo(elem) {
+ try {
+ var imgs = elem.getElementsByTagName('IMG');
+ var spans = elem.getElementsByTagName('SPAN');
+
+ for (var i = 0; i < imgs.length; i++) {
+ if (imgs[i].className == "dismiss")
+ Element.hide(imgs[i]);
+ }
+
+ for (var i = 0; i < spans.length; i++) {
+ if (spans[i].className == "unread")
+ Element.show(spans[i]);
+ }
+ } catch (e) {
+ exception_error("feed_mo", e);
+ }
+}