89 lines
4.6 KiB
Plaintext
89 lines
4.6 KiB
Plaintext
{% import "includes/macros" as macros %}
|
|
{% extends "base" %}
|
|
{% block content %}
|
|
<div class="max-w-screen-lg w-full">
|
|
<h1 class="h1">Users</h1>
|
|
{% if allowed_to_edit %}
|
|
<details class="mt-5 bg-gray-200 dark:bg-primary-600 p-3 rounded-md">
|
|
<summary class="px-3 cursor-pointer text-md font-bold text-primary-950 dark:text-white">
|
|
Neue Person hinzufügen
|
|
</summary>
|
|
<form action="/admin/user/new"
|
|
onsubmit="return confirm('Willst du wirklich einen neuen Benutzer anlegen?');"
|
|
method="post"
|
|
class="flex mt-4 rounded-md sm:flex items-end justify-between">
|
|
<div class="w-full">
|
|
<div>
|
|
<label for="name" class="sr-only">Name</label>
|
|
<input type="text"
|
|
name="name"
|
|
class="input rounded-md w-100"
|
|
placeholder="Name" />
|
|
</div>
|
|
</div>
|
|
<div class="text-right ml-3">
|
|
<input value="Hinzufügen"
|
|
type="submit"
|
|
class="w-28 mt-2 sm:mt-0 rounded-md bg-primary-500 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" />
|
|
</div>
|
|
</form>
|
|
</details>
|
|
{% endif %}
|
|
<!-- START filterBar -->
|
|
<div class="search-wrapper flex">
|
|
<label for="name" class="sr-only">Suche</label>
|
|
<input type="search"
|
|
name="name"
|
|
id="filter-js"
|
|
class="search-bar"
|
|
placeholder="Suchen nach (Name, [yes|no]-role:<name>, has-[no-]membership-pdf)" />
|
|
<div class="relative">
|
|
<button id="dropdownbtn"
|
|
data-dropdown="dropdown"
|
|
class="btn btn-dark ml-3"
|
|
type="button">Sortieren</button>
|
|
<!-- Dropdown menu -->
|
|
<div id="dropdown"
|
|
class="z-10 hidden bg-white divide-y divide-gray-100 text-secondary-900 rounded-lg shadow-sm w-44 absolute right-0">
|
|
<ul class="py-2 text-sm" aria-labelledby="dropdownbtn">
|
|
<li>
|
|
<a href="./user"
|
|
class="block px-4 py-2 hover:bg-gray-100 hover:text-secondary-950">Zuletzt eingeloggt</a>
|
|
</li>
|
|
<li>
|
|
<a href="?sort=name&asc"
|
|
class="block px-4 py-2 hover:bg-gray-100 hover:text-secondary-950">Name A-Z</a>
|
|
</li>
|
|
<li>
|
|
<a href="?sort=name"
|
|
class="block px-4 py-2 hover:bg-gray-100 hover:text-secondary-950">Name Z-A</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- END filterBar -->
|
|
<div id="filter-result-js" class="search-result"></div>
|
|
{% for user in users %}
|
|
<div data-filterable="true"
|
|
data-filter="{{ user.name }} {% for role in roles %} {% if role.name in user.roles %} yes-role:{{ role.name }} {% else %} no-role:{{ role.name }} {% endif %} role-{{ role }} {% endfor %} {% if user.membership_pdf %}has-membership-pdf{% else %}has-no-membership-pdf{% endif %}"
|
|
class="border-t bg-white dark:bg-primary-900 py-3 px-4 relative flex justify-between items-center">
|
|
<span class="text-black dark:text-white cursor-pointer">
|
|
<span class="font-bold">
|
|
{{ user.name }}
|
|
{% if user.last_access %}• ⏳ {{ user.last_access | date }}{% endif %}
|
|
</span>
|
|
<small class="block text-gray-600 dark:text-gray-100">
|
|
{% for role in user.roles -%}
|
|
{{ role }}
|
|
{%- if not loop.last %},
|
|
{% endif -%}
|
|
{% endfor %}
|
|
</small>
|
|
</span>
|
|
<a href="/admin/user/{{ user.id }}" class="btn btn-dark ml-3">{% include "includes/pencil" %}</a>
|
|
</div>
|
|
{% endfor %}
|
|
</div>
|
|
{% endblock content %}
|