118 lines
5.1 KiB
HTML
118 lines
5.1 KiB
HTML
{% import '_macros.html.j2' as mc -%}
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>{{ config.APP_NAME }}</title>
|
|
<!-- meta -->
|
|
<meta name="description" content="">
|
|
<meta name="author" content="">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
|
{% block meta %}{% endblock %}
|
|
<!-- styles -->
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='bootstrap/bootstrap.min.css') }}">
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='bootstrap/toggle-bootstrap.min.css') }}">
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='bootstrap/toggle-bootstrap-dark.min.css') }}">
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='bootstrap/toggle-bootstrap-print.min.css') }}">
|
|
<!-- Century gothic font -->
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='fonts/century-gothic.css') }}">
|
|
<!-- fontawesome -->
|
|
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.0/css/all.css" integrity="sha384-lZN37f5QGtY3VHgisS14W3ExzMWZxybE1SJSEsQp9S+oqd12jhcu+A56Ebc1zFSJ" crossorigin="anonymous">
|
|
|
|
<link href="{{ url_for('static', filename='main.css') }}" rel="stylesheet" media="screen">
|
|
<!-- Datatables -->
|
|
<link href="{{ url_for('static', filename='datatables/datatables.min.css') }}" rel="stylesheet">
|
|
{% block links %}{% endblock %}
|
|
<link rel="icon" type="image/png" sizes="180x180" href="{{ url_for('static', filename='favicon/apple-touch-icon.png') }}">
|
|
<link rel="icon" type="image/png" sizes="32x32" href="{{ url_for('static', filename='favicon/favicon-32x32.png') }}">
|
|
<link rel="icon" type="image/png" sizes="16x16" href="{{ url_for('static', filename='favicon/favicon-16x16.png') }}">
|
|
<link rel="icon" type="image/png" sizes="192x192" href="{{ url_for('static', filename='favicon/android-chrome-192x192.png') }}">
|
|
<link rel="icon" type="image/png" sizes="512x512" href="{{ url_for('static', filename='favicon/android-chrome-512x512.png') }}">
|
|
<link rel="manifest" href="{{ url_for('static', filename='favicon/site.webmanifest') }}">
|
|
</head>
|
|
|
|
<body class="bootstrap bootstrap-dark">
|
|
<!-- Header -->
|
|
<header>
|
|
<!-- Navigation -->
|
|
<nav class="navbar navbar-expand-lg navbar-themed">
|
|
<!-- Navbar Brand -->
|
|
<a class="navbar-brand" href="{{ url_for('main.index') }}">
|
|
<img src="{{ url_for('static', filename='/hsman.png') }}">
|
|
<!-- HSMAN -->
|
|
</a>
|
|
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav"
|
|
aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
|
|
<div class="collapse navbar-collapse" id="navbarNav">
|
|
<ul class="navbar-nav mr-auto">
|
|
{% if auth.isAdmin %}
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="{{ url_for('main.nodes') }}"><i class="fas fa-desktop"></i> nodes</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="{{ url_for('main.users') }}"><i class="fas fa-address-card"></i> users</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="{{ url_for('main.routes') }}"><i class="fas fa-satellite-dish"></i> routes</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="{{ url_for('main.policy') }}"><i class="fas fa-user-shield"></i> policy</a>
|
|
</li>
|
|
{% endif %}
|
|
</ul>
|
|
<ul class="navbar-nav">
|
|
<li class="nav-item me-right">
|
|
<a href="{{url_for('main.logout') }}" id="themeSwitch">
|
|
<i class="fas fa-sign-out-alt"></i>
|
|
<!-- <i class="fas fa-plug-circle-xmark"></i> -->
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</nav>
|
|
</header>
|
|
{% if g.is_mobile %}
|
|
<div class="container-fluid">
|
|
{% else %}
|
|
<div class="container-lg">
|
|
{% endif %}
|
|
<p></p>
|
|
<!-- Main Content -->
|
|
{% block content %}{% endblock %}
|
|
</div>
|
|
|
|
<!-- Footer-->
|
|
<footer class="footer text-center">
|
|
<div class="container">
|
|
<div class="row">
|
|
<!-- Copyrights -->
|
|
<div class="col-lg-12 text-center">
|
|
<p class="text-muted mb-0 py-2">
|
|
<!-- <img src="/static/hsman.png" height="20px"> -->
|
|
Headscale Manager |
|
|
ver. {{ config.APP_VERSION }} ({{ config.APP_SHA }})
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</footer>
|
|
<!-- scripts -->
|
|
<script src="{{ url_for('static', filename='bootstrap/jquery-3.7.1.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='bootstrap/popper-1.12.9.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='bootstrap/bootstrap.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='datatables/datatables.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='main.js') }}" type="text/javascript"></script>
|
|
<script>
|
|
$(function () {
|
|
$('[data-toggle="tooltip"]').tooltip();
|
|
})
|
|
</script>
|
|
{% block scripts %}{% endblock %}
|
|
</body>
|
|
|
|
</html>
|