optimize counter responses in markSelected, etc

This commit is contained in:
Andrew Dolgov 2007-08-10 05:03:56 +01:00
parent c4d0e5351b
commit 2bc2147f2e
3 changed files with 87 additions and 50 deletions

View File

@ -1705,7 +1705,7 @@
} }
} }
function getAllCounters($link, $omode = "tflc") { function getAllCounters($link, $omode = "flc") {
/* getLabelCounters($link); /* getLabelCounters($link);
getFeedCounters($link); getFeedCounters($link);
getTagCounters($link); getTagCounters($link);
@ -1714,7 +1714,7 @@
getCategoryCounters($link); getCategoryCounters($link);
} */ } */
if (!$omode) $omode = "tflc"; if (!$omode) $omode = "flc";
getGlobalCounters($link); getGlobalCounters($link);

View File

@ -180,7 +180,7 @@
print "<rpc-reply>"; print "<rpc-reply>";
print "<counters>"; print "<counters>";
getAllCounters($link); getAllCounters($link, $_GET["omode"]);
print "</counters>"; print "</counters>";
print_runtime_info($link); print_runtime_info($link);
print "</rpc-reply>"; print "</rpc-reply>";
@ -195,7 +195,7 @@
print "<rpc-reply>"; print "<rpc-reply>";
print "<counters>"; print "<counters>";
getAllCounters($link); getAllCounters($link, $_GET["omode"]);
print "</counters>"; print "</counters>";
print_runtime_info($link); print_runtime_info($link);
print "</rpc-reply>"; print "</rpc-reply>";
@ -210,7 +210,7 @@
print "<rpc-reply>"; print "<rpc-reply>";
print "<counters>"; print "<counters>";
getAllCounters($link); getAllCounters($link, $_GET["omode"]);
print "</counters>"; print "</counters>";
print_runtime_info($link); print_runtime_info($link);
print "</rpc-reply>"; print "</rpc-reply>";

View File

@ -348,6 +348,14 @@ function toggleMark(id) {
var query = "backend.php?op=rpc&id=" + id + "&subop=mark"; var query = "backend.php?op=rpc&id=" + id + "&subop=mark";
query = query + "&afid=" + getActiveFeedId();
if (tagsAreDisplayed()) {
query = query + "&omode=tl";
} else {
query = query + "&omode=flc";
}
var mark_img = document.getElementById("FMPIC-" + id); var mark_img = document.getElementById("FMPIC-" + id);
var vfeedu = document.getElementById("FEEDU--1"); var vfeedu = document.getElementById("FEEDU--1");
var crow = document.getElementById("RROW-" + id); var crow = document.getElementById("RROW-" + id);
@ -395,56 +403,69 @@ function toggleMark(id) {
function togglePub(id) { function togglePub(id) {
if (!xmlhttp_ready(xmlhttp_rpc)) { try {
printLockingError();
return;
}
var query = "backend.php?op=rpc&id=" + id + "&subop=publ"; if (!xmlhttp_ready(xmlhttp_rpc)) {
printLockingError();
var mark_img = document.getElementById("FPPIC-" + id); return;
var vfeedu = document.getElementById("FEEDU--2");
var crow = document.getElementById("RROW-" + id);
if (mark_img.alt != "Unpublish") {
mark_img.src = "images/pub_set.png";
mark_img.alt = "Unpublish";
query = query + "&pub=1";
if (vfeedu && crow.className.match("Unread")) {
vfeedu.innerHTML = (+vfeedu.innerHTML) + 1;
} }
} else { var query = "backend.php?op=rpc&id=" + id + "&subop=publ";
mark_img.src = "images/pub_unset.png";
mark_img.alt = "Publish";
query = query + "&pub=0";
if (vfeedu && crow.className.match("Unread")) { query = query + "&afid=" + getActiveFeedId();
vfeedu.innerHTML = (+vfeedu.innerHTML) - 1;
}
} if (tagsAreDisplayed()) {
query = query + "&omode=tl";
var vfeedctr = document.getElementById("FEEDCTR--2");
var vfeedr = document.getElementById("FEEDR--2");
if (vfeedu && vfeedctr) {
if ((+vfeedu.innerHTML) > 0) {
if (crow.className.match("Unread") && !vfeedr.className.match("Unread")) {
vfeedr.className = vfeedr.className + "Unread";
vfeedctr.className = "odd";
}
} else { } else {
vfeedctr.className = "invisible"; query = query + "&omode=flc";
vfeedr.className = vfeedr.className.replace("Unread", "");
} }
var mark_img = document.getElementById("FPPIC-" + id);
var vfeedu = document.getElementById("FEEDU--2");
var crow = document.getElementById("RROW-" + id);
if (mark_img.alt != "Unpublish") {
mark_img.src = "images/pub_set.png";
mark_img.alt = "Unpublish";
query = query + "&pub=1";
if (vfeedu && crow.className.match("Unread")) {
vfeedu.innerHTML = (+vfeedu.innerHTML) + 1;
}
} else {
mark_img.src = "images/pub_unset.png";
mark_img.alt = "Publish";
query = query + "&pub=0";
if (vfeedu && crow.className.match("Unread")) {
vfeedu.innerHTML = (+vfeedu.innerHTML) - 1;
}
}
var vfeedctr = document.getElementById("FEEDCTR--2");
var vfeedr = document.getElementById("FEEDR--2");
if (vfeedu && vfeedctr) {
if ((+vfeedu.innerHTML) > 0) {
if (crow.className.match("Unread") && !vfeedr.className.match("Unread")) {
vfeedr.className = vfeedr.className + "Unread";
vfeedctr.className = "odd";
}
} else {
vfeedctr.className = "invisible";
vfeedr.className = vfeedr.className.replace("Unread", "");
}
}
debug("toggle published for aid " + id);
new Ajax.Request(query);
} catch (e) {
exception_error("togglePub", e);
} }
debug("toggle published for aid " + id);
new Ajax.Request(query);
} }
function correctHeadlinesOffset(id) { function correctHeadlinesOffset(id) {
@ -670,6 +691,14 @@ function selectionToggleMarked(cdm_mode) {
var query = "backend.php?op=rpc&subop=markSelected&ids=" + var query = "backend.php?op=rpc&subop=markSelected&ids=" +
param_escape(rows.toString()) + "&cmode=2"; param_escape(rows.toString()) + "&cmode=2";
query = query + "&afid=" + getActiveFeedId();
if (tagsAreDisplayed()) {
query = query + "&omode=tl";
} else {
query = query + "&omode=flc";
}
xmlhttp_rpc.open("GET", query, true); xmlhttp_rpc.open("GET", query, true);
xmlhttp_rpc.onreadystatechange=all_counters_callback; xmlhttp_rpc.onreadystatechange=all_counters_callback;
xmlhttp_rpc.send(null); xmlhttp_rpc.send(null);
@ -727,6 +756,14 @@ function selectionTogglePublished(cdm_mode) {
var query = "backend.php?op=rpc&subop=publishSelected&ids=" + var query = "backend.php?op=rpc&subop=publishSelected&ids=" +
param_escape(rows.toString()) + "&cmode=2"; param_escape(rows.toString()) + "&cmode=2";
query = query + "&afid=" + getActiveFeedId();
if (tagsAreDisplayed()) {
query = query + "&omode=tl";
} else {
query = query + "&omode=flc";
}
xmlhttp_rpc.open("GET", query, true); xmlhttp_rpc.open("GET", query, true);
xmlhttp_rpc.onreadystatechange=all_counters_callback; xmlhttp_rpc.onreadystatechange=all_counters_callback;
xmlhttp_rpc.send(null); xmlhttp_rpc.send(null);