diff --git a/docs/superpowers/plans/2026-06-09-maliodate-saisie-manuelle.md b/docs/superpowers/plans/2026-06-09-maliodate-saisie-manuelle.md new file mode 100644 index 0000000..6c1dfa7 --- /dev/null +++ b/docs/superpowers/plans/2026-06-09-maliodate-saisie-manuelle.md @@ -0,0 +1,635 @@ +# MalioDate — saisie manuelle au clavier — Implementation Plan + +> **For agentic workers:** REQUIRED SUB-SKILL: Use superpowers:subagent-driven-development (recommended) or superpowers:executing-plans to implement this plan task-by-task. Steps use checkbox (`- [ ]`) syntax for tracking. + +**Goal:** Permettre la saisie clavier `JJ/MM/AAAA` dans `MalioDate` (opt-in via prop `editable`), en plus de la sélection au calendrier, avec validation au blur et état d'erreur visuel. + +**Architecture:** `CalendarField` (interne, partagé) gagne un mode `editable` : input non `readonly`, masque `maska`, buffer local `draft` synchronisé sur `displayValue`, émission d'un event `commit(text)` au blur / à Entrée. `MalioDate` conserve toute la logique date : parse (`parseDisplayToIso`), validation bornes (`isDateInRange`), état d'erreur interne fusionné avec la prop `error` du consommateur. `CalendarField` reste agnostique au format. + +**Tech Stack:** Nuxt 4 layer, Vue 3 `