]> git.wh0rd.org - tt-rss.git/blobdiff - digest.js
add some more lockfiles to update_daemon2
[tt-rss.git] / digest.js
index 5cf8d4ec9aa7c4386d6f1a85319d194fdab164e3..98ae14d8c1b16aa83fbdf5e6f685424cad511d53 100644 (file)
--- a/digest.js
+++ b/digest.js
@@ -1,9 +1,15 @@
 var last_feeds = [];
+var init_params = {};
+
+var db = false;
+var store = false;
 
 var _active_feed_id = false;
 var _active_feed_offset = false;
 var _update_timeout = false;
+var _view_update_timeout = false;
 var _feedlist_expanded = false;
+var _update_seq = 1;
 
 function article_appear(article_id) {
        try {
@@ -41,20 +47,31 @@ function catchup_feed(feed_id, callback) {
        }
 }
 
+function get_visible_article_ids() {
+       try {
+               var elems = $("headlines-content").getElementsByTagName("LI");
+               var ids = [];
+                       
+               for (var i = 0; i < elems.length; i++) {
+                       if (elems[i].id && elems[i].id.match("A-")) {
+                       ids.push(elems[i].id.replace("A-", ""));
+                       }
+               }
+
+               return ids;
+
+       } catch (e) {
+               exception_error("get_visible_article_ids", e);
+       }
+}
+
 function catchup_visible_articles(callback) {
        try {
 
-               if (confirm(__("Mark all displayed articles as read?"))) {
+               var ids = get_visible_article_ids();
+
+               if (confirm(__("Mark %d displayed articles as read?").replace("%d", ids.length))) {
 
-                       var elems = $("headlines-content").getElementsByTagName("LI");
-                       var ids = [];
-                       
-                       for (var i = 0; i < elems.length; i++) {
-                               if (elems[i].id && elems[i].id.match("A-")) {
-                                       ids.push(elems[i].id.replace("A-", ""));
-                               }
-                       }
-       
                        var query = "?op=rpc&subop=catchupSelected" +
                                "&cmode=0&ids=" + param_escape(ids);
        
@@ -128,6 +145,15 @@ function zoom(elem, article_id) {
 
                                        elem.onclick = false;
                                        elem.style.cursor = "auto";
+
+                                       catchup_article(article_id, 
+                                               function() {                                                    
+                                                       window.clearTimeout(_view_update_timeout);
+                                                       _view_update_timeout = window.setTimeout("view_update()", 500);
+                                                       $("A-" + article_id).className = "read";
+                                       });
+
+
                                } else {
                                        elem.innerHTML = __("Error: unable to load article.");
                                }
@@ -142,13 +168,22 @@ function zoom(elem, article_id) {
 
 function load_more() {
        try {
-               viewfeed(_active_feed_id, _active_feed_offset + 10);
+               var pr = $("H-LOADING-IMG");
+
+               if (pr) Element.show(pr);
+
+               viewfeed(_active_feed_id, _active_feed_offset + 10, false, false, true,
+                       function() { 
+                               var pr = $("H-LOADING-IMG");
+
+                               if (pr) Element.hide(pr);       
+                       });
        } catch (e) {
                exception_error("load_more", e);
        }
 }
 
-function update() {
+function update(callback) {
        try {
                console.log('updating feeds...');
 
@@ -160,6 +195,8 @@ function update() {
                                fatal_error_check(transport);
                                parse_feeds(transport);
                                set_selected_feed(_active_feed_id);
+
+                               if (callback) callback(transport);
                                } });
 
                _update_timeout = window.setTimeout('update()', 5*1000);
@@ -181,14 +218,23 @@ function remove_headline_entry(article_id) {
        }
 }
 
+function view_update() {
+       try {
+               viewfeed(_active_feed_id, _active_feed_offset, false, true, true);
+               update();
+       } catch (e) {
+               exception_error("view_update", e);
+       }
+}
+
 function view(article_id, dismiss_only) {
        try {
                remove_headline_entry(article_id);
 
                catchup_article(article_id, 
                        function() { 
-                               viewfeed(_active_feed_id, _active_feed_offset, false, true);
-                               update();       
+                               window.clearTimeout(_view_update_timeout);
+                               _view_update_timeout = window.setTimeout("view_update()", 500);
                        });
 
                return dismiss_only != true;
@@ -197,7 +243,7 @@ function view(article_id, dismiss_only) {
        }
 }
 
-function viewfeed(feed_id, offset, replace, no_effects) {
+function viewfeed(feed_id, offset, replace, no_effects, no_indicator, callback) {
        try {
 
                if (!feed_id) feed_id = _active_feed_id;
@@ -210,27 +256,38 @@ function viewfeed(feed_id, offset, replace, no_effects) {
 
                if (replace == undefined) replace = (offset == 0);
 
+               _update_seq = _update_seq + 1;
+
                var query = "backend.php?op=rpc&subop=digest-update&feed_id=" + 
-                               param_escape(feed_id) + "&offset=" + offset;
+                               param_escape(feed_id) + "&offset=" + offset +
+                               "&seq=" + _update_seq;
 
                console.log(query);
 
-               var img = $("F-" + feed_id).getElementsByTagName("IMG")[0];
-
-               img.setAttribute("orig_src", img.src);
-               img.src = 'images/indicator_tiny.gif';
+               if ($("F-" + feed_id)) {
+                       var img = $("F-" + feed_id).getElementsByTagName("IMG")[0];
 
-               if ($('H-LOADING-IMG')) Element.show("H-LOADING-IMG");
+                       if (img && !no_indicator) {
+                               img.setAttribute("orig_src", img.src);
+                               img.src = 'images/indicator_tiny.gif';
+                       }
+               }
 
                new Ajax.Request("backend.php", {
                        parameters: query, 
                        onComplete: function(transport) {
+                               Element.hide("overlay");
+
                                fatal_error_check(transport);
                                parse_headlines(transport, replace, no_effects);
-                               set_selected_feed(feed_id);
+                               set_selected_feed(feed_id);                             
                                _active_feed_offset = offset;
-                               img.src = img.getAttribute("orig_src");
-                               if ($('H-LOADING-IMG')) Element.hide("H-LOADING-IMG");
+
+                               if (img && !no_indicator)
+                                       img.src = img.getAttribute("orig_src");
+
+                               if (callback) callback(transport);
+
                        } });
 
        } catch (e) {
@@ -269,7 +326,7 @@ function find_feed(feeds, feed_id) {
 function get_feed_icon(feed) {
        try {
                if (feed.has_icon)
-                       return 'icons/' + feed.id + '.ico';
+                       return getInitParam('icons_location') + "/" + feed.id + '.ico';
 
                if (feed.id == -1)
                        return 'images/mark_set.png';
@@ -358,7 +415,18 @@ function add_headline_entry(article, feed, no_effects) {
 
                if (!no_effects) style = "style=\"display : none\"";
 
-               var tmp_html = "<li id=\"A-"+article.id+"\" "+style+">" + 
+               if (article.excerpt.trim() == "")
+                       article.excerpt = __("Click to expand article.");
+
+               var li_class = "unread";
+
+               var fresh_max = getInitParam("fresh_article_max_age") * 60 * 60;
+               var d = new Date();
+
+               if (d.getTime() / 1000 - article.updated < fresh_max)
+                       li_class = "fresh";
+
+               var tmp_html = "<li id=\"A-"+article.id+"\" "+style+" class=\""+li_class+"\">" + 
                        icon_part +
 
                        "<div class='digest-check'>" +
@@ -465,6 +533,18 @@ function parse_headlines(transport, replace, no_effects) {
        try {
                if (!transport.responseXML) return;
 
+               var seq = transport.responseXML.getElementsByTagName('seq')[0];
+
+               if (seq) {
+                       seq = seq.firstChild.nodeValue;
+                       if (seq != _update_seq) {
+                               console.log("parse_headlines: wrong sequence received.");
+                               return;
+                       }
+               } else {
+                       return;
+               }
+
                var headlines = transport.responseXML.getElementsByTagName('headlines')[0];
                var headlines_title = transport.responseXML.getElementsByTagName('headlines-title')[0];
 
@@ -496,19 +576,25 @@ function parse_headlines(transport, replace, no_effects) {
                                }
                        }
 
-                       if (pr) {
-                               $('headlines-content').appendChild(pr);
-                               if (!no_effects) new Effect.ScrollTo(inserted);
-                       } else {
-                               $('headlines-content').innerHTML += "<li id='H-MORE-PROMPT'>" +
-                                       "<div class='body'>" +
-                                       "<a href=\"javascript:catchup_visible_articles()\">" +
-                                       __("Mark as read") + "</a> | " + 
-                                       "<a href=\"javascript:load_more()\">" +
-                                       __("Load more...") + "</a>" + 
-                                       "<img style=\"display : none\" "+
+                       var ids = get_visible_article_ids();
+
+                       if (ids.length > 0) {
+                               if (pr) {
+                                       $('headlines-content').appendChild(pr);
+                                       if (!no_effects) new Effect.ScrollTo(inserted);
+                               } else {
+                                       $('headlines-content').innerHTML += "<li id='H-MORE-PROMPT'>" +
+                                               "<div class='body'>" +
+                                               "<a href=\"javascript:catchup_visible_articles()\">" +
+                                               __("Mark as read") + "</a> | " + 
+                                               "<a href=\"javascript:load_more()\">" +
+                                               __("Load more...") + "</a>" + 
+                                               "<img style=\"display : none\" "+
                                                "id=\"H-LOADING-IMG\" src='images/indicator_tiny.gif'>" +
-                                       "</div></li>";
+                                               "</div></li>";
+                               }
+                       } else {
+                               // FIXME : display some kind of "nothing to see here" prompt here
                        }
 
                        if (replace && !no_effects) 
@@ -522,9 +608,8 @@ function parse_headlines(transport, replace, no_effects) {
        }
 }
 
-function init() {
+function init_second_stage() {
        try {
-               
                new Ajax.Request("backend.php", {
                        parameters: "backend.php?op=rpc&subop=digest-init",
                        onComplete: function(transport) {
@@ -533,6 +618,20 @@ function init() {
                                _update_timeout = window.setTimeout('update()', 5*1000);
                                } });
 
+       } catch (e) {
+               exception_error("init_second_stage", e);
+       }
+}
+
+function init() {
+       try {
+
+               new Ajax.Request("backend.php", {
+                       parameters: "?op=rpc&subop=sanityCheck",
+                       onComplete: function(transport) { 
+                               backend_sanity_check_callback(transport);
+                       } });
+
        } catch (e) {
                exception_error("digest_init", e);
        }