From c2f3de4d529ca7d8e5a47663b2e9e7b419be9d13 Mon Sep 17 00:00:00 2001 From: adrien charrier Date: Tue, 15 Oct 2024 17:28:12 +0200 Subject: [PATCH] Refactor DatePicker component to improve validation behavior --- .../src/patterns/DatePicker/DatePicker.vue | 14 +++++++++++--- .../src/patterns/DatePicker/config.ts | 2 +- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/packages/synapse-bridge/src/patterns/DatePicker/DatePicker.vue b/packages/synapse-bridge/src/patterns/DatePicker/DatePicker.vue index 0e300fcc15..62f1e32a86 100644 --- a/packages/synapse-bridge/src/patterns/DatePicker/DatePicker.vue +++ b/packages/synapse-bridge/src/patterns/DatePicker/DatePicker.vue @@ -9,7 +9,6 @@ import { vMaska } from 'maska' import { type ComponentPublicInstance, defineComponent, - nextTick, type PropType, } from 'vue' import { VTextField } from 'vuetify/lib/components/index.mjs' @@ -172,6 +171,13 @@ export default defineComponent({ this.calendarValue = [start.toDate(), end.toDate()] } }, + rules() { + if (this.calendarValue) { + this.$nextTick(() => { + this.updateMessages() + }) + } + }, }, methods: { toggleCalendar() { @@ -195,7 +201,9 @@ export default defineComponent({ }, handleFocusChange(focus: boolean) { if (!focus) { - this.updateMessages() + setTimeout(() => { + this.updateMessages() + }, 200) // avoid graphical glitch when the calendar is closed } else { if (this.textFieldActivator || this.noIcon) { if (!this.$refs.calendar) return @@ -217,7 +225,7 @@ export default defineComponent({ if (!textField) return this.validateWarning(this.internalValue) - await nextTick() + await this.$nextTick() this.errorMessages = await textField.validate() }, handleTextInput(date: string, updateCalendar: (s: string) => void) { diff --git a/packages/synapse-bridge/src/patterns/DatePicker/config.ts b/packages/synapse-bridge/src/patterns/DatePicker/config.ts index 4698dee8fb..bb0f6cdefd 100644 --- a/packages/synapse-bridge/src/patterns/DatePicker/config.ts +++ b/packages/synapse-bridge/src/patterns/DatePicker/config.ts @@ -2,7 +2,7 @@ export const config = { textField: { hideDetails: 'auto', persistentHint: true, - validateOn: 'blur', + validateOn: 'submit', color: '#0C419A', maxErrors: 5, },