summaryrefslogtreecommitdiffhomepage
path: root/libs
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-11-07 20:01:12 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-11-07 20:01:12 +0000
commitd26ceda459234aa239f43a3744181ddbe5a6adfe (patch)
tree60f508456588e20de1123bca072b791fa60ed439 /libs
parentbfb0bb3f8d0b66198cbabbc79c005cded57738e8 (diff)
libs/web: support local destination in zonelist widget
Diffstat (limited to 'libs')
-rw-r--r--libs/web/luasrc/view/cbi/firewall_zonelist.htm28
1 files changed, 18 insertions, 10 deletions
diff --git a/libs/web/luasrc/view/cbi/firewall_zonelist.htm b/libs/web/luasrc/view/cbi/firewall_zonelist.htm
index 891c70e77..037b75081 100644
--- a/libs/web/luasrc/view/cbi/firewall_zonelist.htm
+++ b/libs/web/luasrc/view/cbi/firewall_zonelist.htm
@@ -21,23 +21,31 @@ $Id$
local zone, net, iface
local zones = fwm:get_zones()
local value = self:formvalue(section)
- if not value or value == "-" then value = self:cfgvalue(section) or self.default end
+ if not value or value == "-" then
+ value = self:cfgvalue(section) or self.default
+ end
local selected = false
local checked = { }
- if value and #value == 0 then
- value = nil
- elseif type(value) == "table" then
- for _, value in ipairs(value) do
- checked[value] = true
- end
- elseif value then
+ for value in utl.imatch(value) do
checked[value] = true
end
+
+ if not next(checked) then
+ checked[""] = true
+ end
-%>
<ul style="margin:0; list-style-type:none; text-align:left">
+ <% if self.allowlocal then %>
+ <li style="padding:0.5em">
+ <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 .. "_empty") .. attr("name", cbid) .. attr("value", "") .. ifattr(checked[""], "checked", "checked")%> /> &nbsp;
+ <label<%=attr("for", cbid .. "_empty")%> style="background-color:<%=fwm.zone.get_color()%>; padding:0.5em">
+ <strong><%:Device%></strong>
+ </label>
+ </li>
+ <% end %>
<%
for _, zone in utl.spairs(zones, function(a,b) return (zones[a]:name() < zones[b]:name()) end) do
if zone:name() ~= self.exclude then
@@ -67,10 +75,10 @@ $Id$
%>
<img<%=attr("title", iface:get_i18n())%> style="width:16px; height:16px; vertical-align:middle" src="<%=resource%>/icons/<%=iface:type()%><%=iface:is_up() and "" or "_disabled"%>.png" />
<% end %>
- <% if nempty then %><em><%:(no interfaces attached)%></em><% end %>
+ <% if nempty then %><em><%:(empty)%></em><% end %>
</span>
<% end end %>
- <% if zempty then %><em><%:(no interfaces attached)%></em><% end %>
+ <% if zempty then %><em><%:(empty)%></em><% end %>
</label>
</li>
<% end end %>