2023-11-29 23:38:12 Auto Sync
This commit is contained in:
parent
5994ae095b
commit
c55ca8a600
@ -1,16 +0,0 @@
|
||||
#
|
||||
# Copyright (C) 2008-2014 The LuCI Team <luci@lists.subsignal.org>
|
||||
#
|
||||
# This is free software, licensed under the Apache License, Version 2.0 .
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
LUCI_TITLE:=Bootstrap lightblue Theme
|
||||
LUCI_DEPENDS:=
|
||||
|
||||
PKG_LICENSE:=Apache-2.0
|
||||
|
||||
include $(TOPDIR)/feeds/luci/luci.mk
|
||||
|
||||
# call BuildPackage - OpenWrt buildroot signature
|
File diff suppressed because it is too large
Load Diff
Binary file not shown.
Before Width: | Height: | Size: 5.3 KiB |
Binary file not shown.
Before Width: | Height: | Size: 61 KiB |
@ -1,411 +0,0 @@
|
||||
header h3 a, header .brand {
|
||||
display:none !important;
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 600px) {
|
||||
#maincontent.container {
|
||||
margin-top: 30px;
|
||||
}
|
||||
|
||||
.tabs, .cbi-tabmenu {
|
||||
background: linear-gradient(#fff 20%, #ddd 100%);
|
||||
background-size: 1px 34px;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
.tabs > li, .cbi-tabmenu > li {
|
||||
height: 30px;
|
||||
}
|
||||
|
||||
.tabs > li > a, .cbi-tabmenu > li > a {
|
||||
padding: 0 8px;
|
||||
line-height: 30px;
|
||||
}
|
||||
|
||||
.table {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.tr {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: wrap;
|
||||
align-items: flex-end;
|
||||
border-top: 1px solid #ddd;
|
||||
padding: 5px 0;
|
||||
margin: 0 -3px;
|
||||
}
|
||||
|
||||
.table .th,
|
||||
.table .td,
|
||||
.table .tr::before {
|
||||
flex: 2 2 33%;
|
||||
align-self: flex-start;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
display: inline-block;
|
||||
border-top: none;
|
||||
padding: 3px;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
.table .td.cbi-dropdown-open {
|
||||
overflow: visible;
|
||||
}
|
||||
|
||||
.col-1 { flex: 1 1 30px !important; -webkit-flex: 1 1 30px !important; }
|
||||
.col-2 { flex: 2 2 60px !important; -webkit-flex: 2 2 60px !important; }
|
||||
.col-3 { flex: 3 3 90px !important; -webkit-flex: 3 3 90px !important; }
|
||||
.col-4 { flex: 4 4 120px !important; -webkit-flex: 4 4 120px !important; }
|
||||
.col-5 { flex: 5 5 150px !important; -webkit-flex: 5 5 150px !important; }
|
||||
.col-6 { flex: 6 6 180px !important; -webkit-flex: 6 6 180px !important; }
|
||||
.col-7 { flex: 7 7 210px !important; -webkit-flex: 7 7 210px !important; }
|
||||
.col-8 { flex: 8 8 240px !important; -webkit-flex: 8 8 240px !important; }
|
||||
.col-9 { flex: 9 9 270px !important; -webkit-flex: 9 9 270px !important; }
|
||||
.col-10 { flex: 10 10 300px !important; -webkit-flex: 10 10 300px !important; }
|
||||
|
||||
.td select {
|
||||
word-wrap: normal;
|
||||
}
|
||||
|
||||
.td[data-widget="button"],
|
||||
.td[data-widget="fvalue"] {
|
||||
flex: 1 1 17%;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.td.cbi-value-field {
|
||||
align-self: flex-start;
|
||||
}
|
||||
|
||||
.td.cbi-value-field .cbi-button {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.table.cbi-section-table {
|
||||
border: none;
|
||||
background: none;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.tr.table-titles,
|
||||
.cbi-section-table-titles,
|
||||
.cbi-section-table-descr {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.cbi-section-table-row {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: wrap;
|
||||
margin: 0 0 .5em 0;
|
||||
}
|
||||
|
||||
.cbi-section-table + .cbi-section-create {
|
||||
padding-top: 0;
|
||||
}
|
||||
|
||||
.tr[data-title]::before {
|
||||
display: block;
|
||||
flex: 1 1 100%;
|
||||
background: #f5f5f5 !important;
|
||||
font-size: 16px;
|
||||
border-bottom: 1px solid #ddd;
|
||||
}
|
||||
|
||||
.td[data-title]::before,
|
||||
.td[data-description]::after {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.td[data-title] ~ .td.cbi-section-actions {
|
||||
align-self: flex-start;
|
||||
}
|
||||
|
||||
.td[data-title] ~ .td.cbi-section-actions::before {
|
||||
display: block;
|
||||
content: "\a0";
|
||||
}
|
||||
|
||||
.td.cbi-section-actions {
|
||||
overflow: initial;
|
||||
max-width: 100%;
|
||||
padding: 3px 2px;
|
||||
}
|
||||
|
||||
.hide-sm,
|
||||
.hide-xs {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
.td.cbi-value-field {
|
||||
flex-basis: 100%;
|
||||
}
|
||||
|
||||
.td.cbi-value-field[data-widget="dvalue"] {
|
||||
flex-basis: 50%;
|
||||
}
|
||||
|
||||
.td.cbi-value-field[data-widget="button"],
|
||||
.td.cbi-value-field[data-widget="fvalue"] {
|
||||
flex-basis: 25%;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.cbi-section-table .tr:hover .td,
|
||||
.cbi-section-table .tr:hover .th,
|
||||
.cbi-section-table .tr:hover::before {
|
||||
background-color: transparent;
|
||||
}
|
||||
|
||||
.cbi-value {
|
||||
padding-bottom: .5em;
|
||||
border-bottom: 1px solid #ddd;
|
||||
margin-bottom: .5em;
|
||||
}
|
||||
|
||||
.cbi-value label.cbi-value-title {
|
||||
float: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.cbi-value-field, .cbi-dropdown {
|
||||
width: 100%;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
input, textarea, select,
|
||||
.cbi-dropdown > ul > li input[type="text"] {
|
||||
font-size: 16px !important;
|
||||
line-height: 28px;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
select, input[type="text"], input[type="password"] {
|
||||
width: 100%;
|
||||
height: 30px;
|
||||
}
|
||||
|
||||
input.cbi-input-password {
|
||||
width: calc(100% - 25px);
|
||||
}
|
||||
|
||||
[data-dynlist] {
|
||||
display: block;
|
||||
}
|
||||
|
||||
[data-dynlist] > .add-item > input {
|
||||
width: calc(100% - 21px);
|
||||
}
|
||||
|
||||
[data-dynlist] > .add-item > .cbi-button {
|
||||
margin-right: -1px;
|
||||
}
|
||||
|
||||
input[type="text"] + .cbi-button,
|
||||
input[type="password"] + .cbi-button,
|
||||
select + .cbi-button {
|
||||
font-size: 14px !important;
|
||||
line-height: 28px;
|
||||
height: 30px;
|
||||
box-sizing: border-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
.cbi-value-field input[type="checkbox"],
|
||||
.cbi-value-field input[type="radio"] {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.btn, .cbi-button {
|
||||
font-size: 14px !important;
|
||||
padding: 4px 8px;
|
||||
}
|
||||
|
||||
.actions,
|
||||
.cbi-page-actions {
|
||||
border-top: none;
|
||||
margin-top: -.5em;
|
||||
padding: 8px;
|
||||
}
|
||||
|
||||
[data-page="admin-status-overview"] .cbi-section:nth-of-type(1) .td:first-child,
|
||||
[data-page="admin-status-overview"] .cbi-section:nth-of-type(2) .td:first-child {
|
||||
flex-grow: 1;
|
||||
}
|
||||
|
||||
header .pull-right .label {
|
||||
white-space: normal;
|
||||
display: inline-block;
|
||||
text-align: center;
|
||||
line-height: 12px;
|
||||
margin: 1px 0;
|
||||
}
|
||||
|
||||
header > .fill {
|
||||
padding: 1px;
|
||||
}
|
||||
|
||||
header > .fill > .container {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
header .nav {
|
||||
flex: 3 3 80%;
|
||||
margin: 2px 5px 2px 0;
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: flex-start;
|
||||
}
|
||||
|
||||
header .nav a {
|
||||
padding: 2px 6px;
|
||||
}
|
||||
|
||||
header .pull-right {
|
||||
flex: 1 1 20%;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
padding: 0;
|
||||
justify-content: space-around;
|
||||
}
|
||||
|
||||
.menu-dropdown, .dropdown-menu {
|
||||
top: 23px;
|
||||
}
|
||||
|
||||
body {
|
||||
padding-top: 30px;
|
||||
}
|
||||
|
||||
.cbi-optionals,
|
||||
.cbi-section-create {
|
||||
padding: 0 0 14px 0;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .th,
|
||||
#cbi-network-switch_vlan .td {
|
||||
flex-basis: 12%;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions {
|
||||
flex-basis: 100%;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions::before {
|
||||
display: none;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions > * {
|
||||
width: auto;
|
||||
display: block;
|
||||
}
|
||||
|
||||
#wifi_assoclist_table .td,
|
||||
[data-page="admin-status-processes"] .td {
|
||||
flex-basis: 50% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-status-processes"] .td[data-widget="button"] {
|
||||
flex-basis: 33% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-status-processes"] .td[data-name="PID"],
|
||||
[data-page="admin-status-processes"] .td[data-name="USER"] {
|
||||
flex-basis: 25% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-system-fstab"] .td[data-widget="button"]::before,
|
||||
[data-page="admin-system-startup"] .td[data-widget="button"]::before,
|
||||
[data-page="admin-status-processes"] .td[data-widget="button"]::before {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 375px) {
|
||||
#maincontent.container {
|
||||
margin-top: 55px;
|
||||
}
|
||||
|
||||
.cbi-page-actions {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
margin: 0 -1px;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.cbi-page-actions .cbi-button:not(.cbi-dropdown) {
|
||||
flex: 1 1 calc(50% - 2px);
|
||||
margin: 1px !important;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
.cbi-page-actions .cbi-button-negative,
|
||||
.cbi-page-actions .cbi-button-primary,
|
||||
.cbi-page-actions .cbi-button-apply {
|
||||
flex-basis: calc(100% - -2px);
|
||||
}
|
||||
|
||||
.cbi-section-actions .cbi-button {
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_badge"] {
|
||||
max-width: 50px;
|
||||
align-self: center;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_badge"] .ifacebadge {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_stat"] {
|
||||
flex-basis: 60%;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-network"] .td.cbi-section-actions::before,
|
||||
body[data-page="admin-network-wireless"] .td.cbi-section-actions::before {
|
||||
content: none !important;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 200px) {
|
||||
#maincontent.container {
|
||||
margin-top: 230px;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-width: 375px) {
|
||||
.td .ifacebox {
|
||||
width: 100%;
|
||||
margin: 0 !important;
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head {
|
||||
min-width: 25%;
|
||||
justify-content: space-around;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head,
|
||||
.td .ifacebox .ifacebox-body {
|
||||
display: flex;
|
||||
border-bottom: none;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head > *,
|
||||
.ifacebox .ifacebox-body > * {
|
||||
margin: .125em;
|
||||
}
|
||||
}
|
@ -1,118 +0,0 @@
|
||||
'use strict';
|
||||
'require baseclass';
|
||||
'require ui';
|
||||
|
||||
return baseclass.extend({
|
||||
__init__: function() {
|
||||
ui.menu.load().then(L.bind(this.render, this));
|
||||
},
|
||||
|
||||
render: function(tree) {
|
||||
var node = tree,
|
||||
url = '';
|
||||
|
||||
this.renderModeMenu(tree);
|
||||
|
||||
if (L.env.dispatchpath.length >= 3) {
|
||||
for (var i = 0; i < 3 && node; i++) {
|
||||
node = node.children[L.env.dispatchpath[i]];
|
||||
url = url + (url ? '/' : '') + L.env.dispatchpath[i];
|
||||
}
|
||||
|
||||
if (node)
|
||||
this.renderTabMenu(node, url);
|
||||
}
|
||||
|
||||
document.addEventListener('poll-start', this.handleBodyMargin);
|
||||
document.addEventListener('poll-stop', this.handleBodyMargin);
|
||||
document.addEventListener('uci-new-changes', this.handleBodyMargin);
|
||||
document.addEventListener('uci-clear-changes', this.handleBodyMargin);
|
||||
window.addEventListener('resize', this.handleBodyMargin);
|
||||
|
||||
this.handleBodyMargin();
|
||||
},
|
||||
|
||||
renderTabMenu: function(tree, url, level) {
|
||||
var container = document.querySelector('#tabmenu'),
|
||||
ul = E('ul', { 'class': 'tabs' }),
|
||||
children = ui.menu.getChildren(tree),
|
||||
activeNode = null;
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var isActive = (L.env.dispatchpath[3 + (level || 0)] == children[i].name),
|
||||
activeClass = isActive ? ' active' : '',
|
||||
className = 'tabmenu-item-%s %s'.format(children[i].name, activeClass);
|
||||
|
||||
ul.appendChild(E('li', { 'class': className }, [
|
||||
E('a', { 'href': L.url(url, children[i].name) }, [ _(children[i].title) ] )]));
|
||||
|
||||
if (isActive)
|
||||
activeNode = children[i];
|
||||
}
|
||||
|
||||
if (ul.children.length == 0)
|
||||
return E([]);
|
||||
|
||||
container.appendChild(ul);
|
||||
container.style.display = '';
|
||||
|
||||
if (activeNode)
|
||||
this.renderTabMenu(activeNode, url + '/' + activeNode.name, (level || 0) + 1);
|
||||
|
||||
return ul;
|
||||
},
|
||||
|
||||
renderMainMenu: function(tree, url, level) {
|
||||
var ul = level ? E('ul', { 'class': 'dropdown-menu' }) : document.querySelector('#topmenu'),
|
||||
children = ui.menu.getChildren(tree);
|
||||
|
||||
if (children.length == 0 || level > 1)
|
||||
return E([]);
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var submenu = this.renderMainMenu(children[i], url + '/' + children[i].name, (level || 0) + 1),
|
||||
subclass = (!level && submenu.firstElementChild) ? 'dropdown' : null,
|
||||
linkclass = (!level && submenu.firstElementChild) ? 'menu' : null,
|
||||
linkurl = submenu.firstElementChild ? '#' : L.url(url, children[i].name);
|
||||
|
||||
var li = E('li', { 'class': subclass }, [
|
||||
E('a', { 'class': linkclass, 'href': linkurl }, [ _(children[i].title) ]),
|
||||
submenu
|
||||
]);
|
||||
|
||||
ul.appendChild(li);
|
||||
}
|
||||
|
||||
ul.style.display = '';
|
||||
|
||||
return ul;
|
||||
},
|
||||
|
||||
renderModeMenu: function(tree) {
|
||||
var ul = document.querySelector('#modemenu'),
|
||||
children = ui.menu.getChildren(tree);
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var isActive = (L.env.requestpath.length ? children[i].name == L.env.requestpath[0] : i == 0);
|
||||
|
||||
ul.appendChild(E('li', { 'class': isActive ? 'active' : null }, [
|
||||
E('a', { 'href': L.url(children[i].name) }, [ _(children[i].title) ]),
|
||||
' ',
|
||||
E('span', { 'class': 'divider' }, [ '|' ])
|
||||
]));
|
||||
|
||||
if (isActive)
|
||||
this.renderMainMenu(children[i], children[i].name);
|
||||
}
|
||||
|
||||
if (ul.children.length > 1)
|
||||
ul.style.display = '';
|
||||
},
|
||||
|
||||
handleBodyMargin: function(ev) {
|
||||
var body = document.querySelector('body'),
|
||||
head = document.querySelector('header');
|
||||
|
||||
body.style.marginTop = head.offsetHeight + 'px';
|
||||
}
|
||||
});
|
@ -1,18 +0,0 @@
|
||||
<%#
|
||||
Copyright 2008 Steven Barth <steven@midlink.org>
|
||||
Copyright 2008 Jo-Philipp Wich <jow@openwrt.org>
|
||||
Copyright 2012 David Menting <david@nut-bolt.nl>
|
||||
Licensed to the public under the Apache License 2.0.
|
||||
-%>
|
||||
|
||||
<% local ver = require "luci.version" %>
|
||||
|
||||
<footer>
|
||||
<div style="height:40px;font-size:95%;color:#999;font-family: Arial,sans-serif;"><%= ver.distversion %> © 132lan.ru 2022 </div>
|
||||
<ul class="breadcrumb pull-right" id="modemenu" style="display:none"></ul>
|
||||
</footer>
|
||||
</div>
|
||||
<script type="text/javascript">L.require('menu-lightblue')</script>
|
||||
</body>
|
||||
</html>
|
||||
|
@ -1,69 +0,0 @@
|
||||
<%#
|
||||
Copyright 2008 Steven Barth <steven@midlink.org>
|
||||
Copyright 2008-2016 Jo-Philipp Wich <jow@openwrt.org>
|
||||
Copyright 2012 David Menting <david@nut-bolt.nl>
|
||||
Licensed to the public under the Apache License 2.0.
|
||||
-%>
|
||||
|
||||
<%
|
||||
local sys = require "luci.sys"
|
||||
local util = require "luci.util"
|
||||
local http = require "luci.http"
|
||||
local disp = require "luci.dispatcher"
|
||||
|
||||
local boardinfo = util.ubus("system", "board")
|
||||
|
||||
local node = disp.context.dispatched
|
||||
|
||||
-- send as HTML5
|
||||
http.prepare_content("text/html")
|
||||
-%>
|
||||
<!DOCTYPE html>
|
||||
<html lang="<%=luci.i18n.context.lang%>">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title><%=striptags( (boardinfo.hostname or "?") .. ( (node and node.title) and ' - ' .. translate(node.title) or '')) %> - LuCI</title>
|
||||
<meta name="viewport" content="initial-scale=1.0">
|
||||
<link rel="stylesheet" href="<%=media%>/cascade.css">
|
||||
<link rel="stylesheet" media="only screen and (max-device-width: 854px)" href="<%=media%>/mobile.css" type="text/css" />
|
||||
<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="<%=url('admin/translations', luci.i18n.context.lang)%><%# ?v=PKG_VERSION %>"></script>
|
||||
<script src="<%=resource%>/cbi.js"></script>
|
||||
</head>
|
||||
|
||||
<body class="lang_<%=luci.i18n.context.lang%> <% if node then %><%= striptags( node.title ) %><%- end %>" data-page="<%= pcdata(table.concat(disp.context.requestpath, "-")) %>">
|
||||
<header>
|
||||
<div class="fill">
|
||||
<div class="container">
|
||||
<a class="brand" href="/"></a>
|
||||
<ul class="nav" id="topmenu" style="display:none"></ul>
|
||||
<div id="indicators" class="pull-right"></div>
|
||||
</div>
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<div id="maincontent" 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>
|
||||
<p><%:There is no password set on this router. Please configure a root password to protect the web interface.%></p>
|
||||
<% if disp.lookup("admin/system/admin") then %>
|
||||
<div class="right"><a class="btn" href="<%=url("admin/system/admin")%>"><%:Go to password configuration...%></a></div>
|
||||
<% end %>
|
||||
</div>
|
||||
<%- end -%>
|
||||
|
||||
<noscript>
|
||||
<div class="alert-message warning">
|
||||
<h4><%:JavaScript required!%></h4>
|
||||
<p><%:You must enable JavaScript in your browser or LuCI will not work properly.%></p>
|
||||
</div>
|
||||
</noscript>
|
||||
|
||||
<div id="tabmenu" style="display:none"></div>
|
@ -1,12 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
if [ "$PKG_UPGRADE" != 1 ]; then
|
||||
uci get luci.themes.Lightblue >/dev/null 2>&1 || \
|
||||
uci batch <<-EOF
|
||||
set luci.themes.Lightblue=/luci-static/lightblue
|
||||
set luci.main.mediaurlbase=/luci-static/lightblue
|
||||
commit luci
|
||||
EOF
|
||||
fi
|
||||
|
||||
exit 0
|
@ -1,16 +0,0 @@
|
||||
#
|
||||
# Copyright (C) 2008-2014 The LuCI Team <luci@lists.subsignal.org>
|
||||
#
|
||||
# This is free software, licensed under the Apache License, Version 2.0 .
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
LUCI_TITLE:=Bootstrap Teleofis Theme
|
||||
LUCI_DEPENDS:=
|
||||
|
||||
PKG_LICENSE:=Apache-2.0
|
||||
|
||||
include $(TOPDIR)/feeds/luci/luci.mk
|
||||
|
||||
# call BuildPackage - OpenWrt buildroot signature
|
@ -1,118 +0,0 @@
|
||||
'use strict';
|
||||
'require baseclass';
|
||||
'require ui';
|
||||
|
||||
return baseclass.extend({
|
||||
__init__: function() {
|
||||
ui.menu.load().then(L.bind(this.render, this));
|
||||
},
|
||||
|
||||
render: function(tree) {
|
||||
var node = tree,
|
||||
url = '';
|
||||
|
||||
this.renderModeMenu(tree);
|
||||
|
||||
if (L.env.dispatchpath.length >= 3) {
|
||||
for (var i = 0; i < 3 && node; i++) {
|
||||
node = node.children[L.env.dispatchpath[i]];
|
||||
url = url + (url ? '/' : '') + L.env.dispatchpath[i];
|
||||
}
|
||||
|
||||
if (node)
|
||||
this.renderTabMenu(node, url);
|
||||
}
|
||||
|
||||
document.addEventListener('poll-start', this.handleBodyMargin);
|
||||
document.addEventListener('poll-stop', this.handleBodyMargin);
|
||||
document.addEventListener('uci-new-changes', this.handleBodyMargin);
|
||||
document.addEventListener('uci-clear-changes', this.handleBodyMargin);
|
||||
window.addEventListener('resize', this.handleBodyMargin);
|
||||
|
||||
this.handleBodyMargin();
|
||||
},
|
||||
|
||||
renderTabMenu: function(tree, url, level) {
|
||||
var container = document.querySelector('#tabmenu'),
|
||||
ul = E('ul', { 'class': 'tabs' }),
|
||||
children = ui.menu.getChildren(tree),
|
||||
activeNode = null;
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var isActive = (L.env.dispatchpath[3 + (level || 0)] == children[i].name),
|
||||
activeClass = isActive ? ' active' : '',
|
||||
className = 'tabmenu-item-%s %s'.format(children[i].name, activeClass);
|
||||
|
||||
ul.appendChild(E('li', { 'class': className }, [
|
||||
E('a', { 'href': L.url(url, children[i].name) }, [ _(children[i].title) ] )]));
|
||||
|
||||
if (isActive)
|
||||
activeNode = children[i];
|
||||
}
|
||||
|
||||
if (ul.children.length == 0)
|
||||
return E([]);
|
||||
|
||||
container.appendChild(ul);
|
||||
container.style.display = '';
|
||||
|
||||
if (activeNode)
|
||||
this.renderTabMenu(activeNode, url + '/' + activeNode.name, (level || 0) + 1);
|
||||
|
||||
return ul;
|
||||
},
|
||||
|
||||
renderMainMenu: function(tree, url, level) {
|
||||
var ul = level ? E('ul', { 'class': 'dropdown-menu' }) : document.querySelector('#topmenu'),
|
||||
children = ui.menu.getChildren(tree);
|
||||
|
||||
if (children.length == 0 || level > 1)
|
||||
return E([]);
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var submenu = this.renderMainMenu(children[i], url + '/' + children[i].name, (level || 0) + 1),
|
||||
subclass = (!level && submenu.firstElementChild) ? 'dropdown' : null,
|
||||
linkclass = (!level && submenu.firstElementChild) ? 'menu' : null,
|
||||
linkurl = submenu.firstElementChild ? '#' : L.url(url, children[i].name);
|
||||
|
||||
var li = E('li', { 'class': subclass }, [
|
||||
E('a', { 'class': linkclass, 'href': linkurl }, [ _(children[i].title) ]),
|
||||
submenu
|
||||
]);
|
||||
|
||||
ul.appendChild(li);
|
||||
}
|
||||
|
||||
ul.style.display = '';
|
||||
|
||||
return ul;
|
||||
},
|
||||
|
||||
renderModeMenu: function(tree) {
|
||||
var ul = document.querySelector('#modemenu'),
|
||||
children = ui.menu.getChildren(tree);
|
||||
|
||||
for (var i = 0; i < children.length; i++) {
|
||||
var isActive = (L.env.requestpath.length ? children[i].name == L.env.requestpath[0] : i == 0);
|
||||
|
||||
ul.appendChild(E('li', { 'class': isActive ? 'active' : null }, [
|
||||
E('a', { 'href': L.url(children[i].name) }, [ _(children[i].title) ]),
|
||||
' ',
|
||||
E('span', { 'class': 'divider' }, [ '|' ])
|
||||
]));
|
||||
|
||||
if (isActive)
|
||||
this.renderMainMenu(children[i], children[i].name);
|
||||
}
|
||||
|
||||
if (ul.children.length > 1)
|
||||
ul.style.display = '';
|
||||
},
|
||||
|
||||
handleBodyMargin: function(ev) {
|
||||
var body = document.querySelector('body'),
|
||||
head = document.querySelector('header');
|
||||
|
||||
body.style.marginTop = head.offsetHeight + 'px';
|
||||
}
|
||||
});
|
File diff suppressed because it is too large
Load Diff
Binary file not shown.
Before Width: | Height: | Size: 3.2 KiB |
Binary file not shown.
Before Width: | Height: | Size: 6.8 KiB |
@ -1,411 +0,0 @@
|
||||
header h3 a, header .brand {
|
||||
display:none !important;
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 600px) {
|
||||
#maincontent.container {
|
||||
margin-top: 30px;
|
||||
}
|
||||
|
||||
.tabs, .cbi-tabmenu {
|
||||
background: linear-gradient(#fff 20%, #ddd 100%);
|
||||
background-size: 1px 34px;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
.tabs > li, .cbi-tabmenu > li {
|
||||
height: 30px;
|
||||
}
|
||||
|
||||
.tabs > li > a, .cbi-tabmenu > li > a {
|
||||
padding: 0 8px;
|
||||
line-height: 30px;
|
||||
}
|
||||
|
||||
.table {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.tr {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: wrap;
|
||||
align-items: flex-end;
|
||||
border-top: 1px solid #ddd;
|
||||
padding: 5px 0;
|
||||
margin: 0 -3px;
|
||||
}
|
||||
|
||||
.table .th,
|
||||
.table .td,
|
||||
.table .tr::before {
|
||||
flex: 2 2 33%;
|
||||
align-self: flex-start;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
display: inline-block;
|
||||
border-top: none;
|
||||
padding: 3px;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
.table .td.cbi-dropdown-open {
|
||||
overflow: visible;
|
||||
}
|
||||
|
||||
.col-1 { flex: 1 1 30px !important; -webkit-flex: 1 1 30px !important; }
|
||||
.col-2 { flex: 2 2 60px !important; -webkit-flex: 2 2 60px !important; }
|
||||
.col-3 { flex: 3 3 90px !important; -webkit-flex: 3 3 90px !important; }
|
||||
.col-4 { flex: 4 4 120px !important; -webkit-flex: 4 4 120px !important; }
|
||||
.col-5 { flex: 5 5 150px !important; -webkit-flex: 5 5 150px !important; }
|
||||
.col-6 { flex: 6 6 180px !important; -webkit-flex: 6 6 180px !important; }
|
||||
.col-7 { flex: 7 7 210px !important; -webkit-flex: 7 7 210px !important; }
|
||||
.col-8 { flex: 8 8 240px !important; -webkit-flex: 8 8 240px !important; }
|
||||
.col-9 { flex: 9 9 270px !important; -webkit-flex: 9 9 270px !important; }
|
||||
.col-10 { flex: 10 10 300px !important; -webkit-flex: 10 10 300px !important; }
|
||||
|
||||
.td select {
|
||||
word-wrap: normal;
|
||||
}
|
||||
|
||||
.td[data-widget="button"],
|
||||
.td[data-widget="fvalue"] {
|
||||
flex: 1 1 17%;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.td.cbi-value-field {
|
||||
align-self: flex-start;
|
||||
}
|
||||
|
||||
.td.cbi-value-field .cbi-button {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.table.cbi-section-table {
|
||||
border: none;
|
||||
background: none;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.tr.table-titles,
|
||||
.cbi-section-table-titles,
|
||||
.cbi-section-table-descr {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.cbi-section-table-row {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: wrap;
|
||||
margin: 0 0 .5em 0;
|
||||
}
|
||||
|
||||
.cbi-section-table + .cbi-section-create {
|
||||
padding-top: 0;
|
||||
}
|
||||
|
||||
.tr[data-title]::before {
|
||||
display: block;
|
||||
flex: 1 1 100%;
|
||||
background: #f5f5f5 !important;
|
||||
font-size: 16px;
|
||||
border-bottom: 1px solid #ddd;
|
||||
}
|
||||
|
||||
.td[data-title]::before,
|
||||
.td[data-description]::after {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.td[data-title] ~ .td.cbi-section-actions {
|
||||
align-self: flex-start;
|
||||
}
|
||||
|
||||
.td[data-title] ~ .td.cbi-section-actions::before {
|
||||
display: block;
|
||||
content: "\a0";
|
||||
}
|
||||
|
||||
.td.cbi-section-actions {
|
||||
overflow: initial;
|
||||
max-width: 100%;
|
||||
padding: 3px 2px;
|
||||
}
|
||||
|
||||
.hide-sm,
|
||||
.hide-xs {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
.td.cbi-value-field {
|
||||
flex-basis: 100%;
|
||||
}
|
||||
|
||||
.td.cbi-value-field[data-widget="dvalue"] {
|
||||
flex-basis: 50%;
|
||||
}
|
||||
|
||||
.td.cbi-value-field[data-widget="button"],
|
||||
.td.cbi-value-field[data-widget="fvalue"] {
|
||||
flex-basis: 25%;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.cbi-section-table .tr:hover .td,
|
||||
.cbi-section-table .tr:hover .th,
|
||||
.cbi-section-table .tr:hover::before {
|
||||
background-color: transparent;
|
||||
}
|
||||
|
||||
.cbi-value {
|
||||
padding-bottom: .5em;
|
||||
border-bottom: 1px solid #ddd;
|
||||
margin-bottom: .5em;
|
||||
}
|
||||
|
||||
.cbi-value label.cbi-value-title {
|
||||
float: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.cbi-value-field, .cbi-dropdown {
|
||||
width: 100%;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
input, textarea, select,
|
||||
.cbi-dropdown > ul > li input[type="text"] {
|
||||
font-size: 16px !important;
|
||||
line-height: 28px;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
select, input[type="text"], input[type="password"] {
|
||||
width: 100%;
|
||||
height: 30px;
|
||||
}
|
||||
|
||||
input.cbi-input-password {
|
||||
width: calc(100% - 25px);
|
||||
}
|
||||
|
||||
[data-dynlist] {
|
||||
display: block;
|
||||
}
|
||||
|
||||
[data-dynlist] > .add-item > input {
|
||||
width: calc(100% - 21px);
|
||||
}
|
||||
|
||||
[data-dynlist] > .add-item > .cbi-button {
|
||||
margin-right: -1px;
|
||||
}
|
||||
|
||||
input[type="text"] + .cbi-button,
|
||||
input[type="password"] + .cbi-button,
|
||||
select + .cbi-button {
|
||||
font-size: 14px !important;
|
||||
line-height: 28px;
|
||||
height: 30px;
|
||||
box-sizing: border-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
.cbi-value-field input[type="checkbox"],
|
||||
.cbi-value-field input[type="radio"] {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.btn, .cbi-button {
|
||||
font-size: 14px !important;
|
||||
padding: 4px 8px;
|
||||
}
|
||||
|
||||
.actions,
|
||||
.cbi-page-actions {
|
||||
border-top: none;
|
||||
margin-top: -.5em;
|
||||
padding: 8px;
|
||||
}
|
||||
|
||||
[data-page="admin-status-overview"] .cbi-section:nth-of-type(1) .td:first-child,
|
||||
[data-page="admin-status-overview"] .cbi-section:nth-of-type(2) .td:first-child {
|
||||
flex-grow: 1;
|
||||
}
|
||||
|
||||
header .pull-right .label {
|
||||
white-space: normal;
|
||||
display: inline-block;
|
||||
text-align: center;
|
||||
line-height: 12px;
|
||||
margin: 1px 0;
|
||||
}
|
||||
|
||||
header > .fill {
|
||||
padding: 1px;
|
||||
}
|
||||
|
||||
header > .fill > .container {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
header .nav {
|
||||
flex: 3 3 80%;
|
||||
margin: 2px 5px 2px 0;
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: flex-start;
|
||||
}
|
||||
|
||||
header .nav a {
|
||||
padding: 2px 6px;
|
||||
}
|
||||
|
||||
header .pull-right {
|
||||
flex: 1 1 20%;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
padding: 0;
|
||||
justify-content: space-around;
|
||||
}
|
||||
|
||||
.menu-dropdown, .dropdown-menu {
|
||||
top: 23px;
|
||||
}
|
||||
|
||||
body {
|
||||
padding-top: 30px;
|
||||
}
|
||||
|
||||
.cbi-optionals,
|
||||
.cbi-section-create {
|
||||
padding: 0 0 14px 0;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .th,
|
||||
#cbi-network-switch_vlan .td {
|
||||
flex-basis: 12%;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions {
|
||||
flex-basis: 100%;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions::before {
|
||||
display: none;
|
||||
}
|
||||
|
||||
#cbi-network-switch_vlan .td.cbi-section-actions > * {
|
||||
width: auto;
|
||||
display: block;
|
||||
}
|
||||
|
||||
#wifi_assoclist_table .td,
|
||||
[data-page="admin-status-processes"] .td {
|
||||
flex-basis: 50% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-status-processes"] .td[data-widget="button"] {
|
||||
flex-basis: 33% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-status-processes"] .td[data-name="PID"],
|
||||
[data-page="admin-status-processes"] .td[data-name="USER"] {
|
||||
flex-basis: 25% !important;
|
||||
}
|
||||
|
||||
[data-page="admin-system-fstab"] .td[data-widget="button"]::before,
|
||||
[data-page="admin-system-startup"] .td[data-widget="button"]::before,
|
||||
[data-page="admin-status-processes"] .td[data-widget="button"]::before {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 375px) {
|
||||
#maincontent.container {
|
||||
margin-top: 55px;
|
||||
}
|
||||
|
||||
.cbi-page-actions {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
margin: 0 -1px;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.cbi-page-actions .cbi-button:not(.cbi-dropdown) {
|
||||
flex: 1 1 calc(50% - 2px);
|
||||
margin: 1px !important;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
.cbi-page-actions .cbi-button-negative,
|
||||
.cbi-page-actions .cbi-button-primary,
|
||||
.cbi-page-actions .cbi-button-apply {
|
||||
flex-basis: calc(100% - -2px);
|
||||
}
|
||||
|
||||
.cbi-section-actions .cbi-button {
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_badge"] {
|
||||
max-width: 50px;
|
||||
align-self: center;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_badge"] .ifacebadge {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-wireless"] .td[data-name="_stat"] {
|
||||
flex-basis: 60%;
|
||||
}
|
||||
|
||||
body[data-page="admin-network-network"] .td.cbi-section-actions::before,
|
||||
body[data-page="admin-network-wireless"] .td.cbi-section-actions::before {
|
||||
content: none !important;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-device-width: 200px) {
|
||||
#maincontent.container {
|
||||
margin-top: 230px;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (max-width: 375px) {
|
||||
.td .ifacebox {
|
||||
width: 100%;
|
||||
margin: 0 !important;
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head {
|
||||
min-width: 25%;
|
||||
justify-content: space-around;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head,
|
||||
.td .ifacebox .ifacebox-body {
|
||||
display: flex;
|
||||
border-bottom: none;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.td .ifacebox .ifacebox-head > *,
|
||||
.ifacebox .ifacebox-body > * {
|
||||
margin: .125em;
|
||||
}
|
||||
}
|
@ -1,18 +0,0 @@
|
||||
<%#
|
||||
Copyright 2008 Steven Barth <steven@midlink.org>
|
||||
Copyright 2008 Jo-Philipp Wich <jow@openwrt.org>
|
||||
Copyright 2012 David Menting <david@nut-bolt.nl>
|
||||
Licensed to the public under the Apache License 2.0.
|
||||
-%>
|
||||
|
||||
<% local ver = require "luci.version" %>
|
||||
|
||||
<footer>
|
||||
<div style="height:40px;font-size:95%;color:#999;font-family: Arial,sans-serif;">© TELEOFIS 2004-2022 </div>
|
||||
<ul class="breadcrumb pull-right" id="modemenu" style="display:none"></ul>
|
||||
</footer>
|
||||
</div>
|
||||
<script type="text/javascript">L.require('menu-teleofis')</script>
|
||||
</body>
|
||||
</html>
|
||||
|
@ -1,69 +0,0 @@
|
||||
<%#
|
||||
Copyright 2008 Steven Barth <steven@midlink.org>
|
||||
Copyright 2008-2016 Jo-Philipp Wich <jow@openwrt.org>
|
||||
Copyright 2012 David Menting <david@nut-bolt.nl>
|
||||
Licensed to the public under the Apache License 2.0.
|
||||
-%>
|
||||
|
||||
<%
|
||||
local sys = require "luci.sys"
|
||||
local util = require "luci.util"
|
||||
local http = require "luci.http"
|
||||
local disp = require "luci.dispatcher"
|
||||
|
||||
local boardinfo = util.ubus("system", "board")
|
||||
|
||||
local node = disp.context.dispatched
|
||||
|
||||
-- send as HTML5
|
||||
http.prepare_content("text/html")
|
||||
-%>
|
||||
<!DOCTYPE html>
|
||||
<html lang="<%=luci.i18n.context.lang%>">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title><%=striptags( (boardinfo.hostname or "?") .. ( (node and node.title) and ' - ' .. translate(node.title) or '')) %> - LuCI</title>
|
||||
<meta name="viewport" content="initial-scale=1.0">
|
||||
<link rel="stylesheet" href="<%=media%>/cascade.css">
|
||||
<link rel="stylesheet" media="only screen and (max-device-width: 854px)" href="<%=media%>/mobile.css" type="text/css" />
|
||||
<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="<%=url('admin/translations', luci.i18n.context.lang)%><%# ?v=PKG_VERSION %>"></script>
|
||||
<script src="<%=resource%>/cbi.js"></script>
|
||||
</head>
|
||||
|
||||
<body class="lang_<%=luci.i18n.context.lang%> <% if node then %><%= striptags( node.title ) %><%- end %>" data-page="<%= pcdata(table.concat(disp.context.requestpath, "-")) %>">
|
||||
<header>
|
||||
<div class="fill">
|
||||
<div class="container">
|
||||
<a class="brand" href="/"></a>
|
||||
<ul class="nav" id="topmenu" style="display:none"></ul>
|
||||
<div id="indicators" class="pull-right"></div>
|
||||
</div>
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<div id="maincontent" 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>
|
||||
<p><%:There is no password set on this router. Please configure a root password to protect the web interface.%></p>
|
||||
<% if disp.lookup("admin/system/admin") then %>
|
||||
<div class="right"><a class="btn" href="<%=url("admin/system/admin")%>"><%:Go to password configuration...%></a></div>
|
||||
<% end %>
|
||||
</div>
|
||||
<%- end -%>
|
||||
|
||||
<noscript>
|
||||
<div class="alert-message warning">
|
||||
<h4><%:JavaScript required!%></h4>
|
||||
<p><%:You must enable JavaScript in your browser or LuCI will not work properly.%></p>
|
||||
</div>
|
||||
</noscript>
|
||||
|
||||
<div id="tabmenu" style="display:none"></div>
|
@ -1,12 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
if [ "$PKG_UPGRADE" != 1 ]; then
|
||||
uci get luci.themes.Teleofis >/dev/null 2>&1 || \
|
||||
uci batch <<-EOF
|
||||
set luci.themes.Teleofis=/luci-static/teleofis
|
||||
set luci.main.mediaurlbase=/luci-static/teleofis
|
||||
commit luci
|
||||
EOF
|
||||
fi
|
||||
|
||||
exit 0
|
Loading…
Reference in New Issue
Block a user