treewide: always include cbi.js
[project/luci.git] / modules / luci-mod-admin-full / luasrc / view / admin_system / packages.htm
1 <%#
2 Copyright 2008 Steven Barth <steven@midlink.org>
3 Copyright 2008-2010 Jo-Philipp Wich <jow@openwrt.org>
4 Licensed to the public under the Apache License 2.0.
5 -%>
6
7 <%-
8 local opkg = require "luci.model.ipkg"
9 local fs = require "nixio.fs"
10 local wa = require "luci.tools.webadmin"
11 local rowcnt = 1
12
13 function rowstyle()
14 rowcnt = rowcnt + 1
15 return (rowcnt % 2) + 1
16 end
17
18 local fstat = fs.statvfs(opkg.overlay_root())
19 local space_total = fstat and fstat.blocks or 0
20 local space_free = fstat and fstat.bfree or 0
21 local space_used = space_total - space_free
22
23 local used_perc = math.floor(0.5 + ((space_total > 0) and ((100 / space_total) * space_used) or 100))
24 local free_byte = space_free * fstat.frsize
25
26 local filter = { }
27
28
29 local opkg_list = luci.model.ipkg.list_all
30 local querypat
31 if query and #query > 0 then
32 querypat = '*%s*' % query
33 opkg_list = luci.model.ipkg.find
34 end
35
36 local letterpat
37 if letter == 35 then
38 letterpat = "[^a-z]*"
39 else
40 letterpat = string.char(letter, 42) -- 'A' '*'
41 end
42
43 -%>
44
45 <%+header%>
46
47
48 <h2 name="content"><%:Software%></h2>
49
50 <div class="cbi-map">
51
52 <ul class="cbi-tabmenu">
53 <li class="cbi-tab"><a href="#"><%:Actions%></a></li>
54 <li class="cbi-tab-disabled"><a href="<%=REQUEST_URI%>/ipkg"><%:Configuration%></a></li>
55 </ul>
56
57 <form method="post" action="<%=REQUEST_URI%>">
58 <input type="hidden" name="exec" value="1" />
59 <input type="hidden" name="token" value="<%=token%>" />
60
61 <div class="cbi-section">
62 <div class="cbi-section-node">
63 <% if (install and next(install)) or (remove and next(remove)) or update or upgrade then %>
64 <div class="cbi-value">
65 <% if #stdout > 0 then %><pre><%=pcdata(stdout)%></pre><% end %>
66 <% if #stderr > 0 then %><pre class="error"><%=pcdata(stderr)%></pre><% end %>
67 </div>
68 <% end %>
69
70 <% if querypat then %>
71 <div class="cbi-value">
72 <%:Displaying only packages containing%> <strong>"<%=pcdata(query)%>"</strong>
73 <input type="button" onclick="location.href='?display=<%=luci.http.urlencode(display)%>'" href="#" class="cbi-button cbi-button-reset" style="margin-left:1em" value="<%:Reset%>" />
74 <br style="clear:both" />
75 </div>
76 <% end %>
77
78 <% if no_lists or old_lists then %>
79 <div class="cbi-value">
80 <% if old_lists then %>
81 <%:Package lists are older than 24 hours%>
82 <% else %>
83 <%:No package lists available%>
84 <% end %>
85 <input type="submit" name="update" href="#" class="cbi-button cbi-button-apply" style="margin-left:3em" value="<%:Update lists%>" />
86 </div>
87 <% end %>
88
89 <div class="cbi-value cbi-value-last">
90 <%:Free space%>: <strong><%=(100-used_perc)%>%</strong> (<strong><%=wa.byte_format(free_byte)%></strong>)
91 <div style="margin:3px 0; width:300px; height:10px; border:1px solid #000000; background-color:#80C080">
92 <div style="background-color:#F08080; border-right:1px solid #000000; height:100%; width:<%=used_perc%>%">&#160;</div>
93 </div>
94 </div>
95 </div>
96
97 <br />
98
99 <div class="cbi-section-node">
100 <input type="hidden" name="display" value="<%=pcdata(display)%>" />
101
102 <div class="cbi-value">
103 <label class="cbi-value-title"><%:Download and install package%>:</label>
104 <div class="cbi-value-field">
105 <input type="text" name="url" size="30" value="" />
106 <input class="cbi-button cbi-button-save" type="submit" name="go" value="<%:OK%>" />
107 </div>
108 </div>
109
110 <div class="cbi-value cbi-value-last">
111 <label class="cbi-value-title"><%:Filter%>:</label>
112 <div class="cbi-value-field">
113 <input type="text" name="query" size="20" value="<%=pcdata(query)%>" />
114 <input type="submit" class="cbi-button cbi-button-action" name="search" value="<%:Find package%>" />
115 </div>
116 </div>
117 </div>
118 </div>
119 </form>
120
121
122 <h3><%:Status%></h3>
123
124
125 <ul class="cbi-tabmenu">
126 <li class="cbi-tab<% if display ~= "available" then %>-disabled<% end %>"><a href="?display=available&amp;query=<%=pcdata(query)%>"><%:Available packages%><% if query then %> (<%=pcdata(query)%>)<% end %></a></li>
127 <li class="cbi-tab<% if display ~= "installed" then %>-disabled<% end %>"><a href="?display=installed&amp;query=<%=pcdata(query)%>"><%:Installed packages%><% if query then %> (<%=pcdata(query)%>)<% end %></a></li>
128 </ul>
129
130 <% if display ~= "available" then %>
131 <div class="cbi-section">
132 <div class="cbi-section-node">
133 <div class="table">
134 <div class="tr cbi-section-table-titles">
135 <div class="th left"><%:Package name%></div>
136 <div class="th left"><%:Version%></div>
137 <div class="th cbi-section-actions">&#160;</div>
138 </div>
139 <% local empty = true; luci.model.ipkg.list_installed(querypat, function(n, v, s, d) empty = false; filter[n] = true %>
140 <div class="tr cbi-rowstyle-<%=rowstyle()%>">
141 <div class="td left"><%=luci.util.pcdata(n)%></div>
142 <div class="td left"><%=luci.util.pcdata(v)%></div>
143 <div class="td cbi-section-actions">
144 <form method="post" class="inline" action="<%=REQUEST_URI%>">
145 <input type="hidden" name="exec" value="1" />
146 <input type="hidden" name="token" value="<%=token%>" />
147 <input type="hidden" name="remove" value="<%=pcdata(n)%>" />
148 <input class="cbi-button cbi-button-remove" type="submit" onclick="window.confirm('<%:Remove%> &quot;<%=luci.util.pcdata(n)%>&quot; ?') &#38;&#38; this.parentNode.submit(); return false" value="<%:Remove%>" />
149 </form>
150 </div>
151 </div>
152 <% end) %>
153 <% if empty then %>
154 <div class="tr cbi-section-table-row">
155 <div class="td left">&#160;</div>
156 <div class="td left"><em><%:none%></em></div>
157 <div class="td left"><em><%:none%></em></div>
158 </div>
159 <% end %>
160 </div>
161 </div>
162 </div>
163 <% else %>
164 <div class="cbi-section">
165 <% if not querypat then %>
166 <ul class="cbi-tabmenu" style="flex-wrap:wrap">
167 <% local i; for i = 65, 90 do %>
168 <li class="cbi-tab<% if letter ~= i then %>-disabled<% end %>"><a href="?display=available&amp;letter=<%=string.char(i)%>"><%=string.char(i)%></a></li>
169 <% end %>
170 <li class="cbi-tab<% if letter ~= 35 then %>-disabled<% end %>"><a href="?display=available&amp;letter=%23">#</a></li>
171 </ul>
172 <% end %>
173 <div class="cbi-section-node cbi-section-node-tabbed">
174 <div class="table">
175 <div class="tr cbi-section-table-titles">
176 <div class="th col-2 left"><%:Package name%></div>
177 <div class="th col-2 left"><%:Version%></div>
178 <div class="th col-1 center"><%:Size (.ipk)%></div>
179 <div class="th col-10 left"><%:Description%></div>
180 <div class="th cbi-section-actions">&#160;</div>
181 </div>
182 <% local empty = true; opkg_list(querypat or letterpat, function(n, v, s, d) if filter[n] then return end; empty = false %>
183 <div class="tr cbi-rowstyle-<%=rowstyle()%>">
184 <div class="td col-2 left"><%=luci.util.pcdata(n)%></div>
185 <div class="td col-2 left"><%=luci.util.pcdata(v)%></div>
186 <div class="td col-1 center"><%=luci.util.pcdata(s)%></div>
187 <div class="td col-10 left"><%=luci.util.pcdata(d)%></div>
188 <div class="td cbi-section-actions">
189 <form method="post" class="inline" action="<%=REQUEST_URI%>">
190 <input type="hidden" name="exec" value="1" />
191 <input type="hidden" name="token" value="<%=token%>" />
192 <input type="hidden" name="install" value="<%=pcdata(n)%>" />
193 <input class="cbi-button cbi-button-apply" type="submit" onclick="window.confirm('<%:Install%> &quot;<%=luci.util.pcdata(n)%>&quot; ?') &#38;&#38; this.parentNode.submit(); return false" value="<%:Install%>" />
194 </form>
195 </div>
196 </div>
197 <% end) %>
198 <% if empty then %>
199 <div class="tr">
200 <div class="td left">&#160;</div>
201 <div class="td left"><em><%:none%></em></div>
202 <div class="td left"><em><%:none%></em></div>
203 <div class="td right"><em><%:none%></em></div>
204 <div class="td left"><em><%:none%></em></div>
205 </div>
206 <% end %>
207 </div>
208 </div>
209 </div>
210 <% end %>
211 </div>
212
213 <%+footer%>