From bb4eb8886dbd2064ffc4a2214f711b57eb911017 Mon Sep 17 00:00:00 2001 From: Richard Acquaye Date: Sat, 13 Apr 2024 10:29:36 +0100 Subject: [PATCH] refactor: Rename certain variables + tidy validity funcs --- src/components/DobInput/DobInput.tsx | 44 ++++++++++++++++++---------- src/utils/Validations.tsx | 14 ++++++++- 2 files changed, 42 insertions(+), 16 deletions(-) diff --git a/src/components/DobInput/DobInput.tsx b/src/components/DobInput/DobInput.tsx index dbde102..15f6452 100644 --- a/src/components/DobInput/DobInput.tsx +++ b/src/components/DobInput/DobInput.tsx @@ -1,4 +1,4 @@ -import { useRef, useState } from "react"; +import { useEffect, useRef, useState } from "react"; import { DOBInput } from "../../types/ComponentProps"; import detailedAge from "../../utils/AgeCalc"; import { @@ -7,6 +7,7 @@ import { dateCheck, monthCheck, yearCheck, + clearErrors, } from "../../utils/Validations"; import "./DobInput-styles.scss"; @@ -19,10 +20,31 @@ const DobInput = ({ const dobMonth = useRef(null); const dobDay = useRef(null); + const yearField = dobYear.current; + const monthField = dobMonth.current; + const dayField = dobDay.current; + const [dateErr, setDateErr] = useState(""); const [monthErr, setMonthErr] = useState(""); const [yearErr, setYearErr] = useState(""); + const allValidFields = [ + dayField?.validity.valid, + monthField?.validity.valid, + yearField?.validity.valid, + ].every((field) => field === true); + + const checkAllFields = () => { + if (allValidFields) { + //Final check to clear date error : "Must be a valid date" (added onSubmit through handleSubmit) + clearErrors(dobDay, setDateErr); + } + }; + + useEffect(() => { + checkAllFields(); + }, [yearField?.value, monthField?.value, dayField?.value]); + // Auto-switch fields const nextFieldFocus = ( currentFieldEl: React.RefObject, @@ -37,22 +59,11 @@ const DobInput = ({ const handleSubmit = (e: React.SyntheticEvent): void => { e.preventDefault(); - - const yearField = dobYear.current; - const monthField = dobMonth.current; - const dayField = dobDay.current; - - const fieldCollection = yearField && monthField && dayField; - const allValidFields = [ - dayField?.validity.valid, - monthField?.validity.valid, - yearField?.validity.valid, - ].every((fieldIsValid) => fieldIsValid === true); - const noErrors = fieldCollection && allValidFields; - + const noEmptyFields = yearField && monthField && dayField; const isValidDate = - fieldCollection && + noEmptyFields && checkFullDate(dayField?.value, monthField?.value, yearField?.value); + const noErrors = noEmptyFields && allValidFields; if (noErrors && isValidDate) { const yearVal = +yearField.value; @@ -131,6 +142,9 @@ const DobInput = ({ onInput={() => { yearCheck(dobYear, setYearErr); }} + onChange={() => { + yearCheck(dobYear, setYearErr); + }} onKeyDown={blockInvalidChars} >