Files
xamxam/TODO.md
Pontoporeia ab6e266807 fix: add help email, preserve file names on validation error, license fix
The share link (partage) form does not expose a license field and does
not send access_type_id (defaults to 2/Interne). Server-side validation
was unconditionally requiring a license for non-admin submissions,
causing all share link submissions to fail.

Now the license check is gated on adminMode=false AND accessTypeId=1
(Libre), matching the client-side HTMX fragment behaviour in
licence-fragment.php. Also fixed a use-before-definition where
accessTypeId was referenced before being assigned.

Student form improvements:
- Add xamxam@erg.be mailto link at top of form
- On validation error, append "Si le problème persiste, envoyez un
  e-mail à xamxam@erg.be" to the flash message
- Preserve uploaded file names across validation redirects: store in
  session (share_primed_files_<slug>), display as warning on form
  re-render so the student knows which files to re-select

- License: only required for non-admin when access_type_id=1 (Libre),
  not for Interne (2) or Interdit (3). Fixes share link submissions
  failing with "Veuillez sélectionner une licence". Also fixed
  use-before-definition of accessTypeId.
2026-05-19 00:08:05 +02:00

2.3 KiB

TODO

  • Fix language-search-fragment: use searchLanguages() like tag fragment, remove broken predefined exclusion logic
  • Both fragments now follow identical patterns
  • Fix "Créer" button not appearing on language search: both language and tag inputs used name="q" in the same form, causing HTMX to submit the wrong (empty) value — renamed to unique names (language_search_q / tag_search_q)
  • Exclude Français, Anglais, Néerlandais from language-search suggestions (handled by the checkbox list)
  • Refactor file upload naming convention
    • Create shared ThesisFileHandler trait (src/Controllers/ThesisFileHandler.php)
    • New pattern: theses/{YYYY}/{YYYY}{AUTHORS}{TITLE_SLUG}/
    • COUVERTURE: single cover image in thesis folder (covers/ directory deprecated)
    • NOTE_INTENTION: single PDF in thesis folder
    • TFE_{XX}: main files, contiguous numbering 01+, hierarchy PDF > video > audio > subtitles > images > other
    • Subtitles (VTT) placed immediately after their associated video in TFE sequence
    • ANNEXE_{XX}: annex files, separate numbering 01+
    • Two-digit zero-padded numbering (sprintf('%02d', ...))
    • Update ThesisCreateController.php: use trait, new file handling
    • Update ThesisEditController.php: use trait, new file handling
    • Remove duplicate methods (generateAuthorSlug, sanitizeFilename, etc.) from both controllers
    • Update Database.php: deprecate handleCoverUpload, remove banner_path from queries
    • Update SystemController.php: remove banners/ stats
    • Update schema.sql: remove banner_path column and view field
    • Create migration 027_drop_banner_path.sql
    • Update PureLogicTest.php: adapt detectFileType call signature
    • All pure logic tests pass
  • Fix license validation: only require license for non-admin when access_type_id=1 (Libre), not for Interne (2) or Interdit (3) — fixes share link submissions failing with "Veuillez sélectionner une licence"
  • Add xamxam@erg.be mailto link at top of student (partage) form
  • On validation error, append "envoyez un e-mail à xamxam@erg.be" to flash error message
  • Preserve uploaded file names across validation redirects: store in session, display as warning on re-render so the student knows which files to re-select