110 lines
No EOL
5.3 KiB
Markdown
110 lines
No EOL
5.3 KiB
Markdown
# Changelog — Expria Frontend
|
|
|
|
Toutes les modifications notables du projet frontend sont documentées dans ce fichier.
|
|
|
|
Format basé sur [Keep a Changelog](https://keepachangelog.com/fr/1.1.0/).
|
|
|
|
## Convention
|
|
|
|
Chaque entrée suit ce format :
|
|
|
|
```
|
|
## [Unreleased] — YYYY-MM-DD — Session <nom>
|
|
|
|
### Added (nouveautés)
|
|
- ...
|
|
|
|
### Changed (modifications)
|
|
- ...
|
|
|
|
### Fixed (corrections)
|
|
- ...
|
|
|
|
### Removed (suppressions)
|
|
- ...
|
|
|
|
### Security (sécurité)
|
|
- ...
|
|
```
|
|
|
|
---
|
|
|
|
## [Unreleased]
|
|
|
|
### Added
|
|
- Documentation initiale du projet (ARCHITECTURE, ONBOARDING, SECURITY, etc.)
|
|
- 5 ADRs pour les décisions architecturales majeures
|
|
- Code source de `src/entities/user/access.ts` et `lib.ts` avec tests
|
|
|
|
|
|
## 2026-04-20 — Audit frontend ↔ backend — alignement types Report
|
|
|
|
### Modifié
|
|
- `src/entities/report/types.ts` — `Critere.note` → `Critere.score`, `Report.exercices: Exercice[]` → `Report.exercices: string[]`, JSDoc ajusté
|
|
- `src/features/simulations/pages/RapportPage.tsx` — import `Exercice` retiré, `critere.note` → `critere.score`, `ExerciceCard` refactoré pour consommer une `string` rendue en Markdown, clé d'itération par index
|
|
|
|
### Supprimé
|
|
- Interface `Exercice { titre, contenu }` de `entities/report/types.ts` — remplacée par `string[]` pour coller au contrat backend
|
|
|
|
### Contexte (backend associé, expria-backend)
|
|
Quatre commits côté backend finalisent l'alignement du contrat `Report` :
|
|
- `feat(corrections)`: renommages `production_modele`→`modele`, `suggestions_idees`→`idees`, ajout `feedback_court` + prompts DeepSeek mis à jour + validations runtime
|
|
- `feat(corrections)`: réponse enrichie avec `simulation_id` côté `correctionController`
|
|
- `feat(simulations)`: nouvelle route `GET /simulations/:id` (auth owner, gestion `SIMULATION_NOT_FOUND`/`AUTH_REQUIRED`/`REPORT_NOT_READY`) + 4 tests
|
|
- `feat(simulations)`: sujet aléatoire (table `sujets`) retourné avec chaque production créée (EO_T2_LIVE exclu, non bloquant si aucun sujet actif)
|
|
|
|
### Tests
|
|
- Typecheck : 0 erreur
|
|
- Vitest : 59/59 passés
|
|
|
|
### À faire (hors scope — session frontend dédiée ultérieurement)
|
|
- Ajouter `sujet: SujetData | null` dans `entities/production/types.ts`
|
|
- Consommer le sujet retourné dans `SimulationPage` (affichage consigne + docs)
|
|
- Consommer `feedback_court` dans `RapportPage` (rendu toujours visible — cf. PLANS_TARIFAIRES §2 — déjà supporté par le type `Report`, reste à brancher dans l'UI si ce n'est pas déjà le cas)
|
|
|
|
|
|
## 2026-04-20 — Sprint 0.5 bis — AppLayout + primitives UI + refonte visuelle
|
|
|
|
### Ajouté
|
|
- `src/app/AppLayout.tsx` — layout applicatif desktop/mobile (sidebar fixe 240px, drawer mobile, BottomNav)
|
|
- `src/app/Sidebar.tsx` — navigation latérale avec verrouillage `hasAccess()` (Progression, Examen blanc, Historique)
|
|
- `src/app/MobileHeader.tsx` — header mobile sticky (Logo, ThemeToggle, bouton menu hamburger)
|
|
- `src/app/BottomNav.tsx` — navigation mobile fixe (4 items, bottom sheet "Simuler", tap target min 44px)
|
|
- `src/shared/ui/Button.tsx` — primitive Button (variants: primary/secondary/ghost/upgrade ; sizes: sm/md/lg ; loading Loader2)
|
|
- `src/shared/ui/Card.tsx` — primitive Card (variants: default/raised/interactive ; rendu `<button>` si `onClick` fourni)
|
|
- `src/shared/ui/Badge.tsx` — primitive Badge (variants: plan/nclc/neutral ; couleur selon `planValue` pour variant plan)
|
|
|
|
### Modifié
|
|
- `src/app/router.tsx` — layout routes via `PrivateLayout` (`ProtectedRoute` + `AppLayout` + `Outlet`) ; `ComingSoon` inline ; redirect `/simulation` → `/simulation/ee`
|
|
- `src/features/simulations/components/TaskSelector.tsx` — refonte avec `Card interactive` / `Card default opacity-60`, `Badge` "EE"/"EO", eyebrow `tracking-widest`, icône verrou
|
|
- `src/features/simulations/pages/SimulationPage.tsx` — suppression header interne (Logo + ThemeToggle) ; root `<main>` ; `Button` migré vers `@/shared/ui/Button` `variant="secondary"`
|
|
- `src/features/dashboard/pages/DashboardPage.tsx` — suppression header interne ; `Button` `variant="primary"` avec `navigate('/simulation/ee')` ; `Badge` `variant="plan" planValue={data.plan}` ; tout migré vers `@/shared/ui/`
|
|
|
|
### Documentation
|
|
- `docs/TECH_DEBT.md` v1.6 — ajout FTD-18 (SimulationForm migration Button), FTD-19 (token `--shadow-focus` manquant)
|
|
|
|
### Tests
|
|
- Typecheck : 0 erreur
|
|
- Vitest : 59/59 passés
|
|
- Tests manuels : à valider par Hermann
|
|
|
|
---
|
|
|
|
## 2026-04-19 — Sprint 1 / Étape 6 — Maintenance mode + outillage sécurité
|
|
|
|
### Ajouté
|
|
- Page de maintenance statique (`src/app/MaintenancePage.tsx`) — logo + message, tokens Direction H, zéro dépendance
|
|
- Guard `VITE_MAINTENANCE_MODE` dans `main.tsx` — si `true`, aucun provider ne se monte, aucun appel réseau
|
|
- Variable `VITE_MAINTENANCE_MODE` dans `env.ts` (optionnelle, défaut `false`)
|
|
- Hook PreToolUse Claude Code (`security-check.sh`) — 9 patterns SECURITY.md §2
|
|
- Hook Stop Claude Code (`check-file-size.sh`) — alerte fichiers > 200 lignes
|
|
- MCP server Semgrep enregistré dans Claude Code
|
|
|
|
### Documentation
|
|
- `ARCHITECTURE.md` §7 — ajout `VITE_MAINTENANCE_MODE` dans la liste des variables
|
|
- `TECH_DEBT.md` — FTD-16 résolu (maintenance mode implémenté)
|
|
|
|
### Tests
|
|
- Typecheck : 0 erreur
|
|
- Vitest : 37/37 passés
|
|
- Test manuel : maintenance mode vérifié (page affichée, aucun appel réseau, routing bloqué) |