]>
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 (!background
&& _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
+ "&" +
155 query
= query
+ "&m=" + param_escape(method
);
160 force_nocache
= true;
161 query
= query
+ "&" + _search_query
;
162 //_search_query = false;
166 query
= query
+ "&skip=" + offset
;
168 // to prevent duplicate feed titles when showing grouped vfeeds
169 if (vgroup_last_feed
) {
170 query
= query
+ "&vgrlf=" + param_escape(vgroup_last_feed
);
173 if (!method
&& !is_cat
&& feed
== getActiveFeedId()) {
174 query
= query
+ "&m=ForceUpdate";
178 Form
.enable("main_toolbar_form");
182 if (!setFeedExpandoIcon(feed
, is_cat
, 'images/indicator_white.gif'))
183 notify_progress("Loading, please wait...", true);
185 notify_progress("Loading, please wait...", true);
189 query
+= "&cat=" + is_cat
;
193 new Ajax
.Request("backend.php", {
195 onComplete: function(transport
) {
196 setFeedExpandoIcon(feed
, is_cat
, 'images/blank_icon.gif');
197 headlines_callback2(transport
, offset
, background
, infscroll_req
);
201 exception_error("viewfeed", e
);
205 function feedlist_init() {
207 console
.log("in feedlist init");
209 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
210 document
.onkeydown
= hotkey_handler
;
211 setTimeout("hotkey_prefix_timeout()", 5*1000);
213 if (!getActiveFeedId()) {
214 setTimeout("viewfeed(-3)", 100);
218 getInitParam("cdm_auto_catchup") + " " + getFeedUnread(-3));
220 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
222 setTimeout("timeout()", 5000);
223 setTimeout("precache_headlines_idle()", 15000);
226 exception_error("feedlist/init", e
);
230 function request_counters_real() {
232 console
.log("requesting counters...");
234 var query
= "?op=rpc&method=getAllCounters&seq=" + next_seq();
236 query
= query
+ "&omode=flc";
238 new Ajax
.Request("backend.php", {
240 onComplete: function(transport
) {
242 handle_rpc_json(transport
);
244 exception_error("viewfeed/getcounters", e
);
249 exception_error("request_counters_real", e
);
254 function request_counters() {
258 //if (getInitParam("bw_limit") == "1") return;
260 var date
= new Date();
261 var timestamp
= Math
.round(date
.getTime() / 1000);
263 if (timestamp
- counters_last_request
> 5) {
264 console
.log("scheduling request of counters...");
266 window
.clearTimeout(counter_timeout_id
);
267 counter_timeout_id
= window
.setTimeout("request_counters_real()", 1000);
269 counters_last_request
= timestamp
;
271 console
.log("request_counters: rate limit reached: " + (timestamp
- counters_last_request
));
275 exception_error("request_counters", e
);
279 function displayNewContentPrompt(id
) {
282 var msg
= "<a href='#' onclick='viewCurrentFeed()'>" +
283 __("New articles available in this feed (click to show)") + "</a>";
285 msg
= msg
.replace("%s", getFeedName(id
));
287 $('auxDlg').innerHTML
= msg
;
289 new Effect
.Appear('auxDlg', {duration
: 0.5});
292 exception_error("displayNewContentPrompt", e
);
296 function parse_counters(elems
, scheduled_call
) {
298 for (var l
= 0; l
< elems
.length
; l
++) {
300 var id
= elems
[l
].id
;
301 var kind
= elems
[l
].kind
;
302 var ctr
= parseInt(elems
[l
].counter
);
303 var error
= elems
[l
].error
;
304 var has_img
= elems
[l
].has_img
;
305 var updated
= elems
[l
].updated
;
307 if (id
== "global-unread") {
313 if (id
== "subscribed-feeds") {
318 // TODO: enable new content notification for categories
320 if (!activeFeedIsCat() && id
== getActiveFeedId()
321 && ctr
> getFeedUnread(id
) && scheduled_call
) {
322 displayNewContentPrompt(id
);
325 if (getFeedUnread(id
, (kind
== "cat")) != ctr
||
328 cache_delete("feed:" + id
+ ":" + (kind
== "cat"));
331 setFeedUnread(id
, (kind
== "cat"), ctr
);
334 setFeedValue(id
, false, 'error', error
);
335 setFeedValue(id
, false, 'updated', updated
);
339 setFeedIcon(id
, false,
340 getInitParam("icons_url") + "/" + id
+ ".ico");
342 setFeedIcon(id
, false, 'images/blank_icon.gif');
348 hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
351 exception_error("parse_counters", e
);
355 function getFeedUnread(feed
, is_cat
) {
357 var tree
= dijit
.byId("feedTree");
359 if (tree
&& tree
.model
)
360 return tree
.model
.getFeedUnread(feed
, is_cat
);
369 function getFeedCategory(feed
) {
371 var tree
= dijit
.byId("feedTree");
373 if (tree
&& tree
.model
)
374 return tree
.getFeedCategory(feed
);
383 function hideOrShowFeeds(hide
) {
384 var tree
= dijit
.byId("feedTree");
387 return tree
.hideRead(hide
, getInitParam("hide_read_shows_special"));
390 function getFeedName(feed
, is_cat
) {
391 var tree
= dijit
.byId("feedTree");
393 if (tree
&& tree
.model
)
394 return tree
.model
.getFeedValue(feed
, is_cat
, 'name');
397 function getFeedValue(feed
, is_cat
, key
) {
399 var tree
= dijit
.byId("feedTree");
401 if (tree
&& tree
.model
)
402 return tree
.model
.getFeedValue(feed
, is_cat
, key
);
410 function setFeedUnread(feed
, is_cat
, unread
) {
412 var tree
= dijit
.byId("feedTree");
414 if (tree
&& tree
.model
)
415 return tree
.model
.setFeedUnread(feed
, is_cat
, unread
);
418 exception_error("setFeedUnread", e
);
422 function setFeedValue(feed
, is_cat
, key
, value
) {
424 var tree
= dijit
.byId("feedTree");
426 if (tree
&& tree
.model
)
427 return tree
.model
.setFeedValue(feed
, is_cat
, key
, value
);
434 function selectFeed(feed
, is_cat
) {
436 var tree
= dijit
.byId("feedTree");
438 if (tree
) return tree
.selectFeed(feed
, is_cat
);
441 exception_error("selectFeed", e
);
445 function setFeedIcon(feed
, is_cat
, src
) {
447 var tree
= dijit
.byId("feedTree");
449 if (tree
) return tree
.setFeedIcon(feed
, is_cat
, src
);
452 exception_error("setFeedIcon", e
);
456 function setFeedExpandoIcon(feed
, is_cat
, src
) {
458 var tree
= dijit
.byId("feedTree");
460 if (tree
) return tree
.setFeedExpandoIcon(feed
, is_cat
, src
);
463 exception_error("setFeedIcon", e
);
468 function getNextUnreadFeed(feed
, is_cat
) {
470 var tree
= dijit
.byId("feedTree");
471 var nuf
= tree
.model
.getNextUnreadFeed(feed
, is_cat
);
474 return tree
.model
.store
.getValue(nuf
, 'bare_id');
477 exception_error("getNextUnreadFeed", e
);
481 function catchupCurrentFeed() {
482 return catchupFeed(getActiveFeedId(), activeFeedIsCat());
485 function catchupFeedInGroup(id
) {
488 var title
= getFeedName(id
);
490 var str
= __("Mark all articles in %s as read?").replace("%s", title
);
492 if (getInitParam("confirm_feed_catchup") != 1 || confirm(str
)) {
493 return viewCurrentFeed('MarkAllReadGR:' + id
);
497 exception_error("catchupFeedInGroup", e
);
501 function catchupFeed(feed
, is_cat
) {
503 if (is_cat
== undefined) is_cat
= false;
505 var str
= __("Mark all articles in %s as read?");
506 var fn
= getFeedName(feed
, is_cat
);
508 str
= str
.replace("%s", fn
);
510 if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str
)) {
516 if (feed
== getActiveFeedId() && is_cat
== activeFeedIsCat()) {
517 $$("#headlines-frame > div[id*=RROW]").each(
519 var id
= parseInt(child
.id
.replace("RROW-", ""));
521 if (id
> max_id
) max_id
= id
;
526 var catchup_query
= "?op=rpc&method=catchupFeed&feed_id=" +
527 feed
+ "&is_cat=" + is_cat
+ "&max_id=" + max_id
;
529 console
.log(catchup_query
);
531 notify_progress("Loading, please wait...", true);
533 new Ajax
.Request("backend.php", {
534 parameters
: catchup_query
,
535 onComplete: function(transport
) {
536 handle_rpc_json(transport
);
538 if (feed
== getActiveFeedId() && is_cat
== activeFeedIsCat()) {
540 $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
542 child
.removeClassName("Unread");
547 var show_next_feed
= getInitParam("on_catchup_show_next_feed") == "1";
549 if (show_next_feed
) {
550 var nuf
= getNextUnreadFeed(feed
, is_cat
);
553 viewfeed(nuf
, '', is_cat
);
561 exception_error("catchupFeed", e
);
565 function decrementFeedCounter(feed
, is_cat
) {
567 var ctr
= getFeedUnread(feed
, is_cat
);
570 setFeedUnread(feed
, is_cat
, ctr
- 1);
573 var cat
= parseInt(getFeedCategory(feed
));
576 ctr
= getFeedUnread(cat
, true);
579 setFeedUnread(cat
, true, ctr
- 1);
585 cache_delete("feed:" + feed
+ ":" + is_cat
);
588 exception_error("decrement_feed_counter", e
);