]> git.wh0rd.org - chrome-ext/web-power-switch.git/blobdiff - popup.js
rewrite options page to be more chrome like
[chrome-ext/web-power-switch.git] / popup.js
index 7ba21e2505df7cb947b21b1a30bb5e7b91871813..742962dd074def469fca2bed4e2743b8b7176888 100644 (file)
--- a/popup.js
+++ b/popup.js
@@ -88,6 +88,31 @@ function initpopup(xhr, state) {
 
        // There is no clean API for extracting the current state.
        // Example result:
+       /*
+               <tr>
+               <th bgcolor="#DDDDFF" align=left>
+               Controller: !!!Web Power Switch 6
+               </th>
+               </tr>
+       */
+
+       var th, ths = state.currentTarget.responseXML.querySelectorAll('th');
+       for (var i = 0; th = ths[i]; ++i) {
+               if (th.bgColor != '#DDDDFF')
+                       continue;
+
+               var controller_name = trim(th.innerText);
+               if (controller_name.slice(0, 12) != 'Controller: ')
+                       continue;
+
+               row = tbl.insertRow(-1);
+               cell = row.insertCell(-1);
+               cell.colSpan = 2;
+               cell.align = 'center';
+               cell.innerText = controller_name.slice(12);
+               cell.innerHTML = '<a href="' + url_base + '" target="_blank">' + cell.innerHTML + '</a>'
+       }
+
        /*
                <tr bgcolor="#F4F4F4"><td align=center>1</td>
                <td>Outlet 1</td><td>
@@ -111,7 +136,10 @@ function initpopup(xhr, state) {
 
                row = tbl.insertRow(-1);
                cell = row.insertCell(-1);
-               cell.innerText = outlet_name + ':';
+               if (outlet_name === '')
+                       cell.innerHTML = '<i>unnamed</i>';
+               else
+                       cell.innerText = outlet_name + ':';
                cell = row.insertCell(-1);
                button = document.createElement('input');
                button.type = 'button';
@@ -138,6 +166,24 @@ document.addEventListener('DOMContentLoaded', function() {
                url_base = settings['url'] || settings_defaults['url'];
                user = settings['user'] || settings_defaults['user'];
                pass = settings['pass'] || settings_defaults['pass'];
-               fetchpage('index.htm', initpopup);
+               chrome.permissions.contains({
+                       origins: [url_base + '/*']
+               }, function(granted) {
+                       if (granted) {
+                               fetchpage('index.htm', initpopup);
+                       } else {
+                               setstatus(
+                                       'Missing permissions;<br>please visit the ' +
+                                       '<a href="' + chrome.extension.getURL('options.html') + '" target=_blank>settings page</a>' +
+                                       '<br>to grant access.<br>' +
+                                       '<center><input id=retry type=submit value=Retry></center>'
+                               );
+                               // Work around http://crbug.com/125706.
+                               document.getElementById('retry').onclick = function() {
+                                       chrome.permissions.request({origins: [url_base + '/*']});
+                                       fetchpage('index.htm', initpopup);
+                               };
+                       }
+               });
        });
 });