libs/web: use imatch() in model related widgets, support multivalues in netlist widget
This commit is contained in:
parent
95886d4585
commit
fc5b9e27f0
3 changed files with 27 additions and 11 deletions
|
@ -15,8 +15,8 @@ $Id$
|
|||
|
||||
<%-
|
||||
local utl = require "luci.util"
|
||||
local fwm = require "luci.model.firewall"
|
||||
local nwm = require "luci.model.network"
|
||||
local fwm = require "luci.model.firewall".init()
|
||||
local nwm = require "luci.model.network".init()
|
||||
|
||||
local zone, net, iface
|
||||
local zones = fwm:get_zones()
|
||||
|
@ -33,7 +33,7 @@ $Id$
|
|||
checked[value] = true
|
||||
end
|
||||
elseif value then
|
||||
checked[value] = true
|
||||
checked[value] = true
|
||||
end
|
||||
-%>
|
||||
|
||||
|
|
|
@ -14,16 +14,16 @@ $Id$
|
|||
<%+cbi/valueheader%>
|
||||
|
||||
<%-
|
||||
local net = require "luci.model.network"
|
||||
local utl = require "luci.util"
|
||||
local net = require "luci.model.network".init()
|
||||
|
||||
local iface
|
||||
local ifaces = net:get_interfaces()
|
||||
local value = (self:formvalue(section) or self.default or "")
|
||||
local value = (self:formvalue(section) or self.default)
|
||||
local checked = { }
|
||||
|
||||
if value and #value > 0 then
|
||||
if type(value) == "table" then value = table.concat(value, " ") end
|
||||
for value in value:gmatch("%S+") do
|
||||
if value then
|
||||
for value in utl.imatch(value) do
|
||||
checked[value] = true
|
||||
end
|
||||
else
|
||||
|
@ -42,7 +42,12 @@ $Id$
|
|||
local link = iface:adminlink()
|
||||
if not self.nobridges or not iface:is_bridge() then %>
|
||||
<li>
|
||||
<input class="cbi-input-<%=self.widget or "radio"%>" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)"<%=attr("type", self.widget or "radio") .. attr("id", cbid .. "." .. iface:name()) .. attr("name", cbid) .. attr("value", iface:name()) .. ifattr(checked[iface:name()], "checked", "checked")%> />
|
||||
<input class="cbi-input-<%=self.widget or "radio"%>" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)"<%=
|
||||
attr("type", self.widget or "radio") ..
|
||||
attr("id", cbid .. "." .. iface:name()) ..
|
||||
attr("name", cbid) .. attr("value", iface:name()) ..
|
||||
ifattr(checked[iface:name()], "checked", "checked")
|
||||
%> />
|
||||
<label<%=attr("for", cbid .. "." .. iface:name())%>>
|
||||
<% if link then -%><a href="<%=link%>"><% end -%>
|
||||
<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" />
|
||||
|
|
|
@ -14,7 +14,8 @@ $Id$
|
|||
<%+cbi/valueheader%>
|
||||
|
||||
<%-
|
||||
local nwm = require "luci.model.network"
|
||||
local utl = require "luci.util"
|
||||
local nwm = require "luci.model.network".init()
|
||||
|
||||
local net, iface
|
||||
local networks = nwm:get_networks()
|
||||
|
@ -23,13 +24,23 @@ $Id$
|
|||
if not value or value == "-" then
|
||||
value = self:cfgvalue(section) or self.default
|
||||
end
|
||||
|
||||
local checked = { }
|
||||
for value in utl.imatch(value) do
|
||||
checked[value] = true
|
||||
end
|
||||
-%>
|
||||
|
||||
<ul style="margin:0; list-style-type:none; text-align:left">
|
||||
<% for _, net in ipairs(networks) do
|
||||
if net:name() ~= "loopback" then %>
|
||||
<li style="padding:0.25em 0">
|
||||
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)"<%=attr("type", self.widget or "radio") .. attr("id", cbid .. "." .. net:name()) .. attr("name", cbid) .. attr("value", net:name()) .. ifattr(value == net:name(), "checked", "checked")%> />
|
||||
<input class="cbi-input-radio" onclick="cbi_d_update(this.id)" onchange="cbi_d_update(this.id)"<%=
|
||||
attr("type", self.widget or "radio") ..
|
||||
attr("id", cbid .. "." .. net:name()) ..
|
||||
attr("name", cbid) .. attr("value", net:name()) ..
|
||||
ifattr(checked[net:name()], "checked", "checked")
|
||||
%> />
|
||||
<label<%=attr("for", cbid .. "." .. net:name())%>>
|
||||
<span style="background-color:#FFFFFF; border:1px solid #CCCCCC; padding:2px"><%=net:name()%>:
|
||||
<%
|
||||
|
|
Loading…
Reference in a new issue