88 lines
5.0 KiB
Plaintext
88 lines
5.0 KiB
Plaintext
{% macro header(loggedin_user) %}
|
|
<header class="bg-primary-900 text-white flex justify-center p-3 fixed w-full z-10">
|
|
<div class="max-w-screen-xl w-full flex justify-between items-center">
|
|
<div>
|
|
<a href="/">
|
|
Hü {{ loggedin_user.name }}
|
|
</a>
|
|
</div>
|
|
|
|
<div>
|
|
<a href="/faq" class="inline-flex justify-center rounded-md bg-primary-600 mx-1 px-3 py-2 text-sm font-semibold text-white hover:bg-primary-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-primary-600 cursor-pointer">
|
|
{% include "includes/question-icon" %}
|
|
<span class="sr-only">FAQs</span>
|
|
</a>
|
|
{% if loggedin_user.is_admin %}
|
|
<a href="/admin/boat" class="inline-flex justify-center rounded-md bg-primary-600 mx-1 px-3 py-2 text-sm font-semibold text-white hover:bg-primary-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-primary-600 cursor-pointer">
|
|
BOATS
|
|
<span class="sr-only">Bootsverwaltung</span>
|
|
</a>
|
|
|
|
|
|
<a href="/admin/user" class="inline-flex justify-center rounded-md bg-primary-600 mx-1 px-3 py-2 text-sm font-semibold text-white hover:bg-primary-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-primary-600 cursor-pointer">
|
|
<svg class="inline h-4" width="16" height="16" fill="currentColor" class="bi bi-person-lines-fill" viewBox="0 0 16 16"> <path d="M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-5 6s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zM11 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4zm2 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2zm0 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2z"/> </svg>
|
|
<span class="sr-only">Userverwaltung</span>
|
|
</a>
|
|
{% endif %}
|
|
<a href="/auth/logout" class="inline-flex justify-center rounded-md bg-primary-600 ml-1 px-3 py-2 text-sm font-semibold text-white hover:bg-primary-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-primary-600 cursor-pointer">
|
|
<svg class="inline h-4" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-log-out"><path d="M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4"></path><polyline points="16 17 21 12 16 7"></polyline><line x1="21" y1="12" x2="9" y2="12"></line></svg>
|
|
<span class="sr-only">Ausloggen</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</header>
|
|
<div class="h-8"></div>
|
|
{% endmacro header %}
|
|
|
|
{% macro input(label, name, type, required=false, class='rounded-md', value='', min='', hide_label=false) %}
|
|
<div>
|
|
<label for="{{ name }}" class="{% if hide_label %} sr-only {% else %} small text-gray-600 {% endif %}">{{ label }}</label>
|
|
<input id="{{ name }}" name="{{ name }}" type="{{ type }}" {% if required %} required {% endif %} value="{{ value }}" class="input {{ class }}" placeholder="{% if hide_label %}{{ label }}{% endif %}" {% if min %} min="{{ min }}" {% endif %}>
|
|
</div>
|
|
{% endmacro input %}
|
|
|
|
{% macro checkbox(label, name, id='', checked=false) %}
|
|
<label for="{{ name }}{{ id }}" class="flex items-center cursor-pointer hover:text-gray-900">
|
|
<input type="checkbox" id="{{ name }}{{ id }}" name="{{ name }}" {% if checked %} checked {% endif %} class="h-4 w-4 accent-primary-600 mr-2"/> {{ label }}
|
|
</label>
|
|
{% endmacro checkbox %}
|
|
|
|
{% macro select(data, select_name='trip_type', default='', selected_id='') %}
|
|
<select name="{{ select_name }}" class="input rounded-md h-10">
|
|
{% if default %}
|
|
<option selected value>{{ default }}</option>
|
|
{% endif %}
|
|
{% for d in data %}
|
|
<option value="{{ d.id }}" {% if d.id == selected_id %} selected {% endif %}>{{ d.name }}</option>
|
|
{% endfor %}
|
|
</select>
|
|
{% endmacro select %}
|
|
|
|
{% macro alert(message, type, class='') %}
|
|
<div class="{{ class }} alert-{{ type }} text-white px-3 py-1 rounded-md text-center">
|
|
{{ message }}
|
|
</div>
|
|
{% endmacro alert %}
|
|
|
|
{% macro box(participants, empty_seats='', header='Freie Plätze:', text='Keine Ruderer angemeldet', bg='primary-600', color='white') %}
|
|
<div class="text-{{ color }} bg-{{ bg }} text-center p-1 mt-1 rounded-t-md">{{ header }} {{ empty_seats }}</div>
|
|
<div class="p-2 border border-t-0 border-{{ bg }} mb-4 rounded-b-md">
|
|
{% if participants | length > 0 %}
|
|
{% for rower in participants %}
|
|
{{ rower.name }} {% if rower.is_guest %} <small class="text-gray-600">(Gast)</small> {% endif %}<span class="hidden">(angemeldet seit {{ rower.registered_at }})</span><br />
|
|
{% endfor %}
|
|
{% else %}
|
|
{{ text }}
|
|
{% endif %}
|
|
</div>
|
|
{% endmacro box %}
|
|
|
|
{% macro faq(question, answer) %}
|
|
<div>
|
|
<h2 class="flex mb-4 text-lg font-bold text-primary-900">
|
|
{{ question }}
|
|
</h2>
|
|
<p class="text-primary-950">{{ answer | safe }}</p>
|
|
</div>
|
|
{% endmacro faq %}
|