feat: Permettre à l'enseignant de saisir les notes dans une grille inline
L'enseignant avait besoin d'un moyen rapide de saisir les notes après une évaluation. La grille inline permet de compléter 30 élèves en moins de 3 minutes grâce à la navigation clavier (Tab/Enter/Shift+Tab), la validation temps réel, l'auto-save debounced (500ms) et les raccourcis /abs et /disp pour marquer absents/dispensés. Les notes restent en brouillon jusqu'à publication explicite (avec confirmation modale). Une fois publiées, les élèves les voient immédiatement ; les parents après un délai de 24h (VisibiliteNotesPolicy). Le mode offline stocke les notes en IndexedDB et synchronise automatiquement au retour de la connexion. Chaque modification est auditée dans grade_events via un event subscriber qui écoute NoteSaisie/NoteModifiee sur le bus d'événements.
This commit is contained in:
@@ -46,7 +46,9 @@ function cleanupClasses() {
|
||||
`DELETE FROM homework_rule_exceptions WHERE homework_id IN (SELECT id FROM homework WHERE tenant_id = '${TENANT_ID}')`,
|
||||
`DELETE FROM homework_attachments WHERE homework_id IN (SELECT id FROM homework WHERE tenant_id = '${TENANT_ID}')`,
|
||||
`DELETE FROM homework WHERE tenant_id = '${TENANT_ID}'`,
|
||||
// Delete evaluations
|
||||
// Delete evaluations (grades cleaned by global-setup)
|
||||
`DELETE FROM grade_events WHERE grade_id IN (SELECT id FROM grades WHERE tenant_id = '${TENANT_ID}')`,
|
||||
`DELETE FROM grades WHERE tenant_id = '${TENANT_ID}'`,
|
||||
`DELETE FROM evaluations WHERE tenant_id = '${TENANT_ID}'`,
|
||||
// Delete schedule slots (CASCADE on FK, but be explicit)
|
||||
`DELETE FROM schedule_slots WHERE tenant_id = '${TENANT_ID}'`,
|
||||
|
||||
Reference in New Issue
Block a user