libs/cbi: various widget fixes
This commit is contained in:
parent
0533309ef2
commit
988de587ee
4 changed files with 22 additions and 18 deletions
|
@ -15,48 +15,51 @@ $Id$
|
||||||
|
|
||||||
<%-
|
<%-
|
||||||
local utl = require "luci.util"
|
local utl = require "luci.util"
|
||||||
local wba = require "luci.tools.webadmin"
|
|
||||||
local wbi = require "luci.tools.webadmin_interfaces"
|
|
||||||
local fwm = require "luci.model.firewall"
|
local fwm = require "luci.model.firewall"
|
||||||
|
local nwm = require "luci.model.network"
|
||||||
|
|
||||||
wbi.init(self.map.uci)
|
local zone, net, iface
|
||||||
|
|
||||||
local zone, iface, ifname
|
|
||||||
local zones = fwm:get_zones()
|
local zones = fwm:get_zones()
|
||||||
local value = self:cfgvalue(section) or self.default
|
local value = self:cfgvalue(section) or self.default
|
||||||
|
local selected = false
|
||||||
|
|
||||||
if value and #value == 0 then value = nil end
|
if value and #value == 0 then value = nil end
|
||||||
-%>
|
-%>
|
||||||
|
|
||||||
<ul style="margin:0; list-style-type:none">
|
<ul style="margin:0; list-style-type:none">
|
||||||
<% for _, zone in utl.spairs(zones, function(a,b) return (zones[a]:name() < zones[b]:name()) end) do %>
|
<%
|
||||||
|
for _, zone in utl.spairs(zones, function(a,b) return (zones[a]:name() < zones[b]:name()) end) do
|
||||||
|
selected = selected or (value == zone:name())
|
||||||
|
%>
|
||||||
<li style="padding:0.5em">
|
<li style="padding:0.5em">
|
||||||
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="radio"<%=attr("id", cbid .. "." .. zone:name()) .. attr("name", cbid) .. attr("value", zone:name()) .. ifattr(value == zone:name(), "checked", "checked")%> />
|
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="radio"<%=attr("id", cbid .. "." .. zone:name()) .. attr("name", cbid) .. attr("value", zone:name()) .. ifattr(value == zone:name(), "checked", "checked")%> />
|
||||||
<label<%=attr("for", cbid .. "." .. zone:name())%> style="background-color:<%=zone:get_color()%>; padding:0.5em">
|
<label<%=attr("for", cbid .. "." .. zone:name())%> style="background-color:<%=zone:get_color()%>; padding:0.5em">
|
||||||
<strong><%=zone:name()%>:</strong>
|
<strong><%=zone:name()%>:</strong>
|
||||||
<%
|
<%
|
||||||
local empty = true
|
local empty = true
|
||||||
for _, iface in ipairs(zone:get_networks()) do
|
for _, net in ipairs(zone:get_networks()) do
|
||||||
local ifname = wbi.network_get_ifname(iface)
|
net = nwm:get_network(net)
|
||||||
local dev = wbi.iface_get_list()[ifname]
|
for _, iface in ipairs(net and net:get_interfaces() or {}) do
|
||||||
|
if not iface:is_bridgeport() then
|
||||||
|
empty = false
|
||||||
%>
|
%>
|
||||||
<% if ifname and dev then empty = false %>
|
<img title="<%=iface:get_type_i18n()%>" style="width:16px; height:16px; vertical-align:middle" src="<%=resource%>/icons/<%=iface:type()%><%=iface:is_up() and "" or "_disabled"%>.png" />
|
||||||
<img title="<%=wbi.iface_format_type(dev.type)%>" style="width:16px; height:16px; vertical-align:middle" src="<%=resource%>/icons/<%=dev.type or "ethernet"%><%=dev.flags and dev.flags.up and "" or "_disabled"%>.png" />
|
<% if iface:name() == self.iface then %><strong><%=iface:name()%></strong><% else %><%=iface:name()%><% end %>
|
||||||
<% if iface == self.iface then %><strong><%=ifname%></strong><% else %><%=ifname%><% end %>
|
<% end end end %>
|
||||||
<% end %>
|
|
||||||
<% end %>
|
|
||||||
<% if empty then %><em><%:a_s_ipt_zone_empty (no interfaces attached)%></em><% end %>
|
<% if empty then %><em><%:a_s_ipt_zone_empty (no interfaces attached)%></em><% end %>
|
||||||
</label>
|
</label>
|
||||||
</li>
|
</li>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
|
<% if not self.nocreate then %>
|
||||||
<li style="padding:0.5em">
|
<li style="padding:0.5em">
|
||||||
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="radio"<%=attr("id", cbid .. "_new") .. attr("name", cbid) .. attr("value", "-") .. ifattr(not value, "checked", "checked")%> />
|
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="radio"<%=attr("id", cbid .. "_new") .. attr("name", cbid) .. attr("value", "-") .. ifattr(not selected, "checked", "checked")%> />
|
||||||
<div style="background-color:<%=fwm.zone.get_color()%>; padding:0.5em; display:inline">
|
<div style="background-color:<%=fwm.zone.get_color()%>; padding:0.5em; display:inline">
|
||||||
<label<%=attr("for", cbid .. "_new")%>><em><%:a_s_ipt_zone_unspec_create unspecified -or- create:%> </em></label>
|
<label<%=attr("for", cbid .. "_new")%>><em><%:a_s_ipt_zone_unspec_create unspecified -or- create:%> </em></label>
|
||||||
<input style="width:6em" type="text"<%=attr("name", cbid .. ".newzone")%> onfocus="document.getElementById('<%=cbid%>_new').checked=true" />
|
<input style="width:6em" type="text"<%=attr("name", cbid .. ".newzone") .. ifattr(not selected, "value", self.default)%> onfocus="document.getElementById('<%=cbid%>_new').checked=true" />
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
<% end %>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<%+cbi/valuefooter%>
|
<%+cbi/valuefooter%>
|
||||||
|
|
|
@ -13,5 +13,5 @@ $Id$
|
||||||
|
|
||||||
-%>
|
-%>
|
||||||
<%+cbi/valueheader%>
|
<%+cbi/valueheader%>
|
||||||
<input class="cbi-input-checkbox" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="checkbox"<%= attr("id", cbid) .. attr("name", cbid) .. ifattr(self:cfgvalue(section) == self.enabled, "checked", "checked") %> value="1" />
|
<input class="cbi-input-checkbox" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)" type="checkbox"<%= attr("id", cbid) .. attr("name", cbid) .. ifattr((self:cfgvalue(section) or self.default) == self.enabled, "checked", "checked") %> value="1" />
|
||||||
<%+cbi/valuefooter%>
|
<%+cbi/valuefooter%>
|
||||||
|
|
|
@ -22,6 +22,7 @@ $Id$
|
||||||
local value = (self:cfgvalue(section) or self.default or "")
|
local value = (self:cfgvalue(section) or self.default or "")
|
||||||
local checked = { }
|
local checked = { }
|
||||||
|
|
||||||
|
if type(value) == "table" then value = table.concat(value, " ") end
|
||||||
for value in value:gmatch("%S+") do
|
for value in value:gmatch("%S+") do
|
||||||
checked[value] = true
|
checked[value] = true
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,7 +13,7 @@ $Id$
|
||||||
|
|
||||||
-%>
|
-%>
|
||||||
<%+cbi/valueheader%>
|
<%+cbi/valueheader%>
|
||||||
<input type="<%=self.password and 'password" class="cbi-input-password' or 'text" class="cbi-input-text' %>" onchange="cbi_d_update(this.id)"<%= attr("name", cbid) .. attr("id", cbid) .. attr("value", self:cfgvalue(section)) .. ifattr(self.size, "size")%> />
|
<input type="<%=self.password and 'password" class="cbi-input-password' or 'text" class="cbi-input-text' %>" onchange="cbi_d_update(this.id)"<%= attr("name", cbid) .. attr("id", cbid) .. attr("value", self:cfgvalue(section) or self.default) .. ifattr(self.size, "size")%> />
|
||||||
<% if #self.keylist > 0 then -%>
|
<% if #self.keylist > 0 then -%>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
cbi_combobox_init('<%=cbid%>', {
|
cbi_combobox_init('<%=cbid%>', {
|
||||||
|
|
Loading…
Reference in a new issue