feat(ui) : gabarit fantome de saisie + saisie clavier DateTime + fix clear (#MUI-43)
- gabarit fantome progressif sur la famille Date editable (Date, DateTime) : le format s'affiche en gris et se remplit au fil de la saisie (overlay ghost) - separateurs (/, espace, :) poses automatiquement (maska eager) - espace insecable pour eviter le collage « 12/12/1999HH:MM » - CalendarField : prop placeholderTemplate (masque maska derive), remplace mask - fix : la croix reinitialise la saisie clavier meme apres une date invalide - tests + COMPONENTS.md + CHANGELOG.md Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -200,6 +200,30 @@ describe('MalioDateTime', () => {
|
||||
})
|
||||
})
|
||||
|
||||
describe('gabarit de saisie (editable)', () => {
|
||||
it('affiche le gabarit date+heure complet en gris quand editable + focus + vide', async () => {
|
||||
const wrapper = mountDateTime({editable: true})
|
||||
await wrapper.get('[data-test="date-input"]').trigger('focus')
|
||||
expect(wrapper.get('[data-test="format-ghost"]').text().replace(/\xa0/g, ' ')).toBe('JJ/MM/AAAA HH:MM')
|
||||
expect(wrapper.get('[data-test="ghost-remaining"]').classes()).toContain('text-m-muted')
|
||||
})
|
||||
|
||||
it('remplit le gabarit au fur et à mesure de la saisie', async () => {
|
||||
const wrapper = mountDateTime({editable: true})
|
||||
const input = wrapper.get('[data-test="date-input"]')
|
||||
await input.trigger('focus')
|
||||
await input.setValue('190520')
|
||||
expect(wrapper.get('[data-test="format-ghost"]').text().replace(/\xa0/g, ' ')).toBe('19/05/20AA HH:MM')
|
||||
expect(wrapper.get('[data-test="ghost-typed"]').text()).toBe('19/05/20')
|
||||
})
|
||||
|
||||
it('n\'affiche pas de gabarit en mode non editable', async () => {
|
||||
const wrapper = mountDateTime({modelValue: '2026-05-20T14:30:00'})
|
||||
await wrapper.get('[data-test="date-input"]').trigger('click')
|
||||
expect(wrapper.find('[data-test="format-ghost"]').exists()).toBe(false)
|
||||
})
|
||||
})
|
||||
|
||||
describe('état de validité (update:valid)', () => {
|
||||
it('émet valid=true au montage avec une valeur valide', () => {
|
||||
const wrapper = mountDateTime({modelValue: '2026-05-20T14:30:00'})
|
||||
|
||||
Reference in New Issue
Block a user