luci-app-adblock: sync with adblock 3.8.3
[project/luci.git] / applications / luci-app-adblock / luasrc / view / adblock / runtime.htm
index 7609ba5e66c77efb743a0c9a3bb19a99c8f91058..2cec5733460f811aeb0bbcbde4eb9e1e5d6e628f 100644 (file)
@@ -1,76 +1,65 @@
 <%#
-Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
+Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
 This is free software, licensed under the Apache License, Version 2.0
-local sys     = require("luci.sys")
-
 -%>
-<style type="text/css">
-.runtime
-{
-       color:#0069d6;
-       font-weight:bold;
-       display:inline-block;
-       width:100%;
-       padding-top: 0.5rem;
-}
-</style>
 
+<%+adblock/adblock_css%>
 <script type="text/javascript">
 //<![CDATA[
+       function format(number)
+       {
+               var string = number.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1.');
+               return string;
+       }
+
        function status_update(json)
        {
-                       var view  = document.getElementById("value_1");
-                       var btn1  = document.getElementById("btn1");
-                       var btn2  = document.getElementById("btn2");
-                       var input = json.data.adblock_status;
+               var btn1         = document.getElementById("btn1");
+               var btn1_running = document.getElementById("btn1_running");
+               var btn2         = document.getElementById("btn2");
+               var btn2_running = document.getElementById("btn2_running");
+               var input        = json.data.adblock_status || "-";
 
-                       view.innerHTML = input || "-";
-                       if (input === "enabled")
-                       {
-                               btn1.value = "<%:Suspend%>";
-                               btn1.name  = "do_suspend";
-                               btn2.value = "<%:Refresh%>";
-                               btn2.name  = "do_refresh";
-                               btn1.disabled = false;
-                               running(btn1_running, 0);
-                               btn2.disabled = false;
-                               running(btn2_running, 0);
-                       }
-                       else if (input === "paused")
-                       {
-                               btn1.value = "<%:Resume%>";
-                               btn1.name  = "do_resume";
-                               btn2.value = "<%:Refresh%>";
-                               btn2.name  = "do_refresh";
-                               btn1.disabled = false;
-                               running(btn1_running, 0);
-                               btn2.disabled = false;
-                               running(btn2_running, 0);
-                       }
-                       else
-                       {
-                               btn1.value = "<%:Suspend%>";
-                               btn1.name  = "do_suspend";
-                               btn2.value = "<%:Refresh%>";
-                               btn2.name  = "do_refresh";
-                               btn1.disabled = true;
-                               btn2.disabled = true;
-                       }
-                       view = document.getElementById("value_2");
-                       input = json.data.adblock_version;
-                       view.innerHTML = input || "-";
-                       view = document.getElementById("value_3");
-                       input = json.data.fetch_utility;
-                       view.innerHTML = input || "-";
-                       view = document.getElementById("value_4");
-                       input = json.data.dns_backend;
-                       view.innerHTML = input || "-";
-                       view = document.getElementById("value_5");
-                       input = json.data.overall_domains;
-                       view.innerHTML = input || "-";
-                       view = document.getElementById("value_6");
-                       input = json.data.last_rundate;
-                       view.innerHTML = input || "-";
+               document.getElementById("value_1").innerHTML = input;
+               if (input === "enabled")
+               {
+                       btn1.value = "<%:Suspend%>";
+                       btn1.name  = "do_suspend";
+                       btn2.value = "<%:Refresh%>";
+                       btn2.name  = "do_refresh";
+                       btn1.disabled = false;
+                       running(btn1_running, 0);
+                       btn2.disabled = false;
+                       running(btn2_running, 0);
+               }
+               else if (input === "paused")
+               {
+                       btn1.value = "<%:Resume%>";
+                       btn1.name  = "do_resume";
+                       btn2.value = "<%:Refresh%>";
+                       btn2.name  = "do_refresh";
+                       btn1.disabled = false;
+                       running(btn1_running, 0);
+                       btn2.disabled = false;
+                       running(btn2_running, 0);
+               }
+               else
+               {
+                       btn1.value = "<%:Suspend%>";
+                       btn1.name  = "do_suspend";
+                       btn2.value = "<%:Refresh%>";
+                       btn2.name  = "do_refresh";
+                       btn1.disabled = true;
+                       btn2.disabled = true;
+               }
+
+               document.getElementById("value_2").innerHTML = json.data.adblock_version || "-";
+               document.getElementById("value_3").innerHTML = json.data.fetch_utility || "-";
+               document.getElementById("value_4").innerHTML = json.data.dns_backend || "-";
+               document.getElementById("value_5").innerHTML = json.data.dns_variant || "-";
+               document.getElementById("value_6").innerHTML = json.data.backup_dir || "-";
+               document.getElementById("value_7").innerHTML = format(json.data.overall_domains) || "-";
+               document.getElementById("value_8").innerHTML = json.data.last_rundate || "-";
        }
 
        function btn_action(action)
@@ -115,32 +104,44 @@ local sys     = require("luci.sys")
                }
        }
 
-       XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "status")%>', null,
+       function reset_view()
+       {
+               document.getElementById("btn1").value        = "<%:Suspend%>";
+               document.getElementById("btn1").name         = "do_suspend";
+               document.getElementById("btn2").value        = "<%:Refresh%>";
+               document.getElementById("btn2").name         = "do_refresh";
+               document.getElementById("btn1").disabled     = true;
+               document.getElementById("btn2").disabled     = true;
+               document.getElementById("value_1").innerHTML = "-";
+               document.getElementById("value_2").innerHTML = "-";
+               document.getElementById("value_3").innerHTML = "-";
+               document.getElementById("value_4").innerHTML = "-";
+               document.getElementById("value_5").innerHTML = "-";
+               document.getElementById("value_6").innerHTML = "-";
+               document.getElementById("value_7").innerHTML = "-";
+               document.getElementById("value_8").innerHTML = "-";
+       }
+
+       XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "status_update")%>', null,
        function(x, json_info)
        {
-               if (!x || !json_info)
+               if (!x || !json_info || !json_info.data)
                {
-                       var btn1 = document.getElementById("btn1");
-                       var btn2 = document.getElementById("btn2");
-                       btn1.value = "<%:Suspend%>";
-                       btn1.name  = "do_suspend";
-                       btn2.value = "<%:Refresh%>";
-                       btn2.name  = "do_refresh";
-                       btn1.disabled = true;
-                       btn2.disabled = false;
+                       reset_view();
                        return;
                }
-               status_update(json_info)
+               status_update(json_info);
        });
 
-       XHR.poll(5, '<%=luci.dispatcher.build_url("admin", "services", "adblock", "status")%>', null,
+       XHR.poll(-1, '<%=luci.dispatcher.build_url("admin", "services", "adblock", "status_update")%>', null,
        function(x, json_info)
        {
-               if (!x || !json_info)
+               if (!x || !json_info || !json_info.data)
                {
+                       reset_view();
                        return;
                }
-               status_update(json_info)
+               status_update(json_info);
        });
 //]]>
 </script>
@@ -165,29 +166,41 @@ local sys     = require("luci.sys")
        </div>
 </div>
 <div class="cbi-value" id="status_4">
-       <label class="cbi-value-title" for="status_4"><%:DNS Backend (DNS Directory)%></label>
+       <label class="cbi-value-title" for="status_4"><%:DNS Backend, DNS Directory%></label>
        <div class="cbi-value-field">
                <span class="runtime" id="value_4">-</span>
        </div>
 </div>
 <div class="cbi-value" id="status_5">
-       <label class="cbi-value-title" for="status_5"><%:Overall Domains%></label>
+       <label class="cbi-value-title" for="status_5"><%:DNS Variant, DNS File Reset%></label>
        <div class="cbi-value-field">
                <span class="runtime" id="value_5">-</span>
        </div>
 </div>
 <div class="cbi-value" id="status_6">
-       <label class="cbi-value-title" for="status_6"><%:Last Run%></label>
+       <label class="cbi-value-title" for="status_6"><%:Backup Directory%></label>
        <div class="cbi-value-field">
                <span class="runtime" id="value_6">-</span>
        </div>
 </div>
+<div class="cbi-value" id="status_7">
+       <label class="cbi-value-title" for="status_7"><%:Overall Domains%></label>
+       <div class="cbi-value-field">
+               <span class="runtime" id="value_7">-</span>
+       </div>
+</div>
+<div class="cbi-value" id="status_8">
+       <label class="cbi-value-title" for="status_8"><%:Last Run%></label>
+       <div class="cbi-value-field">
+               <span class="runtime" id="value_8">-</span>
+       </div>
+</div>
 <hr />
 <div class="cbi-value" id="button_1">
        <label class="cbi-value-title" for="button_1"><%:Suspend / Resume Adblock%></label>
        <div class="cbi-value-field">
                <input class="cbi-button cbi-button-reset" id="btn1" type="button" value="" onclick="btn_action(this)" />
-               <span id="btn1_running" style="display:inline-block; width:16px; height:16px; margin:0 5px"></span>
+               <span id="btn1_running" class="btn_running"></span>
        </div>
 </div>
 <p />
@@ -195,6 +208,6 @@ local sys     = require("luci.sys")
        <label class="cbi-value-title" for="button_2"><%:Refresh Blocklist Sources%></label>
        <div class="cbi-value-field">
                <input class="cbi-button cbi-button-apply" id="btn2" type="button" value="" onclick="btn_action(this)" />
-               <span id="btn2_running" style="display:inline-block; width:16px; height:16px; margin:0 5px"></span>
+               <span id="btn2_running" class="btn_running"></span>
        </div>
 </div>