* luci/libs/cbi: various template cleanups

This commit is contained in:
Jo-Philipp Wich 2008-07-15 17:27:58 +00:00
parent 8bb8b7c09c
commit 05d3bf06b4
17 changed files with 228 additions and 179 deletions

View file

@ -554,6 +554,24 @@ function AbstractValue.render(self, s, scope)
if not self.optional or self:cfgvalue(s) or self:formcreated(s) then if not self.optional or self:cfgvalue(s) or self:formcreated(s) then
scope = scope or {} scope = scope or {}
scope.section = s scope.section = s
scope.cbid = "cbid." .. self.config ..
"." .. s ..
"." .. self.option
scope.ifattr = function(cond,key,val)
if cond then
return string.format(
' %s="%s"', tostring(key),
tostring( val or scope[key] or self[key] or "" )
)
else
return ''
end
end
scope.attr = function(...)
return scope.ifattr( true, ... )
end
Node.render(self, scope) Node.render(self, scope)
end end

View file

@ -13,15 +13,15 @@ $Id$
-%> -%>
<%- if self.tag_invalid[section] then -%> <% if self.tag_invalid[section] then -%>
<div class="cbi-error"><%:cbi_invalid%></div> <div class="cbi-error"><%:cbi_invalid%></div>
<%- end -%> <%- end %>
</td> </td>
<%- if #self.deps > 0 then -%> <% if #self.deps > 0 then -%>
<script type="text/javascript"> <script type="text/javascript">
<% for j, d in ipairs(self.deps) do -%> <% for j, d in ipairs(self.deps) do -%>
cbi_d_add("cbi-<%=self.config.."-"..section.."-"..self.option%>", "cbid.<%=self.config.."."..section.."."..d.field%>", "<%=d.value%>"); cbi_d_add("cbi-<%=self.config.."-"..section.."-"..self.option%>", "cbid.<%=self.config.."."..section.."."..d.field%>", "<%=d.value%>");
<%- end %> <%- end %>
</script> </script>
<%- end -%> <%- end %>

View file

@ -12,4 +12,5 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<td class="cbi-value-field" id="cbi-<%=self.config.."-"..section.."-"..self.option%>"> <td class="cbi-value-field" id="cbi-<%=self.config.."-"..section.."-"..self.option%>">

View file

@ -12,6 +12,7 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<%+cbi/valueheader%> <%+cbi/valueheader%>
<% if self.value then <% if self.value then
if type(self.value) == "function" then %> if type(self.value) == "function" then %>

View file

@ -12,10 +12,11 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<div> <div>
<input type="submit" value="<%:save%>" /> <input type="submit" value="<%:save%>" />
<input type="reset" value="<%:reset%>" /> <input type="reset" value="<%:reset%>" />
<script type="text/javascript">cbi_d_init();</script> <script type="text/javascript">cbi_d_init();</script>
</div> </div>
</form> </form>
<%+footer%> <%+footer%>

View file

@ -12,11 +12,21 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<% if #self.description > 0 then %><div class="cbi-value-description"><%=self.description%></div><% end %>
<% if #self.description > 0 then -%>
<div class="cbi-value-description"><%=self.description%></div>
<%- end %>
</div> </div>
<% if self.tag_invalid[section] then %><div class="cbi-error"><%:cbi_invalid%></div><% end %>
</div> <% if self.tag_invalid[section] then -%>
<% if #self.deps > 0 then %><script type="text/javascript"> <div class="cbi-error"><%:cbi_invalid%></div>
<% for j, d in ipairs(self.deps) do %>cbi_d_add("cbi-<%=self.config.."-"..section.."-"..self.option%>", "cbid.<%=self.config.."."..section.."."..d.field%>", "<%=d.value%>"); <%- end %>
<% end %> </div>
</script><% end %>
<% if #self.deps > 0 then -%>
<script type="text/javascript">
<% for j, d in ipairs(self.deps) do -%>
cbi_d_add("cbi-<%=self.config.."-"..section.."-"..self.option%>", "cbid.<%=self.config.."."..section.."."..d.field%>", "<%=d.value%>");
<%- end %>
</script>
<%- end %>

View file

@ -12,6 +12,7 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<div class="cbi-value" id="cbi-<%=self.config.."-"..section.."-"..self.option%>">
<label for="cbid.<%=self.config.."."..section.."."..self.option%>" class="cbi-value-title"><%=self.title%></label> <div class="cbi-value" id="cbi-<%=self.config.."-"..section.."-"..self.option%>">
<label class="cbi-value-title"<%= attr("for", cbid) %>><%=self.title%></label>
<div class="cbi-value-field"> <div class="cbi-value-field">

View file

@ -13,5 +13,5 @@ $Id$
-%> -%>
<%+cbi/valueheader%> <%+cbi/valueheader%>
<input onchange="cbi_d_update(this.id)" type="checkbox" id="cbid.<%=self.config.."."..section.."."..self.option%>" name="cbid.<%=self.config.."."..section.."."..self.option%>"<% if self:cfgvalue(section) == self.enabled then %> checked="checked"<% end %> value="1" /> <input onchange="cbi_d_update(this.id)" type="checkbox"<%= attr("id", cbid) .. attr("name", cbid) .. ifattr(self:cfgvalue(section) == self.enabled, "checked", "checked") %> value="1" />
<%+cbi/valuefooter%> <%+cbi/valuefooter%>

View file

@ -12,8 +12,9 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<%+header%> <%+header%>
<form method="post" action="<%=luci.http.getenv("REQUEST_URI")%>"> <form method="post" action="<%=luci.http.getenv("REQUEST_URI")%>">
<div> <div>
<script type="text/javascript" src="<%=resource%>/cbi.js"></script> <script type="text/javascript" src="<%=resource%>/cbi.js"></script>
<input type="hidden" name="cbi.submit" value="1" /> <input type="hidden" name="cbi.submit" value="1" />

View file

@ -14,17 +14,18 @@ $Id$
-%> -%>
<%+cbi/valueheader%> <%+cbi/valueheader%>
<% if self.widget == "select" then %> <% if self.widget == "select" then %>
<select onchange="cbi_d_update(this.id)" id="cbid.<%=self.config.."."..section.."."..self.option%>" name="cbid.<%=self.config.."."..section.."."..self.option%>"<% if self.size then %> size="<%=self.size%>"<% end %>> <select onchange="cbi_d_update(this.id)"<%= attr("id", cbid) .. attr("name", cbid) .. ifattr(self.size, "size") %>>
<%for i, key in pairs(self.keylist) do%> <% for i, key in pairs(self.keylist) do -%>
<option<% if self:cfgvalue(section) == key then %> selected="selected"<% end %> value="<%=key%>"><%=self.vallist[i]%></option> <option<%= attr("value", key) .. ifattr(self:cfgvalue(section) == key, "selected", "selected") %>><%=self.vallist[i]%></option>
<% end %> <%- end %>
</select> </select>
<% elseif self.widget == "radio" then <% elseif self.widget == "radio" then
local c = 0; local c = 0
for i, key in pairs(self.keylist) do for i, key in pairs(self.keylist) do
c = c + 1%> c = c + 1
<input type="radio" id="cbid.<%=self.config.."."..section.."."..self.option%>" name="cbid.<%=self.config.."."..section.."."..self.option%>"<% if self:cfgvalue(section) == key then %> checked="checked"<% end %> value="<%=key%>" /> %>
<label for="cbid.<%=self.config.."."..section.."."..self.option%>"><%=self.vallist[i]%></label><br /> <input type="radio"<%= attr("id", cbid..c) .. attr("name", cbid) .. attr("value", key) .. ifattr(self:cfgvalue(section) == key, "checked", "checked") %> />
<label<%= attr("for", cbid..c) %>><%=self.vallist[i]%></label><br />
<% if c == self.size then c = 0 %><br /> <% if c == self.size then c = 0 %><br />
<% end end %> <% end end %>
<% end %> <% end %>

View file

@ -12,9 +12,10 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<div class="cbi-map" id="cbi-<%=self.config%>">
<div class="cbi-map" id="cbi-<%=self.config%>">
<h1><%=self.title%></h1> <h1><%=self.title%></h1>
<div class="cbi-map-descr"><%=self.description%></div> <div class="cbi-map-descr"><%=self.description%></div>
<% self:render_children() %> <%- self:render_children() %>
<br /> <br />
</div> </div>

View file

@ -17,17 +17,18 @@ local v = self:valuelist(section)
%> %>
<%+cbi/valueheader%> <%+cbi/valueheader%>
<% if self.widget == "select" then %> <% if self.widget == "select" then %>
<select multiple="multiple" name="cbid.<%=self.config.."."..section.."."..self.option%>"<% if self.size then %> size="<%=self.size%>"<% end %>> <select multiple="multiple"<%= attr("name", cbid) .. ifattr(self.size, "size") %>>
<%for i, key in pairs(self.keylist) do %> <% for i, key in pairs(self.keylist) do -%>
<option<% if luci.util.contains(v, key) then %> selected="selected"<% end %> value="<%=key%>"><%=self.vallist[i]%></option> <option<%= attr("value", key) .. ifattr(luci.util.contains(v, key), "selected", "selected") %>><%=self.vallist[i]%></option>
<% end %> <%- end %>
</select> </select>
<% elseif self.widget == "checkbox" then <% elseif self.widget == "checkbox" then
local c = 0; local c = 0;
for i, key in pairs(self.keylist) do for i, key in pairs(self.keylist) do
c = c + 1%> c = c + 1
<input type="checkbox" id="cbid.<%=self.config.."."..section.."."..self.option.."."..i%>" name="cbid.<%=self.config.."."..section.."."..self.option%>"<% if luci.util.contains(v, key) then %> checked="checked"<% end %> value="<%=key%>" /> %>
<label for="cbid.<%=self.config.."."..section.."."..self.option.."."..i%>"><%=self.vallist[i]%></label><br /> <input type="checkbox"<%= attr("id", cbid..c) .. attr("name", cbid) .. attr("value", key) .. ifattr(luci.util.contains(v, key), "checked", "checked") />
<label<%= attr("for", cbid..c) %>><%=self.vallist[i]%></label><br />
<% if c == self.size then c = 0 %><br /> <% if c == self.size then c = 0 %><br />
<% end end %> <% end end %>
<% end %> <% end %>

View file

@ -12,18 +12,20 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<% if self:cfgvalue(self.section) then
section = self.section %> <% if self:cfgvalue(self.section) then section = self.section %>
<div class="cbi-section" id="cbi-<%=self.config%>-<%=section%>"> <div class="cbi-section" id="cbi-<%=self.config%>-<%=section%>">
<h2><%=self.title%></h2> <h2><%=self.title%></h2>
<div class="cbi-section-descr"><%=self.description%></div> <div class="cbi-section-descr"><%=self.description%></div>
<% if self.addremove then %><div class="cbi-section-remove right"> <% if self.addremove then -%>
<div class="cbi-section-remove right">
<input type="submit" name="cbi.rns.<%=self.config%>.<%=section%>" value="<%:cbi_del%>" /> <input type="submit" name="cbi.rns.<%=self.config%>.<%=section%>" value="<%:cbi_del%>" />
</div><% end %> </div>
<div class="cbi-section-node" id="cbi-<%=self.config%>-<%=section%>"> <%- end %>
<%+cbi/ucisection%> <div class="cbi-section-node" id="cbi-<%=self.config%>-<%=section%>">
</div> <%+cbi/ucisection%>
<br /> </div>
<br />
</div> </div>
<% elseif self.addremove then %> <% elseif self.addremove then %>
<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.section%>"> <div class="cbi-section" id="cbi-<%=self.config%>-<%=self.section%>">

View file

@ -12,7 +12,8 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.sectiontype%>">
<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.sectiontype%>">
<h2><%=self.title%></h2> <h2><%=self.title%></h2>
<div class="cbi-section-descr"><%=self.description%></div> <div class="cbi-section-descr"><%=self.description%></div>
<div class="cbi-section-node"> <div class="cbi-section-node">
@ -72,4 +73,4 @@ $Id$
<%- end -%> <%- end -%>
</table> </table>
</div> </div>
</div> </div>

View file

@ -12,28 +12,36 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.sectiontype%>">
<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.sectiontype%>">
<h2><%=self.title%></h2> <h2><%=self.title%></h2>
<div class="cbi-section-descr"><%=self.description%></div> <div class="cbi-section-descr"><%=self.description%></div>
<% for i, k in ipairs(self:cfgsections()) do%> <% for i, k in ipairs(self:cfgsections()) do -%>
<% if self.addremove then %><div class="cbi-section-remove right"> <% if self.addremove then -%>
<div class="cbi-section-remove right">
<input type="submit" name="cbi.rts.<%=self.config%>.<%=k%>" value="<%:cbi_del%>" /> <input type="submit" name="cbi.rts.<%=self.config%>.<%=k%>" value="<%:cbi_del%>" />
</div><% end %> </div>
<%- end %>
<% if not self.anonymous then %><h3><%=k%></h3><% end %> <% if not self.anonymous then %><h3><%=k%></h3><% end %>
<% section = k %> <% section = k %>
<div class="cbi-section-node" id="cbi-<%=self.config%>-<%=section%>"> <div class="cbi-section-node" id="cbi-<%=self.config%>-<%=section%>">
<%+cbi/ucisection%> <%+cbi/ucisection%>
</div> </div>
<br /> <br />
<% end %> <%- end %>
<% if self.addremove then %>
<% if self.addremove then -%>
<div class="cbi-section-create"> <div class="cbi-section-create">
<% if self.anonymous then %> <% if self.anonymous then -%>
<input type="submit" name="cbi.cts.<%=self.config%>.<%=self.sectiontype%>" value="<%:cbi_add%>" /> <input type="submit" name="cbi.cts.<%=self.config%>.<%=self.sectiontype%>" value="<%:cbi_add%>" />
<% else %> <%- else -%>
<input type="text" class="cbi-section-create-name" name="cbi.cts.<%=self.config%>.<%=self.sectiontype%>" /> <input type="text" class="cbi-section-create-name" name="cbi.cts.<%=self.config%>.<%=self.sectiontype%>" />
<input type="submit" value="<%:cbi_add%>" /> <input type="submit" value="<%:cbi_add%>" />
<% end %><% if self.err_invalid then %><div class="cbi-error"><%:cbi_invalid%></div><% end %> <%- end %>
<% if self.err_invalid then -%>
<div class="cbi-error"><%:cbi_invalid%></div>
<%- end %>
</div> </div>
<% end %> <%- end %>
</div> </div>

View file

@ -12,8 +12,10 @@ You may obtain a copy of the License at
$Id$ $Id$
-%> -%>
<% self:render_children(section, scope or {}) %> <% self:render_children(section, scope or {}) %>
<% if #self.optionals[section] > 0 or self.dynamic then %>
<% if #self.optionals[section] > 0 or self.dynamic then %>
<div class="cbi-optionals"> <div class="cbi-optionals">
<% if self.dynamic then %> <% if self.dynamic then %>
<input type="text" name="cbi.opt.<%=self.config%>.<%=section%>" /> <input type="text" name="cbi.opt.<%=self.config%>.<%=section%>" />
@ -31,4 +33,4 @@ $Id$
<% end %> <% end %>
<input type="submit" value="<%:add%>" /> <input type="submit" value="<%:add%>" />
</div> </div>
<% end %> <% end %>

View file

@ -13,5 +13,5 @@ $Id$
-%> -%>
<%+cbi/valueheader%> <%+cbi/valueheader%>
<input type="text" onchange="cbi_d_update(this.id)" <% if self.size then %>size="<%=self.size%>" <% end %><% if self.maxlength then %>maxlength="<%=self.maxlength%>" <% end %>name="cbid.<%=self.config.."."..section.."."..self.option%>" id="cbid.<%=self.config.."."..section.."."..self.option%>" value="<%=self:cfgvalue(section)%>" /> <input type="text" onchange="cbi_d_update(this.id)"<%= attr("name", cbid) .. attr("id", cbid) .. attr("value", self:cfgvalue(section)) .. ifattr(self.size, "size") .. ifattr(self.maxlength, "maxlength") %> />
<%+cbi/valuefooter%> <%+cbi/valuefooter%>