small gui fixes
This commit is contained in:
parent
b481ffeacc
commit
bdb4710f0c
@ -41,9 +41,9 @@
|
|||||||
<span> | </span>
|
<span> | </span>
|
||||||
<a href="{{ url_for('connections') }}">Verbindungen</a>
|
<a href="{{ url_for('connections') }}">Verbindungen</a>
|
||||||
<span> | </span>
|
<span> | </span>
|
||||||
<a href="{{ url_for('dashboard') }}">Auswertung-Downloads</a>
|
<a href="{{ url_for('dashboard') }}">Dashbord</a>
|
||||||
<span> | </span>
|
<span> | </span>
|
||||||
<a href="{{ url_for('songs_dashboard') }}">Auswertung-Wiederholungen</a>
|
<a href="{{ url_for('songs_dashboard') }}">Wiederholungen</a>
|
||||||
{% if admin_enabled %}
|
{% if admin_enabled %}
|
||||||
<span> | </span>
|
<span> | </span>
|
||||||
<a href="{{ url_for('folder_secret_config_editor') }}" id="edit-folder-config">Ordnerkonfiguration</a>
|
<a href="{{ url_for('folder_secret_config_editor') }}" id="edit-folder-config">Ordnerkonfiguration</a>
|
||||||
|
|||||||
@ -6,8 +6,10 @@
|
|||||||
|
|
||||||
{# page‐specific content #}
|
{# page‐specific content #}
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
|
||||||
|
<!-- Main Container -->
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h2>Übersicht deiner gültigen Links</h2>
|
<h2>Übersicht deiner Links</h2>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
{% if valid_secrets %}
|
{% if valid_secrets %}
|
||||||
{% for secret in valid_secrets %}
|
{% for secret in valid_secrets %}
|
||||||
@ -17,7 +19,7 @@
|
|||||||
class="card-img-top qr-code p-3"
|
class="card-img-top qr-code p-3"
|
||||||
alt="QR Code for secret">
|
alt="QR Code for secret">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title">Geheimnis: {{ secret }}</h5>
|
<h5 class="card-title">Secret Link:</h5>
|
||||||
<p class="card-text">
|
<p class="card-text">
|
||||||
<small class="text-muted">Gültig bis: {{ secret_valid_to[secret] }}</small>
|
<small class="text-muted">Gültig bis: {{ secret_valid_to[secret] }}</small>
|
||||||
</p>
|
</p>
|
||||||
@ -29,16 +31,14 @@
|
|||||||
<button type="submit" class="btn btn-danger btn-sm">Link entfernen</button>
|
<button type="submit" class="btn btn-danger btn-sm">Link entfernen</button>
|
||||||
</form>
|
</form>
|
||||||
{% if secret_folders[secret] %}
|
{% if secret_folders[secret] %}
|
||||||
<h6 class="mt-3">Ordner</h6>
|
<h5 class="mt-3">Ordner:</h5>
|
||||||
<ul class="list-group list-group-flush">
|
<div class="list-group">
|
||||||
{% for folder in secret_folders[secret] %}
|
{% for folder in secret_folders[secret] %}
|
||||||
<li class="list-group-item">
|
<a class="btn btn-outline-secondary" style="margin: 5px;" href="/path/{{ folder.foldername }}">{{ folder.foldername }}</a>
|
||||||
<strong>{{ folder.foldername }}</strong>
|
|
||||||
</li>
|
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</div>
|
||||||
{% else %}
|
{% else %}
|
||||||
<p class="text-muted">Keine Ordner für dieses Gemeimnis hinterlegt.</p>
|
<p class="text-muted">Keine Ordner für dieses Secret hinterlegt.</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -66,16 +66,14 @@
|
|||||||
<button type="submit" class="btn btn-danger btn-sm">Link entfernen</button>
|
<button type="submit" class="btn btn-danger btn-sm">Link entfernen</button>
|
||||||
</form>
|
</form>
|
||||||
{% if token_folders[token] %}
|
{% if token_folders[token] %}
|
||||||
<h6 class="mt-3">Ordner</h6>
|
<h5 class="mt-3">Ordner:</h5>
|
||||||
<ul class="list-group list-group-flush">
|
<div class="list-group">
|
||||||
{% for folder in token_folders[token] %}
|
{% for folder in token_folders[token] %}
|
||||||
<li class="list-group-item">
|
<a class="btn btn-outline-secondary" style="margin: 5px;" href="/path/{{ folder.foldername }}">{{ folder.foldername }}</a>
|
||||||
<strong>{{ folder.foldername }}</strong>
|
|
||||||
</li>
|
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</div>
|
||||||
{% else %}
|
{% else %}
|
||||||
<p class="text-muted">Keine Ordner für dieses Gemeimnis hinterlegt.</p>
|
<p class="text-muted">Keine Ordner für diesen Token hinterlegt.</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@ -7,147 +7,144 @@
|
|||||||
{# page content #}
|
{# page content #}
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
|
||||||
<!-- Main Container -->
|
<!-- Main Container -->
|
||||||
<div class="container-fluid px-4">
|
<div class="container-fluid px-4">
|
||||||
<h2>Analyse Wiederholungen</h2>
|
<h2>Analyse Wiederholungen</h2>
|
||||||
<!-- Dropdown Controls -->
|
<!-- Dropdown Controls -->
|
||||||
<div class="mb-4 d-flex flex-wrap gap-2">
|
<div class="mb-4 d-flex flex-wrap gap-2">
|
||||||
|
<!-- Site Dropdown -->
|
||||||
|
<div class="dropdown">
|
||||||
|
<button class="btn btn-secondary dropdown-toggle"
|
||||||
|
type="button" id="siteDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
||||||
|
{% if session['songs_dashboard_site'] == 'Speyer' %}
|
||||||
|
Speyer
|
||||||
|
{% elif session['songs_dashboard_site'] == 'Schwegenheim' %}
|
||||||
|
Schwegenheim
|
||||||
|
{% else %}
|
||||||
|
Select Site
|
||||||
|
{% endif %}
|
||||||
|
</button>
|
||||||
|
<ul class="dropdown-menu" aria-labelledby="siteDropdown">
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_site'] == 'Speyer' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', site='Speyer') }}">
|
||||||
|
Speyer
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_site'] == 'Schwegenheim' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', site='Schwegenheim') }}">
|
||||||
|
Schwegenheim
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Timeframe Dropdown -->
|
||||||
|
<div class="dropdown">
|
||||||
|
<button class="btn btn-secondary dropdown-toggle"
|
||||||
|
type="button" id="timeframeDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
||||||
|
{% if session['songs_dashboard_timeframe'] == '7' %}
|
||||||
|
Last 7 Days
|
||||||
|
{% elif session['songs_dashboard_timeframe'] == '30' %}
|
||||||
|
Last 30 Days
|
||||||
|
{% elif session['songs_dashboard_timeframe'] == '90' %}
|
||||||
|
Last 90 Days
|
||||||
|
{% elif session['songs_dashboard_timeframe'] == '365' %}
|
||||||
|
Last 365 Days
|
||||||
|
{% elif session['songs_dashboard_timeframe'] == 'all' %}
|
||||||
|
All Data
|
||||||
|
{% else %}
|
||||||
|
Select Timeframe
|
||||||
|
{% endif %}
|
||||||
|
</button>
|
||||||
|
<ul class="dropdown-menu" aria-labelledby="timeframeDropdown">
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '7' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', timeframe='7') }}">
|
||||||
|
Last 7 Days
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '30' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', timeframe='30') }}">
|
||||||
|
Last 30 Days
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '90' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', timeframe='90') }}">
|
||||||
|
Last 90 Days
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '365' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', timeframe='365') }}">
|
||||||
|
Last 365 Days
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == 'all' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', timeframe='all') }}">
|
||||||
|
All Data
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
<!-- Site Dropdown -->
|
<!-- category Dropdown -->
|
||||||
<div class="dropdown">
|
<div class="dropdown">
|
||||||
<button class="btn btn-secondary dropdown-toggle"
|
<button class="btn btn-secondary dropdown-toggle" type="button" id="categoryDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
||||||
type="button" id="siteDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
{% if session['songs_dashboard_category'] == 'Gemeinsamer Gesang' %}
|
||||||
{% if session['songs_dashboard_site'] == 'Speyer' %}
|
Gemeinsamer Gesang
|
||||||
Speyer
|
{% elif session['songs_dashboard_category'] == 'Chor' %}
|
||||||
{% elif session['songs_dashboard_site'] == 'Schwegenheim' %}
|
Chor
|
||||||
Schwegenheim
|
{% elif session['songs_dashboard_category'] == 'Gruppenlied' %}
|
||||||
{% else %}
|
Gruppenlied
|
||||||
Select Site
|
{% else %}
|
||||||
{% endif %}
|
Select Category
|
||||||
</button>
|
{% endif %}
|
||||||
<ul class="dropdown-menu" aria-labelledby="siteDropdown">
|
</button>
|
||||||
<li>
|
<ul class="dropdown-menu" aria-labelledby="categoryDropdown">
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_site'] == 'Speyer' %}active{% endif %}"
|
<li>
|
||||||
href="{{ url_for('songs_dashboard', site='Speyer') }}">
|
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Gemeinsamer Gesang' %}active{% endif %}"
|
||||||
Speyer
|
href="{{ url_for('songs_dashboard', category='Gemeinsamer Gesang') }}">
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_site'] == 'Schwegenheim' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', site='Schwegenheim') }}">
|
|
||||||
Schwegenheim
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Timeframe Dropdown -->
|
|
||||||
<div class="dropdown">
|
|
||||||
<button class="btn btn-secondary dropdown-toggle"
|
|
||||||
type="button" id="timeframeDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
|
||||||
{% if session['songs_dashboard_timeframe'] == '7' %}
|
|
||||||
Last 7 Days
|
|
||||||
{% elif session['songs_dashboard_timeframe'] == '30' %}
|
|
||||||
Last 30 Days
|
|
||||||
{% elif session['songs_dashboard_timeframe'] == '90' %}
|
|
||||||
Last 90 Days
|
|
||||||
{% elif session['songs_dashboard_timeframe'] == '365' %}
|
|
||||||
Last 365 Days
|
|
||||||
{% elif session['songs_dashboard_timeframe'] == 'all' %}
|
|
||||||
All Data
|
|
||||||
{% else %}
|
|
||||||
Select Timeframe
|
|
||||||
{% endif %}
|
|
||||||
</button>
|
|
||||||
<ul class="dropdown-menu" aria-labelledby="timeframeDropdown">
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '7' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', timeframe='7') }}">
|
|
||||||
Last 7 Days
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '30' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', timeframe='30') }}">
|
|
||||||
Last 30 Days
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '90' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', timeframe='90') }}">
|
|
||||||
Last 90 Days
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == '365' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', timeframe='365') }}">
|
|
||||||
Last 365 Days
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_timeframe'] == 'all' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', timeframe='all') }}">
|
|
||||||
All Data
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- category Dropdown -->
|
|
||||||
<div class="dropdown">
|
|
||||||
<button class="btn btn-secondary dropdown-toggle" type="button" id="categoryDropdown" data-bs-toggle="dropdown" aria-expanded="false">
|
|
||||||
{% if session['songs_dashboard_category'] == 'Gemeinsamer Gesang' %}
|
|
||||||
Gemeinsamer Gesang
|
Gemeinsamer Gesang
|
||||||
{% elif session['songs_dashboard_category'] == 'Chor' %}
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Chor' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', category='Chor') }}">
|
||||||
Chor
|
Chor
|
||||||
{% elif session['songs_dashboard_category'] == 'Gruppenlied' %}
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Gruppenlied' %}active{% endif %}"
|
||||||
|
href="{{ url_for('songs_dashboard', category='Gruppenlied') }}">
|
||||||
Gruppenlied
|
Gruppenlied
|
||||||
{% else %}
|
</a>
|
||||||
Select Category
|
</li>
|
||||||
{% endif %}
|
</ul>
|
||||||
</button>
|
</div>
|
||||||
<ul class="dropdown-menu" aria-labelledby="categoryDropdown">
|
</div>
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Gemeinsamer Gesang' %}active{% endif %}"
|
<!-- Table Output -->
|
||||||
href="{{ url_for('songs_dashboard', category='Gemeinsamer Gesang') }}">
|
<table class="table table-bordered">
|
||||||
Gemeinsamer Gesang
|
<thead>
|
||||||
</a>
|
<tr>
|
||||||
</li>
|
<th>Anzahl</th>
|
||||||
<li>
|
<th>Titel</th>
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Chor' %}active{% endif %}"
|
</tr>
|
||||||
href="{{ url_for('songs_dashboard', category='Chor') }}">
|
</thead>
|
||||||
Chor
|
<tbody>
|
||||||
</a>
|
{% for count, titel in performance_data %}
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a class="dropdown-item {% if session['songs_dashboard_category'] == 'Gruppenlied' %}active{% endif %}"
|
|
||||||
href="{{ url_for('songs_dashboard', category='Gruppenlied') }}">
|
|
||||||
Gruppenlied
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Table Output -->
|
|
||||||
<table class="table table-bordered">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
<tr>
|
||||||
<th>Anzahl</th>
|
<td>{{ count }}</td>
|
||||||
<th>Titel</th>
|
<td>{{ titel }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
{% endfor %}
|
||||||
<tbody>
|
</tbody>
|
||||||
{% for count, titel in performance_data %}
|
</table>
|
||||||
<tr>
|
</div>
|
||||||
<td>{{ count }}</td>
|
|
||||||
<td>{{ titel }}</td>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
Loading…
x
Reference in New Issue
Block a user