Rework forms

This commit is contained in:
William Bouzourène 2025-01-12 17:14:39 +01:00
parent aa6d89aac8
commit efafb845f3
Signed by: bouzoure
SSH key fingerprint: SHA256:19MbXpLua4rUtk8tunMesD8KUKb91LXLHg8E/qTooww
14 changed files with 1539 additions and 679 deletions

View file

@ -24,10 +24,11 @@
<form id="user" method="post"> <form id="user" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="col-md-2 form-label">
Nom complet Nom complet
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -37,11 +38,13 @@
value="{{ User.Name }}" value="{{ User.Name }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="email" class="form-label"> <label for="email" class="col-md-2 form-label">
Email Email
</label> </label>
<div class="col-md-10">
<input <input
id="email" id="email"
class="form-control" class="form-control"
@ -51,11 +54,13 @@
value="{{ User.Email }}" value="{{ User.Email }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="password" class="form-label"> <label for="password" class="col-md-2 form-label">
Mot de passe Mot de passe
</label> </label>
<div class="col-md-10">
<input <input
id="password" id="password"
class="form-control" class="form-control"
@ -66,11 +71,13 @@
Laisser vide pour ne pas changer Laisser vide pour ne pas changer
</div> </div>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="password" class="form-label"> <label for="password" class="col-md-2 form-label">
Confirmer le mot de passe Confirmer le mot de passe
</label> </label>
<div class="col-md-10">
<input <input
id="password-verify" id="password-verify"
class="form-control" class="form-control"
@ -78,8 +85,9 @@
name="password-verify" name="password-verify"
> >
</div> </div>
</div>
<div class="mt-4"> <div class="my-4">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">
<i class="me-1 bi-floppy"></i> <i class="me-1 bi-floppy"></i>
Enregistrer Enregistrer

View file

@ -31,7 +31,7 @@
</div> </div>
</div> </div>
<div class="mt-4"> <div class="my-4">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">
<i class="me-1 bi-floppy"></i> <i class="me-1 bi-floppy"></i>
Enregistrer Enregistrer

View file

@ -14,40 +14,97 @@
<hr> <hr>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom du champ</b><br> <div class="col-md-2">
{{ Field.Name }} Nom du champ
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ Field.Name }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Population</b><br> <div class="col-md-2">
Population
</div>
<div class="col-md-10">
{% for Key, Value in PersonTypes %} {% for Key, Value in PersonTypes %}
{% if Key == Field.PersonType %} {% if Key == Field.PersonType %}
{{ Value }} <input
type="text"
class="form-control"
value="{{ Value }}"
disabled
readonly
>
{% endif %} {% endif %}
{% endfor %} {% endfor %}
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<b>Type de champ</b><br> <div class="col-md-2">
Type de champ
</div>
<div class="col-md-10">
{% for Key, Value in FieldTypes %} {% for Key, Value in FieldTypes %}
{% if Key == Field.FieldType %} {% if Key == Field.FieldType %}
{{ Value }} <input
type="text"
class="form-control"
value="{{ Value }}"
disabled
readonly
>
{% endif %} {% endif %}
{% endfor %} {% endfor %}
</div> </div>
{% if Field.ListID %}
<div class="mb-3">
<b>Liste</b><br>
<a href="/admin/lists/{{ Field.List.ID }}">
{{ Field.List.Name }}
</a>
</div> </div>
<div class="row mb-3">
<div class="col-md-2">
Liste
</div>
<div class="col-md-10">
<div class="input-group">
{% if Field.ListID %}
<input
type="text"
class="form-control"
value="{{ Field.List.Name }}"
readonly
disabled
>
<span class="input-group-text">
<a href="/admin/lists/{{ Field.List.ID }}">
Afficher
<i class="bi-box-arrow-up-right ms-1"></i>
</a>
</span>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %} {% endif %}
</div>
</div>
<div class="mt-3"> <div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/fields/{{ Field.ID }}/edit"> <a class="btn btn-md btn-primary" href="/admin/fields/{{ Field.ID }}/edit">
<i class="bi-pencil-square"></i> <i class="bi-pencil-square"></i>
Modifier Modifier

View file

@ -34,10 +34,11 @@
<form id="field" method="post"> <form id="field" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="form-label col-md-2">
Nom du champ Nom du champ
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -47,12 +48,14 @@
value="{{ Field.Name }}" value="{{ Field.Name }}"
> >
</div> </div>
</div>
{% if !Field.ID %} {% if !Field.ID %}
<div class="mb-3"> <div class="row mb-3">
<label for="person_type" class="form-label"> <label for="person_type" class="form-label col-md-2">
Population Population
</label> </label>
<div class="col-md-10">
<select <select
name="person_type" name="person_type"
id="person_type" id="person_type"
@ -64,11 +67,13 @@
{% endfor %} {% endfor %}
</select> </select>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="field_type" class="form-label"> <label for="field_type" class="form-label col-md-2">
Type de champ Type de champ
</label> </label>
<div class="col-md-10">
<select <select
name="field_type" name="field_type"
id="field_type" id="field_type"
@ -80,11 +85,13 @@
{% endfor %} {% endfor %}
</select> </select>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="list" class="form-label"> <label for="list" class="form-label col-md-2">
Liste Liste
</label> </label>
<div class="col-md-10">
<select <select
name="list" name="list"
id="list" id="list"
@ -98,9 +105,10 @@
{% endfor %} {% endfor %}
</select> </select>
</div> </div>
</div>
{% endif %} {% endif %}
<div class="mt-4"> <div class="my-4">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">
<i class="me-1 bi-floppy"></i> <i class="me-1 bi-floppy"></i>
Enregistrer Enregistrer
@ -118,6 +126,10 @@
var enable = false; var enable = false;
if ($(this).val() == "list") { if ($(this).val() == "list") {
enable = true; enable = true;
$("#list-disabled").remove();
} else {
$("#list").append("<option id=\"list-disabled\" selected></option>");
} }
$("#list").prop("disabled", !enable); $("#list").prop("disabled", !enable);

View file

@ -14,17 +14,55 @@
<hr> <hr>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom</b><br> <div class="col-md-2">
{{ List.Name }} Nom
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ List.Name }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Liste à choix multiples</b><br> <div class="col-md-2">
{% if List.Multi %}Oui{% else %}Non{% endif %} Liste à choix multiples
</div>
<div class="col-md-10">
{% if Section.Multi %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div> </div>
<div class="mt-3"> <div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/lists/{{ List.ID }}/edit"> <a class="btn btn-md btn-primary" href="/admin/lists/{{ List.ID }}/edit">
<i class="bi-pencil-square"></i> <i class="bi-pencil-square"></i>
Modifier Modifier
@ -41,7 +79,11 @@
</form> </form>
</div> </div>
<hr> <div class="mt-4 mb-3">
<span class="h4">
Contenu de la liste
</span>
</div>
{% if ListItems %} {% if ListItems %}
<table class="table"> <table class="table">
<thead> <thead>
@ -61,18 +103,20 @@
</td> </td>
<td> <td>
{% if Item.Default %} {% if Item.Default %}
<i class="bi-check-lg text-success me-1"></i>
Oui Oui
{% else %} {% else %}
<i class="bi-x-lg text-danger me-1"></i>
Non Non
{% endif %} {% endif %}
</td> </td>
<td> <td class="text-end">
<form <form
action="/admin/lists/{{ List.ID }}/items/{{ Item.ID }}/delete" action="/admin/lists/{{ List.ID }}/items/{{ Item.ID }}/delete"
method="post" method="post"
class="d-inline p-0" class="d-inline p-0"
> >
<button class="btn btn-md btn-danger areyousure" type="submit"> <button class="btn btn-sm btn-danger areyousure" type="submit">
<i class="bi-trash3"></i> <i class="bi-trash3"></i>
Supprimer Supprimer
</button> </button>
@ -88,7 +132,7 @@
</div> </div>
{% endif %} {% endif %}
<div class="mt-3"> <div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/lists/{{ List.ID }}/items/add"> <a class="btn btn-md btn-primary" href="/admin/lists/{{ List.ID }}/items/add">
<i class="bi-plus-lg"></i> <i class="bi-plus-lg"></i>
Ajouter Ajouter

View file

@ -32,10 +32,11 @@
<form id="list" method="post"> <form id="list" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="form-label col-md-2">
Nom Nom
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -45,8 +46,10 @@
value="{{ List.Name }}" value="{{ List.Name }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -58,6 +61,7 @@
Liste à choix multiples Liste à choix multiples
</label> </label>
</div> </div>
</div>
<div class="mt-3"> <div class="mt-3">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">

View file

@ -32,10 +32,11 @@
<form id="list" method="post"> <form id="list" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="value" class="form-label"> <label for="value" class="form-label col-md-2">
Valeur Valeur
</label> </label>
<div class="col-md-10">
<input <input
id="value" id="value"
class="form-control" class="form-control"
@ -45,19 +46,24 @@
value="{{ ListItem.Value }}" value="{{ ListItem.Value }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
id="default" id="default"
name="default" name="default"
{% if ListItem.Default %}checked{% endif %} {% if ListItem.Default %}
checked
{% endif %}
> >
<label for="default" class="form-label"> <label for="default" class="form-label">
Valeur sélectionnée par défaut Valeur sélectionnée par défaut
</label> </label>
</div> </div>
</div>
<div class="mt-3"> <div class="mt-3">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">

View file

@ -14,100 +14,562 @@
<hr> <hr>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom</b><br> <div class="col-md-2">
{{ Role.Name }} Nom
</div> </div>
<div class="col-md-10">
<div class="mb-4"> <input
<div class="mb-3"> type="text"
<b>Permissions - Membres</b> class="form-control"
</div> value="{{ Role.Name }}"
<div style="max-width: 400px;"> disabled
<table class="table table-bordered"> readonly
<tbody> >
<tr>
<td>Afficher membres</td>
<td>{% if Role.ShowMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Créer membres</td>
<td>{% if Role.CreateMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Modifier membres</td>
<td>{% if Role.EditMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Afficher membres archivés</td>
<td>{% if Role.ShowArchivedMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Archiver membres</td>
<td>{% if Role.ArchiveMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Restaurer membres</td>
<td>{% if Role.RestoreMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Purger membres (suppression définitive)</td>
<td>{% if Role.PurgeMember %}Oui{% else %}Non{% endif %}</td>
</tr>
<tr>
<td>Convertir membres en contacts</td>
<td>{% if Role.ConvertMemberToContact %}Oui{% else %}Non{% endif %}</td>
</tr>
</tbody>
</table>
</div> </div>
</div> </div>
<div class="mb-4"> <div class="mt-4 mb-3">
<div class="mb-3"> <span class="h4">
<b>Permissions - Contacts</b> Permissions membres
</span>
</div> </div>
<div style="max-width: 400px;">
<table class="table table-bordered"> <div class="row mb-3">
<tbody> <div class="col-md-2">
<tr> Afficher membres
<td>Afficher contacts</td> </div>
<td>{% if Role.ShowContact %}Oui{% else %}Non{% endif %}</td> <div class="col-md-10">
</tr> {% if Role.ShowMember %}
<tr> <div class="input-group">
<td>Créer contacts</td> <span class="input-group-text">
<td>{% if Role.CreateContact %}Oui{% else %}Non{% endif %}</td> <i class="bi-check-lg text-success"></i>
</tr> </span>
<tr> <input
<td>Modifier contacts</td> type="text"
<td>{% if Role.EditContact %}Oui{% else %}Non{% endif %}</td> class="form-control"
</tr> value="Oui"
<tr> disabled
<td>Afficher contacts archivés</td> >
<td>{% if Role.ShowArchivedContact %}Oui{% else %}Non{% endif %}</td> </div>
</tr> {% else %}
<tr> <div class="input-group">
<td>Archiver contacts</td> <span class="input-group-text">
<td>{% if Role.ArchiveContact %}Oui{% else %}Non{% endif %}</td> <i class="bi-x-lg text-danger"></i>
</tr> </span>
<tr> <input
<td>Restaurer contacts</td> type="text"
<td>{% if Role.RestoreContact %}Oui{% else %}Non{% endif %}</td> class="form-control"
</tr> value="Non"
<tr> disabled
<td>Purger contacts (suppression définitive)</td> >
<td>{% if Role.PurgeContact %}Oui{% else %}Non{% endif %}</td> </div>
</tr> {% endif %}
<tr>
<td>Convertir contacts en membres</td>
<td>{% if Role.ConvertContactToMember %}Oui{% else %}Non{% endif %}</td>
</tr>
</tbody>
</table>
</div> </div>
</div> </div>
<div class="mt-3"> <div class="row mb-3">
<div class="col-md-2">
Créer membres
</div>
<div class="col-md-10">
{% if Role.CreateMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Modifier membres
</div>
<div class="col-md-10">
{% if Role.EditMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Afficher membres archivés
</div>
<div class="col-md-10">
{% if Role.ShowArchivedMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Archiver membres
</div>
<div class="col-md-10">
{% if Role.ArchiveMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Restaurer membres
</div>
<div class="col-md-10">
{% if Role.RestoreMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Purger membres (suppression définitive)
</div>
<div class="col-md-10">
{% if Role.PurgeMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Convertir membres en contacts
</div>
<div class="col-md-10">
{% if Role.ConvertMemberToContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="mt-4 mb-3">
<span class="h4">
Permissions contacts
</span>
</div>
<div class="row mb-3">
<div class="col-md-2">
Afficher contacts
</div>
<div class="col-md-10">
{% if Role.ShowContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Créer contacts
</div>
<div class="col-md-10">
{% if Role.CreateContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Modifier contacts
</div>
<div class="col-md-10">
{% if Role.EditContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Afficher contacts archivés
</div>
<div class="col-md-10">
{% if Role.ShowArchivedContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Archiver contacts
</div>
<div class="col-md-10">
{% if Role.ArchiveContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Restaurer contacts
</div>
<div class="col-md-10">
{% if Role.RestoreContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Purger contacts (suppression définitive)
</div>
<div class="col-md-10">
{% if Role.PurgeContact %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="row mb-3">
<div class="col-md-2">
Convertir contacts en membres
</div>
<div class="col-md-10">
{% if Role.ConvertContactToMember %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/roles/{{ Role.ID }}/edit"> <a class="btn btn-md btn-primary" href="/admin/roles/{{ Role.ID }}/edit">
<i class="bi-pencil-square"></i> <i class="bi-pencil-square"></i>
Modifier Modifier

View file

@ -32,10 +32,11 @@
<form id="role" method="post"> <form id="role" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="form-label col-md-2">
Nom Nom
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -45,12 +46,21 @@
value="{{ Role.Name }}" value="{{ Role.Name }}"
> >
</div> </div>
<div class="mb-3 mt-4">
<b>Permissions - Membres</b>
</div> </div>
<div class="mb-3"> <div class="mt-4 mb-3 d-md-none">
<span class="h4">
Permissions membres
</span>
</div>
<div class="row mb-3">
<div class="col-md-2">
<div class="d-none d-md-block">
Permissions membres
</div>
</div>
<div class="col-md-10">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -62,8 +72,10 @@
Afficher membres Afficher membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -75,8 +87,10 @@
Créer membres Créer membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -88,8 +102,10 @@
Modifier membres Modifier membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -101,8 +117,10 @@
Afficher membres archivés Afficher membres archivés
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -114,8 +132,10 @@
Archiver membres Archiver membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -127,8 +147,10 @@
Restaurer membres Restaurer membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -140,8 +162,10 @@
Purger membres (suppression définitive) Purger membres (suppression définitive)
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -153,12 +177,21 @@
Convertir membres en contacts Convertir membres en contacts
</label> </label>
</div> </div>
<div class="mb-3 mt-4">
<b>Permissions - Contacts</b>
</div> </div>
<div class="mb-3"> <div class="mt-4 mb-3 d-md-none">
<span class="h4">
Permissions contacts
</span>
</div>
<div class="row mb-3">
<div class="col-md-2">
<div class="d-none d-md-block">
Permissions contacts
</div>
</div>
<div class="col-md-10">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -170,8 +203,10 @@
Afficher contacts Afficher contacts
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -183,8 +218,10 @@
Créer contacts Créer contacts
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -196,8 +233,10 @@
Modifier contacts Modifier contacts
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -209,8 +248,10 @@
Afficher contacts archivés Afficher contacts archivés
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -222,8 +263,10 @@
Archiver contacts Archiver contacts
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -235,8 +278,10 @@
Restaurer contacts Restaurer contacts
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -248,8 +293,10 @@
Purger contacts (suppression définitive) Purger contacts (suppression définitive)
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -261,8 +308,9 @@
Convertir contacts en membres Convertir contacts en membres
</label> </label>
</div> </div>
</div>
<div class="mt-3"> <div class="my-4">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">
<i class="me-1 bi-floppy"></i> <i class="me-1 bi-floppy"></i>
Enregistrer Enregistrer

View file

@ -14,36 +14,132 @@
<hr> <hr>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom</b><br> <div class="col-md-2">
{{ Section.Name }} Nom
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ Section.Name }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom technique</b><br> <div class="col-md-2">
{{ Section.ShortName }} Nom technique
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ Section.ShortName }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Section parente</b><br> <div class="col-md-2">
Section parente
</div>
<div class="col-md-10">
{% if Section.ParentSectionID %} {% if Section.ParentSectionID %}
{{ Section.ParentSection.Name }} <input
type="text"
class="form-control"
value="{{ Section.ParentSection.Name }}"
disabled
readonly
>
{% else %} {% else %}
N/A <div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %} {% endif %}
</div> </div>
<div class="mb-3">
<b>Contient des membres</b><br>
{% if Section.ContainsMembers %}Oui{% else %}Non{% endif %}
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Contient des contacts</b><br> <div class="col-md-2">
{% if Section.ContainsContacts %}Oui{% else %}Non{% endif %} Peut contenir des membres
</div>
<div class="col-md-10">
{% if Section.ContainsMembers %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div> </div>
<div class="mt-3"> <div class="row mb-3">
<div class="col-md-2">
Peut contenir des contacts
</div>
<div class="col-md-10">
{% if Section.ContainsContacts %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %}
<div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %}
</div>
</div>
<div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/sections/{{ Section.ID }}/edit"> <a class="btn btn-md btn-primary" href="/admin/sections/{{ Section.ID }}/edit">
<i class="bi-pencil-square"></i> <i class="bi-pencil-square"></i>
Modifier Modifier

View file

@ -32,10 +32,11 @@
<form id="section" method="post"> <form id="section" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="form-label col-md-2">
Nom Nom
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -45,11 +46,13 @@
value="{{ Section.Name }}" value="{{ Section.Name }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="short_name" class="form-label"> <label for="short_name" class="form-label col-md-2">
Nom technique Nom technique
</label> </label>
<div class="col-md-10">
<input <input
id="short_name" id="short_name"
class="form-control" class="form-control"
@ -59,18 +62,24 @@
value="{{ Section.ShortName }}" value="{{ Section.ShortName }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="parent_section" class="form-label"> <label for="parent_section" class="form-label col-md-2">
Section parente Section parente
</label> </label>
<div class="col-md-10">
<select <select
id="parent_section" id="parent_section"
class="form-control" class="form-control"
name="parent_section" name="parent_section"
{% if IsParent %}disabled{% endif %} {% if IsParent %}
disabled
{% endif %}
> >
<option value="0">--- Pas de section parente ---</option> <option value="0">
--- Pas de section parente ---
</option>
{% if !IsParent %} {% if !IsParent %}
{% for ParentSection in Sections %} {% for ParentSection in Sections %}
<option <option
@ -83,32 +92,41 @@
{% endif %} {% endif %}
</select> </select>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
id="contains_members" id="contains_members"
name="contains_members" name="contains_members"
{% if Section.ContainsMembers %}checked{% endif %} {% if Section.ContainsMembers %}
checked
{% endif %}
> >
<label for="contains_members" class="form-label"> <label for="contains_members" class="form-label">
Contient des membres Contient des membres
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
id="contains_contacts" id="contains_contacts"
name="contains_contacts" name="contains_contacts"
{% if Section.ContainsContacts %}checked{% endif %} {% if Section.ContainsContacts %}
checked
{% endif %}
> >
<label for="contains_contacts" class="form-label"> <label for="contains_contacts" class="form-label">
Contient des contacts Contient des contacts
</label> </label>
</div> </div>
</div>
<div class="mt-3"> <div class="mt-3">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">

View file

@ -14,70 +14,175 @@
<hr> <hr>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Nom complet</b><br> <div class="col-md-2">
{{ User.Name }} Nom complet
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ User.Name }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Email</b><br> <div class="col-md-2">
{{ User.Email }} Email
</div>
<div class="col-md-10">
<input
type="text"
class="form-control"
value="{{ User.Email }}"
disabled
readonly
>
</div>
</div> </div>
<div class="mb-3"> <div class="row mb-3">
<b>Administrateur</b><br> <div class="col-md-2">
Administrateur
</div>
<div class="col-md-10">
{% if User.IsAdmin %} {% if User.IsAdmin %}
Oui <div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% else %} {% else %}
Non <div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% endif %} {% endif %}
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<b>Ecran de bienvenue à la prochaine connexion</b><br> <div class="col-md-2">
Ecran de bienvenue à la prochaine connexion
</div>
<div class="col-md-10">
{% if User.SkipWelcome %} {% if User.SkipWelcome %}
Non <div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Non"
disabled
>
</div>
{% else %} {% else %}
Oui <div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Oui"
disabled
>
</div>
{% endif %} {% endif %}
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<b>Double facteur (TOTP)</b><br> <div class="col-md-2">
Double facteur (TOTP)
</div>
<div class="col-md-10">
{% if User.TotpSecret.Valid %} {% if User.TotpSecret.Valid %}
Enrollé <div class="input-group">
<span class="input-group-text">
<i class="bi-check-lg text-success"></i>
</span>
<input
type="text"
class="form-control"
value="Enrollé"
disabled
>
</div>
{% else %} {% else %}
Enrollement lors de la prochaine connexion <div class="input-group">
<span class="input-group-text">
<i class="bi-x-lg text-danger"></i>
</span>
<input
type="text"
class="form-control"
value="Enrollement lors de la prochaine connexion"
disabled
>
</div>
{% endif %} {% endif %}
</div> </div>
</div>
<div class="mt-4 mb-3">
<span class="h4">
Permissions
</span>
</div>
{% if UserRoles %} {% if UserRoles %}
<div class="mb-4">
<div class="mb-3">
<b>Permissions</b>
</div>
<div style="max-width: 500px;">
<table class="table table-bordered">
<tbody>
{% for UserRole in UserRoles %} {% for UserRole in UserRoles %}
<tr> <div class="row mb-3">
<td>{{ UserRole.Section.Name }}</td> <div class="col-md-2">
<td>{{ UserRole.Role.Name }}</td> {{ UserRole.Section.Name }}
</tr>
{% endfor %}
</tbody>
</table>
</div> </div>
<div class="col-md-10">
<div class="input-group">
<span class="input-group-text">
<i class="bi-key"></i>
</span>
<input
type="text"
class="form-control"
value="{{ UserRole.Role.Name }}"
disabled
readonly
>
</div>
</div>
</div>
{% endfor %}
{% else %}
<div>
Pas encore de permissions pour cet utilisateur.
</div> </div>
{% endif %} {% endif %}
<div class="mt-3"> <div class="my-4">
<a class="btn btn-md btn-primary" href="/admin/users/{{ User.ID }}/edit"> <a class="btn btn-md btn-primary" href="/admin/users/{{ User.ID }}/edit">
<i class="bi-pencil-square"></i> <i class="bi-pencil-square me-1"></i>
Modifier Modifier
</a> </a>
<a class="btn btn-md btn-primary" href="/admin/users/{{ User.ID }}/permissions"> <a class="btn btn-md btn-primary" href="/admin/users/{{ User.ID }}/permissions">
<i class="bi-key"></i> <i class="bi-key me-1"></i>
Permissions Permissions
</a> </a>

View file

@ -32,10 +32,11 @@
<form id="user" method="post"> <form id="user" method="post">
<div class="mb-3"> <div class="row mb-3">
<label for="name" class="form-label"> <label for="name" class="form-label col-md-2">
Nom complet Nom complet
</label> </label>
<div class="col-md-10">
<input <input
id="name" id="name"
class="form-control" class="form-control"
@ -45,11 +46,13 @@
value="{{ User.Name }}" value="{{ User.Name }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="email" class="form-label"> <label for="email" class="form-label col-md-2">
Email Email
</label> </label>
<div class="col-md-10">
<input <input
id="email" id="email"
class="form-control" class="form-control"
@ -59,24 +62,30 @@
value="{{ User.Email }}" value="{{ User.Email }}"
> >
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
id="is_admin" id="is_admin"
name="is_admin" name="is_admin"
{% if User.IsAdmin %}checked{% endif %} {% if User.IsAdmin %}
checked
{% endif %}
> >
<label for="is_admin" class="form-label"> <label for="is_admin" class="form-label">
Administrateur Administrateur
</label> </label>
</div> </div>
</div>
<div class="mb-3"> <div class="row mb-3">
<label for="password" class="form-label"> <label for="password" class="form-label col-md-2">
Mot de passe Mot de passe
</label> </label>
<div class="col-md-10">
<input <input
id="password" id="password"
class="form-control" class="form-control"
@ -90,9 +99,11 @@
</div> </div>
{% endif %} {% endif %}
</div> </div>
</div>
{% if User.ID %} {% if User.ID %}
<div class="mb-3"> <div class="row mb-3">
<div class="col-md-10 offset-md-2">
<input <input
type="checkbox" type="checkbox"
class="form-check-input me-2" class="form-check-input me-2"
@ -107,9 +118,10 @@
un enrollement TOTP à la prochaine connexion. un enrollement TOTP à la prochaine connexion.
</div> </div>
</div> </div>
</div>
{% endif %} {% endif %}
<div class="mt-3"> <div class="my-4">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">
<i class="me-1 bi-floppy"></i> <i class="me-1 bi-floppy"></i>
Enregistrer Enregistrer

View file

@ -27,26 +27,16 @@
<form id="user" method="post"> <form id="user" method="post">
<div class="table-responsive">
<table class="table">
<thead>
<tr>
<th>Section</th>
<th>Rôle</th>
</tr>
</thead>
<tbody>
{% for Section in Sections %} {% for Section in Sections %}
<tr> <div class="row mb-3">
<td> <div class="col-md-2">
<input {{ Section.Name }}
type="text" </div>
class="form-control" <div class="col-md-10">
readonly <div class="input-group">
value="{{ Section.Name }}" <span class="input-group-text">
> <i class="bi-key"></i>
</td> </span>
<td>
<select <select
class="form-control" class="form-control"
name="section-{{ Section.ID }}" name="section-{{ Section.ID }}"
@ -67,12 +57,10 @@
</option> </option>
{% endfor %} {% endfor %}
</select> </select>
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div> </div>
</div>
</div>
{% endfor %}
<div class="mt-3"> <div class="mt-3">
<button class="btn btn-primary" type="submit"> <button class="btn btn-primary" type="submit">