libs/cbi: various widget fixes
authorJo-Philipp Wich <jow@openwrt.org>
Sat, 10 Oct 2009 14:47:37 +0000 (14:47 +0000)
committerJo-Philipp Wich <jow@openwrt.org>
Sat, 10 Oct 2009 14:47:37 +0000 (14:47 +0000)
libs/cbi/luasrc/view/cbi/firewall_zonelist.htm
libs/cbi/luasrc/view/cbi/fvalue.htm
libs/cbi/luasrc/view/cbi/network_ifacelist.htm
libs/cbi/luasrc/view/cbi/value.htm

index 847010b7cbe0f35d26d5179ba696348c66bfb4f1..26c46cb549565efd503d1db2f5773ebe8140205e 100644 (file)
@@ -15,48 +15,51 @@ $Id$
 
 <%-
        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 nwm = require "luci.model.network"
 
-       wbi.init(self.map.uci)
-
-       local zone, iface, ifname
+       local zone, net, iface
        local zones = fwm:get_zones()
        local value = self:cfgvalue(section) or self.default
+       local selected = false
 
        if value and #value == 0 then value = nil end
 -%>
 
 <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">
                <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")%> /> &nbsp;
                <label<%=attr("for", cbid .. "." .. zone:name())%> style="background-color:<%=zone:get_color()%>; padding:0.5em">
                        <strong><%=zone:name()%>:</strong>
                        <%
                                local empty = true
-                               for _, iface in ipairs(zone:get_networks()) do
-                                       local ifname = wbi.network_get_ifname(iface)
-                                       local dev    = wbi.iface_get_list()[ifname]
+                               for _, net in ipairs(zone:get_networks()) do
+                                       net = nwm:get_network(net)
+                                       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="<%=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 == self.iface then %><strong><%=ifname%></strong><% else %><%=ifname%><% end %> &nbsp;
-                               <% end %>
-                       <% 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" />
+                               <% if iface:name() == self.iface then %><strong><%=iface:name()%></strong><% else %><%=iface:name()%><% end %> &nbsp;
+                       <% end end end %>
                        <% if empty then %><em><%:a_s_ipt_zone_empty (no interfaces attached)%></em><% end %>
                </label>
        </li>
        <% end %>
 
+       <% if not self.nocreate then %>
        <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")%> /> &nbsp;
+               <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")%> /> &nbsp;
                <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:%>&nbsp;</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>
        </li>
+       <% end %>
 </ul>
 
 <%+cbi/valuefooter%>
index b46817c6f77618d49d7728e1ef497075eb004eaf..35ebac6e1c9e9ed55492121ed3598ac61dd37795 100644 (file)
@@ -13,5 +13,5 @@ $Id$
 
 -%>
 <%+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%>
index b3a61fa6ad89a4dda6e58cdb33c587ca5e527c20..00bb83a2e4443dcbd08c53cef186c9e9b14b8143 100644 (file)
@@ -22,6 +22,7 @@ $Id$
        local value = (self:cfgvalue(section) or self.default or "")
        local checked = { }
 
+       if type(value) == "table" then value = table.concat(value, " ") end
        for value in value:gmatch("%S+") do
                checked[value] = true
        end
index e6a7ab6d9fd092623ca4576b7d17f13c245f2cf0..de083e62cf7f8e4436e34f3c5e96e1b5887693ec 100644 (file)
@@ -13,7 +13,7 @@ $Id$
 
 -%>
 <%+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 -%>
        <script type="text/javascript">
                cbi_combobox_init('<%=cbid%>', {