1
0
mirror of https://git.tt-rss.org/git/tt-rss.git synced 2025-12-18 11:41:29 +00:00

digest: support feed catchup

This commit is contained in:
Andrew Dolgov
2010-09-12 11:05:03 +04:00
parent e0cebf2a81
commit c1b5cd23e0
3 changed files with 139 additions and 74 deletions

View File

@@ -109,6 +109,11 @@ a:hover {
margin-right : 5px; margin-right : 5px;
} }
#feeds ul#feeds-content div.unread-ctr img.dismiss {
margin-right : 0px;
cursor : pointer;
}
#feeds ul#feeds-content div.unread-ctr { #feeds ul#feeds-content div.unread-ctr {
color : gray; color : gray;
float : right; float : right;

194
digest.js
View File

@@ -3,6 +3,36 @@ var last_feeds = [];
var _active_feed_id = false; var _active_feed_id = false;
var _active_feed_offset = false; var _active_feed_offset = false;
var _update_timeout = 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) { function catchup_article(article_id, callback) {
try { try {
@@ -205,10 +235,14 @@ function add_feed_entry(feed) {
icon_part = "<img src='" + get_feed_icon(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 + icon_part +
"<a href=\"#\" onclick=\"viewfeed("+feed.id+")\">" + feed.title + "<a href=\"#\" onclick=\"viewfeed("+feed.id+")\">" + feed.title + "</a>" +
"<div class='unread-ctr'>" + feed.unread + "</div>" + "<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>"; "</li>";
$("feeds-content").innerHTML += tmp_html; $("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) { function parse_feeds(transport) {
try { try {
if (!transport.responseXML) return;
var feeds = transport.responseXML.getElementsByTagName('feeds')[0]; var feeds = transport.responseXML.getElementsByTagName('feeds')[0];
if (feeds) { if (feeds) {
@@ -275,11 +348,7 @@ function parse_feeds(transport) {
last_feeds = feeds; last_feeds = feeds;
$('feeds-content').innerHTML = ""; redraw_feedlist(feeds);
for (var i = 0; i < feeds.length; i++) {
add_feed_entry(feeds[i]);
}
} }
} catch (e) { } catch (e) {
@@ -289,6 +358,8 @@ function parse_feeds(transport) {
function parse_headlines(transport, replace) { function parse_headlines(transport, replace) {
try { try {
if (!transport.responseXML) return;
var headlines = transport.responseXML.getElementsByTagName('headlines')[0]; var headlines = transport.responseXML.getElementsByTagName('headlines')[0];
if (headlines) { if (headlines) {
@@ -296,7 +367,7 @@ function parse_headlines(transport, replace) {
if (replace) $('headlines-content').innerHTML = ''; if (replace) $('headlines-content').innerHTML = '';
var pr = $('MORE-PROMPT'); var pr = $('H-MORE-PROMPT');
if (pr) pr.parentNode.removeChild(pr); if (pr) pr.parentNode.removeChild(pr);
@@ -311,7 +382,7 @@ function parse_headlines(transport, replace) {
if (pr) { if (pr) {
$('headlines-content').appendChild(pr); $('headlines-content').appendChild(pr);
} else { } else {
$('headlines-content').innerHTML += "<li id='MORE-PROMPT'>" + $('headlines-content').innerHTML += "<li id='H-MORE-PROMPT'>" +
"<div class='body'><a href=\"javascript:load_more()\">" + "<div class='body'><a href=\"javascript:load_more()\">" +
__("More articles...") + "</a></div></li>"; __("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() { function init() {
try { try {
@@ -555,4 +562,43 @@ function fatal_error_check(transport) {
return true; 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);
}
}

View File

@@ -1029,6 +1029,20 @@
return; return;
} }
if ($subop == "catchupFeed") {
$feed_id = db_escape_string($_REQUEST['feed_id']);
$is_cat = db_escape_string($_REQUEST['is_cat']);
print "<rpc-reply>";
catchup_feed($link, $feed_id, $is_cat);
print "</rpc-reply>";
return;
}
print "<rpc-reply><error>Unknown method: $subop</error></rpc-reply>"; print "<rpc-reply><error>Unknown method: $subop</error></rpc-reply>";
} }
?> ?>