]> git.wh0rd.org - tt-rss.git/commitdiff
remove raw xmlhttp code from tt-rss.js
authorAndrew Dolgov <fox@bah.spb.su>
Sat, 25 Aug 2007 09:10:18 +0000 (10:10 +0100)
committerAndrew Dolgov <fox@bah.spb.su>
Sat, 25 Aug 2007 09:10:18 +0000 (10:10 +0100)
tt-rss.js

index 00c7e21096dda7c2e5a6a2971855fc30c133ebfb..92fa161b1058088aae029dddf4511b30beecc4ab 100644 (file)
--- a/tt-rss.js
+++ b/tt-rss.js
@@ -1,4 +1,3 @@
-var xmlhttp = false;
 var total_unread = 0;
 var first_run = true;
 var display_tags = false;
@@ -7,7 +6,7 @@ var active_title_text = "";
 var current_subtitle = "";
 var daemon_enabled = false;
 var daemon_refresh_only = false;
-var _qfd_deleted_feed = 0;
+//var _qfd_deleted_feed = 0;
 var firsttime_update = true;
 var cookie_lifetime = 0;
 var active_feed_id = 0;
@@ -15,8 +14,6 @@ var active_feed_is_cat = false;
 var number_of_feeds = 0;
 var sanity_check_done = false;
 
-var xmlhttp = Ajax.getTransport();
-
 var init_params = new Object();
 
 function tagsAreDisplayed() {
@@ -51,20 +48,16 @@ function toggleTags(show_all) {
        }
 }
 
-function dlg_frefresh_callback() {
-       if (xmlhttp.readyState == 4) {          
-//             notify(xmlhttp.responseText);
-
-               if (getActiveFeedId() == _qfd_deleted_feed) {
-                       var h = document.getElementById("headlines-frame");
-                       if (h) {
-                               h.innerHTML = "<div class='whiteBox'>" + __('No feed selected.') + "</div>";
-                       }
+function dlg_frefresh_callback(transport, deleted_feed) {
+       if (getActiveFeedId() == deleted_feed) {
+               var h = document.getElementById("headlines-frame");
+               if (h) {
+                       h.innerHTML = "<div class='whiteBox'>" + __('No feed selected.') + "</div>";
                }
+       }
 
-               setTimeout('updateFeedList(false, false)', 50);
-               closeInfoBox();
-       } 
+       setTimeout('updateFeedList(false, false)', 50);
+       closeInfoBox();
 }
 
 function refetch_callback2(transport) {
@@ -88,61 +81,58 @@ function refetch_callback2(transport) {
        }
 }
 
-function backend_sanity_check_callback() {
+function backend_sanity_check_callback(transport) {
 
-       if (xmlhttp.readyState == 4) {
+       try {
 
-               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 (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 (!xmlhttp.responseXML) {
-                               fatalError(3, "[D001, Received reply is not XML]: " + xmlhttp.responseText);
-                               return;
-                       }
-       
-                       var reply = xmlhttp.responseXML.firstChild.firstChild;
-       
-                       if (!reply) {
-                               fatalError(3, "[D002, Invalid RPC reply]: " + xmlhttp.responseText);
-                               return;
-                       }
-       
-                       var error_code = reply.getAttribute("error-code");
-               
-                       if (error_code && error_code != 0) {
-                               return fatalError(error_code, reply.getAttribute("error-msg"));
-                       }
+               if (!transport.responseXML) {
+                       fatalError(3, "[D001, Received reply is not XML]: " + transport.responseText);
+                       return;
+               }
+
+               var reply = transport.responseXML.firstChild.firstChild;
+
+               if (!reply) {
+                       fatalError(3, "[D002, Invalid RPC reply]: " + transport.responseText);
+                       return;
+               }
+
+               var error_code = reply.getAttribute("error-code");
        
-                       debug("sanity check ok");
+               if (error_code && error_code != 0) {
+                       return fatalError(error_code, reply.getAttribute("error-msg"));
+               }
 
-                       var params = reply.nextSibling;
+               debug("sanity check ok");
 
-                       if (params) {
-                               debug('reading init-params...');
-                               var param = params.firstChild;
+               var params = reply.nextSibling;
 
-                               while (param) {
-                                       var k = param.getAttribute("key");
-                                       var v = param.getAttribute("value");
-                                       debug(k + " => " + v);
-                                       init_params[k] = v;                                     
-                                       param = param.nextSibling;
-                               }
+               if (params) {
+                       debug('reading init-params...');
+                       var param = params.firstChild;
+
+                       while (param) {
+                               var k = param.getAttribute("key");
+                               var v = param.getAttribute("value");
+                               debug(k + " => " + v);
+                               init_params[k] = v;                                     
+                               param = param.nextSibling;
                        }
+               }
 
-                       sanity_check_done = true;
+               sanity_check_done = true;
 
-                       init_second_stage();
+               init_second_stage();
 
-               } catch (e) {
-                       exception_error("backend_sanity_check_callback", e);
-               }
+       } catch (e) {
+               exception_error("backend_sanity_check_callback", e);    
        } 
 }
 
@@ -315,7 +305,7 @@ function updateTitle(s) {
 
 function genericSanityCheck() {
 
-       if (!xmlhttp) fatalError(1);
+//     if (!Ajax.getTransport()) fatalError(1);
 
        setCookie("ttrss_vf_test", "TEST");
        
@@ -349,9 +339,10 @@ function init() {
 
                var params = "&ua=" + param_escape(navigator.userAgent);
 
-               xmlhttp.open("GET", "backend.php?op=rpc&subop=sanityCheck" + params, true);
-               xmlhttp.onreadystatechange=backend_sanity_check_callback;
-               xmlhttp.send(null);
+               new Ajax.Request("backend.php?op=rpc&subop=sanityCheck" + params,       {
+                       onComplete: function(transport) {
+                                       backend_sanity_check_callback(transport);
+                               } });
 
        } catch (e) {
                exception_error("init", e);
@@ -498,16 +489,13 @@ function qfdDelete(feed_id) {
 
        notify_progress("Removing feed...");
 
-       if (!xmlhttp_ready(xmlhttp)) {
-               printLockingError();
-               return
-       }
+       var query = "backend.php?op=pref-feeds&quiet=1&subop=remove&ids=" + feed_id;
 
-       _qfd_deleted_feed = feed_id;
+       new Ajax.Request(query, {
+               onComplete: function(transport) {
+                               dlg_frefresh_callback(transport, feed_id);
+                       } });
 
-       xmlhttp.open("GET", "backend.php?op=pref-feeds&quiet=1&subop=remove&ids=" + feed_id);
-       xmlhttp.onreadystatechange=dlg_frefresh_callback;
-       xmlhttp.send(null);
 
        return false;
 }
@@ -521,11 +509,6 @@ function updateFeedTitle(t) {
 function toggleDispRead() {
        try {
 
-               if (!xmlhttp_ready(xmlhttp)) {
-                       printLockingError();
-                       return
-               } 
-
                var hide_read_feeds = (getInitParam("hide_read_feeds") == "1");
 
                hide_read_feeds = !hide_read_feeds;
@@ -535,11 +518,6 @@ function toggleDispRead() {
                hideOrShowFeeds(getFeedsContext().document, hide_read_feeds);
 
                storeInitParam("hide_read_feeds", hide_read_feeds, true);
-
-/*             var query = "backend.php?op=rpc&subop=setpref" +
-                       "&key=HIDE_READ_FEEDS&value=" + param_escape(hide_read_feeds);
-
-               new Ajax.Request(query); */
                                
        } catch (e) {
                exception_error("toggleDispRead", e);
@@ -662,21 +640,18 @@ function feedEditSave() {
 
        try {
        
-               if (!xmlhttp_ready(xmlhttp)) {
-                       printLockingError();
-                       return
-               }
-
                // FIXME: add parameter validation
 
                var query = Form.serialize("edit_feed_form");
 
                notify_progress("Saving feed...");
 
-               xmlhttp.open("POST", "backend.php", true);
-               xmlhttp.onreadystatechange=dlg_frefresh_callback;
-               xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
-               xmlhttp.send(query);
+               new Ajax.Request("backend.php", {
+                       parameters: query,
+                       onComplete: function(transport) { 
+                               dlg_frefresh_callback(transport); 
+                       } });
+
 
                closeInfoBox();
 
@@ -696,21 +671,17 @@ function labelEditSave() {
 
        try {
 
-               if (!xmlhttp_ready(xmlhttp)) {
-                       printLockingError();
-                       return
-               }
-       
                closeInfoBox();
        
                notify_progress("Saving label...");
        
                query = Form.serialize("label_edit_form");
        
-               xmlhttp.open("GET", "backend.php?" + query, true);              
-               xmlhttp.onreadystatechange=dlg_frefresh_callback;
-               xmlhttp.send(null);
-       
+               new Ajax.Request("backend.php?" + query, {
+                       onComplete: function(transport) { 
+                               dlg_frefresh_callback(transport); 
+                       } });
+
                return false;
 
        } catch (e) {