From dba52daf27cfba59bcc4119ef2a54e64885e4acb Mon Sep 17 00:00:00 2001 From: alaa-yahia Date: Thu, 12 Dec 2024 00:04:22 +0200 Subject: [PATCH] fix: prevent runtime error when only one date range is selected --- .../FiltersForTypes/Date/DateFilter.component.js | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/src/core_modules/capture-core/components/FiltersForTypes/Date/DateFilter.component.js b/src/core_modules/capture-core/components/FiltersForTypes/Date/DateFilter.component.js index c326e4477b..b0fa8f967e 100644 --- a/src/core_modules/capture-core/components/FiltersForTypes/Date/DateFilter.component.js +++ b/src/core_modules/capture-core/components/FiltersForTypes/Date/DateFilter.component.js @@ -117,16 +117,24 @@ const getRelativeRangeErrors = (startValue, endValue, submitAttempted) => { return errors; }; -const isAbsoluteRangeFilterValid = (fromValue, toValue) => { - if (!fromValue && !toValue) { +const isAbsoluteRangeFilterValid = (from, to) => { + if (!from?.value && !to?.value) { return false; } + const fromValue = from?.value; + const toValue = to?.value; + const parseResultFrom = fromValue ? parseDate(fromValue) : { isValid: true, moment: null }; + const parseResultTo = toValue ? parseDate(toValue) : { isValid: true, moment: null }; - if ((fromValue && !fromValue.isValid) || (toValue && !toValue.isValid)) { + if (!(parseResultFrom.isValid && parseResultTo.isValid)) { return false; } + const isValidMomentDate = () => + parseResultFrom.momentDate && + parseResultTo.momentDate && + parseResultFrom.momentDate.isAfter(parseResultTo.momentDate); - return !DateFilter.isFromAfterTo(fromValue?.value, toValue?.value); + return !isValidMomentDate(); }; const isRelativeRangeFilterValid = (startValue, endValue) => {