summaryrefslogtreecommitdiffstats
path: root/modules/luci-compat/luasrc/view/cbi/firewall_zonelist.htm
blob: 69737de452b3167c09f78d152295224e09ea4a69 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<%+cbi/valueheader%>

<%-
	local utl = require "luci.util"
	local fwm = require "luci.model.firewall".init()
	local nwm = require "luci.model.network".init()

	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

	local selected = false
	local checked = { }

	for value in utl.imatch(value) do
		checked[value] = true
	end

	if not next(checked) then
		checked[""] = true
	end
-%>

<div class="cbi-dropdown" dropdown-items="5" placeholder="<%:-- please select -- %>"<%=
	attr("name", cbid) ..
	ifattr(self.widget == "checkbox", "multiple", "multiple") ..
	ifattr(self.rmempty or self.optional, "optional", "optional")
%>>
	<script type="item-template"><!--
		<li data-value="{{value}}">
			<span class="zonebadge" style="background:repeating-linear-gradient(45deg,rgba(204,204,204,0.5),rgba(204,204,204,0.5) 5px,rgba(255,255,255,0.5) 5px,rgba(255,255,255,0.5) 10px)">
				<strong>{{value}}:</strong><em>(<%:create%>)</em>
			</span>
		</li>
	--></script>
	<ul>
		<% if self.allowlocal then %>
		<li data-value=""<%=ifattr(checked[""], "selected", "selected")%>>
			<span style="background-color:<%=fwm.zone.get_color()%>" class="zonebadge">
				<strong><%:Device%></strong>
				<% if self.allowany and self.allowlocal then -%>
					(<%= self.alias ~= "dest"
						and translate("output") or translate("input") %>)
				<%- end %>
			</span>
		</li>
		<% elseif self.widget ~= "checkbox" and (self.rmempty or self.optional) then %>
		<li data-value=""<%=ifattr(checked[""], "selected", "selected")%>>
			<span class="zonebadge">
				<em><%:unspecified%></em>
			</span>
		</li>
		<% end %>
		<% if self.allowany then %>
		<li data-value="*"<%=ifattr(checked["*"], "selected", "selected")%>>
			<span style="background-color:<%=fwm.zone.get_color()%>" class="zonebadge">
				<strong><%:Any zone%></strong>
				<% if self.allowany and self.allowlocal then %>(<%:forward%>)<% end %>
			</span>
		</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
					selected = selected or (value == zone:name())
		%>
		<li<%=attr("data-value", zone:name()) .. ifattr(checked[zone:name()], "selected", "selected")%>>
			<span style="background-color:<%=zone:get_color()%>" class="zonebadge">
				<strong><%=zone:name()%>:</strong>
				<%-
					local zempty = true
					for _, net in ipairs(zone:get_networks()) do
						net = nwm:get_network(net)
						if net then
							zempty = false
				-%>
					<span class="ifacebadge<% if net:name() == self.network then %> ifacebadge-active<% end %>"><%=net:name()%>:
					<%-
						local nempty = true
						for _, iface in ipairs(net:is_bridge() and net:get_interfaces() or { net:get_interface() }) do
							nempty = false
					%>
						<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"%>.svg" />
					<% end %>
					<% if nempty then %><em><%:(empty)%></em><% end -%>
					</span>
				<%- end end -%>
				<%- if zempty then %><em><%:(empty)%></em><% end -%>
			</span>
		</li>
		<% end end %>

		<% if self.widget ~= "checkbox" and not self.nocreate then %>
		<li data-value="-">
			<span class="zonebadge">
				<em><%:create%>:</em>
				<input type="password" style="display:none" />
				<input class="create-item-input" type="text" data-type="and(uciname,maxlength(11))" data-optional="true" />
			</span>
		</li>
		<% end %>
	</ul>
</div>

<%+cbi/valuefooter%>