mirror of
				https://github.com/kenzok8/openwrt-packages.git
				synced 2025-11-03 08:28:50 +08:00 
			
		
		
		
	update 2024-08-25 20:10:08
This commit is contained in:
		
							
								
								
									
										69
									
								
								luci-theme-design/luasrc/view/themes/design/footer.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								luci-theme-design/luasrc/view/themes/design/footer.htm
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,69 @@
 | 
			
		||||
<%#
 | 
			
		||||
    Material is a clean HTML5 theme for LuCI. It is based on luci-theme-bootstrap and MUI
 | 
			
		||||
 | 
			
		||||
    luci-theme-material
 | 
			
		||||
        Copyright 2015 Lutty Yang <lutty@wcan.in>
 | 
			
		||||
            
 | 
			
		||||
    luci-theme-neobird
 | 
			
		||||
    Copyright 2021 2smile <thinktip@gmail.com>
 | 
			
		||||
 | 
			
		||||
    luci-theme-design
 | 
			
		||||
    Copyright 2023 gngpp <gngppz@gmail.com>
 | 
			
		||||
 | 
			
		||||
    Have a bug? Please create an issue here on GitHub!
 | 
			
		||||
        https://github.com/LuttyYang/luci-theme-material/issues
 | 
			
		||||
 | 
			
		||||
    luci-theme-bootstrap:
 | 
			
		||||
    Copyright 2008 Steven Barth <steven@midlink.org>
 | 
			
		||||
    Copyright 2008 Jo-Philipp Wich <jow@openwrt.org>
 | 
			
		||||
    Copyright 2012 David Menting <david@nut-bolt.nl>
 | 
			
		||||
 | 
			
		||||
    MUI:
 | 
			
		||||
    https://github.com/muicss/mui
 | 
			
		||||
 | 
			
		||||
    Licensed to the public under the Apache License 2.0
 | 
			
		||||
-%>
 | 
			
		||||
 | 
			
		||||
<%
 | 
			
		||||
	local ver = require "luci.version"
 | 
			
		||||
	local disp = require "luci.dispatcher"
 | 
			
		||||
	local request  = disp.context.path
 | 
			
		||||
	local category = request[1]
 | 
			
		||||
	local tree = disp.node()
 | 
			
		||||
	local categories = disp.node_childs(tree)
 | 
			
		||||
%>
 | 
			
		||||
                </div>
 | 
			
		||||
                <footer class="footer" style="text-align:center">
 | 
			
		||||
                    <a href="https://github.com/openwrt/luci">Powered by <%= ver.luciname %></a> |
 | 
			
		||||
                    <a href="https://www.lede-project.org/"><%= ver.distversion %></a>
 | 
			
		||||
                    <br />
 | 
			
		||||
                    © 2021-2022 2smile. All Rights Reserved.
 | 
			
		||||
                    <% if #categories > 1 then %>
 | 
			
		||||
                    <ul class="breadcrumb pull-right" id="modemenu">
 | 
			
		||||
                        <% for i, r in ipairs(categories) do %>
 | 
			
		||||
                        <li<% if category == r then %> class="active"<%end%>><a href="<%=controller%>/<%=r%>/"><%=striptags(translate(tree.nodes[r].title))%></a> <span class="divider">|</span></li>
 | 
			
		||||
                        <% end %>
 | 
			
		||||
                    </ul>
 | 
			
		||||
                    <% end %>
 | 
			
		||||
                </footer>
 | 
			
		||||
            </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
    <script>
 | 
			
		||||
            $(".cbi-button-up").val("");
 | 
			
		||||
            $(".cbi-button-down").val("");
 | 
			
		||||
        	// fix legend position
 | 
			
		||||
			$("legend").each(function () {
 | 
			
		||||
        		var that = $(this);
 | 
			
		||||
        		that.after("<span class='panel-title'>" + that.text() + "</span>");
 | 
			
		||||
    		});
 | 
			
		||||
            // Fixed openclash plugin causing env(safe-area-inset-bottom) to be 0 under
 | 
			
		||||
            if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent) && self.location.pathname.indexOf("openclash") != -1) {
 | 
			
		||||
                var oMeta = document.createElement('meta');
 | 
			
		||||
                oMeta.content = 'width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0,viewport-fit=cover';
 | 
			
		||||
                oMeta.name = 'viewport';
 | 
			
		||||
                document.querySelector('head').appendChild(oMeta);
 | 
			
		||||
            }
 | 
			
		||||
    </script>  
 | 
			
		||||
</body>
 | 
			
		||||
</html>
 | 
			
		||||
							
								
								
									
										323
									
								
								luci-theme-design/luasrc/view/themes/design/header.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										323
									
								
								luci-theme-design/luasrc/view/themes/design/header.htm
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,323 @@
 | 
			
		||||
<%#
 | 
			
		||||
	Material is a clean HTML5 theme for LuCI. It is based on luci-theme-bootstrap and MUI
 | 
			
		||||
 | 
			
		||||
	luci-theme-material
 | 
			
		||||
	Copyright 2015 Lutty Yang <lutty@wcan.in>
 | 
			
		||||
 | 
			
		||||
	luci-theme-neobird
 | 
			
		||||
	Copyright 2021 2smile <thinktip@gmail.com>
 | 
			
		||||
	
 | 
			
		||||
	luci-theme-design
 | 
			
		||||
	Copyright 2023 2smile <gngppz@gmail.com>
 | 
			
		||||
 | 
			
		||||
	Have a bug? Please create an issue here on GitHub!
 | 
			
		||||
	https://github.com/gngpp/luci-theme-design
 | 
			
		||||
 | 
			
		||||
	luci-theme-bootstrap:
 | 
			
		||||
	Copyright 2008 Steven Barth <steven@midlink.org>
 | 
			
		||||
	Copyright 2008 Jo-Philipp Wich <jow@openwrt.org>
 | 
			
		||||
	Copyright 2012 David Menting <david@nut-bolt.nl>
 | 
			
		||||
 | 
			
		||||
	MUI:
 | 
			
		||||
	https://github.com/muicss/mui
 | 
			
		||||
 | 
			
		||||
	Licensed to the public under the Apache License 2.0
 | 
			
		||||
-%>
 | 
			
		||||
 | 
			
		||||
<%
 | 
			
		||||
	local ver = require "luci.version"
 | 
			
		||||
	local sys  = require "luci.sys"
 | 
			
		||||
	local util = require "luci.util"
 | 
			
		||||
	local http = require "luci.http"
 | 
			
		||||
	local disp = require "luci.dispatcher"
 | 
			
		||||
	local uci = require 'luci.model.uci'.cursor()
 | 
			
		||||
	local fs  = require "nixio.fs"
 | 
			
		||||
 | 
			
		||||
	local boardinfo = util.ubus("system", "board")
 | 
			
		||||
	local boardinfo={}
 | 
			
		||||
	boardinfo.hostname=sys.hostname()
 | 
			
		||||
	
 | 
			
		||||
	local request  = disp.context.path
 | 
			
		||||
	local request2 = disp.context.request
 | 
			
		||||
 | 
			
		||||
	local category = request[1]
 | 
			
		||||
	local cattree  = category and disp.node(category)
 | 
			
		||||
 | 
			
		||||
	local leaf = request2[#request2]
 | 
			
		||||
 | 
			
		||||
	local tree = disp.node()
 | 
			
		||||
	local node = disp.context.dispatched
 | 
			
		||||
 | 
			
		||||
	local categories = disp.node_childs(tree)
 | 
			
		||||
 | 
			
		||||
	local c = tree
 | 
			
		||||
	local i, r
 | 
			
		||||
 | 
			
		||||
	-- tag all nodes leading to this page
 | 
			
		||||
	for i, r in ipairs(request) do
 | 
			
		||||
		if c.nodes and c.nodes[r] then
 | 
			
		||||
			c = c.nodes[r]
 | 
			
		||||
			c._menu_selected = true
 | 
			
		||||
		end
 | 
			
		||||
	end
 | 
			
		||||
 | 
			
		||||
    -- send as HTML5
 | 
			
		||||
	http.prepare_content("text/html")
 | 
			
		||||
 | 
			
		||||
	local function nodeurl(prefix, name, query)
 | 
			
		||||
		local url = controller .. prefix .. name .. "/"
 | 
			
		||||
		if query then
 | 
			
		||||
			url = url .. http.build_querystring(query)
 | 
			
		||||
		end
 | 
			
		||||
		return pcdata(url)
 | 
			
		||||
	end
 | 
			
		||||
 | 
			
		||||
	local function subtree(prefix, node, level)
 | 
			
		||||
		if not level then
 | 
			
		||||
			level = 1
 | 
			
		||||
		end
 | 
			
		||||
 | 
			
		||||
		local childs = disp.node_childs(node)
 | 
			
		||||
		if #childs > 0 then
 | 
			
		||||
 | 
			
		||||
            if level > 2 then
 | 
			
		||||
%>
 | 
			
		||||
	<ul class="tabs">
 | 
			
		||||
		<%
 | 
			
		||||
            end
 | 
			
		||||
 | 
			
		||||
			local selected_node
 | 
			
		||||
			local selected_name
 | 
			
		||||
			local i, v
 | 
			
		||||
 | 
			
		||||
			for i, v in ipairs(childs) do
 | 
			
		||||
				local nnode = node.nodes[v]
 | 
			
		||||
				if nnode._menu_selected then
 | 
			
		||||
					selected_node = nnode
 | 
			
		||||
					selected_name = v
 | 
			
		||||
				end
 | 
			
		||||
                if level > 2 then
 | 
			
		||||
		%>
 | 
			
		||||
			<li class="tabmenu-item-<%=v%><%- if nnode._menu_selected or (node.leaf and v == leaf) then %> active<% end %>">
 | 
			
		||||
			    <a href="<%=nodeurl(prefix, v, nnode.query)%>"><%=striptags(translate(nnode.title))%></a>
 | 
			
		||||
			</li>
 | 
			
		||||
		<%      end
 | 
			
		||||
			end
 | 
			
		||||
 | 
			
		||||
            if level > 2 then
 | 
			
		||||
		%>
 | 
			
		||||
	</ul>
 | 
			
		||||
<%          end
 | 
			
		||||
 | 
			
		||||
			if selected_node then
 | 
			
		||||
				subtree(prefix .. selected_name .. "/", selected_node, level + 1)
 | 
			
		||||
			end
 | 
			
		||||
		end
 | 
			
		||||
		
 | 
			
		||||
	end
 | 
			
		||||
 | 
			
		||||
	-- Custom settings
 | 
			
		||||
	local mode = 'normal'
 | 
			
		||||
	local navbar = 'display'
 | 
			
		||||
	local navbar_proxy = 'shadowsocksr'
 | 
			
		||||
	if fs.access('/etc/config/design') then
 | 
			
		||||
		mode = uci:get_first('design', 'global', 'mode')
 | 
			
		||||
		navbar = uci:get_first('design', 'global', 'navbar')
 | 
			
		||||
		navbar_proxy = uci:get_first('design', 'global', 'navbar_proxy')
 | 
			
		||||
	end 
 | 
			
		||||
-%>
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="<%=luci.i18n.context.lang%>">
 | 
			
		||||
<head>
 | 
			
		||||
    <meta charset="utf-8">
 | 
			
		||||
    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0,viewport-fit=cover" />
 | 
			
		||||
    <link rel="manifest" href="<%=media%>/manifest.json">
 | 
			
		||||
    <title><%=striptags( (boardinfo.hostname or "?") .. ( (node and node.title) and ' - ' .. translate(node.title) or '')) %> - LuCI</title>
 | 
			
		||||
    <meta name="format-detection" content="telephone=no, email=no"/>
 | 
			
		||||
    <meta name="x5-fullscreen" content="true">
 | 
			
		||||
    <meta name="full-screen" content="yes">
 | 
			
		||||
    <meta name="x5-page-mode" content="app">
 | 
			
		||||
    <meta name="browsermode" content="application">
 | 
			
		||||
    <meta name="msapplication-tap-highlight" content="no">
 | 
			
		||||
	<meta name="apple-mobile-web-app-status-bar-style" content="default" />
 | 
			
		||||
    <meta name="application-name" content="<%=striptags( (boardinfo.hostname or "?") ) %>">
 | 
			
		||||
    <meta name="apple-mobile-web-app-title" content="<%=striptags( (boardinfo.hostname or "?") ) %>">
 | 
			
		||||
    <meta name="msapplication-TileImage" content="<%=media%>/images/icon.png"/>
 | 
			
		||||
    <link rel="icon" href="<%=media%>/images/icon.png">
 | 
			
		||||
    <link rel="apple-touch-icon" href="<%=media%>/images/apple-touch-icon.png">
 | 
			
		||||
    <meta name="apple-mobile-web-app-capable" content="yes">
 | 
			
		||||
    <meta name="mobile-web-app-capable" content="yes">
 | 
			
		||||
    <meta name="apple-touch-fullscreen" content="yes" /> 
 | 
			
		||||
    <link rel="stylesheet" href="<%=media%>/css/style.css?v=<%= ver.luciversion %>">
 | 
			
		||||
	<meta name="theme-color" media="(prefers-color-scheme: light)" content="white">
 | 
			
		||||
	<meta name="theme-color" media="(prefers-color-scheme: dark)" content="black">
 | 
			
		||||
 | 
			
		||||
    <link rel="shortcut icon" href="<%=media%>/favicon.ico">
 | 
			
		||||
    <% if node and node.css then %>
 | 
			
		||||
        <link rel="stylesheet" href="<%=resource%>/<%=node.css%>">
 | 
			
		||||
    <% end -%>
 | 
			
		||||
    <% if css then %>
 | 
			
		||||
        <style title="text/css">
 | 
			
		||||
            <%-= css %>
 | 
			
		||||
        </style>
 | 
			
		||||
    <% end -%>
 | 
			
		||||
	<script src="<%=media%>/js/jquery.min.js?v=<%= ver.luciversion %>"></script>
 | 
			
		||||
	<script src="<%=media%>/js/design.js?v=<%= ver.luciversion %>"></script>
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body class="lang_<%=luci.i18n.context.lang%> <%- if node then %><%= striptags( node.title ) %><%- end %> <% if luci.dispatcher.context.authsession then %>logged-in<% end %>"
 | 
			
		||||
	<% if mode ~= 'normal' then %>
 | 
			
		||||
	data-theme = "<%= mode %>"
 | 
			
		||||
	<% end -%>
 | 
			
		||||
	>
 | 
			
		||||
 | 
			
		||||
<header>
 | 
			
		||||
	<% if mode == 'normal' then %>
 | 
			
		||||
	<script>
 | 
			
		||||
		function setTheme() {
 | 
			
		||||
			let color_scheme = window.matchMedia('(prefers-color-scheme: dark)');
 | 
			
		||||
			document.body.setAttribute('data-theme', color_scheme.matches? 'dark': 'light');
 | 
			
		||||
		}
 | 
			
		||||
		setTheme();
 | 
			
		||||
		window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', setTheme);
 | 
			
		||||
	</script>	
 | 
			
		||||
	<% end -%>	
 | 
			
		||||
	
 | 
			
		||||
<% if navbar == 'display' then %>
 | 
			
		||||
<style>
 | 
			
		||||
	:root {
 | 
			
		||||
		--vssrBottom: 50px;
 | 
			
		||||
	}
 | 
			
		||||
</style>
 | 
			
		||||
<div class="navbar">
 | 
			
		||||
<% else  %>
 | 
			
		||||
<style>
 | 
			
		||||
	:root {
 | 
			
		||||
		--vssrBottom: 0px;
 | 
			
		||||
	}
 | 
			
		||||
</style>
 | 
			
		||||
<div class="navbar" style="display: none;">
 | 
			
		||||
<% end -%>
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/status/overview"><img src="<%=media%>/images/home.png" /></a>
 | 
			
		||||
  <% if navbar_proxy == 'openclash' then %>
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/services/<%=navbar_proxy%>"><img src="<%=media%>/images/<%=navbar_proxy%>.png" /></a>
 | 
			
		||||
  <% else  %>
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/services/<%=navbar_proxy%>"><img src="<%=media%>/images/ssr.png" /></a>
 | 
			
		||||
  <% end -%>	
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/network/network"><img src="<%=media%>/images/link.png" /></a>
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/status/realtime"><img src="<%=media%>/images/rank.png" /></a>
 | 
			
		||||
  <a href="/cgi-bin/luci/admin/system/admin"><img src="<%=media%>/images/user.png" /></a>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<div class="container">
 | 
			
		||||
	<span class="showSide"></span>
 | 
			
		||||
	<a class="brand" href="#"><%=boardinfo.hostname or "OpenWrt"%></a>
 | 
			
		||||
		<div class="pull-right">
 | 
			
		||||
		<script>
 | 
			
		||||
			if ($(window).width() > 992) {
 | 
			
		||||
        		$("header>.container>.brand").css("padding", "0 0px")
 | 
			
		||||
	    	}
 | 
			
		||||
		</script>
 | 
			
		||||
		<%
 | 
			
		||||
		-- calculate the number of unsaved changes
 | 
			
		||||
		if tree.nodes[category] and tree.nodes[category].ucidata then
 | 
			
		||||
			local ucichanges = 0
 | 
			
		||||
			for i, j in pairs(require("luci.model.uci").cursor():changes()) do
 | 
			
		||||
				for k, l in pairs(j) do
 | 
			
		||||
					for m, n in pairs(l) do
 | 
			
		||||
						ucichanges = ucichanges + 1;
 | 
			
		||||
					end
 | 
			
		||||
				end
 | 
			
		||||
			end
 | 
			
		||||
			%>
 | 
			
		||||
			<% if ucichanges > 0 then %>
 | 
			
		||||
			<style>
 | 
			
		||||
				.notice:after {
 | 
			
		||||
   				 	content: "<%=ucichanges%>";
 | 
			
		||||
    			 	font-size: 0.8rem;
 | 
			
		||||
    				font-family: Tahoma;
 | 
			
		||||
    				position: absolute;
 | 
			
		||||
    				top: -5px;
 | 
			
		||||
    				font-weight: normal !important;
 | 
			
		||||
				}
 | 
			
		||||
			</style>
 | 
			
		||||
			<a id="notice_status" class="label notice" href="<%=url(category, 'uci/changes')%>?redir=<%=http.urlencode(http.formvalue('redir') or table.concat(disp.context.request, "/"))%>"></a>
 | 
			
		||||
			<% end %>
 | 
			
		||||
			<span id="xhr_poll_status" style="display:none" onclick="XHR.running() ? XHR.halt() : XHR.run()">
 | 
			
		||||
				<span class="label success" id="xhr_poll_status_on"><span id="refresh_on" class="mobile-hide"></span></span>
 | 
			
		||||
				<span class="label" id="xhr_poll_status_off" style="display:none"><span id="refresh_off" class="mobile-hide"></span></span>
 | 
			
		||||
			</span>
 | 
			
		||||
		<% end %>
 | 
			
		||||
		</div>
 | 
			
		||||
		</div>
 | 
			
		||||
</header>
 | 
			
		||||
 | 
			
		||||
 <div class="main">
 | 
			
		||||
	 <div class="main-left">
 | 
			
		||||
		 <ul class="nav">
 | 
			
		||||
			 <%-
 | 
			
		||||
			 local function submenu(prefix, node)
 | 
			
		||||
			 local childs = disp.node_childs(node)
 | 
			
		||||
			 if #childs > 0 then
 | 
			
		||||
			 %>
 | 
			
		||||
			 <ul class="slide-menu">
 | 
			
		||||
				 <%-
 | 
			
		||||
				 for i, r in ipairs(childs) do
 | 
			
		||||
				 local nnode = node.nodes[r]
 | 
			
		||||
				 local href  = controller .. "" .. prefix .. r ..
 | 
			
		||||
				 (nnode.query and http.build_querystring(nnode.query) or "")
 | 
			
		||||
				 %>
 | 
			
		||||
				 <li><a data-title="<%=pcdata(striptags(nnode.title))%>" href="<%=pcdata(href)%>"><%=pcdata(striptags(translate(nnode.title)))%></a></li>
 | 
			
		||||
				 <%-
 | 
			
		||||
				 end
 | 
			
		||||
				 %>
 | 
			
		||||
			 </ul>
 | 
			
		||||
			 <%-
 | 
			
		||||
			 end
 | 
			
		||||
			 end
 | 
			
		||||
 | 
			
		||||
			 childs = disp.node_childs(cattree)
 | 
			
		||||
 | 
			
		||||
			 if #childs > 0 then
 | 
			
		||||
			 for i, r in ipairs(childs) do
 | 
			
		||||
			 local nnode = cattree.nodes[r]
 | 
			
		||||
			 local href  = controller .. "/" .. category .. "/" .. r ..
 | 
			
		||||
			 (nnode.query and http.build_querystring(k.query) or "")
 | 
			
		||||
			 local grandchildren = disp.node_childs(nnode)
 | 
			
		||||
 | 
			
		||||
			 if #grandchildren > 0 then
 | 
			
		||||
			 %>
 | 
			
		||||
			 <li class="slide">
 | 
			
		||||
				 <a class="menu" data-title="<%=pcdata(striptags(nnode.title))%>" href="#"><%=pcdata(striptags(translate(nnode.title)))%></a>
 | 
			
		||||
				 <%- submenu("" .. category .. "/" .. r .. "/", nnode) %>
 | 
			
		||||
			 </li>
 | 
			
		||||
			 <%          else %>
 | 
			
		||||
			 <li class="slide">
 | 
			
		||||
				 <a class="menu2" data-title="<%=pcdata(striptags(nnode.title))%>" href="<%=pcdata(href)%>"><%=pcdata(striptags(translate(nnode.title)))%></a>
 | 
			
		||||
			 </li>
 | 
			
		||||
			 <%
 | 
			
		||||
			 end
 | 
			
		||||
			 end
 | 
			
		||||
			 end
 | 
			
		||||
			 %>
 | 
			
		||||
		 </ul>
 | 
			
		||||
	 </div>
 | 
			
		||||
	 <div class="main-right">
 | 
			
		||||
		 <div class="darkMask"></div>
 | 
			
		||||
		 <div id="maincontent">
 | 
			
		||||
			 <div class="container">
 | 
			
		||||
				 <%- if luci.sys.process.info("uid") == 0 and luci.sys.user.getuser("root") and not luci.sys.user.getpasswd("root") then -%>
 | 
			
		||||
					 <div class="alert-message warning">
 | 
			
		||||
						 <h4><%:No password set!%></h4>
 | 
			
		||||
						 <%:There is no password set on this router. Please configure a root password to protect the web interface and enable SSH.%><br>
 | 
			
		||||
						 <a href="<%=pcdata(luci.dispatcher.build_url("admin/system/admin"))%>"><%:Go to password configuration...%></a>
 | 
			
		||||
					 </div>
 | 
			
		||||
				 <%- end -%>
 | 
			
		||||
				 <% if category then subtree("/" .. category .. "/", cattree) end %>
 | 
			
		||||
 | 
			
		||||
    <script>
 | 
			
		||||
            // thanks for Jo-Philipp Wich <jow@openwrt.org>
 | 
			
		||||
            var luciLocation = <%= luci.http.write_json(luci.dispatcher.context.path) %>;
 | 
			
		||||
    </script>  
 | 
			
		||||
    <script src="<%=media%>/js/script.js?v=<%= ver.luciversion %>"></script>
 | 
			
		||||
		Reference in New Issue
	
	Block a user