summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--modules/freifunk/luasrc/view/freifunk/index.htm29
1 files changed, 27 insertions, 2 deletions
diff --git a/modules/freifunk/luasrc/view/freifunk/index.htm b/modules/freifunk/luasrc/view/freifunk/index.htm
index e13d7f9c26..d1862bd3a6 100644
--- a/modules/freifunk/luasrc/view/freifunk/index.htm
+++ b/modules/freifunk/luasrc/view/freifunk/index.htm
@@ -15,6 +15,8 @@ $Id$
<%+header%>
<%
local uci = require "luci.model.uci".cursor()
+local tpl = require "luci.template"
+local fs = require "luci.fs"
local ff = {}
local ff = uci:get_all("freifunk")
@@ -33,8 +35,7 @@ local co = "profile_" .. community
local url = uci:get_first(co, "community", "homepage") or "http://www.freifunk.net"
-require("luci.fs")
-local usertext = luci.fs.readfile("/www/luci-static/index_user.html")
+local usertext = fs.readfile("/www/luci-static/index_user.html")
if DefaultText ~= "disabled" then
@@ -69,4 +70,28 @@ end
<%=defaulttext%>
<%=usertext%>
+<%
+-- add custom widgets from view/freifunk/widgets
+local widgets = {}
+local dir = "/usr/lib/lua/luci/view/freifunk/widgets"
+
+uci:foreach("freifunk-widgets", "widget",
+ function(s)
+ if s.enabled == "1" then
+ local name = s[".name"]
+ widgets[name] = s
+ end
+ end)
+
+local function cmp(a, b)
+ return (widgets[a].order or 100) > (widgets[b].order or 100)
+end
+
+for k, v in luci.util.spairs(widgets, function(a,b) return (tonumber(widgets[a].order) < tonumber(widgets[b].order)) end) do
+ if v['template'] and fs.access(dir .. "/" .. v['template'] .. "/main.htm") then
+ tpl.render("freifunk/widgets/" .. v['template'] .. "/main", { name = k, data = v })
+ end
+end
+
+%>
<%+footer%>