forked from Ruderverein-Donau-Linz/rowt
		
	[TASK] change list view user
This commit is contained in:
		| @@ -67,115 +67,21 @@ | ||||
|         {% 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"> | ||||
|                 <details class="block dark:text-white w-full"> | ||||
|                     <summary> | ||||
|                         <span class="text-black dark:text-white cursor-pointer"> | ||||
|                             <span class="font-bold"> | ||||
|                                 {{ user.name }} | ||||
|                                 {% if not user.last_access and allowed_to_edit and user.mail %} | ||||
|                                     <form action="/admin/user" | ||||
|                                           method="post" | ||||
|                                           enctype="multipart/form-data" | ||||
|                                           class="inline"> | ||||
|                                         • <a class="font-normal text-primary-600 dark:text-primary-200 hover:text-primary-900 dark:hover:text-primary-300 underline" | ||||
|     href="/admin/user/{{ user.id }}/send-welcome-mail" | ||||
|     onclick="return confirm('Willst du wirklich das Willkommensmail an {{ user.name }} ausschicken?');">Willkommensmail verschicken</a> | ||||
|                                     </form> | ||||
|                                 {% endif %} | ||||
|                                 {% 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> | ||||
|                     </summary> | ||||
|                     <a class="block my-1 font-normal text-[#f43f5e] dark:text-primary-200 hover:text-primary-900 dark:hover:text-primary-300 underline" | ||||
|                        href="/admin/user/{{ user.id }}">✏️</a> | ||||
|                     <form action="/admin/user" | ||||
|                           method="post" | ||||
|                           enctype="multipart/form-data" | ||||
|                           class="w-full mt-2"> | ||||
|                         {% if user.pw %} | ||||
|                             <a class="block my-1 font-normal text-[#f43f5e] dark:text-primary-200 hover:text-primary-900 dark:hover:text-primary-300 underline" | ||||
|                                href="/admin/user/{{ user.id }}/reset-pw" | ||||
|                                onclick="return confirm('Willst du wirklich das Passwort zurücksetzen?');">Passwort zurücksetzen</a> | ||||
|                         {% endif %} | ||||
|                         <div class="w-full grid gap-3 mt-3"> | ||||
|                             <input type="hidden" name="id" value="{{ user.id }}" /> | ||||
|                             <div class="grid sm:grid-cols-2 lg:grid-cols-4 gap-3"> | ||||
|                                 {% for cluster, cluster_roles in roles | group_by(attribute="cluster") %} | ||||
|                                     <label for="cluster_{{ loop.index }}">{{ cluster }}</label> | ||||
|                                     {# Determine the initially selected role within the cluster #} | ||||
|                                     {% set_global selected_role_id = "none" %} | ||||
|                                     {% for role in cluster_roles %} | ||||
|                                         {% if selected_role_id == "none" and role.name in user.roles %} | ||||
|                                             {% set_global selected_role_id = role.id %} | ||||
|                                         {% endif %} | ||||
|                                     {% endfor %} | ||||
|                                     {# Set default name to the selected role ID or first role if none selected #} | ||||
|                                     <select id="cluster_{{ loop.index }}" | ||||
|                                             {% if selected_role_id == 'none' %} {% else %} name="roles[{{ selected_role_id }}]" {% endif %} | ||||
|                                             {% if allowed_to_edit == false %}disabled{% endif %} | ||||
|                                             onchange=" if (this.value === '') { this.removeAttribute('name'); } else { this.name = 'roles[' + this.options[this.selectedIndex].getAttribute('data-role-id') + ']'; }"> | ||||
|                                         <option value="" | ||||
|                                                 data-role-id="none" | ||||
|                                                 {% if selected_role_id == 'none' %}selected="selected"{% endif %}> | ||||
|                                             None | ||||
|                                         </option> | ||||
|                                         {% for role in cluster_roles %} | ||||
|                                             <option value="on" | ||||
|                                                     data-role-id="{{ role.id }}" | ||||
|                                                     {% if role.id == selected_role_id %}selected="selected"{% endif %}> | ||||
|                                                 {{ role.name }} | ||||
|                                             </option> | ||||
|                                         {% endfor %} | ||||
|                                     </select> | ||||
|                                 {% endfor %} | ||||
|                                 {% for role in roles %} | ||||
|                                     {% if not role.cluster %} | ||||
|                                         {{ macros::checkbox(label=role.name, name="roles[" ~ role.id ~ "]", id=loop.index , checked=role.name in user.roles, disabled=allowed_to_edit == false) }} | ||||
|                                     {% endif %} | ||||
|                                 {% endfor %} | ||||
|                                 <hr class="sm:col-span-2 lg:col-span-4 my-3" /> | ||||
|                                 {% if user.membership_pdf %} | ||||
|                                     <a href="/admin/user/{{ user.id }}/membership" | ||||
|                                        class="text-black dark:text-white">Beitrittserklärung herunterladen</a> | ||||
|                                 {% else %} | ||||
|                                     {{ macros::input(label='Beitrittserklärung', name='membership_pdf', id=loop.index, type="file", readonly=allowed_to_edit == false, accept='application/pdf') }} | ||||
|                                 {% endif %} | ||||
|                                 {{ macros::input(label='DOB', name='dob', id=loop.index, type="text", value=user.dob, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Weight (kg)', name='weight', id=loop.index, type="text", value=user.weight, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Sex', name='sex', id=loop.index, type="text", value=user.sex, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Mitglied seit', name='member_since_date', id=loop.index, type="text", value=user.member_since_date, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Geburtsdatum', name='birthdate', id=loop.index, type="text", value=user.birthdate, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Mail', name='mail', id=loop.index, type="text", value=user.mail, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Nickname', name='nickname', id=loop.index, type="text", value=user.nickname, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Notizen', name='notes', id=loop.index, type="text", value=user.notes, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Telefon', name='phone', id=loop.index, type="text", value=user.phone, readonly=allowed_to_edit == false) }} | ||||
|                                 {{ macros::input(label='Adresse', name='address', id=loop.index, type="text", value=user.address, readonly=allowed_to_edit == false) }} | ||||
|                                 {% if allowed_to_edit %} | ||||
|                                     {{ macros::select(label="Familie", data=families, name='family_id', selected_id=user.family_id, display=['names'], default="Keine Familie", new_last_entry='Neue Familie anlegen') }} | ||||
|                                 {% endif %} | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         {% if allowed_to_edit %} | ||||
|                             <div class="mt-3 text-right"> | ||||
|                                 <a href="/admin/user/{{ user.id }}/delete" | ||||
|                                    class="w-28 btn btn-alert" | ||||
|                                    onclick="return confirm('Wirklich löschen?');"> | ||||
|                                     {% include "includes/delete-icon" %} | ||||
|                                     Löschen | ||||
|                                 </a> | ||||
|                                 <input value="Ändern" type="submit" class="w-28 btn btn-primary ml-1" /> | ||||
|                             </div> | ||||
|                         {% endif %} | ||||
|                     </form> | ||||
|                 </details> | ||||
|                  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> | ||||
|   | ||||
| @@ -198,7 +198,10 @@ function setChoiceByLabel(choicesInstance, label) { | ||||
|                    {% if pattern %}pattern="{{ pattern }}"{% endif %} | ||||
|                    readonly /> | ||||
|             {% if allowed_to_edit %} | ||||
|                 <button type="button" class="btn btn-dark rounded-l-none-important edit-js">{% include "includes/pencil" %}</button> | ||||
|                 <button type="button" class="btn btn-dark rounded-l-none-important edit-js"> | ||||
|                   {% include "includes/pencil" %} | ||||
|                   <span class="sr-only">Bearbeiten</span> | ||||
|                 </button> | ||||
|                 <input value="x" | ||||
|                        type="reset" | ||||
|                        class="edit-js btn btn-alert btn-hidden rounded-none-important" /> | ||||
| @@ -244,7 +247,10 @@ function setChoiceByLabel(choicesInstance, label) { | ||||
|                 {% if new_last_entry %}<option value="-1">{{ new_last_entry }}</option>{% endif %} | ||||
|             </select> | ||||
|             {% if allowed_to_edit %} | ||||
|                 <button type="button" class="btn btn-dark rounded-l-none-important edit-js">{% include "includes/pencil" %}</button> | ||||
|                 <button type="button" class="btn btn-dark rounded-l-none-important edit-js"> | ||||
|                   {% include "includes/pencil" %} | ||||
|                   <span class="sr-only">Bearbeiten</span> | ||||
|                 </button> | ||||
|                 <input value="x" | ||||
|                        type="reset" | ||||
|                        class="edit-js btn btn-alert btn-hidden rounded-none-important" /> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Marie Birner
					Marie Birner