129 lines
5.6 KiB
Twig
129 lines
5.6 KiB
Twig
{% extends "Froxlor/base.html.twig" %}
|
|
|
|
{% set body_class = "min-vh-100 d-flex flex-column" %}
|
|
|
|
{% block navigation %}
|
|
{% if get_setting('panel.is_configured') == 0 and userinfo.adminsession == 1 and userinfo.change_serversettings == 1 %}
|
|
<div class="alert alert-info rounded-0 mb-0 d-flex justify-content-between align-items-baseline" role="alert">
|
|
<span>
|
|
<i class="alert-icon fa-solid fa-info-circle"></i> {{ lng('panel.not_configured') }}
|
|
</span>
|
|
|
|
<span>
|
|
<a href="{{ linker({'section': 'configfiles', 'page': 'configfiles'}) }}" class="btn btn-light btn-sm">
|
|
Setup starten
|
|
</a>
|
|
</span>
|
|
</div>
|
|
{% endif %}
|
|
|
|
<nav class="navbar navbar-expand-md navbar-light p-0 {% if not block('heading') %}shadow-sm{% endif %}">
|
|
<div class="container-fluid gx-0">
|
|
<a class="navbar-brand" href="{{ linker({'section': 'index'}) }}">
|
|
<img src="{{ header_logo }}" alt="" width="auto" height="24" class="d-inline-block align-text-top">
|
|
</a>
|
|
<div class="me-3 me-sm-0">
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbar" aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#sidebar" aria-controls="sidebar" aria-expanded="false" aria-label="Toggle sidebar">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
</div>
|
|
<div class="collapse navbar-collapse px-3 px-lg-5" id="navbar">
|
|
<form id="search" method="post">
|
|
<div class="d-flex align-items-center">
|
|
<i class="fa-solid fa-search text-muted"></i>
|
|
<input title="search" type="search" class="search-input" placeholder="{{ lng('panel.search') }}...">
|
|
</div>
|
|
<div class="search-results-box p-2 shadow" style="display:none;">
|
|
<div class="search-results list-group-flush"></div>
|
|
</div>
|
|
</form>
|
|
<ul class="navbar-nav ms-auto">
|
|
{% if call_static('\\Froxlor\\CurrentUser', 'getField', ['switched_user']) is not empty and call_static('\\Froxlor\\CurrentUser', 'getField', ['switched_user']) is iterable %}
|
|
<a class="nav-link text-success" href="{{ linker({'section': 'index', 'action': 'suback'}) }}">
|
|
<i class="fa-solid fa-reply me-1"></i> {{ userinfo.switched_user.loginname }}
|
|
</a>
|
|
{% endif %}
|
|
{% if userinfo.adminsession == 1 %}
|
|
<li class="nav-item" id="updatecheck"></li>
|
|
{% endif %}
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="{{ linker({'section': 'index'}) }}">
|
|
{{ lng('panel.dashboard') }}
|
|
</a>
|
|
</li>
|
|
<li class="nav-item dropdown">
|
|
<a class="nav-link dropdown-toggle" href="#" id="navbarOpts" role="button" data-bs-toggle="dropdown" aria-expanded="false">
|
|
{{ userinfo.loginname }}
|
|
</a>
|
|
<ul class="dropdown-menu dropdown-menu-end" aria-labelledby="navbarOpts">
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': 'change_password'}) }}"><i class="fa-solid fa-lock"></i> {{ lng('login.password') }}</a>
|
|
</li>
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': 'change_language'}) }}"><i class="fa-solid fa-flag"></i> {{ lng('login.language') }}</a>
|
|
</li>
|
|
{% if get_setting('2fa.enabled') == 1 %}
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': '2fa'}) }}"><i class="fa-solid fa-shield"></i> {{ lng('2fa.2fa') }}</a>
|
|
</li>
|
|
{% endif %}
|
|
{% if get_setting('panel.allow_theme_change_admin') == '1' and userinfo.adminsession == 1 %}
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': 'change_theme'}) }}"><i class="fa-solid fa-image"></i> {{ lng('panel.theme') }}</a>
|
|
</li>
|
|
{% elseif get_setting('panel.allow_theme_change_customer') == '1' and userinfo.adminsession == 0 %}
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': 'change_theme'}) }}"><i class="fa-solid fa-image"></i> {{ lng('panel.theme') }}</a>
|
|
</li>
|
|
{% endif %}
|
|
{% if get_setting('api.enabled') == 1 and userinfo.api_allowed == 1 %}
|
|
<li><hr class="dropdown-divider"></li>
|
|
<li>
|
|
<a class="dropdown-item" href="{{ linker({'section': 'index', 'page': 'apikeys'}) }}"><i class="fa-solid fa-key"></i> {{ lng('menue.main.apikeys') }}</a>
|
|
</li>
|
|
<li>
|
|
<a class="dropdown-item" href="https://docs.froxlor.org/apiguide/index.html" rel="external" target="_blank"><i class="fa-solid fa-circle-info"></i> {{ lng('menue.main.apihelp') }}</a>
|
|
</li>
|
|
{% endif %}
|
|
</ul>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="btn btn-link pe-0" title="{{ lng('login.logout') }}" href="{{ linker({'section': 'index', 'action': 'logout'}) }}">
|
|
<i class="fas fa-power-off"></i>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
{% endblock %}
|
|
|
|
{% block body %}
|
|
<div class="d-flex flex-grow-1">
|
|
{{ include('Froxlor/sidebar.html.twig') }}
|
|
|
|
<div class="d-flex flex-grow-1 overflow-hidden">
|
|
|
|
<main class="d-flex flex-column flex-grow-1 overflow-auto">
|
|
{% if block('heading') %}
|
|
<section class="py-3 px-3 px-lg-5 bg-white shadow-sm border-top d-flex justify-content-between align-items-center">
|
|
<div>{% block heading %}{% endblock %}</div>
|
|
<div>{% block actions %}{% endblock %}</div>
|
|
</section>
|
|
{% endif %}
|
|
|
|
<section class="flex-grow-1 p-3 p-lg-5">
|
|
{% block content %}{% endblock %}
|
|
</section>
|
|
|
|
{{ include('Froxlor/footer.html.twig') }}
|
|
</main>
|
|
|
|
{% block subsidebar %}{% endblock %}
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|