]> git.wh0rd.org - tt-rss.git/blobdiff - feedlist.js
config: remove option ENABLE_UPDATE_DAEMON
[tt-rss.git] / feedlist.js
index 9fb9c9efbc1e56ff679569d33d8857444efd1462..954a67c162a7badd6cfdd9081f6f51a4ad3345b7 100644 (file)
@@ -1,6 +1,7 @@
 var _feed_cur_page = 0;
 var _infscroll_disable = 0;
 var _infscroll_request_sent = 0;
+var _search_query = false;
 
 var counter_timeout_id = false;
 
@@ -29,6 +30,7 @@ function viewNextFeedPage() {
 function viewfeed(feed, subop, is_cat, offset) {
        try {
                if (is_cat == undefined) is_cat = false;
+               if (subop == undefined) subop = '';
 
 //             if (!offset) page_offset = 0;
 
@@ -42,7 +44,7 @@ function viewfeed(feed, subop, is_cat, offset) {
 /*             if (getInitParam("theme") == "" || getInitParam("theme") == "compact") {
                        if (getInitParam("hide_feedlist") == 1) {
                                Element.hide("feeds-holder");
-                       }               
+                       }
                } */
 
                dijit.byId("content-tabs").selectChild(
@@ -77,12 +79,10 @@ function viewfeed(feed, subop, is_cat, offset) {
                                return;
                        }
 
-                       _infscroll_request_sent = timestamp;                    
+                       _infscroll_request_sent = timestamp;
                }
 
-               enableHotkeys();
                hideAuxDlg();
-               closeInfoBox();
 
                Form.enable("main_toolbar_form");
 
@@ -99,12 +99,10 @@ function viewfeed(feed, subop, is_cat, offset) {
                var query = "?op=viewfeed&feed=" + feed + "&" +
                        toolbar_query + "&subop=" + param_escape(subop);
 
-               if ($("search_form")) {
-                       var search_query = Form.serialize("search_form");
-                       query = query + "&" + search_query;
-                       $("search_form").query.value = "";
-                       closeInfoBox(true);
+               if (_search_query) {
                        force_nocache = true;
+                       query = query + "&" + _search_query;
+                       _search_query = false;
                }
 
 //             console.log("IS_CAT_STORED: " + activeFeedIsCat() + ", IS_CAT: " + is_cat);
@@ -114,7 +112,14 @@ function viewfeed(feed, subop, is_cat, offset) {
                        var show_next_feed = getInitParam("on_catchup_show_next_feed") == "1";
 
                        if (show_next_feed) {
-                               // TODO: implement show_next_feed handling
+                               var tree = dijit.byId("feedTree");
+                               var nuf = tree.model.getNextUnreadFeed(feed, is_cat);
+
+                               if (nuf) {
+                                       var nuf_id = tree.model.store.getValue(nuf, 'bare_id');
+
+                                       query = query + "&nuf=" + param_escape(nuf_id);
+                               }
                        }
                }
 
@@ -135,8 +140,8 @@ function viewfeed(feed, subop, is_cat, offset) {
 
                console.log(query);
 
-               var unread_ctr = -1;
-               
+/*             var unread_ctr = -1;
+
                if (!is_cat) unread_ctr = getFeedUnread(feed);
 
                var cache_check = false;
@@ -144,7 +149,7 @@ function viewfeed(feed, subop, is_cat, offset) {
                if (unread_ctr != -1 && !page_offset && !force_nocache && !subop) {
 
                        var cache_prefix = "";
-                               
+
                        if (is_cat) {
                                cache_prefix = "C:";
                        } else {
@@ -158,14 +163,14 @@ function viewfeed(feed, subop, is_cat, offset) {
                if (cache_check) {
 
                        setActiveFeedId(feed, is_cat);
-               
-                       $("headlines-frame").innerHTML = cache_find_param(cache_prefix + feed, 
+
+                       $("headlines-frame").innerHTML = cache_find_param(cache_prefix + feed,
                                unread_ctr);
 
                        request_counters();
                        remove_splash();
 
-               } else {
+               } else { */
 
                        if (!is_cat) {
                                if (!setFeedExpandoIcon(feed, is_cat, 'images/indicator_white.gif'))
@@ -176,38 +181,36 @@ function viewfeed(feed, subop, is_cat, offset) {
 
                        new Ajax.Request("backend.php", {
                                parameters: query,
-                               onComplete: function(transport) { 
+                               onComplete: function(transport) {
                                        setFeedExpandoIcon(feed, is_cat, 'images/blank_icon.gif');
-                                       headlines_callback2(transport, page_offset); 
+                                       headlines_callback2(transport, page_offset);
                                } });
-               }
+//             }
 
        } catch (e) {
                exception_error("viewfeed", e);
-       }               
+       }
 }
 
 function feedlist_init() {
        try {
                console.log("in feedlist init");
-               
+
                hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
                document.onkeydown = hotkey_handler;
                setTimeout("hotkey_prefix_timeout()", 5*1000);
 
                 if (!getActiveFeedId()) {
-                       if (getInitParam("cdm_auto_catchup") != 1) {
-                               setTimeout("viewfeed(-3)", 100);
-                       } else {
-                               setTimeout("viewfeed(-5)", 100);
-                       }
-               } 
+                       setTimeout("viewfeed(-3)", 100);
+               }
 
-               console.log("T:" + 
+               console.log("T:" +
                                getInitParam("cdm_auto_catchup") + " " + getFeedUnread(-3));
 
                hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
 
+               setTimeout("timeout()", 5000);
+
        } catch (e) {
                exception_error("feedlist/init", e);
        }
@@ -223,9 +226,9 @@ function request_counters_real() {
 
                new Ajax.Request("backend.php", {
                        parameters: query,
-                       onComplete: function(transport) { 
+                       onComplete: function(transport) {
                                try {
-                                       handle_rpc_reply(transport);
+                                       handle_rpc_json(transport);
                                } catch (e) {
                                        exception_error("viewfeed/getcounters", e);
                                }
@@ -279,13 +282,11 @@ function displayNewContentPrompt(id) {
        }
 }
 
-function parse_counters(reply, scheduled_call) {
+function parse_counters(elems, scheduled_call) {
        try {
 
                var feeds_found = 0;
 
-               var elems = JSON.parse(reply.firstChild.nodeValue);
-
                for (var l = 0; l < elems.length; l++) {
 
                        var id = elems[l].id
@@ -295,7 +296,7 @@ function parse_counters(reply, scheduled_call) {
                        var has_img = elems[l].has_img;
                        var updated = elems[l].updated;
                        var title = elems[l].title;
-       
+
                        if (id == "global-unread") {
                                global_unread = ctr;
                                updateTitle();
@@ -311,7 +312,7 @@ function parse_counters(reply, scheduled_call) {
 
                        // TODO: enable new content notification for categories
 
-                       if (!activeFeedIsCat() && id == getActiveFeedId() 
+                       if (!activeFeedIsCat() && id == getActiveFeedId()
                                        && ctr > getFeedUnread(id) && scheduled_call) {
                                displayNewContentPrompt(id);
                        }
@@ -319,12 +320,12 @@ function parse_counters(reply, scheduled_call) {
                        setFeedUnread(id, (kind == "cat"), ctr);
 
                        if (kind != "cat") {
-                               //setFeedValue(id, false, 'error', error);
+                               setFeedValue(id, false, 'error', error);
                                setFeedValue(id, false, 'updated', updated);
 
                                if (id > 0) {
                                        if (has_img) {
-                                               setFeedIcon(id, false, 
+                                               setFeedIcon(id, false,
                                                        getInitParam("icons_url") + "/" + id + ".ico");
                                        } else {
                                                setFeedIcon(id, false, 'images/blank_icon.gif');
@@ -332,19 +333,8 @@ function parse_counters(reply, scheduled_call) {
                                }
                        }
                }
-       
-               hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
 
-               var feeds_stored = number_of_feeds;
-
-               if (feeds_stored != feeds_found) {
-                       number_of_feeds = feeds_found;
-
-                       if (feeds_stored != 0 && feeds_found != 0) {
-                               console.log("Subscribed feed number changed, refreshing feedlist");
-                               setTimeout('updateFeedList()', 50);
-                       }
-               }
+               hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
 
        } catch (e) {
                exception_error("parse_counters", e);
@@ -355,7 +345,7 @@ function getFeedUnread(feed, is_cat) {
        try {
                var tree = dijit.byId("feedTree");
 
-               if (tree && tree.model) 
+               if (tree && tree.model)
                        return tree.model.getFeedUnread(feed, is_cat);
 
        } catch (e) {
@@ -376,20 +366,20 @@ function hideOrShowFeeds(hide) {
                return tree.hideRead(hide, getInitParam("hide_read_shows_special"));
 }
 
-function getFeedName(feed, is_cat) {   
+function getFeedName(feed, is_cat) {
        var tree = dijit.byId("feedTree");
 
-       if (tree && tree.model) 
+       if (tree && tree.model)
                return tree.model.getFeedValue(feed, is_cat, 'name');
 }
 
-function getFeedValue(feed, is_cat, key) {     
+function getFeedValue(feed, is_cat, key) {
        try {
                var tree = dijit.byId("feedTree");
 
-               if (tree && tree.model) 
+               if (tree && tree.model)
                        return tree.model.getFeedValue(feed, is_cat, key);
-       
+
        } catch (e) {
                //
        }
@@ -400,7 +390,7 @@ function setFeedUnread(feed, is_cat, unread) {
        try {
                var tree = dijit.byId("feedTree");
 
-               if (tree && tree.model) 
+               if (tree && tree.model)
                        return tree.model.setFeedUnread(feed, is_cat, unread);
 
        } catch (e) {
@@ -412,7 +402,7 @@ function setFeedValue(feed, is_cat, key, value) {
        try {
                var tree = dijit.byId("feedTree");
 
-               if (tree && tree.model) 
+               if (tree && tree.model)
                        return tree.model.setFeedValue(feed, is_cat, key, value);
 
        } catch (e) {