summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-olsr-services/luasrc
diff options
context:
space:
mode:
authorManuel Munz <freifunk@somakoma.de>2011-11-09 18:47:55 +0000
committerManuel Munz <freifunk@somakoma.de>2011-11-09 18:47:55 +0000
commit014b7ff1fd9d8ac370fe337c24609d626ab64022 (patch)
tree605d2feba97f2c968e3fe770aef92b3ff523132e /applications/luci-olsr-services/luasrc
parentb1ef4c398bc2d35b333331ac5f823bc17bf56ff2 (diff)
applications/luci-olsr-services: Update using javascript/json
Diffstat (limited to 'applications/luci-olsr-services/luasrc')
-rw-r--r--applications/luci-olsr-services/luasrc/view/freifunk-services/services.htm124
1 files changed, 94 insertions, 30 deletions
diff --git a/applications/luci-olsr-services/luasrc/view/freifunk-services/services.htm b/applications/luci-olsr-services/luasrc/view/freifunk-services/services.htm
index c9385cd57..3b6a523d0 100644
--- a/applications/luci-olsr-services/luasrc/view/freifunk-services/services.htm
+++ b/applications/luci-olsr-services/luasrc/view/freifunk-services/services.htm
@@ -1,8 +1,20 @@
-<%+header%>
+<%#
+LuCI - Lua Configuration Interface
+
+Copyright 2011 Manuel Munz <freifunk at somakoma dot de>
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+-%>
<%
local fs = require "luci.fs"
local utl = require "luci.util"
+local i = 1
-- check if nameservice plugin is enabled and where to find the services file
local has_services = false
@@ -22,7 +34,6 @@ uci:foreach("olsrd", "LoadPlugin", function(s)
end
end)
-
function fetch_services()
local rawdata = fs.readfile(services_file)
@@ -48,40 +59,93 @@ function fetch_services()
return tables
end
-%>
+local table = fetch_services()
-<% if has_services then %>
-<div class="cbi-map">
- <h2><a id="content" name="content"><%:Services%></a></h2>
- <div class="cbi-map-descr"/>
- <div class="cbi-section">
- <div class="cbi-section-node">
- <table class="cbi-section-table">
- <tr class="cbi-section-table-titles">
- <th class="cbi-section-table-cell"><%:Url%></th>
- <th class="cbi-section-table-cell"><%:Source%></th>
- </tr>
-
- <% table=fetch_services()
- local i = 1
+if luci.http.formvalue("status") == "1" then
+ local rv = {}
for k, line in ipairs(table) do
- local field = {}
- -- split line at # and |, 1=url, 2=proto, 3=description, 4=source
local field = utl.split(line, "[#|]", split, true)
local url,descr,origin = pcdata(field[1]),pcdata(field[3]),pcdata(field[4])
- %>
- <tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
- <td class="cbi-section-table-cell"><a href="<%=url%>"><%=descr%></a></td>
- <td class="cbi-section-table-cell"><%=origin%></td>
- </tr>
- <% if i == 1 then i = 0 elseif i == 0 then i = 1 end %>
- <%end%>
- </table>
- </div>
- </div>
- </div>
+ local rs = i
+ rv[#rv+1] = {
+ url = url,
+ origin = origin,
+ descr = descr,
+ rs = rs
+ }
+ if i == 1 then i = 0 elseif i == 0 then i = 1 end
+ end
+ luci.http.prepare_content("application/json")
+ luci.http.write_json(rv)
+ return
+end
+
+%>
+
+<% if has_services then %>
+
+<%+header%>
+
+<script type="text/javascript" src="<%=resource%>/cbi.js"></script>
+<script type="text/javascript">//<![CDATA[
+
+ XHR.poll(10 , '<%=REQUEST_URI%>', { status: 1 },
+ function(x, info)
+ {
+ var tbody = document.getElementById('olsr_services');
+ if (tbody)
+ {
+ var s = '';
+ for (var idx = 0; idx < info.length; idx++)
+ {
+ var service = info[idx];
+ s += String.format(
+ '<tr class="cbi-section-table-row cbi-rowstyle-%s">' +
+ '<td class="cbi-section-table-cell"><a href="%s">%s</a></td>' +
+ '<td class="cbi-section-table-cell">%s</td>' +
+ '</tr>',
+ service.rs, service.url, service.descr, service.origin || '?'
+ );
+ }
+ tbody.innerHTML = s;
+ }
+ }
+ );
+//]]></script>
+
+
+
+
+ <h2><a id="content" name="content"><%:Services%></a></h2>
+
+ <fieldset class="cbi-section">
+ <legend><%:Internal services%></legend>
+ <table class="cbi-section-table">
+ <tr class="cbi-section-table-titles">
+ <th class="cbi-section-table-cell"><%:Url%></th>
+ <th class="cbi-section-table-cell"><%:Source%></th>
+ </tr>
+
+ <tbody id="olsr_services">
+ <%
+ for k, line in ipairs(table) do
+ local field = {}
+ -- split line at # and |, 1=url, 2=proto, 3=description, 4=source
+ local field = utl.split(line, "[#|]", split, true)
+ local url,descr,origin = pcdata(field[1]),pcdata(field[3]),pcdata(field[4])
+ %>
+
+ <tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
+ <td class="cbi-section-table-cell"><a href="<%=url%>"><%=descr%></a></td>
+ <td class="cbi-section-table-cell"><%=origin%></td>
+ </tr>
+ <% if i == 1 then i = 0 elseif i == 0 then i = 1 end
+ end %>
+ </tbody>
+ </table>
<br />
<%=last_update%>
+ </fieldset>
<%else%>
<%:No services can be shown, because olsrd is not running or the olsrd-nameservice Plugin is not loaded.%>