From 29701e8162902cda6c6b1c5620bbfc82180f536c Mon Sep 17 00:00:00 2001 From: leejeongho Date: Fri, 13 Sep 2024 22:11:56 +0900 Subject: [PATCH 1/2] =?UTF-8?q?refactor:=20=EC=9D=B8=ED=92=8B=20=EC=97=90?= =?UTF-8?q?=EB=9F=AC=20validation=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../components/Form/BasicInfoForm.tsx | 11 ++++++---- .../components/Form/ExtraInfoForm.tsx | 9 +++++--- .../components/TextInput/TextInput.tsx | 19 +++++++++++------ .../components/TextInput/styles.ts | 21 ++++++++++--------- 4 files changed, 37 insertions(+), 23 deletions(-) diff --git a/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx b/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx index ac287172..93793f2e 100644 --- a/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx +++ b/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx @@ -27,13 +27,14 @@ export const BasicInfoForm = () => { register, handleSubmit, control, - formState: { isValid }, + formState: { isValid, errors }, } = useForm({ defaultValues: { userName: searchParams.get('userName') || '', birth: searchParams.get('birth') || '', gender: searchParams.get('gender') || '', }, + mode: 'onTouched', }); const goToNextPage = (data: BasicInfo) => { @@ -46,7 +47,8 @@ export const BasicInfoForm = () => { label="이름이 무엇인가요?" answerNumber={1} placeholder="이름을 입력해주세요" - errorMessage="2자 이상, 5자 이하로 입력해주세요" + hintMessage="2자 이상, 5자 이하로 입력해주세요" + error={errors.userName} maxLength={5} {...register('userName', { required: true, @@ -56,8 +58,9 @@ export const BasicInfoForm = () => { })} /> { maxLength: 8, pattern: { value: /^\d{8}$/, - message: '생년월일은 숫자 8자리여야 합니다', + message: '생년월일 8자리를 입력해주세요', }, })} /> diff --git a/packages/web-domains/src/user/features/get-user-info/components/Form/ExtraInfoForm.tsx b/packages/web-domains/src/user/features/get-user-info/components/Form/ExtraInfoForm.tsx index 24438db6..9c934b65 100644 --- a/packages/web-domains/src/user/features/get-user-info/components/Form/ExtraInfoForm.tsx +++ b/packages/web-domains/src/user/features/get-user-info/components/Form/ExtraInfoForm.tsx @@ -23,12 +23,13 @@ export const ExtraInfoForm = () => { const { register, handleSubmit, - formState: { isValid }, + formState: { isValid, errors }, } = useForm({ defaultValues: { job: searchParams.get('job') || '', location: searchParams.get('location') || '', }, + mode: 'onTouched', }); const goToNextPage = (data: ExtraInfo) => { @@ -42,7 +43,8 @@ export const ExtraInfoForm = () => { answerNumber={4} placeholder="예) 돈 많은 백수" maxLength={15} - errorMessage="1자 이상, 15자 이하로 입력해주세요" + error={errors.job} + hintMessage="1자 이상, 15자 이하로 입력해주세요" {...register('job', { required: true, minLength: 1, @@ -54,8 +56,9 @@ export const ExtraInfoForm = () => { answerNumber={5} label="어디에 거주하고 계신가요?" maxLength={15} + error={errors.location} placeholder="예) 사랑시 고백구 행복동" - errorMessage="1자 이상, 15자 이하로 입력해주세요" + hintMessage="1자 이상, 15자 이하로 입력해주세요" {...register('location', { required: true, minLength: 1, diff --git a/packages/web-domains/src/user/features/get-user-info/components/TextInput/TextInput.tsx b/packages/web-domains/src/user/features/get-user-info/components/TextInput/TextInput.tsx index 761a70d6..0054706c 100644 --- a/packages/web-domains/src/user/features/get-user-info/components/TextInput/TextInput.tsx +++ b/packages/web-domains/src/user/features/get-user-info/components/TextInput/TextInput.tsx @@ -1,17 +1,19 @@ import { Txt } from '@sambad/sds/components'; import { size, colors } from '@sambad/sds/theme'; import { ChangeEvent, forwardRef, InputHTMLAttributes } from 'react'; +import { FieldError } from 'react-hook-form'; import { inputCss, textInputcss } from './styles'; export interface TextInputProps extends InputHTMLAttributes { label: string; - errorMessage?: string; + hintMessage?: string; answerNumber: string | number; + error?: FieldError; } export const TextInput = forwardRef((props, ref) => { - const { maxLength, label, errorMessage, answerNumber, onChange, ...restProps } = props; + const { maxLength, label, hintMessage, answerNumber, onChange, error, ...restProps } = props; const formattedAnswerNumber = answerNumber.toString().padStart(2, '0'); @@ -33,10 +35,15 @@ export const TextInput = forwardRef((props, re {label} - - {errorMessage && ( - - {errorMessage} + + {hintMessage && ( + + {hintMessage} + + )} + {!hintMessage && error && ( + + {error?.message} )} diff --git a/packages/web-domains/src/user/features/get-user-info/components/TextInput/styles.ts b/packages/web-domains/src/user/features/get-user-info/components/TextInput/styles.ts index 65f26054..77ac0b68 100644 --- a/packages/web-domains/src/user/features/get-user-info/components/TextInput/styles.ts +++ b/packages/web-domains/src/user/features/get-user-info/components/TextInput/styles.ts @@ -1,16 +1,17 @@ import { css } from '@emotion/react'; import { colors, borderRadiusVariants, size } from '@sambad/sds/theme'; -export const inputCss = css({ - display: 'block', - width: '100%', - backgroundColor: colors.grey200, - border: `1px solid ${colors.grey400}`, - padding: '12px 16px', - borderRadius: borderRadiusVariants.medium, - ':focus': { borderColor: colors.grey600 }, - outline: 'none', -}); +export const inputCss = (error?: boolean) => + css({ + display: 'block', + width: '100%', + backgroundColor: colors.grey200, + border: `1px solid ${error ? colors.primary500 : colors.grey400}`, + padding: '12px 16px', + borderRadius: borderRadiusVariants.medium, + ':focus': { borderColor: colors.grey600 }, + outline: 'none', + }); export const textInputcss = css({ display: 'flex', From bb63ea7639c08ef689c0a6a70e9f6898e0f77720 Mon Sep 17 00:00:00 2001 From: leejeongho Date: Sat, 14 Sep 2024 01:56:58 +0900 Subject: [PATCH 2/2] =?UTF-8?q?fix:=20=EC=83=9D=EB=85=84=EC=9B=94=EC=9D=BC?= =?UTF-8?q?=20validation=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../features/get-user-info/components/Form/BasicInfoForm.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx b/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx index 93793f2e..7261d28d 100644 --- a/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx +++ b/packages/web-domains/src/user/features/get-user-info/components/Form/BasicInfoForm.tsx @@ -67,7 +67,7 @@ export const BasicInfoForm = () => { required: true, maxLength: 8, pattern: { - value: /^\d{8}$/, + value: /^(19[0-9][0-9]|20\d{2})(0[0-9]|1[0-2])(0[1-9]|[1-2][0-9]|3[0-1])$/, message: '생년월일 8자리를 입력해주세요', }, })}