2023-11-29 23:38:12 Auto Sync

This commit is contained in:
WindyMadman 2023-11-29 23:38:12 +08:00
parent 5994ae095b
commit c55ca8a600
18 changed files with 0 additions and 6446 deletions

View File

@ -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

View File

@ -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;
}
}

View File

@ -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';
}
});

View File

@ -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 %>&nbsp;&#169;&nbsp132lan.ru&nbsp;2022&nbsp;</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>

View File

@ -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>

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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;
}
}

View File

@ -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;">&#169;&nbsp;TELEOFIS&nbsp;2004-2022&nbsp;</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>

View File

@ -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>

View File

@ -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