From 83b69d90c1f0c1b8e771bf053c89b28e24092769 Mon Sep 17 00:00:00 2001 From: Vincenzo Guerrisi Date: Tue, 26 Sep 2023 11:59:42 +0200 Subject: [PATCH] fix shouldDisabledDate and clear date for range picker --- .../src/DateField/DateField.tsx | 25 +++++++++++++------ .../stories/Components/DateField.stories.tsx | 4 +-- 2 files changed, 19 insertions(+), 10 deletions(-) diff --git a/packages/bento-design-system/src/DateField/DateField.tsx b/packages/bento-design-system/src/DateField/DateField.tsx index 12c0c8cd0..6f5e4ce14 100644 --- a/packages/bento-design-system/src/DateField/DateField.tsx +++ b/packages/bento-design-system/src/DateField/DateField.tsx @@ -27,28 +27,31 @@ type RangeDateFieldProps = { type Props = (SingleDateFieldProps | RangeDateFieldProps) & { minDate?: Date; maxDate?: Date; - shouldDisableDate?: (date: DateValue) => boolean; + shouldDisableDate?: (date: Date) => boolean; readOnly?: boolean; }; function dateToCalendarDate(date: Date): CalendarDate { - if (!date) return date; return new CalendarDate(date.getFullYear(), date.getMonth() + 1, date.getDate()); } function SingleDateField({ disabled, readOnly, ...props }: Extract) { + const localTimeZone = getLocalTimeZone(); + const internalProps = { ...props, value: props.value ? dateToCalendarDate(props.value) : props.value, onChange: (date: CalendarDate | null) => { - props.onChange(date?.toDate(getLocalTimeZone()) ?? null); + props.onChange(date?.toDate(localTimeZone) ?? null); }, isDisabled: disabled, isReadOnly: readOnly, validationState: props.issues ? "invalid" : "valid", minValue: props.minDate ? dateToCalendarDate(props.minDate) : undefined, maxValue: props.maxDate ? dateToCalendarDate(props.maxDate) : undefined, - isDateUnavailable: props.shouldDisableDate, + isDateUnavailable: props.shouldDisableDate + ? (date: DateValue) => props.shouldDisableDate!(date.toDate(localTimeZone)) + : undefined, shouldForceLeadingZeros: true, } as const; const state = useDatePickerState(internalProps); @@ -111,6 +114,7 @@ function SingleDateField({ disabled, readOnly, ...props }: Extract) { + const localTimeZone = getLocalTimeZone(); const internalProps = { ...props, isDisabled: disabled, @@ -118,16 +122,21 @@ function RangeDateField({ disabled, readOnly, ...props }: Extract props.shouldDisableDate!(date.toDate(localTimeZone)) + : undefined, value: props.value ? { start: dateToCalendarDate(props.value[0]), end: dateToCalendarDate(props.value[1]), } : props.value, - onChange: (range: RangeValue) => { - const localTimeZone = getLocalTimeZone(); - props.onChange([range.start.toDate(localTimeZone), range.end.toDate(localTimeZone)]); + onChange: (range: RangeValue | null) => { + if (!range) { + props.onChange(null); + } else { + props.onChange([range.start.toDate(localTimeZone), range.end.toDate(localTimeZone)]); + } }, } as const; const state = useDateRangePickerState(internalProps); diff --git a/packages/bento-design-system/stories/Components/DateField.stories.tsx b/packages/bento-design-system/stories/Components/DateField.stories.tsx index d19c1e904..a38474b05 100644 --- a/packages/bento-design-system/stories/Components/DateField.stories.tsx +++ b/packages/bento-design-system/stories/Components/DateField.stories.tsx @@ -119,7 +119,7 @@ export const Range = { export const RangeWithMinMax = { args: { - value: [null, null], + value: null, type: "range", minDate: today, maxDate: inOneMonth, @@ -129,7 +129,7 @@ export const RangeWithMinMax = { export const RangeWithShortcuts = { args: { - value: [null, null], + value: null, type: "range", shortcuts: [ {