From 0f3a9d78592add314ea3f12ef91243481c7c026d Mon Sep 17 00:00:00 2001 From: timwekkenbc Date: Tue, 3 Dec 2024 09:44:39 -0800 Subject: [PATCH] Updated how date validations are handled so that 'today' can be used --- app/utils/utils.ts | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/app/utils/utils.ts b/app/utils/utils.ts index 42db7b6..650bb50 100644 --- a/app/utils/utils.ts +++ b/app/utils/utils.ts @@ -97,12 +97,19 @@ export const getFieldValidation = (validationCriteria: string, validationType: s case "[num]": // Number within range (inclusive) case "(date)": // Date within range (exclusive) case "[date]": // Date within range (inclusive) - const range = validationCriteria.replace(/[\[\]\(\)]/g, "").split(","); - if (range.length === 2) { + const [minRaw, maxRaw] = validationCriteria + .replace(/[\[\]\(\)]/g, "") + .split(",") + .map((s) => s.trim()); + const parseValue = (value: string) => (value === "today" ? new Date() : value); + const min = parseValue(minRaw); + const max = parseValue(maxRaw); + + if (minRaw && maxRaw) { validationRules["range"] = { - min: dataType === "number-input" ? Number(range[0].trim()) : dayjs(range[0].trim()), - max: dataType === "number-input" ? Number(range[1].trim()) : dayjs(range[1].trim()), - inclusive: validationType.startsWith("["), // true for inclusive ranges + min: dataType === "number-input" ? Number(min) : dayjs(min), + max: dataType === "number-input" ? Number(max) : dayjs(max), + inclusive: validationType.startsWith("["), }; } break;