var last_article_view = false;
var active_real_feed_id = false;
-// FIXME: kludges, needs proper implementation
-var _reload_feedlist_after_view = false;
-
-var _cdm_wd_timeout = false;
-var _cdm_wd_vishist = new Array();
-
var article_cache = new Array();
var vgroup_last_feed = false;
var cache_added = [];
-function catchup_callback2(transport, callback) {
- try {
- console.log("catchup_callback2 " + transport + ", " + callback);
- notify("");
- handle_rpc_reply(transport);
- if (callback) {
- setTimeout(callback, 10);
- }
- } catch (e) {
- exception_error("catchup_callback2", e, transport);
- }
-}
-
function headlines_callback2(transport, feed_cur_page) {
try {
+ handle_rpc_json(transport);
- if (!handle_rpc_reply(transport)) return;
-
- loading_set_progress(100);
+ loading_set_progress(25);
console.log("headlines_callback2 [page=" + feed_cur_page + "]");
- if (!transport_error_check(transport)) return;
-
- clean_feed_selections();
-
var is_cat = false;
var feed_id = false;
}
}
- var ll = $('FLL-' + feed_id);
-
- if (ll && ll.parentNode)
- ll.parentNode.removeChild(ll);
-
- if (!is_cat) {
- var feedr = $("FEEDR-" + feed_id);
- if (feedr && !feedr.className.match("Selected")) {
- feedr.className = feedr.className + "Selected";
- }
- } else {
- var feedr = $("FCAT-" + feed_id);
- if (feedr && !feedr.className.match("Selected")) {
- feedr.className = feedr.className + "Selected";
- }
- }
-
- var img = $('FIMG-' + feed_id);
+ var update_btn = document.forms["main_toolbar_form"].update;
- if (img && !is_cat) {
- img.src = img.alt;
- }
+ update_btn.disabled = !(feed_id >= 0 && !is_cat);
- var f = $("headlines-frame");
try {
- if (feed_cur_page == 0) {
- //console.log("resetting headlines scrollTop");
- f.scrollTop = 0;
+ if (feed_cur_page == 0) {
+ $("headlines-frame").scrollTop = 0;
}
} catch (e) { };
-
+
if (transport.responseXML) {
var response = transport.responseXML;
var headlines = response.getElementsByTagName("headlines")[0];
+
+ var headlines_content = headlines.getElementsByTagName("content")[0];
+ var headlines_toolbar = headlines.getElementsByTagName("toolbar")[0];
+
var headlines_info = response.getElementsByTagName("headlines-info")[0];
if (headlines_info)
var headlines_count = headlines_info.count;
var headlines_unread = headlines_info.unread;
var disable_cache = headlines_info.disable_cache;
-
+
vgroup_last_feed = headlines_info.vgroup_last_feed;
- if (headlines_count == 0) {
+ if (parseInt(headlines_count) < getInitParam("default_article_limit")) {
_infscroll_disable = 1;
} else {
_infscroll_disable = 0;
var counters = response.getElementsByTagName("counters")[0];
var articles = response.getElementsByTagName("article");
var runtime_info = response.getElementsByTagName("runtime-info");
-
+
if (feed_cur_page == 0) {
if (headlines) {
- f.innerHTML = headlines.firstChild.nodeValue;
+ dijit.byId("headlines-frame").attr('content',
+ headlines_content.firstChild.nodeValue);
+
+ dijit.byId("headlines-toolbar").attr('content',
+ headlines_toolbar.firstChild.nodeValue);
+
+ initHeadlinesMenu();
- var cache_prefix = "";
+/* var cache_prefix = "";
if (is_cat) {
cache_prefix = "C:";
if (!disable_cache) {
cache_inject(cache_prefix + feed_id,
- headlines.firstChild.nodeValue, headlines_unread);
- }
+ $("headlines-frame").innerHTML, headlines_unread);
+ } */
} else {
console.warn("headlines_callback: returned no data");
- f.innerHTML = "<div class='whiteBox'>" + __('Could not update headlines (missing XML data)') + "</div>";
-
+ dijit.byId("headlines-frame").attr('content',
+ "<div class='whiteBox'>" +
+ __('Could not update headlines (missing XML data)') + "</div>");
+
}
} else {
if (headlines) {
if (headlines_count > 0) {
console.log("adding some more headlines...");
-
- var c = $("headlinesList");
-
- if (!c) {
- c = $("headlinesInnerContainer");
- }
+ var c = dijit.byId("headlines-frame");
var ids = getSelectedArticleIds2();
-
- c.innerHTML = c.innerHTML + headlines.firstChild.nodeValue;
+
+ //c.attr('content', c.attr('content') +
+ // headlines_content.firstChild.nodeValue);
+
+ $("headlines-tmp").innerHTML = headlines_content.firstChild.nodeValue;
+
+ $$("#headlines-tmp > div").each(function(row) {
+ c.domNode.appendChild(row);
+ });
console.log("restore selected ids: " + ids);
markHeadline(ids[i]);
}
+ initHeadlinesMenu();
+
} else {
console.log("no new headlines received");
}
} else {
console.warn("headlines_callback: returned no data");
- notify_error("Error while trying to load more headlines");
+ notify_error("Error while trying to load more headlines");
}
}
-
+
if (articles) {
for (var i = 0; i < articles.length; i++) {
var a_id = articles[i].getAttribute("id");
else
request_counters();
- if (runtime_info) {
- parse_runtime_info(runtime_info[0]);
- }
-
} else {
console.warn("headlines_callback: returned no XML object");
- f.innerHTML = "<div class='whiteBox'>" + __('Could not update headlines (missing XML object)') + "</div>";
- }
-
-
- if (_cdm_wd_timeout) window.clearTimeout(_cdm_wd_timeout);
-
- if (isCdmMode() &&
- getActiveFeedId() != -3 &&
- getInitParam("cdm_auto_catchup") == 1) {
- console.log("starting CDM watchdog");
- _cdm_wd_timeout = window.setTimeout("cdmWatchdog()", 5000);
- _cdm_wd_vishist = new Array();
- } else {
- console.log("not in CDM mode or watchdog disabled");
+ dijit.byId("headlines-frame").attr('content', "<div class='whiteBox'>" +
+ __('Could not update headlines (missing XML object)') + "</div>");
}
-
+
+
+
_feed_cur_page = feed_cur_page;
_infscroll_request_sent = 0;
notify("");
- remove_splash();
-
} catch (e) {
exception_error("headlines_callback2", e, transport);
}
function render_article(article) {
try {
- var f = $("content-frame");
+ dijit.byId("headlines-wrap-inner").addChild(
+ dijit.byId("content-insert"));
+
+ var c = dijit.byId("content-insert");
+
try {
- f.scrollTop = 0;
+ c.domNode.scrollTop = 0;
} catch (e) { };
- var fi = $("content-insert");
+ c.attr('content', article);
+
+ correctHeadlinesOffset(getActiveArticleId());
try {
- fi.scrollTop = 0;
+ c.focus();
} catch (e) { };
-
- fi.innerHTML = article;
-
-// article.evalScripts();
} catch (e) {
exception_error("render_article", e);
try {
- cleanSelected("headlinesList");
-
+ selectArticles("none");
+
var crow = $("RROW-" + id);
if (!crow) return;
- var article_is_unread = crow.className.match("Unread");
-
- crow.className = crow.className.replace("Unread", "");
+ var article_is_unread = crow.hasClassName("Unread");
+
+ crow.removeClassName("Unread");
selectArticles('none');
var upd_img_pic = $("FUPDPIC-" + id);
var cache_prefix = "";
-
+
if (activeFeedIsCat()) {
cache_prefix = "C:";
} else {
var view_mode = false;
try {
- view_mode = document.forms['main_toolbar_form'].view_mode;
+ view_mode = document.forms['main_toolbar_form'].view_mode;
view_mode = view_mode[view_mode.selectedIndex].value;
} catch (e) {
//
}
- if (upd_img_pic && (upd_img_pic.src.match("updated.png") ||
+ if (upd_img_pic && (upd_img_pic.src.match("updated.png") ||
upd_img_pic.src.match("fresh_sign.png"))) {
upd_img_pic.src = "images/blank_icon.gif";
cache_invalidate(cache_prefix + getActiveFeedId());
- cache_inject(cache_prefix + getActiveFeedId(),
+ /* cache_inject(cache_prefix + getActiveFeedId(),
$("headlines-frame").innerHTML,
- get_feed_unread(getActiveFeedId()));
+ getFeedUnread(getActiveFeedId())); */
} else if (article_is_unread && view_mode == "all_articles") {
cache_invalidate(cache_prefix + getActiveFeedId());
- cache_inject(cache_prefix + getActiveFeedId(),
+ /* cache_inject(cache_prefix + getActiveFeedId(),
$("headlines-frame").innerHTML,
- get_feed_unread(getActiveFeedId())-1);
+ getFeedUnread(getActiveFeedId())-1); */
} else if (article_is_unread) {
cache_invalidate(cache_prefix + getActiveFeedId());
try {
console.log("article_callback2 " + id);
- if (!handle_rpc_reply(transport)) return;
+ handle_rpc_json(transport);
- if (transport.responseXML) {
-
- if (!transport_error_check(transport)) return;
+ var reply = JSON.parse(transport.responseText);
-/* var ll = $('LL-' + id);
- var content = $('HLC-' + id);
-
- if (ll && content) content.removeChild(ll); */
-
+ if (reply) {
var upic = $('FUPDPIC-' + id);
- if (upic) {
- upic.src = 'images/blank_icon.gif';
- }
+ if (upic) upic.src = 'images/blank_icon.gif';
if (id != last_requested_article) {
console.log("requested article id is out of sequence, aborting");
return;
}
- active_post_id = id;
-
- //console.log("looking for articles to cache...");
-
- var articles = transport.responseXML.getElementsByTagName("article");
-
- for (var i = 0; i < articles.length; i++) {
- var a_id = articles[i].getAttribute("id");
-
- //console.log("found id: " + a_id);
-
- if (a_id == active_post_id) {
- //console.log("active article, rendering...");
- render_article(articles[i].firstChild.nodeValue);
+ reply.each(function(article) {
+ if (active_post_id == article['id']) {
+ render_article(article['content']);
}
+ cache_inject(article['id'], article['content']);
+ });
- cache_inject(a_id, articles[i].firstChild.nodeValue);
- }
-
-
- showArticleInHeadlines(id);
-
- if (db) {
- db.execute("UPDATE articles SET unread = 0 WHERE id = ?", [id]);
- }
-
- var reply = transport.responseXML.firstChild.firstChild;
-
} else {
- console.warn("article_callback: returned no XML object");
- //var f = $("content-frame");
- //f.innerHTML = "<div class='whiteBox'>" + __('Could not display article (missing XML object)') + "</div>";
+ console.warn("article_callback: returned invalid data");
+
+ render_article("<div class='whiteBox'>" +
+ __('Could not display article (invalid data received)') + "</div>");
}
var date = new Date();
last_article_view = date.getTime() / 1000;
- if (_reload_feedlist_after_view) {
- setTimeout('updateFeedList(false, false)', 50);
- _reload_feedlist_after_view = false;
- } else {
- request_counters();
- }
+ request_counters();
notify("");
} catch (e) {
try {
console.log("loading article: " + id);
- if (offline_mode) return view_offline(id);
-
var cached_article = cache_find(id);
console.log("cache check result: " + (cached_article != false));
-
- enableHotkeys();
+
hideAuxDlg();
var query = "?op=view&id=" + param_escape(id);
}
}
- console.log("additional ids: " + cids_to_request.toString());
-
- /* additional info for piggyback counters */
-
- if (tagsAreDisplayed()) {
- query = query + "&omode=lt";
- } else {
- query = query + "&omode=flc";
- }
+ console.log("additional ids: " + cids_to_request.toString());
query = query + "&cids=" + cids_to_request.toString();
var crow = $("RROW-" + id);
- var article_is_unread = crow.className.match("Unread");
+ var article_is_unread = crow.hasClassName("Unread");
+ active_post_id = id;
showArticleInHeadlines(id);
if (!cached_article) {
var upic = $('FUPDPIC-' + id);
- if (upic) {
+ if (upic) {
upic.src = getInitParam("sign_progress");
}
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- article_callback2(transport, id);
+ onComplete: function(transport) {
+ article_callback2(transport, id);
} });
return false;
return togglePub(id);
}
-function tMark_afh_off(effect) {
- try {
- var elem = effect.effects[0].element;
-
- //console.log("tMark_afh_off : " + elem.id);
-
- if (elem) {
- elem.src = elem.src.replace("mark_set", "mark_unset");
- elem.alt = __("Star article");
- Element.show(elem);
- }
-
- } catch (e) {
- exception_error("tMark_afh_off", e);
- }
-}
-
-function tPub_afh_off(effect) {
- try {
- var elem = effect.effects[0].element;
-
- //console.log("tPub_afh_off : " + elem.id);
-
- if (elem) {
- elem.src = elem.src.replace("pub_set", "pub_unset");
- elem.alt = __("Publish article");
- Element.show(elem);
- }
-
- } catch (e) {
- exception_error("tPub_afh_off", e);
- }
-}
-
-function toggleMark(id, client_only, no_effects) {
-
+function toggleMark(id, client_only) {
try {
-
var query = "?op=rpc&id=" + id + "&subop=mark";
-
- query = query + "&afid=" + getActiveFeedId();
-
- if (tagsAreDisplayed()) {
- query = query + "&omode=tl";
- } else {
- query = query + "&omode=flc";
- }
-
- var mark_img = $("FMPIC-" + id);
- if (!mark_img) return;
+ var img = $("FMPIC-" + id);
- var vfeedu = $("FEEDU--1");
- var crow = $("RROW-" + id);
-
- if (mark_img.src.match("mark_unset")) {
- mark_img.src = mark_img.src.replace("mark_unset", "mark_set");
- mark_img.alt = __("Unstar article");
- query = query + "&mark=1";
+ if (!img) return;
- if (db) {
- db.execute("UPDATE articles SET marked = 1 WHERE id = ?", [id]);
- }
+ if (img.src.match("mark_unset")) {
+ img.src = img.src.replace("mark_unset", "mark_set");
+ img.alt = __("Unstar article");
+ query = query + "&mark=1";
} else {
- mark_img.alt = __("Please wait...");
+ img.src = img.src.replace("mark_set", "mark_unset");
+ img.alt = __("Star article");
query = query + "&mark=0";
-
- if (!isCdmMode() && !no_effects) {
- Effect.Puff(mark_img, {duration : 0.25, afterFinish: tMark_afh_off});
- } else {
- mark_img.src = mark_img.src.replace("mark_set", "mark_unset");
- mark_img.alt = __("Star article");
- }
-
- if (db) {
- db.execute("UPDATE articles SET marked = 0 WHERE id = ?", [id]);
- }
-
}
- if (!no_effects) update_local_feedlist_counters();
-
if (!client_only) {
- //console.log(query);
-
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
-
}
} catch (e) {
}
function togglePub(id, client_only, no_effects, note) {
-
try {
-
var query = "?op=rpc&id=" + id + "&subop=publ";
-
- query = query + "&afid=" + getActiveFeedId();
if (note != undefined) {
query = query + "¬e=" + param_escape(note);
} else {
query = query + "¬e=undefined";
}
-
- if (tagsAreDisplayed()) {
- query = query + "&omode=tl";
- } else {
- query = query + "&omode=flc";
- }
-
- var mark_img = $("FPPIC-" + id);
- if (!mark_img) return;
+ var img = $("FPPIC-" + id);
- var vfeedu = $("FEEDU--2");
- var crow = $("RROW-" + id);
-
- if (mark_img.src.match("pub_unset") || note != undefined) {
- mark_img.src = mark_img.src.replace("pub_unset", "pub_set");
- mark_img.alt = __("Unpublish article");
+ if (!img) return;
+
+ if (img.src.match("pub_unset") || note != undefined) {
+ img.src = img.src.replace("pub_unset", "pub_set");
+ img.alt = __("Unpublish article");
query = query + "&pub=1";
} else {
- mark_img.alt = __("Please wait...");
+ img.src = img.src.replace("pub_set", "pub_unset");
+ img.alt = __("Publish article");
+
query = query + "&pub=0";
-
- if (!isCdmMode() && !no_effects) {
- Effect.Puff(mark_img, {duration : 0.25, afterFinish: tPub_afh_off});
- } else {
- mark_img.src = mark_img.src.replace("pub_set", "pub_unset");
- mark_img.alt = __("Publish article");
- }
}
if (!client_only) {
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
-
- var note = transport.responseXML.getElementsByTagName("note")[0];
-
- if (note) {
- var note_id = note.getAttribute("id");
- var note_size = note.getAttribute("size");
- var note_content = note.firstChild.nodeValue;
-
- var container = $('POSTNOTE-' + note_id);
-
- cache_invalidate(note_id);
-
- if (container) {
- if (note_size == "0") {
- Element.hide(container);
- } else {
- container.innerHTML = note_content;
- Element.show(container);
- }
- }
- }
-
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
}
}
}
-function correctHeadlinesOffset(id) {
-
- try {
-
- var hlist = $("headlinesList");
- var container = $("headlinesInnerContainer");
- var row = $("RROW-" + id);
-
- var viewport = container.offsetHeight;
-
- var rel_offset_top = row.offsetTop - container.scrollTop;
- var rel_offset_bottom = row.offsetTop + row.offsetHeight - container.scrollTop;
-
- console.log("Rtop: " + rel_offset_top + " Rbtm: " + rel_offset_bottom);
- console.log("Vport: " + viewport);
-
- if (rel_offset_top <= 0 || rel_offset_top > viewport) {
- container.scrollTop = row.offsetTop;
- } else if (rel_offset_bottom > viewport) {
-
- /* doesn't properly work with Opera in some cases because
- Opera fucks up element scrolling */
-
- container.scrollTop = row.offsetTop + row.offsetHeight - viewport;
- }
-
- } catch (e) {
- exception_error("correctHeadlinesOffset", e);
- }
-
-}
-
function moveToPost(mode) {
try {
var prev_id = false;
var next_id = false;
-
+
if (!$('RROW-' + active_post_id)) {
active_post_id = false;
}
-
+
if (active_post_id == false) {
next_id = getFirstVisibleHeadlineId();
prev_id = getLastVisibleHeadlineId();
- } else {
+ } else {
for (var i = 0; i < rows.length; i++) {
if (rows[i] == active_post_id) {
prev_id = rows[i-1];
- next_id = rows[i+1];
+ next_id = rows[i+1];
}
}
}
-
+
if (mode == "next") {
if (next_id) {
if (isCdmMode()) {
-
+
cdmExpandArticle(next_id);
cdmScrollToArticleId(next_id);
}
}
}
-
+
if (mode == "prev") {
if (prev_id) {
if (isCdmMode()) {
view(prev_id, getActiveFeedId());
}
}
- }
+ }
} catch (e) {
exception_error("moveToPost", e);
}
}
-function toggleSelected(id) {
+function toggleSelected(id, force_on) {
try {
-
- var cb = $("RCHK-" + id);
+ var cb = $("RCHK-" + id);
var row = $("RROW-" + id);
- if (row) {
- var nc = row.className;
-
- if (!nc.match("Selected")) {
- nc = nc + "Selected";
- if (cb) {
- cb.checked = true;
- }
- // In CDM basically last selected article == active article
- if (isCdmMode()) active_post_id = id;
+ if (row) {
+ if (row.hasClassName('Selected') && !force_on) {
+ row.removeClassName('Selected');
+ if (cb) cb.checked = false;
} else {
- nc = nc.replace("Selected", "");
- if (cb) {
- cb.checked = false;
- }
-
+ row.addClassName('Selected');
+ if (cb) cb.checked = true;
}
-
- row.className = nc;
}
} catch (e) {
exception_error("toggleSelected", e);
} catch (e) {
exception_error("toggleUnread_afh", e);
}
-}
+}
function toggleUnread(id, cmode, effect) {
try {
-
+
var row = $("RROW-" + id);
if (row) {
- var nc = row.className;
- var is_selected = row.className.match("Selected");
- nc = nc.replace("Unread", "");
- nc = nc.replace("Selected", "");
-
- // since we are removing selection from the object, uncheck
- // corresponding checkbox
-
- var cb = $("RCHK-" + id);
- if (cb) {
- cb.checked = false;
- }
-
- // NOTE: I'm not sure that resetting selection here is a feature -fox
-
if (cmode == undefined || cmode == 2) {
- if (row.className.match("Unread")) {
- row.className = nc;
+ if (row.hasClassName("Unread")) {
+ row.removeClassName("Unread");
if (effect) {
new Effect.Highlight(row, {duration: 1, startcolor: "#fff7d5",
afterFinish: toggleUnread_afh,
queue: { position:'end', scope: 'TMRQ-' + id, limit: 1 } } );
- }
+ }
} else {
- row.className = nc + "Unread";
- }
-
- if (db) {
- db.execute("UPDATE articles SET unread = not unread "+
- "WHERE id = ?", [id]);
+ row.addClassName("Unread");
}
} else if (cmode == 0) {
- row.className = nc;
+
+ row.removeClassName("Unread");
if (effect) {
new Effect.Highlight(row, {duration: 1, startcolor: "#fff7d5",
afterFinish: toggleUnread_afh,
queue: { position:'end', scope: 'TMRQ-' + id, limit: 1 } } );
- }
-
- if (db) {
- db.execute("UPDATE articles SET unread = 0 "+
- "WHERE id = ?", [id]);
}
} else if (cmode == 1) {
- row.className = nc + "Unread";
-
- if (db) {
- db.execute("UPDATE articles SET unread = 1 "+
- "WHERE id = ?", [id]);
- }
-
+ row.addClassName("Unread");
}
- update_local_feedlist_counters();
-
- // Disable unmarking as selected for the time being (16.05.08) -fox
- if (is_selected) row.className = row.className + "Selected";
-
if (cmode == undefined) cmode = 2;
var query = "?op=rpc&subop=catchupSelected" +
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
}
}
}
-function selectionRemoveLabel(id) {
+function selectionRemoveLabel(id, ids) {
try {
- var ids = getSelectedArticleIds2();
+ if (!ids) var ids = getSelectedArticleIds2();
if (ids.length == 0) {
alert(__("No articles are selected."));
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
show_labels_in_headlines(transport);
- handle_rpc_reply(transport);
} });
// }
}
}
-function selectionAssignLabel(id) {
+function selectionAssignLabel(id, ids) {
try {
- var ids = getSelectedArticleIds2();
+ if (!ids) ids = getSelectedArticleIds2();
if (ids.length == 0) {
alert(__("No articles are selected."));
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
show_labels_in_headlines(transport);
- handle_rpc_reply(transport);
} });
// }
}
}
-function selectionToggleUnread(set_state, callback_func, no_error) {
+function selectionToggleUnread(set_state, callback, no_error) {
try {
var rows = getSelectedArticleIds2();
for (i = 0; i < rows.length; i++) {
var row = $("RROW-" + rows[i]);
if (row) {
- var nc = row.className;
- nc = nc.replace("Unread", "");
- nc = nc.replace("Selected", "");
-
if (set_state == undefined) {
- if (row.className.match("Unread")) {
- row.className = nc + "Selected";
+ if (row.hasClassName("Unread")) {
+ row.removeClassName("Unread");
} else {
- row.className = nc + "UnreadSelected";
- }
- if (db) {
- db.execute("UPDATE articles SET unread = NOT unread WHERE id = ?",
- [rows[i]]);
+ row.addClassName("Unread");
}
}
if (set_state == false) {
- row.className = nc + "Selected";
- if (db) {
- db.execute("UPDATE articles SET unread = 0 WHERE id = ?",
- [rows[i]]);
- }
+ row.removeClassName("Unread");
}
if (set_state == true) {
- row.className = nc + "UnreadSelected";
- if (db) {
- db.execute("UPDATE articles SET unread = 1 WHERE id = ?",
- [rows[i]]);
- }
+ row.addClassName("Unread");
}
}
}
if (rows.length > 0) {
- update_local_feedlist_counters();
-
var cmode = "";
if (set_state == undefined) {
}
var query = "?op=rpc&subop=catchupSelected" +
- "&cmode=" + cmode + "&ids=" + param_escape(rows.toString());
+ "&cmode=" + cmode + "&ids=" + param_escape(rows.toString());
notify_progress("Loading, please wait...");
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- catchup_callback2(transport, callback_func);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
+ if (callback) callback(transport);
} });
}
function selectionToggleMarked() {
try {
-
+
var rows = getSelectedArticleIds2();
-
+
if (rows.length == 0) {
alert(__("No articles are selected."));
return;
toggleMark(rows[i], true, true);
}
- update_local_feedlist_counters();
-
if (rows.length > 0) {
var query = "?op=rpc&subop=markSelected&ids=" +
param_escape(rows.toString()) + "&cmode=2";
- query = query + "&afid=" + getActiveFeedId();
-
- query = query + "&omode=lc";
-
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
}
function selectionTogglePublished() {
try {
-
+
var rows = getSelectedArticleIds2();
if (rows.length == 0) {
var query = "?op=rpc&subop=publishSelected&ids=" +
param_escape(rows.toString()) + "&cmode=2";
- query = query + "&afid=" + getActiveFeedId();
-
- query = query + "&omode=lc";
-
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
}
}
function getSelectedArticleIds2() {
- var sel_articles = new Array();
- var children;
-
- if (isCdmMode())
- var children = $("headlinesInnerContainer").childNodes;
- else
- var children = $("headlinesList").rows;
+ var rv = [];
- for (i = 0; i < children.length; i++) {
- var child = children[i];
-
- if (child.id && child.id.match("RROW-") && child.className.match("Selected")) {
- var c_id = child.id.replace("RROW-", "");
- sel_articles.push(c_id);
- }
- }
+ $$("#headlines-frame > div[id*=RROW][class*=Selected]").each(
+ function(child) {
+ rv.push(child.id.replace("RROW-", ""));
+ });
- return sel_articles;
+ return rv;
}
function getLoadedArticleIds() {
- var sel_articles = new Array();
-
- if (isCdmMode())
- var children = $("headlinesInnerContainer").childNodes;
- else
- var children = $("headlinesList").rows;
+ var rv = [];
- if (!children) return sel_articles;
+ var children = $$("#headlines-frame > div[id*=RROW-]");
- for (i = 0; i < children.length; i++) {
- var child = children[i];
+ children.each(function(child) {
+ rv.push(child.id.replace("RROW-", ""));
+ });
- if (child.id && child.id.match("RROW-")) {
- var c_id = child.id.replace("RROW-", "");
- sel_articles.push(c_id);
- }
- }
+ return rv;
- return sel_articles;
}
// mode = all,none,unread,invert
function selectArticles(mode) {
try {
- var children;
-
- if (isCdmMode())
- var children = $("headlinesInnerContainer").childNodes;
- else
- var children = $("headlinesList").rows;
-
- for (i = 0; i < children.length; i++) {
- var child = children[i];
-
- if (child.id && child.id.match("RROW-")) {
- var aid = child.id.replace("RROW-", "");
-
- var cb = $("RCHK-" + aid);
-
- if (mode == "all") {
- if (!child.className.match("Selected")) {
- child.className = child.className + "Selected";
- cb.checked = true;
- }
- } else if (mode == "unread") {
- if (child.className.match("Unread") && !child.className.match("Selected")) {
- child.className = child.className + "Selected";
- cb.checked = true;
- }
- } else if (mode == "invert") {
- if (child.className.match("Selected")) {
- child.className = child.className.replace("Selected", "");
- cb.checked = false;
- } else {
- child.className = child.className + "Selected";
- cb.checked = true;
- }
+ var children = $$("#headlines-frame > div[id*=RROW]");
+ children.each(function(child) {
+ var id = child.id.replace("RROW-", "");
+ var cb = $("RCHK-" + id);
+
+ if (mode == "all") {
+ child.addClassName("Selected");
+ cb.checked = true;
+ } else if (mode == "unread") {
+ if (child.hasClassName("Unread")) {
+ child.addClassName("Selected");
+ cb.checked = true;
} else {
- child.className = child.className.replace("Selected", "");
+ child.removeClassName("Selected");
cb.checked = false;
}
- }
- }
+ } else if (mode == "invert") {
+ if (child.hasClassName("Selected")) {
+ child.removeClassName("Selected");
+ cb.checked = false;
+ } else {
+ child.addClassName("Selected");
+ cb.checked = true;
+ }
+
+ } else {
+ child.removeClassName("Selected");
+ cb.checked = false;
+ }
+ });
} catch (e) {
exception_error("selectArticles", e);
function catchupPage() {
var fn = getFeedName(getActiveFeedId(), activeFeedIsCat());
-
+
var str = __("Mark all visible articles in %s as read?");
str = str.replace("%s", fn);
function deleteSelection() {
try {
-
+
var rows = getSelectedArticleIds2();
if (rows.length == 0) {
alert(__("No articles are selected."));
return;
}
-
+
var fn = getFeedName(getActiveFeedId(), activeFeedIsCat());
var str;
var op;
-
+
if (getActiveFeedId() != 0) {
str = __("Delete %d selected articles in %s?");
} else {
str = __("Delete %d selected articles?");
}
-
+
str = str.replace("%d", rows.length);
str = str.replace("%s", fn);
-
+
if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str)) {
return;
}
new Ajax.Request("backend.php", {
parameters: query,
onComplete: function(transport) {
+ handle_rpc_json(transport);
viewCurrentFeed();
} });
alert(__("No articles are selected."));
return;
}
-
+
var fn = getFeedName(getActiveFeedId(), activeFeedIsCat());
var str;
var op;
-
+
if (getActiveFeedId() != 0) {
str = __("Archive %d selected articles in %s?");
op = "archive";
str = __("Move %d archived articles back?");
op = "unarchive";
}
-
+
str = str.replace("%d", rows.length);
str = str.replace("%s", fn);
-
+
if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str)) {
return;
}
new Ajax.Request("backend.php", {
parameters: query,
onComplete: function(transport) {
+ handle_rpc_json(transport);
viewCurrentFeed();
} });
alert(__("No articles are selected."));
return;
}
-
+
var fn = getFeedName(getActiveFeedId(), activeFeedIsCat());
-
+
var str = __("Mark %d selected articles in %s as read?");
-
+
str = str.replace("%d", rows.length);
str = str.replace("%s", fn);
-
+
if (getInitParam("confirm_feed_catchup") == 1 && !confirm(str)) {
return;
}
-
- if ($("headlinesList")) {
- selectionToggleUnread(false, 'viewCurrentFeed()', true);
- } else {
- selectionToggleUnread(false, 'viewCurrentFeed()', true)
- }
+
+ selectionToggleUnread(false, 'viewCurrentFeed()', true)
} catch (e) {
exception_error("catchupSelection", e);
}
}
-function editArticleTags(id, feed_id, cdm_enabled) {
- displayDlg('editArticleTags', id,
- function () {
- $("tags_str").focus();
+function editArticleTags(id) {
+ var query = "backend.php?op=dlg&id=editArticleTags¶m=" + param_escape(id);
- new Ajax.Autocompleter('tags_str', 'tags_choices',
- "backend.php?op=rpc&subop=completeTags",
- { tokens: ',', paramName: "search" });
- });
-}
+ if (dijit.byId("editTagsDlg"))
+ dijit.byId("editTagsDlg").destroyRecursive();
-function editTagsSave() {
+ dialog = new dijit.Dialog({
+ id: "editTagsDlg",
+ title: __("Edit article Tags"),
+ style: "width: 600px",
+ execute: function() {
+ if (this.validate()) {
+ var query = dojo.objectToQuery(this.attr('value'));
- notify_progress("Saving article tags...");
+ notify_progress("Saving article tags...", true);
- var form = document.forms["tag_edit_form"];
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ notify('');
+ dialog.hide();
- var query = Form.serialize("tag_edit_form");
+ var data = JSON.parse(transport.responseText);
- query = "?op=rpc&subop=setArticleTags&" + query;
+ if (data) {
+ var tags_str = data.tags_str;
+ var id = tags_str.id;
- //console.log(query);
+ var tags = $("ATSTR-" + id);
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- try {
- //console.log("tags saved...");
-
- closeInfoBox();
- notify("");
-
- if (tagsAreDisplayed()) {
- _reload_feedlist_after_view = true;
- }
-
- if (transport.responseXML) {
- var tags_str = transport.responseXML.getElementsByTagName("tags-str")[0];
-
- if (tags_str) {
- var id = tags_str.getAttribute("id");
-
- if (id) {
- var tags = $("ATSTR-" + id);
- if (tags) {
- tags.innerHTML = tags_str.firstChild.nodeValue;
- }
-
- cache_invalidate(id);
+ if (tags) {
+ tags.innerHTML = tags_str.content;
}
- }
- }
-
- } catch (e) {
- exception_error("editTagsSave", e);
- }
- } });
-}
-
-function editTagsInsert() {
- try {
- var form = document.forms["tag_edit_form"];
-
- var found_tags = form.found_tags;
- var tags_str = form.tags_str;
+ cache_invalidate(id);
+ }
- var tag = found_tags[found_tags.selectedIndex].value;
+ }});
+ }
+ },
+ href: query,
+ });
- if (tags_str.value.length > 0 &&
- tags_str.value.lastIndexOf(", ") != tags_str.value.length - 2) {
+ var tmph = dojo.connect(dialog, 'onLoad', function() {
+ dojo.disconnect(tmph);
- tags_str.value = tags_str.value + ", ";
- }
+ new Ajax.Autocompleter('tags_str', 'tags_choices',
+ "backend.php?op=rpc&subop=completeTags",
+ { tokens: ',', paramName: "search" });
+ });
- tags_str.value = tags_str.value + tag + ", ";
+ dialog.show();
- found_tags.selectedIndex = 0;
-
- } catch (e) {
- exception_error("editTagsInsert", e);
- }
}
function cdmScrollToArticleId(id) {
try {
- var ctr = $("headlinesInnerContainer");
+ var ctr = $("headlines-frame");
var e = $("RROW-" + id);
if (!e || !ctr) return;
}
}
-function cdmWatchdog() {
+function cache_inject(id, article, param) {
try {
+ if (!cache_check_param(id, param)) {
+ //console.log("cache_article: miss: " + id + " [p=" + param + "]");
- var ctr = $("headlinesInnerContainer");
-
- if (!ctr) return;
-
- var ids = new Array();
-
- var e = ctr.firstChild;
+ var date = new Date();
+ var ts = Math.round(date.getTime() / 1000);
- while (e) {
- if (e.className && e.className == "cdmArticleUnread" && e.id &&
- e.id.match("RROW-")) {
+ var cache_obj = {};
- // article fits in viewport OR article is longer than viewport and
- // its bottom is visible
+ cache_obj["id"] = id;
+ cache_obj["data"] = article;
+ cache_obj["param"] = param;
- if (ctr.scrollTop <= e.offsetTop && e.offsetTop + e.offsetHeight <=
- ctr.scrollTop + ctr.offsetHeight) {
+ if (param) id = id + ":" + param;
-// console.log(e.id + " is visible " + e.offsetTop + "." +
-// (e.offsetTop + e.offsetHeight) + " vs " + ctr.scrollTop + "." +
-// (ctr.scrollTop + ctr.offsetHeight));
+ cache_added["TS:" + id] = ts;
- ids.push(e.id.replace("RROW-", ""));
+ if (has_local_storage())
+ sessionStorage.setItem(id, JSON.stringify(cache_obj));
+ else
+ article_cache.push(cache_obj);
- } else if (e.offsetHeight > ctr.offsetHeight &&
- e.offsetTop + e.offsetHeight >= ctr.scrollTop &&
- e.offsetTop + e.offsetHeight <= ctr.scrollTop + ctr.offsetHeight) {
-
- ids.push(e.id.replace("RROW-", ""));
-
- }
-
- // method 2: article bottom is visible and is in upper 1/2 of the viewport
-
-/* if (e.offsetTop + e.offsetHeight >= ctr.scrollTop &&
- e.offsetTop + e.offsetHeight <= ctr.scrollTop + ctr.offsetHeight/2) {
-
- ids.push(e.id.replace("RROW-", ""));
-
- } */
-
- }
-
- e = e.nextSibling;
- }
-
- console.log("cdmWatchdog, ids= " + ids.toString());
-
- if (ids.length > 0) {
-
- for (var i = 0; i < ids.length; i++) {
- var e = $("RROW-" + ids[i]);
- if (e) {
- e.className = e.className.replace("Unread", "");
- }
- }
-
- var query = "?op=rpc&subop=catchupSelected" +
- "&cmode=0" + "&ids=" + param_escape(ids.toString());
-
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
- } });
-
- }
-
- _cdm_wd_timeout = window.setTimeout("cdmWatchdog()", 4000);
-
- } catch (e) {
- exception_error("cdmWatchdog", e);
- }
-
-}
-
-
-function cache_inject(id, article, param) {
-
- try {
- if (!cache_check_param(id, param)) {
- //console.log("cache_article: miss: " + id + " [p=" + param + "]");
-
- var date = new Date();
- var ts = Math.round(date.getTime() / 1000);
-
- if (db) {
-
- db.execute("INSERT INTO cache (id, article, param, added) VALUES (?, ?, ?, ?)",
- [id, article, param, ts]);
- } else {
-
- var cache_obj = {};
-
- cache_obj["id"] = id;
- cache_obj["data"] = article;
- cache_obj["param"] = param;
-
- if (param) id = id + ":" + param;
-
- cache_added["TS:" + id] = ts;
-
- if (has_local_storage())
- localStorage.setItem(id, JSON.stringify(cache_obj));
- else
- article_cache.push(cache_obj);
- }
-
} else {
//console.log("cache_article: hit: " + id + " [p=" + param + "]");
}
- } catch (e) {
+ } catch (e) {
exception_error("cache_inject", e);
}
}
function cache_find(id) {
- if (db) {
- var rs = db.execute("SELECT article FROM cache WHERE id = ?", [id]);
- var a = false;
+ if (has_local_storage()) {
+ var cache_obj = sessionStorage.getItem(id);
- if (rs.isValidRow()) {
- var a = rs.field(0);
- }
+ if (cache_obj) {
+ cache_obj = JSON.parse(cache_obj);
- rs.close();
-
- return a;
+ if (cache_obj)
+ return cache_obj['data'];
+ }
} else {
-
- if (has_local_storage()) {
- var cache_obj = localStorage.getItem(id);
-
- if (cache_obj) {
- cache_obj = JSON.parse(cache_obj);
-
- if (cache_obj)
- return cache_obj['data'];
- }
-
- } else {
- for (var i = 0; i < article_cache.length; i++) {
- if (article_cache[i]["id"] == id) {
- return article_cache[i]["data"];
- }
+ for (var i = 0; i < article_cache.length; i++) {
+ if (article_cache[i]["id"] == id) {
+ return article_cache[i]["data"];
}
}
}
function cache_find_param(id, param) {
- if (db) {
- var rs = db.execute("SELECT article FROM cache WHERE id = ? AND param = ?",
- [id, param]);
- var a = false;
-
- if (rs.isValidRow()) {
- a = rs.field(0);
- }
-
- rs.close();
+ if (has_local_storage()) {
- return a;
+ if (param) id = id + ":" + param;
- } else {
-
- if (has_local_storage()) {
+ var cache_obj = sessionStorage.getItem(id);
- if (param) id = id + ":" + param;
+ if (cache_obj) {
+ cache_obj = JSON.parse(cache_obj);
- var cache_obj = localStorage.getItem(id);
-
- if (cache_obj) {
- cache_obj = JSON.parse(cache_obj);
-
- if (cache_obj)
- return cache_obj['data'];
- }
+ if (cache_obj)
+ return cache_obj['data'];
+ }
- } else {
- for (var i = 0; i < article_cache.length; i++) {
- if (article_cache[i]["id"] == id && article_cache[i]["param"] == param) {
- return article_cache[i]["data"];
- }
+ } else {
+ for (var i = 0; i < article_cache.length; i++) {
+ if (article_cache[i]["id"] == id && article_cache[i]["param"] == param) {
+ return article_cache[i]["data"];
}
}
}
+
return false;
}
function cache_check(id) {
-
- if (db) {
- var rs = db.execute("SELECT COUNT(*) AS c FROM cache WHERE id = ?",
- [id]);
- var a = false;
-
- if (rs.isValidRow()) {
- a = rs.field(0) != "0";
- }
-
- rs.close();
-
- return a;
-
+ if (has_local_storage()) {
+ if (sessionStorage.getItem(id))
+ return true;
} else {
- if (has_local_storage()) {
- if (localStorage.getItem(id))
+ for (var i = 0; i < article_cache.length; i++) {
+ if (article_cache[i]["id"] == id) {
return true;
- } else {
- for (var i = 0; i < article_cache.length; i++) {
- if (article_cache[i]["id"] == id) {
- return true;
- }
}
}
}
}
function cache_check_param(id, param) {
+ if (has_local_storage()) {
- if (db) {
- var rs = db.execute("SELECT COUNT(*) AS c FROM cache WHERE id = ? AND param = ?",
- [id, param]);
- var a = false;
+ if (param) id = id + ":" + param;
- if (rs.isValidRow()) {
- a = rs.field(0) != "0";
- }
-
- rs.close();
-
- return a;
+ if (sessionStorage.getItem(id))
+ return true;
} else {
-
- if (has_local_storage()) {
-
- if (param) id = id + ":" + param;
-
- if (localStorage.getItem(id))
+ for (var i = 0; i < article_cache.length; i++) {
+ if (article_cache[i]["id"] == id && article_cache[i]["param"] == param) {
return true;
-
- } else {
- for (var i = 0; i < article_cache.length; i++) {
- if (article_cache[i]["id"] == id && article_cache[i]["param"] == param) {
- return true;
- }
}
}
}
}
function cache_expire() {
- if (db) {
- var date = new Date();
- var ts = Math.round(date.getTime() / 1000);
-
- db.execute("DELETE FROM cache WHERE added < ? - 1800 AND id LIKE 'FEEDLIST'", [ts]);
- db.execute("DELETE FROM cache WHERE added < ? - 600 AND (id LIKE 'F:%' OR id LIKE 'C:%')", [ts]);
- db.execute("DELETE FROM cache WHERE added < ? - 86400", [ts]);
+if (has_local_storage()) {
+ var date = new Date();
+ var timestamp = Math.round(date.getTime() / 1000);
- } else {
- if (has_local_storage()) {
-
- var date = new Date();
- var timestamp = Math.round(date.getTime() / 1000);
-
- for (var i = 0; i < localStorage.length; i++) {
+ for (var i = 0; i < sessionStorage.length; i++) {
- var id = localStorage.key(i);
+ var id = sessionStorage.key(i);
- if (timestamp - cache_added["TS:" + id] > 180) {
- localStorage.removeItem(id);
- }
+ if (timestamp - cache_added["TS:" + id] > 180) {
+ sessionStorage.removeItem(id);
}
+ }
- } else {
- while (article_cache.length > 25) {
- article_cache.shift();
- }
+ } else {
+ while (article_cache.length > 25) {
+ article_cache.shift();
}
}
}
function cache_flush() {
- if (db) {
- db.execute("DELETE FROM cache");
- } else if (has_local_storage()) {
- localStorage.clear();
+ if (has_local_storage()) {
+ sessionStorage.clear();
} else {
article_cache = new Array();
}
}
function cache_invalidate(id) {
- try {
-
- if (db) {
- rs = db.execute("DELETE FROM cache WHERE id = ?", [id]);
- return rs.rowsAffected != 0;
- } else {
-
- if (has_local_storage()) {
+ try {
+ if (has_local_storage()) {
- var found = false;
+ var found = false;
- for (var i = 0; i < localStorage.length; i++) {
- var key = localStorage.key(i);
+ for (var i = 0; i < sessionStorage.length; i++) {
+ var key = sessionStorage.key(i);
// console.warn("cache_invalidate: " + key_id + " cmp " + id);
- if (key == id || key.indexOf(id + ":") == 0) {
- localStorage.removeItem(key);
- found = true;
- break;
- }
+ if (key == id || key.indexOf(id + ":") == 0) {
+ sessionStorage.removeItem(key);
+ found = true;
+ break;
}
+ }
- return found;
+ return found;
- } else {
- var i = 0
+ } else {
+ var i = 0
- while (i < article_cache.length) {
- if (article_cache[i]["id"] == id) {
- //console.log("cache_invalidate: removed id " + id);
- article_cache.splice(i, 1);
- return true;
- }
- i++;
+ while (i < article_cache.length) {
+ if (article_cache[i]["id"] == id) {
+ //console.log("cache_invalidate: removed id " + id);
+ article_cache.splice(i, 1);
+ return true;
}
+ i++;
}
}
function preloadBatchedArticles() {
try {
- var query = "?op=rpc&subop=getArticles&ids=" +
+ var query = "?op=rpc&subop=getArticles&ids=" +
preload_id_batch.toString();
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
+ onComplete: function(transport) {
preload_id_batch = [];
- var articles = transport.responseXML.getElementsByTagName("article");
+ var articles = JSON.parse(transport.responseText);
for (var i = 0; i < articles.length; i++) {
- var id = articles[i].getAttribute("id");
+ var id = articles[i]['id'];
if (!cache_check(id)) {
- cache_inject(id, articles[i].firstChild.nodeValue);
+ cache_inject(id, articles[i]['content']);
console.log("preloaded article: " + id);
}
}
- } });
+ } });
} catch (e) {
exception_error("preloadBatchedArticles", e);
}
}
-function headlines_scroll_handler() {
+function headlines_scroll_handler(e) {
try {
- var e = $("headlinesInnerContainer");
-
- var toolbar_form = document.forms["main_toolbar_form"];
-
-// console.log((e.scrollTop + e.offsetHeight) + " vs " + e.scrollHeight + " dis? " +
-// _infscroll_disable);
-
if (e.scrollTop + e.offsetHeight > e.scrollHeight - 100) {
if (!_infscroll_disable) {
viewNextFeedPage();
}
}
+
+ if (getInitParam("cdm_auto_catchup") == 1) {
+
+ var ids = [];
+
+ $$("#headlines-frame > div[id*=RROW][class*=Unread]").each(
+ function(child) {
+ if ($("headlines-frame").scrollTop >
+ (child.offsetTop + child.offsetHeight)) {
+
+ ids.push(child.id.replace("RROW-", ""));
+ }
+ });
+
+ if (ids.length > 0) {
+
+ var query = "?op=rpc&subop=catchupSelected" +
+ "&cmode=0&ids=" + param_escape(ids.toString());
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
+
+ ids.each(function(id) {
+ var elem = $("RROW-" + id);
+ if (elem) elem.removeClassName("Unread");
+ });
+ } });
+ }
+ }
} catch (e) {
exception_error("headlines_scroll_handler", e);
}
if (visible_ids[i] != getActiveArticleId()) {
var e = $("RROW-" + visible_ids[i]);
- if (e && e.className.match("Unread")) {
+ if (e && e.hasClassName("Unread")) {
ids_to_mark.push(visible_ids[i]);
}
} else {
if (visible_ids[i] != getActiveArticleId()) {
var e = $("RROW-" + visible_ids[i]);
- if (e && e.className.match("Unread")) {
+ if (e && e.hasClassName("Unread")) {
ids_to_mark.push(visible_ids[i]);
}
} else {
for (var i = 0; i < ids_to_mark.length; i++) {
var e = $("RROW-" + ids_to_mark[i]);
- e.className = e.className.replace("Unread", "");
+ e.removeClassName("Unread");
}
var query = "?op=rpc&subop=catchupSelected" +
- "&cmode=0" + "&ids=" + param_escape(ids_to_mark.toString());
+ "&cmode=0" + "&ids=" + param_escape(ids_to_mark.toString());
new Ajax.Request("backend.php", {
parameters: query,
- onComplete: function(transport) {
- catchup_callback2(transport);
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
} });
}
var elem = $("CICD-" + active_post_id);
+ var upd_img_pic = $("FUPDPIC-" + id);
+
+ if (upd_img_pic && (upd_img_pic.src.match("updated.png") ||
+ upd_img_pic.src.match("fresh_sign.png"))) {
+
+ upd_img_pic.src = "images/blank_icon.gif";
+ }
+
if (id == active_post_id && Element.visible(elem))
return true;
if (!Element.visible(elem)) {
Element.show(elem);
Element.hide("CEXC-" + id);
+
+ if ($("CWRAP-" + id).innerHTML == "") {
+
+ $("FUPDPIC-" + id).src = "images/indicator_tiny.gif";
+
+ $("CWRAP-" + id).innerHTML = "<div class=\"insensitive\">" +
+ __("Loading, please wait...") + "</div>";
+
+ var query = "?op=rpc&subop=cdmGetArticle&id=" + param_escape(id);
+
+ //console.log(query);
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ $("FUPDPIC-" + id).src = 'images/blank_icon.gif';
+
+ handle_rpc_json(transport);
+
+ var reply = JSON.parse(transport.responseText);
+
+ if (reply) {
+ var article = reply['article']['content'];
+ var recv_id = reply['article']['id'];
+
+ if (recv_id == id)
+ $("CWRAP-" + id).innerHTML = article;
+
+ } else {
+ $("CWRAP-" + id).innerHTML = __("Unable to load article.");
+
+ }
+ }});
+
+ }
}
var new_offset = $("RROW-" + id).offsetTop;
- $("headlinesInnerContainer").scrollTop += (new_offset-old_offset);
+ $("headlines-frame").scrollTop += (new_offset-old_offset);
- if ($("RROW-" + id).offsetTop != old_offset)
- $("headlinesInnerContainer").scrollTop = new_offset;
+ if ($("RROW-" + id).offsetTop != old_offset)
+ $("headlines-frame").scrollTop = new_offset;
toggleUnread(id, 0, true);
toggleSelected(id);
if (e) {
if (i % 2 == 0) {
- e.className = e.className.replace("even", "odd");
+ e.removeClassName("even");
+ e.addClassName("odd");
} else {
- e.className = e.className.replace("odd", "even");
+ e.removeClassName("odd");
+ e.addClassName("even");
}
}
}
}
}
-function invertHeadlineSelection() {
+function getArticleUnderPointer() {
+ return post_under_pointer;
+}
+
+function zoomToArticle(event, id) {
try {
- var rows = new Array();
- var r = false;
-
- if (!isCdmMode()) {
- r = document.getElementsByTagName("TR");
+ var cached_article = cache_find(id);
+
+ if (dijit.byId("ATAB-" + id))
+ if (!event || !event.shiftKey)
+ return dijit.byId("content-tabs").selectChild(dijit.byId("ATAB-" + id));
+
+ if (cached_article) {
+ //closeArticlePanel();
+
+ var article_pane = new dijit.layout.ContentPane({
+ title: __("Loading...") , content: cached_article,
+ style: 'padding : 0px;',
+ id: 'ATAB-' + id,
+ closable: true });
+
+ dijit.byId("content-tabs").addChild(article_pane);
+
+ if (!event || !event.shiftKey)
+ dijit.byId("content-tabs").selectChild(article_pane);
+
+ if ($("PTITLE-" + id))
+ article_pane.attr('title', $("PTITLE-" + id).innerHTML);
+
} else {
- r = document.getElementsByTagName("DIV");
- }
- for (var i = 0; i < r.length; i++) {
- if (r[i].id && r[i].id.match("RROW-")) {
- rows.push(r[i]);
- }
- }
-
- for (var i = 0; i < rows.length; i++) {
- var nc = rows[i].className;
- var id = rows[i].id.replace("RROW-", "");
- var cb = $("RCHK-" + id);
+ var query = "?op=rpc&subop=getArticles&ids=" + param_escape(id);
- if (!rows[i].className.match("Selected")) {
- nc = nc + "Selected";
- cb.checked = true;
- } else {
- nc = nc.replace("Selected", "");
- cb.checked = false;
- }
+ notify_progress("Loading, please wait...", true);
- rows[i].className = nc;
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ notify('');
- }
+ if (transport.responseXML) {
+ //closeArticlePanel();
- } catch (e) {
- exception_error("invertHeadlineSelection", e);
- }
-}
+ var article = transport.responseXML.getElementsByTagName("article")[0];
+ var content = article.firstChild.nodeValue;
-function getArticleUnderPointer() {
- return post_under_pointer;
-}
+ var article_pane = new dijit.layout.ContentPane({
+ title: "article-" + id , content: content,
+ style: 'padding : 0px;',
+ id: 'ATAB-' + id,
+ closable: true });
-function zoomToArticle(id) {
- try {
- var w = window.open("backend.php?op=view&mode=zoom&id=" + param_escape(id),
- "ttrss_zoom_" + id,
- "status=0,toolbar=0,location=0,width=450,height=300,scrollbars=1,menubar=0");
+ dijit.byId("content-tabs").addChild(article_pane);
+
+ if (!event || !event.shiftKey)
+ dijit.byId("content-tabs").selectChild(article_pane);
+
+ if ($("PTITLE-" + id))
+ article_pane.attr('title', $("PTITLE-" + id).innerHTML);
+ }
+
+ } });
+ }
} catch (e) {
exception_error("zoomToArticle", e);
ci.scrollTop += offset;
}
} else {
- var hi = $("headlinesInnerContainer");
+ var hi = $("headlines-frame");
if (hi) {
hi.scrollTop += offset;
}
function show_labels_in_headlines(transport) {
try {
- if (transport.responseXML) {
- var info = transport.responseXML.getElementsByTagName("info-for-headlines")[0];
-
- var elems = info.getElementsByTagName("entry");
+ var data = JSON.parse(transport.responseText);
- for (var l = 0; l < elems.length; l++) {
- var e_id = elems[l].getAttribute("id");
-
- if (e_id) {
-
- var ctr = $("HLLCTR-" + e_id);
-
- if (ctr) {
- ctr.innerHTML = elems[l].firstChild.nodeValue;
- }
- }
-
- }
+ if (data) {
+ data['info-for-headlines'].each(function(elem) {
+ var ctr = $("HLLCTR-" + elem.id);
+ if (ctr) ctr.innerHTML = elem.labels;
+ });
}
} catch (e) {
exception_error("show_labels_in_headlines", e);
-
}
}
}
}
-function publishWithNote(id, def_note) {
+/* function publishWithNote(id, def_note) {
try {
if (!def_note) def_note = '';
} catch (e) {
exception_error("publishWithNote", e);
}
-}
+} */
function emailArticle(id) {
try {
id = ids.toString();
}
- displayDlg('emailArticle', id,
- function () {
- document.forms['article_email_form'].destination.focus();
+ if (dijit.byId("emailArticleDlg"))
+ dijit.byId("emailArticleDlg").destroyRecursive();
- new Ajax.Autocompleter('destination', 'destination_choices',
- "backend.php?op=rpc&subop=completeEmails",
- { tokens: '', paramName: "search" });
+ var query = "backend.php?op=dlg&id=emailArticle¶m=" + param_escape(id);
- });
+ dialog = new dijit.Dialog({
+ id: "emailArticleDlg",
+ title: __("Forward article by email"),
+ style: "width: 600px",
+ execute: function() {
+ if (this.validate()) {
- } catch (e) {
- exception_error("emailArticle", e);
- }
-}
+ new Ajax.Request("backend.php", {
+ parameters: dojo.objectToQuery(this.attr('value')),
+ onComplete: function(transport) {
-function emailArticleDo() {
- try {
- var f = document.forms['article_email_form'];
+ var reply = JSON.parse(transport.responseText);
- if (f.destination.value == "") {
- alert("Please fill in the destination email.");
- return;
- }
+ var error = reply['error'];
- if (f.subject.value == "") {
- alert("Please fill in the subject.");
- return;
- }
+ if (error) {
+ alert(__('Error sending email:') + ' ' + error);
+ } else {
+ notify_info('Your message has been sent.');
+ dialog.hide();
+ }
- var query = Form.serialize("article_email_form");
+ } });
+ }
+ },
+ href: query});
-// console.log(query);
+ var tmph = dojo.connect(dialog, 'onLoad', function() {
+ dojo.disconnect(tmph);
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- try {
+ new Ajax.Autocompleter('emailArticleDlg_destination', 'emailArticleDlg_dst_choices',
+ "backend.php?op=rpc&subop=completeEmails",
+ { tokens: '', paramName: "search" });
+ });
- var error = transport.responseXML.getElementsByTagName('error')[0];
+ dialog.show();
- if (error) {
- alert(__('Error sending email:') + ' ' + error.firstChild.nodeValue);
- } else {
- notify_info('Your message has been sent.');
- closeInfoBox();
- }
+ /* displayDlg('emailArticle', id,
+ function () {
+ document.forms['article_email_form'].destination.focus();
- } catch (e) {
- exception_error("sendEmailDo", e);
- }
+ new Ajax.Autocompleter('destination', 'destination_choices',
+ "backend.php?op=rpc&subop=completeEmails",
+ { tokens: '', paramName: "search" });
- } });
+ }); */
} catch (e) {
- exception_error("emailArticleDo", e);
+ exception_error("emailArticle", e);
}
}
new Effect.Fade(elem, {duration : 0.5});
+ active_post_id = false;
+
} catch (e) {
exception_error("dismissArticle", e);
}
for (var i = 0; i < ids.length; i++) {
var elem = $("RROW-" + ids[i]);
- if (elem.className && elem.className.match("Selected")) {
+ if (elem.className && elem.hasClassName("Selected") &&
+ ids[i] != active_post_id) {
new Effect.Fade(elem, {duration : 0.5});
sel.push(ids[i]);
} else {
for (var i = 0; i < ids.length; i++) {
var elem = $("RROW-" + ids[i]);
- if (elem.className && !elem.className.match("Unread") &&
- !elem.className.match("Selected")) {
-
+ if (elem.className && !elem.hasClassName("Unread") &&
+ !elem.hasClassName("Selected")) {
+
new Effect.Fade(elem, {duration : 0.5});
} else {
tmp.push(ids[i]);
var ids = [];
try {
- var tmp = getLoadedArticleIds();
- for (var i = 0; i < tmp.length; i++) {
- var elem = $("RROW-" + tmp[i]);
+ getLoadedArticleIds().each(function(id) {
+ var elem = $("RROW-" + id);
if (elem && Element.visible(elem))
- ids.push(tmp[i]);
- }
+ ids.push(id);
+ });
} catch (e) {
exception_error("getVisibleArticleIds", e);
hideAuxDlg();
if (!event.ctrlKey) {
- selectArticles("none");
- toggleSelected(id);
- var elem = $("RROW-" + id);
+ if (!getInitParam("cdm_expanded")) {
+ return cdmExpandArticle(id);
+ } else {
- if (elem)
- elem.className = elem.className.replace("Unread", "");
+ selectArticles("none");
+ toggleSelected(id);
- var query = "?op=rpc&subop=catchupSelected" +
- "&cmode=0&ids=" + param_escape(id);
+ var elem = $("RROW-" + id);
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
- handle_rpc_reply(transport);
- } });
+ if (elem)
+ elem.removeClassName("Unread");
+
+ var upd_img_pic = $("FUPDPIC-" + id);
+
+ if (upd_img_pic && (upd_img_pic.src.match("updated.png") ||
+ upd_img_pic.src.match("fresh_sign.png"))) {
+
+ upd_img_pic.src = "images/blank_icon.gif";
+ }
+
+ active_post_id = id;
+
+ var query = "?op=rpc&subop=catchupSelected" +
+ "&cmode=0&ids=" + param_escape(id);
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ handle_rpc_json(transport);
+ } });
+
+ return true;
+ }
- return true;
} else {
- toggleSelected(id);
+ toggleSelected(id, true);
+ toggleUnread(id, 0, false);
+ zoomToArticle(event, id);
}
} catch (e) {
return false;
}
-function hlClicked(event, id) {
+function postClicked(event, id) {
try {
- var shift_key = event.shiftKey;
if (!event.ctrlKey) {
+ return true;
+ } else {
+ postOpenInNewTab(event, id);
+ return false;
+ }
+
+ } catch (e) {
+ exception_error("postClicked");
+ }
+}
+
+function hlOpenInNewTab(event, id) {
+ toggleUnread(id, 0, false);
+ zoomToArticle(event, id);
+}
+
+function postOpenInNewTab(event, id) {
+ closeArticlePanel(id);
+ zoomToArticle(event, id);
+}
+
+function hlClicked(event, id) {
+ try {
+ if (event.altKey) {
+ openArticleInNewWindow(id);
+ } else if (!event.ctrlKey) {
view(id);
return true;
} else {
toggleSelected(id);
+ toggleUnread(id, 0, false);
+ zoomToArticle(event, id);
return false;
}
} catch (e) {
exception_error("hlClicked");
}
-
- return false;
}
function getFirstVisibleHeadlineId() {
var rows = getVisibleArticleIds();
return rows[0];
-
+
}
function getLastVisibleHeadlineId() {
return rows[rows.length-1];
}
-// this only searches loaded headlines list, not in CDM
-function getRelativePostIds(id, limit) {
+function openArticleInNewWindow(id) {
+ toggleUnread(id, 0, false);
+ window.open("backend.php?op=la&id=" + id);
+}
- if (!limit) limit = 3;
+function isCdmMode() {
+ return getInitParam("combined_display_mode");
+}
- //console.log("getRelativePostIds: " + id + " limit=" + limit);
+function markHeadline(id) {
+ var row = $("RROW-" + id);
+ if (row) {
+ var check = $("RCHK-" + id);
- var ids = new Array();
- var container = $("headlinesList");
+ if (check) {
+ check.checked = true;
+ }
- if (container) {
- var rows = container.rows;
+ row.addClassName("Selected");
+ }
+}
- for (var i = 0; i < rows.length; i++) {
- var r_id = rows[i].id.replace("RROW-", "");
+function getRelativePostIds(id, limit) {
- if (r_id == id) {
- for (var k = 1; k <= limit; k++) {
- var nid = false;
+ var tmp = [];
- if (i > k-1) var nid = rows[i-k].id.replace("RROW-", "");
- if (nid) ids.push(nid);
+ try {
- if (i < rows.length-k) nid = rows[i+k].id.replace("RROW-", "");
- if (nid) ids.push(nid);
- }
+ if (!limit) limit = 3;
- return ids;
+ var ids = getVisibleArticleIds();
+
+ for (var i = 0; i < ids.length; i++) {
+ if (ids[i] == id) {
+ for (var k = 1; k <= limit; k++) {
+ if (i > k-1) tmp.push(ids[i-k]);
+ if (i < ids.length-k) tmp.push(ids[i+k]);
+ }
+ break;
}
}
+
+ } catch (e) {
+ exception_error("getRelativePostIds", e);
}
- return false;
+ return tmp;
}
-function openArticleInNewWindow(id) {
+function correctHeadlinesOffset(id) {
+
try {
- console.log("openArticleInNewWindow: " + id);
- var query = "?op=rpc&subop=getArticleLink&id=" + id;
- var wname = "ttrss_article_" + id;
+ var container = $("headlines-frame");
+ var row = $("RROW-" + id);
- console.log(query + " " + wname);
+ var viewport = container.offsetHeight;
- var w = window.open("", wname);
+ var rel_offset_top = row.offsetTop - container.scrollTop;
+ var rel_offset_bottom = row.offsetTop + row.offsetHeight - container.scrollTop;
- if (!w) notify_error("Failed to open window for the article");
+ //console.log("Rtop: " + rel_offset_top + " Rbtm: " + rel_offset_bottom);
+ //console.log("Vport: " + viewport);
- new Ajax.Request("backend.php", {
- parameters: query,
- onComplete: function(transport) {
-
- var link = transport.responseXML.getElementsByTagName("link")[0];
- var id = transport.responseXML.getElementsByTagName("id")[0];
-
- console.log("open_article received link: " + link);
-
- if (link && id) {
-
- var wname = "ttrss_article_" + id.firstChild.nodeValue;
-
- console.log("link url: " + link.firstChild.nodeValue + ", wname " + wname);
-
- var w = window.open(link.firstChild.nodeValue, wname);
-
- if (!w) { notify_error("Failed to load article in new window"); }
-
- if (id) {
- id = id.firstChild.nodeValue;
- if (!$("headlinesList")) {
- window.setTimeout("toggleUnread(" + id + ", 0)", 100);
- }
- }
- } else {
- notify_error("Can't open article: received invalid article link");
- }
- } });
+ if (rel_offset_top <= 0 || rel_offset_top > viewport) {
+ container.scrollTop = row.offsetTop;
+ } else if (rel_offset_bottom > viewport) {
+
+ /* doesn't properly work with Opera in some cases because
+ Opera fucks up element scrolling */
+
+ container.scrollTop = row.offsetTop + row.offsetHeight - viewport;
+ }
} catch (e) {
- exception_error("openArticleInNewWindow", e);
+ exception_error("correctHeadlinesOffset", e);
}
+
}
-function isCdmMode() {
- return !$("headlinesList");
+function headlineActionsChange(elem) {
+ try {
+ eval(elem.value);
+ elem.attr('value', 'false');
+ } catch (e) {
+ exception_error("headlineActionsChange", e);
+ }
}
-function markHeadline(id) {
- var row = $("RROW-" + id);
- if (row) {
- var is_active = false;
-
- if (row.className.match("Active")) {
- is_active = true;
- }
- row.className = row.className.replace("Selected", "");
- row.className = row.className.replace("Active", "");
- row.className = row.className.replace("Insensitive", "");
-
- if (is_active) {
- row.className = row.className = "Active";
- }
-
- var check = $("RCHK-" + id);
+function closeArticlePanel() {
- if (check) {
- check.checked = true;
+ var tabs = dijit.byId("content-tabs");
+ var child = tabs.selectedChildWidget;
+
+ if (child && tabs.getIndexOfChild(child) > 0) {
+ tabs.removeChild(child);
+ child.destroy();
+ } else {
+ if (dijit.byId("content-insert"))
+ dijit.byId("headlines-wrap-inner").removeChild(
+ dijit.byId("content-insert"));
+ }
+}
+
+function initHeadlinesMenu() {
+ try {
+ if (dijit.byId("headlinesMenu"))
+ dijit.byId("headlinesMenu").destroyRecursive();
+
+ var ids = [];
+
+ if (!isCdmMode()) {
+ nodes = $$("#headlines-frame > div[id*=RROW]");
+ } else {
+ nodes = $$("#headlines-frame span[id*=RTITLE]");
}
- row.className = row.className + "Selected";
-
+ nodes.each(function(node) {
+ ids.push(node.id);
+ });
+
+ var menu = new dijit.Menu({
+ id: "headlinesMenu",
+ targetNodeIds: ids,
+ });
+
+ var tmph = dojo.connect(menu, '_openMyself', function (event) {
+ var callerNode = event.target, match = null, tries = 0;
+
+ while (match == null && callerNode && tries <= 3) {
+ match = callerNode.id.match("^[A-Z]+[-]([0-9]+)$");
+ callerNode = callerNode.parentNode;
+ ++tries;
+ }
+
+ if (match) this.callerRowId = parseInt(match[1]);
+
+ });
+
+/* if (!isCdmMode())
+ menu.addChild(new dijit.MenuItem({
+ label: __("View article"),
+ onClick: function(event) {
+ view(this.getParent().callerRowId);
+ }})); */
+
+ menu.addChild(new dijit.MenuItem({
+ label: __("Open original article"),
+ onClick: function(event) {
+ openArticleInNewWindow(this.getParent().callerRowId);
+ }}));
+
+ menu.addChild(new dijit.MenuItem({
+ label: __("View in a tt-rss tab"),
+ onClick: function(event) {
+ hlOpenInNewTab(event, this.getParent().callerRowId);
+ }}));
+
+// menu.addChild(new dijit.MenuSeparator());
+
+ var labels = dijit.byId("feedTree").model.getItemsInCategory(-2);
+
+ if (labels) {
+
+ menu.addChild(new dijit.MenuSeparator());
+
+ var labelAddMenu = new dijit.Menu({ownerMenu: menu});
+ var labelDelMenu = new dijit.Menu({ownerMenu: menu});
+
+ labels.each(function(label) {
+ var id = label.id[0];
+ var bare_id = id.substr(id.indexOf(":")+1);
+ var name = label.name[0];
+
+ bare_id = -11-bare_id;
+
+ labelAddMenu.addChild(new dijit.MenuItem({
+ label: name,
+ labelId: bare_id,
+ onClick: function(event) {
+ selectionAssignLabel(this.labelId,
+ [this.getParent().ownerMenu.callerRowId]);
+ }}));
+
+ labelDelMenu.addChild(new dijit.MenuItem({
+ label: name,
+ labelId: bare_id,
+ onClick: function(event) {
+ selectionRemoveLabel(this.labelId,
+ [this.getParent().ownerMenu.callerRowId]);
+ }}));
+
+ });
+
+ menu.addChild(new dijit.PopupMenuItem({
+ label: __("Assign label"),
+ popup: labelAddMenu,
+ }));
+
+ menu.addChild(new dijit.PopupMenuItem({
+ label: __("Remove label"),
+ popup: labelDelMenu,
+ }));
+
+ }
+
+ menu.startup();
+
+ } catch (e) {
+ exception_error("initHeadlinesMenu", e);
+ }
+}
+
+function tweetArticle(id) {
+ try {
+ var query = "?op=rpc&subop=getTweetInfo&id=" + param_escape(id);
+
+ console.log(query);
+
+ var d = new Date();
+ var ts = d.getTime();
+
+ var w = window.open('backend.php?op=loading', 'ttrss_tweet',
+ "status=0,toolbar=0,location=0,width=500,height=400,scrollbars=1,menubar=0");
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ var ti = JSON.parse(transport.responseText);
+
+ var share_url = "http://twitter.com/share?_=" + ts +
+ "&text=" + param_escape(ti.title) +
+ "&url=" + param_escape(ti.link);
+
+ w.location.href = share_url;
+
+ } });
+
+
+ } catch (e) {
+ exception_error("tweetArticle", e);
+ }
+}
+
+function editArticleNote(id) {
+ try {
+
+ var query = "backend.php?op=dlg&id=editArticleNote¶m=" + param_escape(id);
+
+ if (dijit.byId("editNoteDlg"))
+ dijit.byId("editNoteDlg").destroyRecursive();
+
+ dialog = new dijit.Dialog({
+ id: "editNoteDlg",
+ title: __("Edit article note"),
+ style: "width: 600px",
+ execute: function() {
+ if (this.validate()) {
+ var query = dojo.objectToQuery(this.attr('value'));
+
+ notify_progress("Saving article note...", true);
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ notify('');
+ dialog.hide();
+
+ var reply = JSON.parse(transport.responseText);
+
+ cache_invalidate(id);
+
+ var elem = $("POSTNOTE-" + id);
+
+ if (elem) {
+ Element.hide(elem);
+ elem.innerHTML = reply.note;
+ new Effect.Appear(elem);
+ }
+
+ }});
+ }
+ },
+ href: query,
+ });
+
+ dialog.show();
+
+ } catch (e) {
+ exception_error("editArticleNote", e);
}
}
+function player(elem) {
+ var aid = elem.getAttribute("audio-id");
+ var status = elem.getAttribute("status");
+
+ var audio = $(aid);
+
+ if (audio) {
+ if (status == 0) {
+ audio.play();
+ status = 1;
+ elem.innerHTML = __("Playing...");
+ elem.title = __("Click to pause");
+ elem.addClassName("playing");
+ } else {
+ audio.pause();
+ status = 0;
+ elem.innerHTML = __("Play");
+ elem.title = __("Click to play");
+ elem.removeClassName("playing");
+ }
+
+ elem.setAttribute("status", status);
+ } else {
+ alert("Your browser doesn't seem to support HTML5 audio.");
+ }
+}