var notify_silent = false;
var last_progress_point = 0;
var async_counters_work = false;
+var sanity_check_done = false;
/* add method to remove element from array */
}
}
-function is_opera() {
- return window.opera;
-}
+/* create console.log if it doesn't exist */
+
+if (!window.console) console = {};
+console.log = console.log || function(msg) { debug(msg); };
+console.warn = console.warn || function(msg) { debug(msg); };
+console.error = console.error || function(msg) { debug(msg); };
function exception_error(location, e, ext_info) {
var msg = format_exception_error(location, e);
- if (!ext_info) ext_info = "N/A";
+ if (!ext_info) ext_info = false;
disableHotkeys();
ebc.innerHTML =
"<div><b>Error message:</b></div>" +
- "<pre>" + msg + "</pre>" +
- "<div><b>Additional information:</b></div>" +
+ "<pre>" + msg + "</pre>";
+
+ if (ext_info) {
+ ebc.innerHTML += "<div><b>Additional information:</b></div>" +
"<textarea readonly=\"1\">" + ext_info + "</textarea>";
+ }
+
+ ebc.innerHTML += "<div><b>Stack trace:</b></div>" +
+ "<textarea readonly=\"1\">" + e.stack + "</textarea>";
} else {
alert(msg);
msg = "Exception: " + e + "\nFunction: " + location + "()";
}
- debug("<b>EXCEPTION: " + msg + "</b>");
+ console.error("EXCEPTION: " + msg);
return msg;
}
d.setTime(d.getTime() + (lifetime * 1000));
}
- debug("setCookie: " + name + " => " + value + ": " + d);
+ console.log("setCookie: " + name + " => " + value + ": " + d);
int_setCookie(name, value, d, path, domain, secure);
var feeds_found = 0;
- var elems = reply.getElementsByTagName("counter");
+ var elems = JSON.parse(reply.firstChild.nodeValue);
for (var l = 0; l < elems.length; l++) {
- var id = elems[l].getAttribute("id");
- var t = elems[l].getAttribute("type");
- var ctr = elems[l].getAttribute("counter");
- var error = elems[l].getAttribute("error");
- var has_img = elems[l].getAttribute("hi");
- var updated = elems[l].getAttribute("updated");
- var title = elems[l].getAttribute("title");
- var xmsg = elems[l].getAttribute("xmsg");
+ var id = elems[l].id
+ var is_cat = elems[l].cat;
+ var ctr = parseInt(elems[l].counter)
+ var error = elems[l].error;
+ var has_img = elems[l].has_img;
+ var updated = elems[l].updated;
+ var title = elems[l].title;
+ var xmsg = elems[l].xmsg;
if (id == "global-unread") {
continue;
}
- if (t == "category") {
+ if (is_cat) {
var catctr = $("FCATCTR-" + id);
if (catctr) {
catctr.innerHTML = "(" + ctr + ")";
var feeds_stored = number_of_feeds;
- debug("Feed counters, C: " + feeds_found + ", S:" + feeds_stored);
+ console.log("Feed counters, C: " + feeds_found + ", S:" + feeds_stored);
if (feeds_stored != feeds_found) {
number_of_feeds = feeds_found;
if (feeds_stored != 0 && feeds_found != 0) {
- debug("Subscribed feed number changed, refreshing feedlist");
+ console.log("Subscribed feed number changed, refreshing feedlist");
setTimeout('updateFeedList(false, false)', 50);
}
} else {
var counters = reply.getElementsByTagName("counters")[0];
- parse_counters(counters, scheduled_call);
+ if (counters)
+ parse_counters(counters, scheduled_call);
var runtime_info = reply.getElementsByTagName("runtime-info")[0];
- parse_runtime_info(runtime_info);
+ if (runtime_info)
+ parse_runtime_info(runtime_info);
if (feedsSortByUnread()) {
resort_feedlist();
if (offline_mode) return;
- debug("<b>all_counters_callback2 IN: " + transport + "</b>");
+ console.log("<b>all_counters_callback2 IN: " + transport + "</b>");
parse_counters_reply(transport);
- debug("<b>all_counters_callback2 OUT: " + transport + "</b>");
+ console.log("<b>all_counters_callback2 OUT: " + transport + "</b>");
} catch (e) {
exception_error("all_counters_callback2", e, transport);
try {
- debug("resort_category: " + node + " CM=" + cat_mode);
+ console.log("resort_category: " + node + " CM=" + cat_mode);
var by_unread = feedsSortByUnread();
}
function resort_feedlist() {
- debug("resort_feedlist");
+ console.log("resort_feedlist");
if ($("FCATLIST--1")) {
try {
- debug("hideOrShowFeeds: " + hide);
+ console.log("hideOrShowFeeds: " + hide);
if ($("FCATLIST--1")) {
node = $("feedList"); // no categories
}
- // debug("hideOrShowFeedsCategory: " + node + " (" + hide + ")");
+ // console.log("hideOrShowFeedsCategory: " + node + " (" + hide + ")");
var cat_unread = 0;
if (!node) {
- debug("hideOrShowFeeds: passed node is null, aborting");
+ console.log("hideOrShowFeeds: passed node is null, aborting");
return;
}
- // debug("cat: " + node.id);
+ // console.log("cat: " + node.id);
if (node.hasChildNodes() && node.firstChild.nextSibling != false) {
for (i = 0; i < node.childNodes.length; i++) {
node.childNodes[i].className != "error" &&
node.childNodes[i].className != "tag");
- // debug(node.childNodes[i].id + " --> " + has_unread);
+ // console.log(node.childNodes[i].id + " --> " + has_unread);
if (hide && !has_unread) {
//node.childNodes[i].style.display = "none";
}
}
- // debug("end cat: " + node.id + " unread " + cat_unread);
+ // console.log("end cat: " + node.id + " unread " + cat_unread);
if (cat_node) {
if (cat_unread == 0) {
if (cat_node.style == undefined) {
- debug("ERROR: supplied cat_node " + cat_node +
+ console.log("ERROR: supplied cat_node " + cat_node +
" has no styles. WTF?");
return;
}
try {
cat_node.style.display = "list-item";
} catch (e) {
- debug(e);
+ console.log(e);
}
}
}
-// debug("unread for category: " + cat_unread);
+// console.log("unread for category: " + cat_unread);
} catch (e) {
exception_error("hideOrShowFeedsCategory", e);
var content = $(content_id);
if (!content) {
- alert("[selectTableRows] Element " + content_id + " not found.");
+ console.log("[selectTableRows] Element " + content_id + " not found.");
return;
}
var content = $(content_id);
if (!content) {
- alert("[getSelectedTableRowIds] Element " + content_id + " not found.");
- return;
+ console.log("[getSelectedTableRowIds] Element " + content_id + " not found.");
+ return new Array();
}
var sel_rows = new Array();
}
}
-function getRelativeFeedId(list, id, direction, unread_only) {
- var rows = list.getElementsByTagName("LI");
- var feeds = new Array();
-
- for (var i = 0; i < rows.length; i++) {
- if (rows[i].id.match("FEEDR-")) {
-
- if (rows[i].id == "FEEDR-" + id || (Element.visible(rows[i]) && Element.visible(rows[i].parentNode))) {
-
- if (!unread_only ||
- (rows[i].className.match("Unread") || rows[i].id == "FEEDR-" + id)) {
- feeds.push(rows[i].id.replace("FEEDR-", ""));
- }
- }
- }
- }
-
- if (!id) {
- if (direction == "next") {
- return feeds.shift();
- } else {
- return feeds.pop();
- }
- } else {
- if (direction == "next") {
- var idx = feeds.indexOf(id);
- if (idx != -1 && idx < feeds.length) {
- return feeds[idx+1];
- } else {
- return getRelativeFeedId(list, false, direction, unread_only);
- }
- } else {
- var idx = feeds.indexOf(id);
- if (idx > 0) {
- return feeds[idx-1];
- } else {
- return getRelativeFeedId(list, false, direction, unread_only);
- }
- }
-
- }
-}
-
-function showBlockElement(id, h_id) {
- var elem = $(id);
-
- if (elem) {
- elem.style.display = "block";
-
- if (h_id) {
- elem = $(h_id);
- if (elem) {
- elem.style.display = "none";
- }
- }
- } else {
- alert("[showBlockElement] can't find element with id " + id);
- }
-}
-
-function appearBlockElement_afh(effect) {
-
-}
-
function checkboxToggleElement(elem, id) {
if (elem.checked) {
Effect.Appear(id, {duration : 0.5});
}
}
-function appearBlockElement(id, h_id) {
-
- try {
- if (h_id) {
- Effect.Fade(h_id);
- }
- Effect.SlideDown(id, {duration : 1.0, afterFinish: appearBlockElement_afh});
- } catch (e) {
- exception_error("appearBlockElement", e);
- }
-
-}
-
-function hideParentElement(e) {
- e.parentNode.style.display = "none";
-}
-
function dropboxSelect(e, v) {
for (i = 0; i < e.length; i++) {
if (e[i].value == v) {
return s;
}
+function make_timestamp() {
+ var d = new Date();
+
+ return leading_zero(d.getHours()) + ":" + leading_zero(d.getMinutes()) +
+ ":" + leading_zero(d.getSeconds());
+}
+
+
function closeErrorBox() {
if (Element.visible("errorBoxShadow")) {
function infobox_callback2(transport) {
try {
- debug("infobox_callback2");
+ console.log("infobox_callback2");
var box = $('infoBox');
var query = Form.serialize("feed_add_form");
- debug("subscribe q: " + query);
+ console.log("subscribe q: " + query);
Form.disable("feed_add_form");
c.removeChild(c.lastChild);
}
- var d = new Date();
- var ts = leading_zero(d.getHours()) + ":" + leading_zero(d.getMinutes()) +
- ":" + leading_zero(d.getSeconds());
+ var ts = make_timestamp();
c.innerHTML = "<li class=\"" + debug_last_class + "\"><span class=\"debugTS\">[" + ts + "]</span> " +
msg + "</li>" + c.innerHTML;
}
}
if (!form) {
- debug("filterDlgCheckType: can't find form!");
+ console.log("filterDlgCheckType: can't find form!");
return;
}
}
if (!form) {
- debug("filterDlgCheckAction: can't find form!");
+ console.log("filterDlgCheckAction: can't find form!");
return;
}
var action_param = $("filter_dlg_param_box");
if (!action_param) {
- debug("filterDlgCheckAction: can't find action param box!");
+ console.log("filterDlgCheckAction: can't find action param box!");
return;
}
}
if (!form) {
- debug("filterDlgCheckAction: can't find form!");
+ console.log("filterDlgCheckAction: can't find form!");
return;
}
if (!limit) limit = 3;
- debug("getRelativePostIds: " + id + " limit=" + limit);
+ console.log("getRelativePostIds: " + id + " limit=" + limit);
var ids = new Array();
var container = $("headlinesList");
function openArticleInNewWindow(id) {
try {
- debug("openArticleInNewWindow: " + id);
+ console.log("openArticleInNewWindow: " + id);
var query = "?op=rpc&subop=getArticleLink&id=" + id;
var wname = "ttrss_article_" + id;
- debug(query + " " + wname);
+ console.log(query + " " + wname);
var w = window.open("", wname);
var link = transport.responseXML.getElementsByTagName("link")[0];
var id = transport.responseXML.getElementsByTagName("id")[0];
- debug("open_article received link: " + link);
+ console.log("open_article received link: " + link);
if (link && id) {
var wname = "ttrss_article_" + id.firstChild.nodeValue;
- debug("link url: " + link.firstChild.nodeValue + ", wname " + wname);
+ console.log("link url: " + link.firstChild.nodeValue + ", wname " + wname);
var w = window.open(link.firstChild.nodeValue, wname);
try {
if (p < last_progress_point || !Element.visible("overlay")) return;
- debug("<b>loading_set_progress : " + p + " (" + last_progress_point + ")</b>");
+ console.log("<b>loading_set_progress : " + p + " (" + last_progress_point + ")</b>");
var o = $("l_progress_i");
function remove_splash() {
if (Element.visible("overlay")) {
- debug("about to remove splash, OMG!");
+ console.log("about to remove splash, OMG!");
Element.hide("overlay");
- debug("removed splash!");
+ console.log("removed splash!");
}
}
var ts = Math.round(date.getTime() / 1000);
if (hotkey_prefix_pressed && ts - hotkey_prefix_pressed >= 5) {
- debug("hotkey_prefix seems to be stuck, aborting");
+ console.log("hotkey_prefix seems to be stuck, aborting");
hotkey_prefix_pressed = false;
hotkey_prefix = false;
Element.hide('cmdline');
if (confirm(__("Remove stored feed icon?"))) {
var query = "backend.php?op=pref-feeds&subop=removeicon&feed_id=" + param_escape(id);
- debug(query);
+ console.log(query);
notify_progress("Removing feed icon...", true);
displayDlg('quickAddFilter', '',
function () {document.forms['filter_add_form'].reg_exp.focus();});
}
+
+function unsubscribeFeed(feed_id, title) {
+
+ var msg = __("Unsubscribe from %s?").replace("%s", title);
+
+ if (title == undefined || confirm(msg)) {
+ notify_progress("Removing feed...");
+
+ var query = "?op=pref-feeds&quiet=1&subop=remove&ids=" + feed_id;
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+
+ closeInfoBox();
+
+ if (inPreferences()) {
+ updateFeedList();
+ } else {
+ dlg_frefresh_callback(transport, feed_id);
+ }
+
+ } });
+ }
+
+ return false;
+}
+
+
+function backend_sanity_check_callback(transport) {
+
+ try {
+
+ if (sanity_check_done) {
+ fatalError(11, "Sanity check request received twice. This can indicate "+
+ "presence of Firebug or some other disrupting extension. "+
+ "Please disable it and try again.");
+ return;
+ }
+
+ if (!transport.responseXML) {
+ if (!store) {
+ fatalError(3, "Sanity check: Received reply is not XML",
+ transport.responseText);
+ return;
+ } else {
+ init_offline();
+ return;
+ }
+ }
+
+ if (getURLParam("offline")) {
+ return init_offline();
+ }
+
+ var reply = transport.responseXML.getElementsByTagName("error")[0];
+
+ if (!reply) {
+ fatalError(3, "Sanity check: invalid RPC reply", transport.responseText);
+ return;
+ }
+
+ var error_code = reply.getAttribute("error-code");
+
+ if (error_code && error_code != 0) {
+ return fatalError(error_code, reply.getAttribute("error-msg"));
+ }
+
+ console.log("sanity check ok");
+
+ var params = transport.responseXML.getElementsByTagName("init-params")[0];
+
+ if (params) {
+ console.log('reading init-params...');
+ var param = params.firstChild;
+
+ while (param) {
+ var k = param.getAttribute("key");
+ var v = param.getAttribute("value");
+ console.log(k + " => " + v);
+ init_params[k] = v;
+
+ if (db) {
+ db.execute("DELETE FROM init_params WHERE key = ?", [k]);
+ db.execute("INSERT INTO init_params (key,value) VALUES (?, ?)",
+ [k, v]);
+ }
+
+ param = param.nextSibling;
+ }
+ }
+
+ sanity_check_done = true;
+
+ init_second_stage();
+
+ } catch (e) {
+ exception_error("backend_sanity_check_callback", e, transport);
+ }
+}
+
+