]>
git.wh0rd.org - tt-rss.git/blob - js/feedlist.js
1 var _infscroll_disable
= 0;
2 var _infscroll_request_sent
= 0;
3 var _search_query
= false;
4 var _viewfeed_last
= 0;
6 var counter_timeout_id
= false;
8 var counters_last_request
= 0;
10 function viewCategory(cat
) {
11 viewfeed(cat
, '', true);
15 function loadMoreHeadlines() {
17 console
.log("loadMoreHeadlines");
21 var view_mode
= document
.forms
["main_toolbar_form"].view_mode
.value
;
22 var unread_in_buffer
= $$("#headlines-frame > div[id*=RROW][class*=Unread]").length
;
23 var num_all
= $$("#headlines-frame > div[id*=RROW]").length
;
24 var num_unread
= getFeedUnread(getActiveFeedId(), activeFeedIsCat());
26 // TODO implement marked & published
28 if (view_mode
== "marked") {
29 console
.warn("loadMoreHeadlines: marked is not implemented, falling back.");
31 } else if (view_mode
== "published") {
32 console
.warn("loadMoreHeadlines: published is not implemented, falling back.");
34 } else if (view_mode
== "unread") {
35 offset
= unread_in_buffer
;
36 } else if (_search_query
) {
38 } else if (view_mode
== "adaptive") {
40 offset
= unread_in_buffer
;
47 console
.log("offset: " + offset
);
49 viewfeed(getActiveFeedId(), '', activeFeedIsCat(), offset
, false, true);
52 exception_error("viewNextFeedPage", e
);
57 function viewfeed(feed
, method
, is_cat
, offset
, background
, infscroll_req
) {
59 if (is_cat
== undefined)
64 if (method
== undefined) method
= '';
65 if (offset
== undefined) offset
= 0;
66 if (background
== undefined) background
= false;
67 if (infscroll_req
== undefined) infscroll_req
= false;
69 last_requested_article
= 0;
71 var cached_headlines
= false;
73 if (feed
== getActiveFeedId() && activeFeedIsCat() == is_cat
) {
74 cache_delete("feed:" + feed
+ ":" + is_cat
);
76 cached_headlines
= cache_get("feed:" + feed
+ ":" + is_cat
);
78 if (_search_query
) _search_query
= false;
80 // switching to a different feed, we might as well catchup stuff visible
81 // in headlines buffer (if any)
82 // disabled for now because this behavior is considered confusing -fox
83 /* if (!background && isCdmMode() && getInitParam("cdm_auto_catchup") == 1 && parseInt(getActiveFeedId()) > 0) {
85 $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
87 var hf = $("headlines-frame");
89 if (hf.scrollTop + hf.offsetHeight >=
90 child.offsetTop + child.offsetHeight) {
92 var id = child.id.replace("RROW-", "");
94 if (catchup_id_batch.indexOf(id) == -1)
95 catchup_id_batch.push(id);
99 if (catchup_id_batch.length > 0) {
100 window.clearTimeout(catchup_timeout_id);
102 if (!_infscroll_request_sent) {
103 catchup_timeout_id = window.setTimeout('catchupBatchedArticles()',
112 if (offset
== 0 && !background
)
113 dijit
.byId("content-tabs").selectChild(
114 dijit
.byId("content-tabs").getChildren()[0]);
117 _viewfeed_last
= get_timestamp();
119 if (getActiveFeedId() != feed
|| offset
== 0) {
121 _infscroll_disable
= 0;
124 if (!offset
&& !method
&& cached_headlines
&& !background
) {
126 render_local_headlines(feed
, is_cat
, JSON
.parse(cached_headlines
));
129 console
.warn("render_local_headlines failed: " + e
);
133 if (offset
!= 0 && !method
) {
134 var timestamp
= get_timestamp();
136 if (_infscroll_request_sent
&& _infscroll_request_sent
+ 30 > timestamp
) {
137 //console.log("infscroll request in progress, aborting");
141 _infscroll_request_sent
= timestamp
;
147 Form
.enable("main_toolbar_form");
149 var toolbar_query
= Form
.serialize("main_toolbar_form");
151 var query
= "?op=feeds&method=view&feed=" + feed
+ "&" +
152 toolbar_query
+ "&m=" + param_escape(method
);
156 force_nocache
= true;
157 query
= query
+ "&" + _search_query
;
158 //_search_query = false;
162 query
= query
+ "&skip=" + offset
;
164 // to prevent duplicate feed titles when showing grouped vfeeds
165 if (vgroup_last_feed
) {
166 query
= query
+ "&vgrlf=" + param_escape(vgroup_last_feed
);
170 Form
.enable("main_toolbar_form");
174 if (!setFeedExpandoIcon(feed
, is_cat
, 'images/indicator_white.gif'))
175 notify_progress("Loading, please wait...", true);
177 notify_progress("Loading, please wait...", true);
181 query
+= "&cat=" + is_cat
;
185 new Ajax
.Request("backend.php", {
187 onComplete: function(transport
) {
188 setFeedExpandoIcon(feed
, is_cat
, 'images/blank_icon.gif');
189 headlines_callback2(transport
, offset
, background
, infscroll_req
);
193 exception_error("viewfeed", e
);
197 function feedlist_init() {
199 console
.log("in feedlist init");
201 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
202 document
.onkeydown
= hotkey_handler
;
203 setTimeout("hotkey_prefix_timeout()", 5*1000);
205 if (!getActiveFeedId()) {
206 setTimeout("viewfeed(-3)", 100);
210 getInitParam("cdm_auto_catchup") + " " + getFeedUnread(-3));
212 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
214 setTimeout("timeout()", 5000);
215 setTimeout("precache_headlines_idle()", 15000);
218 exception_error("feedlist/init", e
);
222 function request_counters_real() {
224 console
.log("requesting counters...");
226 var query
= "?op=rpc&method=getAllCounters&seq=" + next_seq();
228 query
= query
+ "&omode=flc";
230 new Ajax
.Request("backend.php", {
232 onComplete: function(transport
) {
234 handle_rpc_json(transport
);
236 exception_error("viewfeed/getcounters", e
);
241 exception_error("request_counters_real", e
);
246 function request_counters() {
250 //if (getInitParam("bw_limit") == "1") return;
252 var date
= new Date();
253 var timestamp
= Math
.round(date
.getTime() / 1000);
255 if (timestamp
- counters_last_request
> 5) {
256 console
.log("scheduling request of counters...");
258 window
.clearTimeout(counter_timeout_id
);
259 counter_timeout_id
= window
.setTimeout("request_counters_real()", 1000);
261 counters_last_request
= timestamp
;
263 console
.log("request_counters: rate limit reached: " + (timestamp
- counters_last_request
));
267 exception_error("request_counters", e
);
271 function displayNewContentPrompt(id
) {
274 var msg
= "<a href='#' onclick='viewCurrentFeed()'>" +
275 __("New articles available in this feed (click to show)") + "</a>";
277 msg
= msg
.replace("%s", getFeedName(id
));
279 $('auxDlg').innerHTML
= msg
;
281 new Effect
.Appear('auxDlg', {duration
: 0.5});
284 exception_error("displayNewContentPrompt", e
);
288 function parse_counters(elems
, scheduled_call
) {
290 for (var l
= 0; l
< elems
.length
; l
++) {
292 var id
= elems
[l
].id
;
293 var kind
= elems
[l
].kind
;
294 var ctr
= parseInt(elems
[l
].counter
);
295 var error
= elems
[l
].error
;
296 var has_img
= elems
[l
].has_img
;
297 var updated
= elems
[l
].updated
;
299 if (id
== "global-unread") {
305 if (id
== "subscribed-feeds") {
310 // TODO: enable new content notification for categories
312 if (!activeFeedIsCat() && id
== getActiveFeedId()
313 && ctr
> getFeedUnread(id
) && scheduled_call
) {
314 displayNewContentPrompt(id
);
317 if (getFeedUnread(id
, (kind
== "cat")) != ctr
||
320 cache_delete("feed:" + id
+ ":" + (kind
== "cat"));
323 setFeedUnread(id
, (kind
== "cat"), ctr
);
326 setFeedValue(id
, false, 'error', error
);
327 setFeedValue(id
, false, 'updated', updated
);
331 setFeedIcon(id
, false,
332 getInitParam("icons_url") + "/" + id
+ ".ico");
334 setFeedIcon(id
, false, 'images/blank_icon.gif');
340 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
343 exception_error("parse_counters", e
);
347 function getFeedUnread(feed
, is_cat
) {
349 var tree
= dijit
.byId("feedTree");
351 if (tree
&& tree
.model
)
352 return tree
.model
.getFeedUnread(feed
, is_cat
);
361 function getFeedCategory(feed
) {
363 var tree
= dijit
.byId("feedTree");
365 if (tree
&& tree
.model
)
366 return tree
.getFeedCategory(feed
);
375 function hideOrShowFeeds(hide
) {
376 var tree
= dijit
.byId("feedTree");
379 return tree
.hideRead(hide
, getInitParam("hide_read_shows_special"));
382 function getFeedName(feed
, is_cat
) {
383 var tree
= dijit
.byId("feedTree");
385 if (tree
&& tree
.model
)
386 return tree
.model
.getFeedValue(feed
, is_cat
, 'name');
389 function getFeedValue(feed
, is_cat
, key
) {
391 var tree
= dijit
.byId("feedTree");
393 if (tree
&& tree
.model
)
394 return tree
.model
.getFeedValue(feed
, is_cat
, key
);
402 function setFeedUnread(feed
, is_cat
, unread
) {
404 var tree
= dijit
.byId("feedTree");
406 if (tree
&& tree
.model
)
407 return tree
.model
.setFeedUnread(feed
, is_cat
, unread
);
410 exception_error("setFeedUnread", e
);
414 function setFeedValue(feed
, is_cat
, key
, value
) {
416 var tree
= dijit
.byId("feedTree");
418 if (tree
&& tree
.model
)
419 return tree
.model
.setFeedValue(feed
, is_cat
, key
, value
);
426 function selectFeed(feed
, is_cat
) {
428 var tree
= dijit
.byId("feedTree");
430 if (tree
) return tree
.selectFeed(feed
, is_cat
);
433 exception_error("selectFeed", e
);
437 function setFeedIcon(feed
, is_cat
, src
) {
439 var tree
= dijit
.byId("feedTree");
441 if (tree
) return tree
.setFeedIcon(feed
, is_cat
, src
);
444 exception_error("setFeedIcon", e
);
448 function setFeedExpandoIcon(feed
, is_cat
, src
) {
450 var tree
= dijit
.byId("feedTree");
452 if (tree
) return tree
.setFeedExpandoIcon(feed
, is_cat
, src
);
455 exception_error("setFeedIcon", e
);
460 function getNextUnreadFeed(feed
, is_cat
) {
462 var tree
= dijit
.byId("feedTree");
463 var nuf
= tree
.model
.getNextUnreadFeed(feed
, is_cat
);
466 return tree
.model
.store
.getValue(nuf
, 'bare_id');
469 exception_error("getNextUnreadFeed", e
);
473 function catchupCurrentFeed() {
474 return catchupFeed(getActiveFeedId(), activeFeedIsCat());
477 function catchupFeedInGroup(id
) {
480 var title
= getFeedName(id
);
482 var str
= __("Mark all articles in %s as read?").replace("%s", title
);
484 if (getInitParam("confirm_feed_catchup") != 1 || confirm(str
)) {
485 return viewCurrentFeed('MarkAllReadGR:' + id
);
489 exception_error("catchupFeedInGroup", e
);
493 function catchupFeed(feed
, is_cat
) {
495 if (is_cat
== undefined) is_cat
= false;
497 var str
= __("Mark all articles in %s as read?");
498 var fn
= getFeedName(feed
, is_cat
);
500 str
= str
.replace("%s", fn
);
502 if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str
)) {
508 if (feed
== getActiveFeedId() && is_cat
== activeFeedIsCat()) {
509 $$("#headlines-frame > div[id*=RROW]").each(
511 var id
= parseInt(child
.id
.replace("RROW-", ""));
513 if (id
> max_id
) max_id
= id
;
518 var catchup_query
= "?op=rpc&method=catchupFeed&feed_id=" +
519 feed
+ "&is_cat=" + is_cat
+ "&max_id=" + max_id
;
521 console
.log(catchup_query
);
523 notify_progress("Loading, please wait...", true);
525 new Ajax
.Request("backend.php", {
526 parameters
: catchup_query
,
527 onComplete: function(transport
) {
528 handle_rpc_json(transport
);
530 if (feed
== getActiveFeedId() && is_cat
== activeFeedIsCat()) {
532 $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
534 child
.removeClassName("Unread");
539 var show_next_feed
= getInitParam("on_catchup_show_next_feed") == "1";
541 if (show_next_feed
) {
542 var nuf
= getNextUnreadFeed(feed
, is_cat
);
545 viewfeed(nuf
, '', is_cat
);
553 exception_error("catchupFeed", e
);
557 function decrementFeedCounter(feed
, is_cat
) {
559 var ctr
= getFeedUnread(feed
, is_cat
);
562 setFeedUnread(feed
, is_cat
, ctr
- 1);
565 var cat
= parseInt(getFeedCategory(feed
));
568 ctr
= getFeedUnread(cat
, true);
571 setFeedUnread(cat
, true, ctr
- 1);
577 cache_delete("feed:" + feed
+ ":" + is_cat
);
580 exception_error("decrement_feed_counter", e
);