* CBI updates

This commit is contained in:
Steven Barth 2008-03-20 20:33:43 +00:00
parent e8b87fffb9
commit e9461f898c
7 changed files with 75 additions and 25 deletions

View file

@ -27,6 +27,8 @@ limitations under the License.
module("ffluci.cbi", package.seeall)
require("ffluci.template")
require("ffluci.util")
require("ffluci.http")
require("ffluci.model.uci")
local Template = ffluci.template.Template
local class = ffluci.util.class
local instanceof = ffluci.util.instanceof
@ -46,8 +48,14 @@ function Node.append(self, obj)
table.insert(self.children, obj)
end
function Node.parse(self)
for k, child in ipairs(self.children) do
child:parse()
end
end
function Node.render(self)
ffluci.template.render(self.template, self)
ffluci.template.render(self.template)
end
@ -64,15 +72,20 @@ end
function Map.section(self, class, ...)
if instanceof(class, AbstractSection) then
local obj = class(...)
obj.map = self.config
table.insert(self.children, obj)
local obj = class(...)
obj.map = self
obj.config = self.config
self:append(obj)
return obj
else
error("class must be a descendent of AbstractSection")
end
end
function Map.read(self)
self.ucidata = self.ucidata or ffluci.model.uci.show(self.config)
return self.ucidata
end
--[[
AbstractSection
@ -86,9 +99,10 @@ end
function AbstractSection.option(self, class, ...)
if instanceof(class, AbstractValue) then
local obj = class(...)
obj.map = self.map
table.insert(self.children, obj)
local obj = class(...)
obj.map = self.map
obj.config = self.config
self:append(obj)
return obj
else
error("class must be a descendent of AbstractValue")
@ -137,7 +151,7 @@ end
--[[
AbstractValue - An abstract Value Type
null: Value can be empty
valid: A function returning nil if invalid
valid: A function returning the value if it is valid otherwise nil
depends: A table of option => value pairs of which one must be true
default: The default value
]]--
@ -151,7 +165,25 @@ function AbstractValue.__init__(self, option, ...)
self.depends = nil
self.default = nil
end
function AbstractValue.formvalue(self)
local key = "uci."..self.map.config.."."..self.section.."."..self.option
return ffluci.http.formvalue(key)
end
function AbstractValue.ucivalue(self)
return self.map.read()[self.section][self.option]
end
function AbstractValue.validate(self, value)
return ffluci.util.validate(value, nil, nil, self.valid)
end
function AbstractValue.write(self, value)
ffluci.model.uci.set(self.config, self.section, self.option, value)
end
--[[
Value - A one-line value
@ -178,7 +210,7 @@ ListValue = class(AbstractValue)
function ListValue.__init__(self, ...)
AbstractValue.__init__(self, ...)
self.template = "cbi/value"
self.template = "cbi/lvalue"
self.list = {}
end

View file

@ -54,6 +54,7 @@ function request_redirect(category, module, action)
redirect(pattern:format(category, module, action))
end
-- Gets form value from key
function formvalue(key, default)
local c = formvalues()

View file

@ -0,0 +1,11 @@
<div class="cbi-lvalue">
<div class="cbi-lvalue-title"><%=self.title%></div>
<div class="cbi-lvalue-field">
<select name="<%=self.map.config.."."..self.section.."."..self.option%>">
<%for k, v in self.list do%>
<option value="<%=k%>"><%=v%></option>
<% end %>
</select>
</div>
<div class="cbi-value-description"><%=self.description%></div>
</div>

View file

@ -1,7 +1,7 @@
<div class="cbi-map" id="cbi-<%=config%>">
<div class="cbi-map" id="cbi-<%=self.config%>">
<form method="post" action="<%=os.getenv("REQUEST_URI")%>">
<h1><%=title%></h1>
<div class="cbi-map-descr"><%=description%></div>
<% for k, node in ipairs(children) do node:render() end %>
<h1><%=self.title%></h1>
<div class="cbi-map-descr"><%=self.description%></div>
<% for k, node in ipairs(self.children) do node:render() end %>
</form>
</div>

View file

@ -1,5 +1,5 @@
<div class="cbi-nsection" id="cbi-<%=map.config%>-<%=sectiontype%>-<%=section%>">
<h2><%=title%></h2>
<div class="cbi-nsection-descr"><%=description%></div>
<% for k, node in ipairs(children) do node:render() end %>
<div class="cbi-nsection" id="cbi-<%=self.map.config%>-<%=self.sectiontype%>-<%=self.section%>">
<h2><%=self.title%></h2>
<div class="cbi-nsection-descr"><%=self.description%></div>
<% for k, node in ipairs(self.children) do node:render() end %>
</div>

View file

@ -1,6 +1,5 @@
<%
require("ffluci.model.uci")
local allsections = ffluci.model.uci.show(map)
local allsections = self.map:read()
local sections = {}
for k, v in pairs(allsections) do
if v[".type"] == sectiontype then
@ -8,12 +7,12 @@ for k, v in pairs(allsections) do
end
end
%>
<div class="cbi-tsection" id="cbi-<%=map%>-<%=sectiontype%>">
<h2><%=title%></h2>
<div class="cbi-tsection-descr"><%=description%></div>
<div class="cbi-tsection" id="cbi-<%=self.map.config%>-<%=self.sectiontype%>">
<h2><%=self.title%></h2>
<div class="cbi-tsection-descr"><%=self.description%></div>
<% for k, v in pairs(sections) do %>
<div class="cbi-tsection-node" id="cbi-<%=map%>-<%=k%>">
<% for k, node in ipairs(children) do
<div class="cbi-tsection-node" id="cbi-<%=self.map.config%>-<%=k%>">
<% for k, node in ipairs(self.children) do
node.section = k
node:render(k)
end %>

View file

@ -0,0 +1,7 @@
<div class="cbi-value">
<div class="cbi-value-title"><%=self.title%></div>
<div class="cbi-value-field">
<input type="text" name="<%=self.map.config.."."..self.section.."."..self.option%>" value="<%=self:ucivalue()%>" />
</div>
<div class="cbi-value-description"><%=self.description%></div>
</div>