{% 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 class="w-1/3 truncate">
                {% if "Donau Linz" in loggedin_user.roles %}
                    <a href="/planned">
                    {% else %}
                        <a href="/">
                        {% endif %}
                        Hü
                        {{ loggedin_user.name }}
                    </a>
                </div>
                <div>
                    <a href="https://wiki.rudernlinz.at/ruderassistent#faq"
                       target="_blank"
                       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 "scheckbuch" in loggedin_user.roles and loggedin_user.weight and loggedin_user.sex and loggedin_user.dob %}
                        <a href="#"
                           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"
                           data-sidebar="true"
                           data-trigger="sidebar"
                           data-header="Ergo Challenge"
                           data-body="#mobile-menu-guest">
                            {% include "includes/book" %}
                            <span class="sr-only">Ergo</span>
                        </a>
                        <div class="hidden">
                            <div id="mobile-menu-guest">
                                <a href="/ergo" class="block w-100 py-2 hover:text-primary-600 border-t">Ergo</a>
                            </div>
                        </div>
                    {% endif %}
                    {% if "scheckbuch" not in loggedin_user.roles %}
                        <a href="#"
                           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"
                           data-sidebar="true"
                           data-trigger="sidebar"
                           data-header="Menü"
                           data-body="#mobile-menu">
                            {% include "includes/book" %}
                            <span class="sr-only">Logbuch</span>
                        </a>
                        <div class="hidden">
                            <div id="mobile-menu">
                                <a href="/log" class="block w-100 py-2 hover:text-primary-600">Ausfahrt eintragen</a>
                                <a href="/log/show"
                                   class="block w-100 py-2 hover:text-primary-600 border-t">Logbuch</a>
                                {% if loggedin_user.weight and loggedin_user.sex and loggedin_user.dob %}
                                    <a href="/ergo" class="block w-100 py-2 hover:text-primary-600 border-t">Ergo</a>
                                {% endif %}
                                <a href="/stat" class="block w-100 py-2 hover:text-primary-600 border-t">Statistik</a>
                                <a href="/stat/boats"
                                   class="block w-100 py-2 hover:text-primary-600 border-t">Bootsauswertung</a>
                                {% if "admin" in loggedin_user.roles %}
                                    <a href="/admin/boat"
                                       class="block w-100 py-2 hover:text-primary-600 border-t">Boote</a>
                                {% endif %}
                                <a href="/boatdamage"
                                   class="block w-100 py-2 hover:text-primary-600 border-t">Bootsschaden</a>
                            </div>
                        </div>
                    {% endif %}
                    {% if "admin" in loggedin_user.roles or "Vorstand" in loggedin_user.roles %}
                        <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-gray-200 ml-1 px-3 py-2 text-sm font-semibold text-primary-950 hover:bg-gray-300 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, id='', autofocus=false, wrapper_class='', pattern='', readonly=false) %}
        <div class="{{ wrapper_class }}">
            <label for="{{ name }}"
                   class="{% if hide_label %} sr-only {% else %} text-sm text-gray-600 dark:text-white {% endif %}">
                {{ label }}
            </label>
            <input {% if type=='datetime-local' %}onclick='if (!this.value) setCurrentdate(this)'{% endif %}
                   {% if id %} id="{{ id }}" {% else %} id="{{ name }}" {% endif %}
                   name="{{ name }}"
                   type="{{ type }}"
                   {% if required %}required{% endif %}
                   value="{{ value }}"
                   class="input {{ class }}"
                   placeholder="{% if hide_label %}{{ label }}{% endif %}"
                   {% if min is defined %}min="{{ min }}"{% endif %}
                   {% if autofocus %}autofocus{% endif %}
                   {% if pattern %}pattern="{{ pattern }}"{% endif %}
                   {% if readonly %}readonly{% endif %}>
        </div>
    {% endmacro input %}
    {% macro checkbox(label, name, id='', checked=false, class='', disabled=false) %}
        <label for="{{ name }}{{ id }}"
               class="flex items-center cursor-pointer text-black dark:text-white hover:text-gray-900 dark:hover:text-gray-100 {{ class }}">
            <input type="checkbox"
                   id="{{ name }}{{ id }}"
                   name="{{ name }}"
                   {% if checked %}checked{% endif %}
                   {% if disabled %}disabled{% endif %}
                   class="h-4 w-4 accent-primary-600 dark:accent-primary-200 mr-2" />
            {{ label }}
        </label>
    {% endmacro checkbox %}
    {% macro select(label, data, name='trip_type', default='', id='', selected_id='', display='', extras='', class='', wrapper_class='', required=false, show_seats=false, new_last_entry='') %}
        <div class="{{ wrapper_class }}">
            <label for="{{ name }}" class="text-sm text-gray-600 dark:text-gray-100">{{ label }}</label>
            {% if display == '' %}
                {% set display = ["name"] %}
            {% endif %}
            <select name="{{ name }}"
                    {% if id %} id="{{ id }}" {% else %} id="{{ name }}" {% endif %}
                    class="input rounded-md {{ class }}"
                    {% if required %}required="required"{% endif %}>
                {% if default %}<option selected value>{{ default }}</option>{% endif %}
                {% for d in data %}
                    <option value="{{ d.id }}" {% if d.id == selected_id %}selected{% endif %} {% if extras != '' %} {% for extra in extras %} {% if extra != 'on_water' and d[extra] %} data-{{ extra }}={{ d[extra] }} {% else %} {% if d[extra] %}disabled{% endif %} {% endif %} {% endfor %} {% endif %} {% if show_seats %} data-custom-properties='{"amount_seats": {{ d["amount_seats"] }}, "owner": "{{ d["owner"] }}", "default_destination": "{{ d["default_destination"] }}", "boat_in_ottensheim": {{ d["location_id"] == 2 }}}'{% endif %}>
                        {% for displa in display -%}
                            {%- if d[displa] -%}
                                {{- d[displa] -}}
                            {%- else -%}
                                {{- displa -}}
                            {%- endif -%}
                        {%- endfor %}
                    </option>
                {% endfor %}
                {% if new_last_entry %}<option value="-1">{{ new_last_entry }}</option>{% endif %}
            </select>
        </div>
    {% 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', trip_details_id='', allow_removing=false) %}
        <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 dark:text-gray-100">(Scheckbuch)</small>{% endif %}
                    {% if rower.is_real_guest %}
                        <small class="text-gray-600 dark:text-gray-100">(Gast)</small>
                        {% if allow_removing %}
                            <a href="/planned/remove/{{ trip_details_id }}/{{ rower.name }}"
                               class="btn btn-attention btn-fw">Abmelden</a>
                        {% endif %}
                    {% 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 %}