2023-09-19 23:04:46 +02:00
|
|
|
<h2>Signalement différé de l'assiduité {{gr |safe}}</h2>
|
|
|
|
<div class="help">
|
2023-06-30 14:38:56 +02:00
|
|
|
<h3>Explication de la saisie différée</h3>
|
2023-09-19 23:04:46 +02:00
|
|
|
<p>Si la colonne n'est pas valide elle sera affichée en rouge, passez le curseur sur la colonne pour afficher
|
2023-06-30 14:38:56 +02:00
|
|
|
le message d'erreur</p>
|
|
|
|
<p>Sélectionner la date de début de la colonne mettra automatiquement la date de fin à la durée d'une séance
|
|
|
|
(préférence de département)</p>
|
2023-09-19 23:04:46 +02:00
|
|
|
<p>Modifier le module alors que des informations d'assiduité sont déjà enregistrées pour la période changera leur
|
2023-09-13 21:11:27 +02:00
|
|
|
module.</p>
|
2023-09-19 23:04:46 +02:00
|
|
|
<p>Il y a 4 boutons sur la colonne permettant d'enregistrer l'information pour tous les étudiants</p>
|
|
|
|
<p>Le dernier des boutons retire l'information présente.</p>
|
2023-06-30 14:38:56 +02:00
|
|
|
<p>Vous pouvez ajouter des colonnes en appuyant sur le bouton + </p>
|
2023-09-19 23:04:46 +02:00
|
|
|
<p>Vous pouvez supprimer une colonne en appuyant sur la croix qui se situe dans le coin haut droit de la colonne.
|
2023-06-30 14:38:56 +02:00
|
|
|
</p>
|
|
|
|
</div>
|
2023-06-20 08:33:49 +02:00
|
|
|
<h3>{{sem | safe }}</h3>
|
|
|
|
|
|
|
|
{{diff | safe}}
|
|
|
|
|
2023-07-25 19:59:47 +02:00
|
|
|
<script>
|
|
|
|
const etudsDefDem = {{ defdem | safe }}
|
|
|
|
|
2023-09-04 14:27:48 +02:00
|
|
|
const timeMorning = "{{ timeMorning | safe}}";
|
|
|
|
const timeNoon = "{{ timeNoon | safe}}";
|
|
|
|
const timeEvening = "{{ timeEvening | safe}}";
|
|
|
|
|
|
|
|
const defaultDates = {{ defaultDates | safe }}
|
|
|
|
const nonWorkDays = [{{ nonworkdays| safe }}];
|
|
|
|
|
|
|
|
|
2023-07-25 19:59:47 +02:00
|
|
|
window.addEventListener('load', () => {
|
|
|
|
[...document.querySelectorAll('.tr[etudid]')].forEach((a) => {
|
|
|
|
try {
|
|
|
|
if (a.getAttribute("etudid") in etudsDefDem) {
|
|
|
|
defdem = etudsDefDem[a.getAttribute("etudid")] == "D" ? "dem" : "def";
|
|
|
|
a.classList.add(defdem);
|
|
|
|
}
|
|
|
|
} catch (_) { }
|
2023-09-04 14:27:48 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
if (defaultDates != null) {
|
|
|
|
defaultDates.forEach((dateString) => {
|
|
|
|
|
2023-11-08 15:12:42 +01:00
|
|
|
d = new Date(dateString).getDay();
|
2023-09-04 14:27:48 +02:00
|
|
|
|
2023-11-17 00:22:46 +01:00
|
|
|
if (isNonWorkDay(d, nonWorkDays)) return;
|
2023-09-04 14:27:48 +02:00
|
|
|
|
|
|
|
matin = `${dateString}T${timeMorning}`;
|
|
|
|
midi = `${dateString}T${timeNoon}`;
|
|
|
|
soir = `${dateString}T${timeEvening}`;
|
|
|
|
|
|
|
|
console.log(matin, midi, soir)
|
|
|
|
|
|
|
|
createColumn(matin, midi);
|
|
|
|
createColumn(midi, soir);
|
|
|
|
});
|
|
|
|
|
|
|
|
updateAllCol();
|
|
|
|
} else {
|
|
|
|
createColumn();
|
|
|
|
}
|
2023-07-25 19:59:47 +02:00
|
|
|
})
|
2023-09-04 14:27:48 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-07-25 19:59:47 +02:00
|
|
|
</script>
|
|
|
|
|
2023-06-30 14:38:56 +02:00
|
|
|
|
|
|
|
|
2023-06-20 08:33:49 +02:00
|
|
|
{% include "assiduites/widgets/alert.j2" %}
|
|
|
|
{% include "assiduites/widgets/prompt.j2" %}
|
|
|
|
{% include "assiduites/widgets/conflict.j2" %}
|
2023-11-17 00:22:46 +01:00
|
|
|
{% include "assiduites/widgets/toast.j2" %}
|