Skip to content

Commit

Permalink
improve validDate rule ans set it by default (#3681)
Browse files Browse the repository at this point in the history
Co-authored-by: David FYON <davidfyon@gmail.com>
  • Loading branch information
VachetVirginie and DavidFyon authored Aug 2, 2024
1 parent ae5d8a9 commit 9b0987e
Show file tree
Hide file tree
Showing 6 changed files with 43 additions and 14 deletions.
36 changes: 27 additions & 9 deletions packages/synapse-bridge/src/patterns/DatePicker/DatePicker.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ import { WarningRules } from '@/mixins/warningRules/index.ts'
import { ErrorProp } from './mixins/errorProp'
import { customizable } from '@/mixins/customizable/index.ts'
import { config } from '@/patterns/DatePicker/config.ts'
import { ruleMessage } from '../../helpers/ruleMessage'
type DatePickerFlow = (
| 'calendar'
Expand All @@ -18,7 +20,7 @@ type DatePickerFlow = (
| 'minutes'
| 'hours'
| 'seconds'
)[]
)[]
interface DatePickerData {
date: Date | null | any[] | string
Expand All @@ -33,6 +35,7 @@ interface DatePickerData {
isCalOpen: boolean
lastTypeAddedDate: string
dayNames: string[]
isNotValid: boolean
}
export default defineComponent({
Expand Down Expand Up @@ -140,6 +143,7 @@ export default defineComponent({
isCalOpen: false,
lastTypeAddedDate: '',
dayNames: ['L', 'M', 'M', 'J', 'V', 'S', 'D'],
isNotValid: false
}
},
computed: {
Expand All @@ -161,7 +165,7 @@ export default defineComponent({
disabled: this.disabled,
hint: this.hint,
persistentHint: true,
rules: this.rules,
rules: [this.validateDateFormat, ...this.rules],
errorMessages: errorMessages || [],
}
},
Expand All @@ -170,7 +174,7 @@ export default defineComponent({
return (
this.errorMessages.includes("La date saisie n'est pas valide") ||
this.errorMessages.includes('Une erreur est survenue') ||
this.errorMessages.includes(this.customErrorMessages)
this.customErrorMessages.some(msg => this.errorMessages.includes(msg))
)
},
textFieldClasses() {
Expand Down Expand Up @@ -287,6 +291,10 @@ export default defineComponent({
// if (newVal.length === 0) {
// this.$emit('update:model-value', null);
// }
if (newVal.length === 0) {
this.warningErrorMessages = [];
this.errorMessages = [];
}
this.lastTypeAddedDate = 'inputValue'
},
},
Expand Down Expand Up @@ -409,7 +417,7 @@ export default defineComponent({
if (value.data === null) {
this.indexedThis[historyKey] = this.indexedThis[
historyKey
].slice(0, -1)
].slice(0, -1)
return
}
Expand Down Expand Up @@ -448,17 +456,19 @@ export default defineComponent({
const isValidFormat = dateRegEx.test(this.inputValue)
// If the date format and the date are valid, update the date and emit an update event
if (isValidFormat) {
if (isValidFormat && dayjs(this.inputValue, this.dateFormat, true).isValid()) {
this.date = this.inputValue
this.isNotValid = false
this.$emit(
'update:model-value',
this.indexedThis[historyKey]
)
} else {
this.isNotValid = true
// If the date format or the date is not valid, add an error message
this.errorMessages.push(
this.customErrorMessages.length > 0
? this.customErrorMessages
? this.customErrorMessages[0]
: "La date saisie n'est pas valide"
)
}
Expand All @@ -469,6 +479,12 @@ export default defineComponent({
}
}
},
validateDateFormat(): boolean | string {
if (this.isNotValid) {
return ruleMessage(this.errorMessages, 'default') || "La date saisie n'est pas valide";
}
return true;
},
getInput(value: any) {
this.updateInputValue(value, 'inputValue')
},
Expand Down Expand Up @@ -538,13 +554,15 @@ export default defineComponent({
this.inputValue = event.clipboardData.getData('text');;
const isValidFormat = this.createDateRegEx(this.dateFormat).test(this.inputValue);
if (isValidFormat) {
if (isValidFormat && dayjs(this.inputValue, this.dateFormat, true).isValid()) {
this.$emit('update:model-value', this.inputValue);
this.date = this.inputValue;
this.isNotValid = false
} else {
this.isNotValid = true
this.errorMessages.push(
this.customErrorMessages.length > 0
? this.customErrorMessages
? this.customErrorMessages[0]
: "La date saisie n'est pas valide"
);
}
Expand Down Expand Up @@ -605,7 +623,7 @@ export default defineComponent({
:hint="hint"
:label="label"
:persistent-hint="true"
:rules="rules"
:rules="[validateDateFormat, ...rules]"
:readonly="range"
:value="
lastTypeAddedDate === 'date'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ describe('Computed', () => {
disabled: false,
hint: wrapper.vm.hint,
persistentHint: true,
rules: [],
rules: [wrapper.vm.validateDateFormat, ...wrapper.vm.rules],
errorMessages: [],
}

Expand Down
4 changes: 2 additions & 2 deletions packages/synapse-bridge/src/rules/notAfterToday/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { ValidationRule, ValidationResult, ErrorMessages, Value } from '../types
import { defaultErrorMessages } from './locales';
import { TODAY } from '../../constants';

function formatDateToDDMMYYYY(date: Date): string {
export function formatDateToDDMMYYYYFn(date: Date): string {
const day = String(date.getDate()).padStart(2, '0');
const month = String(date.getMonth() + 1).padStart(2, '0');
const year = date.getFullYear();
Expand All @@ -17,7 +17,7 @@ export function notAfterTodayFn(errorMessages: ErrorMessages = defaultErrorMessa
if (!value) {
return true;
}
const formattedValue = typeof value === 'object' ? formatDateToDDMMYYYY(value) : value;
const formattedValue = typeof value === 'object' ? formatDateToDDMMYYYYFn(value) : value;
if (isDateAfter(TODAY, formattedValue)) {
return ruleMessage(errorMessages, 'default');
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { notAfterTodayFn } from '@/rules/notAfterToday/index.ts'
import dayjs from 'dayjs'
import { defaultErrorMessages } from '@/rules/notAfterToday/locales'
import { it, describe, expect } from 'vitest'
import {formatDateToDDMMYYYYFn} from '../'

const DATE_FORMAT = 'DD/MM/YYYY'

Expand All @@ -27,4 +28,9 @@ describe('notAfterTodayFn', () => {
it('returns true when value is today', () => {
expect(notAfterToday(today)).toBe(true)
})

it('returns date in DD/MM/YYYY format', () => {
const date = new Date('2021-01-01')
expect(formatDateToDDMMYYYYFn(date)).toBe('01/01/2021')
})
})
2 changes: 1 addition & 1 deletion packages/synapse-bridge/src/rules/notBeforeToday/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { defaultErrorMessages } from './locales'
import { isDateBefore } from '../../functions/validation/isDateBefore'
import { TODAY } from '../../constants'

function formatDateToDDMMYYYY(date: Date): string {
export function formatDateToDDMMYYYY(date: Date): string {
const day = String(date.getDate()).padStart(2, '0');
const month = String(date.getMonth() + 1).padStart(2, '0');
const year = date.getFullYear();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import dayjs from 'dayjs'

import { notBeforeToday, notBeforeTodayFn } from '../'
import { notBeforeToday, notBeforeTodayFn, formatDateToDDMMYYYY } from '../'
import { describe, it, expect } from 'vitest'

const DATE_FORMAT = 'DD/MM/YYYY'
Expand Down Expand Up @@ -33,4 +33,9 @@ describe('notBeforeToday', () => {
it('returns true when value is today', () => {
expect(notBeforeToday(today)).toBe(true)
})

it('returns date in DD/MM/YYYY format', () => {
const date = new Date('2021-01-01')
expect(formatDateToDDMMYYYY(date)).toBe('01/01/2021')
})
})

0 comments on commit 9b0987e

Please sign in to comment.