3bb47f1788147b4a4353bd306dc4b6dbabf77f82
[project/luci.git] / themes / openwrt.org / luasrc / view / themes / openwrt.org / header.htm
1 <%#
2 LuCI - Lua Configuration Interface
3 Copyright 2008 Steven Barth <steven@midlink.org>
4 Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net>
5
6 Licensed under the Apache License, Version 2.0 (the "License");
7 you may not use this file except in compliance with the License.
8 You may obtain a copy of the License at
9
10         http://www.apache.org/licenses/LICENSE-2.0
11
12 $Id$
13
14 -%>
15 <%
16 require("luci.sys")
17 local load1, load5, load15 = luci.sys.loadavg()
18 local request  = require("luci.dispatcher").context.path
19 local category = request[1]
20 local tree     = luci.dispatcher.node()
21 local cattree  = category and luci.dispatcher.node(category)
22 local node     = luci.dispatcher.context.dispatched
23 local hostname = luci.sys.hostname()
24
25 local c = tree
26 for i,r in ipairs(request) do
27         if c.nodes and c.nodes[r] then
28                 c = c.nodes[r]
29                 c._menu_selected = true
30         end
31 end
32
33 require("luci.i18n").loadc("default")
34 require("luci.http").prepare_content("application/xhtml+xml")
35
36 -%>
37
38 <?xml version="1.0" encoding="utf-8"?>
39 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
40 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="<%=luci.i18n.context.lang%>" lang="<%=luci.i18n.context.lang%>">
41 <head>
42 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
43 <meta http-equiv="Content-Script-Type" content="text/javascript" />
44 <link rel="stylesheet" type="text/css" media="screen" href="<%=media%>/cascade.css" />
45 <% if node and node.css then %><link rel="stylesheet" type="text/css" media="screen" href="<%=resource%>/<%=node.css%>" />
46 <% end -%>
47 <script type="text/javascript" src="<%=media%>/VarType.js"></script>
48 <script type="text/javascript" src="<%=media%>/XHTML1.js"></script>
49 <script type="text/javascript" src="<%=media%>/Dropdowns.js"></script>
50 <title><%=striptags( hostname .. ( (node and node.title) and ' - ' .. node.title or '')) %> - LuCI</title>
51 </head>
52 <body class="lang_<%=luci.i18n.context.lang%>">
53
54 <p class="skiplink">
55 <span id="skiplink1"><a href="#navigation"><%:skiplink1 Skip to navigation%></a></span>
56 <span id="skiplink2"><a href="#content"><%:skiplink2 Skip to content%></a></span>
57 </p>
58
59 <div id="header">
60 <h1><%=luci.config.brand.firmware%></h1>
61 <p>
62 <%=luci.config.brand.distro%><br />
63 <%:load%>: <%=load1%> <%=load5%> <%=load15%><br />
64 <%:hostname%>: <%=hostname%>
65 </p>
66 </div>
67
68 <div id="menubar">
69 <h2 class="navigation"><a id="navigation" name="navigation"><%:navigation Navigation%></a></h2>
70 <ul id="mainmenu" class="dropdowns">
71 <%-
72 local function submenu(prefix, node)
73         if not node.nodes or node.hidden then
74                 return false
75         end
76         local index = {}
77         local count = 0
78         for k, n in pairs(node.nodes) do
79                 if n.title and n.target then
80                         table.insert(index, {name=k, order=n.order or 100})
81                         count = count + 1
82                 end
83         end
84
85         table.sort(index, function(a, b) return a.order < b.order end)
86
87         if count > 0 then
88 %>
89 <ul id="submenu_<%=string.gsub(string.gsub(prefix, "/", "_"), "^_(.-)_$", "%1")%>">
90 <%-
91                 for j, v in pairs(index) do
92                         if #v.name > 0 then
93                                 local nnode = node.nodes[v.name]
94                                 local href = controller .. prefix .. v.name .. "/"
95                                 href = (nnode.query) and href .. luci.http.build_querystring(nnode.query) or href
96 %>
97 <li><a<% if nnode._menu_selected then %> class="active"<%end%> href="<%=luci.util.pcdata(href)%>"><%=nnode.title%></a><%-
98 submenu(prefix .. v.name .. "/", nnode)
99 %></li>
100 <%-
101                         end
102                 end
103 %>
104 </ul>
105 <%
106         end
107 end
108
109 if cattree and cattree.nodes then
110         local index = {}
111         for k, node in pairs(cattree.nodes) do
112                 table.insert(index, {name=k, order=node.order or 100})
113         end
114
115         table.sort(index, function(a, b) return a.order < b.order end)
116
117         for i, k in ipairs(index) do
118                 node = cattree.nodes[k.name]
119                 if node.title and node.target and not node.hidden then
120                         local href = controller.."/"..category.."/"..k.name.."/"
121                         href = (k.query) and href .. luci.http.build_querystring(k.query) or href
122 %>
123 <li><a<% if node._menu_selected then %> class="preactive"<%end%> href="<%=href%>"><%=node.title%></a><%
124 submenu("/" .. category .. "/" .. k.name .. "/", node)
125 %></li><% end
126         end
127 end
128 %>
129 </ul>
130
131 <ul id="modemenu"><%
132 for k,node in pairs(tree.nodes) do
133         if node.title and not node.hidden then %>
134 <li><a<% if request[1] == k then %> class="active"<%end%> href="<%=controller%>/<%=k%>/"><%=node.title%></a></li><%
135         end
136 end
137 %>
138 </ul>
139
140 <%
141 if tree.nodes[category] and tree.nodes[category].ucidata then
142         local ucic = 0
143         for i, j in pairs(require("luci.model.uci").cursor():changes()) do
144                 for k, l in pairs(j) do
145                         for m, n in pairs(l) do
146                                 ucic = ucic + 1;
147                         end
148                 end
149         end
150 -%>
151 <ul id="savemenu" class="dropdowns">
152 <li><% if ucic > 0 then %><a class="warning" href="<%=controller%>/<%=category%>/uci/changes/"><%:unsavedchanges%>: <%=ucic%></a><%
153 submenu("/" .. category .. "/uci/", tree.nodes[category].nodes["uci"])
154 else -%>
155 <a href="#"><%:changes%>: 0</a><% end -%>
156 </li>
157 </ul><% end %>
158
159 <div class="clear"></div>
160 </div>
161 <div id="maincontent">