From caddbafa51c013f4e9d1f72f65e5cfa53e61f60b Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 20:34:34 +0900 Subject: [PATCH 1/6] =?UTF-8?q?[=20fix=20]=20=EC=BC=80=EC=9D=B4=ED=81=AC?= =?UTF-8?q?=20=EC=84=A0=EB=AC=BC=20=EC=8B=9C=20=EC=9E=85=EB=A0=A5=20?= =?UTF-8?q?=EC=A0=9C=ED=95=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/Cakes/CakesForm.tsx | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/components/Cakes/CakesForm.tsx b/components/Cakes/CakesForm.tsx index 01dc15fc..026cfb9f 100644 --- a/components/Cakes/CakesForm.tsx +++ b/components/Cakes/CakesForm.tsx @@ -13,6 +13,7 @@ import { CakeListType } from '@/types/cakes/cakeListType'; import { useGetPublicWishes } from '@/hooks/queries/public'; import { UseMutateFunction } from 'react-query'; import theme from '@/styles/theme'; +import { useEffect, useState } from 'react'; interface CakesFormProps { methods: UseFormReturn; @@ -39,11 +40,25 @@ export default function CakesForm(props: CakesFormProps) { const { methods, selectedCake, selectedIndex, selectCake, wishesId, postPublicCakesData } = props; const { publicWishesData } = useGetPublicWishes(wishesId); + const [btnState, setBtnState] = useState(false); const handleClickFn = () => { + if (!btnState) return; postPublicCakesData(); }; + useEffect(() => { + if ( + methods.watch('letter') !== '' && + methods.watch('letter').length <= 300 && + methods.watch('giverName') + ) { + setBtnState(true); + } else { + setBtnState(false); + } + }, [methods.watch()]); + return ( <> @@ -80,7 +95,11 @@ export default function CakesForm(props: CakesFormProps) { - From 5c939982f951043d59d4ac1723bffa2ae36b61f4 Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 20:35:29 +0900 Subject: [PATCH 2/6] =?UTF-8?q?[=20fix=20]=20=EA=B3=84=EC=A2=8C=20?= =?UTF-8?q?=EB=B3=B5=EC=82=AC=ED=95=98=EA=B8=B0=20=EA=B0=80=EA=B2=A9?= =?UTF-8?q?=EC=A0=95=EB=B3=B4=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/Cakes/CakesPay.tsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/components/Cakes/CakesPay.tsx b/components/Cakes/CakesPay.tsx index 6bf4a1c7..52a69266 100644 --- a/components/Cakes/CakesPay.tsx +++ b/components/Cakes/CakesPay.tsx @@ -35,7 +35,8 @@ export default function CakesPay(props: CakesPayProps) { alert('계좌번호에 오류가 있습니다!'); return; } - const accountInfoText = `${publicWishesData.bank} ${publicWishesData.accountNumber}` || ''; + const accountInfoText = + `${publicWishesData.bank} ${publicWishesData.accountNumber} ${selectedCake.price}원` || ''; const isClipboardSupported = () => navigator?.clipboard != null; try { From f37a2cb40cf22f6dea01955da38abc894040af9f Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 20:56:52 +0900 Subject: [PATCH 3/6] =?UTF-8?q?[=20fix=20]=20=EC=A7=84=ED=96=89=EC=A4=91?= =?UTF-8?q?=EC=9D=B8=20=EC=86=8C=EC=9B=90=EB=A7=81=ED=81=AC=EA=B0=80=20?= =?UTF-8?q?=EC=97=86=EC=9D=84=20=EA=B2=BD=EC=9A=B0=20=EB=AA=A8=EB=8B=AC?= =?UTF-8?q?=EC=B0=BD=20=EC=95=88=EB=9C=A8=EA=B2=8C=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/Mypage/index.tsx | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/components/Mypage/index.tsx b/components/Mypage/index.tsx index c07ac747..b99efa1d 100644 --- a/components/Mypage/index.tsx +++ b/components/Mypage/index.tsx @@ -23,11 +23,14 @@ export default function MyPageContainer() { const { progressData } = useGetMainProgressData(); const { handlePatchProgressWishes } = usePatchProgressWishes(); + console.log(); + useEffect(() => { setNicknameState(loginUserInfo.nickName); }, [loginUserInfo]); const handleCancleModalState = () => { + if (progressData?.status === 'END' || progressData === undefined) return; setCancleModalState(!cancleModalState); }; @@ -53,12 +56,12 @@ export default function MyPageContainer() { useResetRecoilState(LoginUserInfo); }; - const handleWithdrawal = () => { - if (window.confirm('탈퇴를 진행하시겠습니까?')) { - deleteUserInfo(); - router.push('/'); - } - }; + // const handleWithdrawal = () => { + // if (window.confirm('탈퇴를 진행하시겠습니까?')) { + // deleteUserInfo(); + // router.push('/'); + // } + // }; return ( <> @@ -106,6 +109,7 @@ export default function MyPageContainer() { > 진행중인 펀딩 중단하기 + {} 지난 소원 링크 모음 @@ -119,7 +123,7 @@ export default function MyPageContainer() { 로그아웃 - 회원탈퇴 + {/* 회원탈퇴 */} From 45070a17a2452f60e3272d5b505e460f91858c40 Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 21:43:52 +0900 Subject: [PATCH 4/6] =?UTF-8?q?[=20fix=20]=20=EC=9E=85=EB=A0=A5=ED=98=95?= =?UTF-8?q?=EC=8B=9D=20=EC=A0=9C=ED=95=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/user.ts | 4 +- components/Common/Input/Input.tsx | 4 +- components/Common/Input/InputLength.tsx | 7 +- components/Common/Input/TextareaBox.tsx | 3 +- components/Common/Modal/BankInput.tsx | 4 +- components/Main/MainCenterContent.tsx | 2 - components/Main/MainTopContent.tsx | 4 +- components/Mypage/EditWishes/index.tsx | 73 +++++++++++++++---- components/Mypage/index.tsx | 2 - .../Wishes/WishesForm/UploadPresent.tsx | 4 +- components/Wishes/WishesForm/WisehsStep2.tsx | 1 + 11 files changed, 75 insertions(+), 33 deletions(-) diff --git a/api/user.ts b/api/user.ts index bd005a4d..2ed20bd3 100644 --- a/api/user.ts +++ b/api/user.ts @@ -3,7 +3,7 @@ import { client } from './common/axios'; import { API_VERSION_01, PATH_USER } from './path'; import { UseFormReturn } from 'react-hook-form'; -import { UserAccountDataResponseType } from '@/types/api/response'; +import { DefaultResponseType, UserAccountDataResponseType } from '@/types/api/response'; import { WishesDataInputType } from '@/types/wishesType'; const ACCESS_TOKEN = getAccessToken(); @@ -11,7 +11,7 @@ const ACCESS_TOKEN = getAccessToken(); export const putUserAccount = async ( methods: UseFormReturn, ) => { - const data = await client.put( + const data = await client.put( `${API_VERSION_01}${PATH_USER.ACCOUNT}`, { accountInfo: { diff --git a/components/Common/Input/Input.tsx b/components/Common/Input/Input.tsx index e7b25f3b..4a51e993 100644 --- a/components/Common/Input/Input.tsx +++ b/components/Common/Input/Input.tsx @@ -39,10 +39,10 @@ export default function Input(props: PropsWithChildren) { ); } -export const StyledInput = styled.input` +export const StyledInput = styled.input<{ readOnly?: boolean }>` width: 100%; height: 100%; ${theme.fonts.body12}; - color: ${theme.colors.dark_blue}; + color: ${(props) => (props.readOnly ? theme.colors.gray1 : theme.colors.dark_blue)}; `; diff --git a/components/Common/Input/InputLength.tsx b/components/Common/Input/InputLength.tsx index 978d8b16..3ad5c771 100644 --- a/components/Common/Input/InputLength.tsx +++ b/components/Common/Input/InputLength.tsx @@ -10,15 +10,16 @@ export default function InputLength(props: InputLengthProps) { const { inputLength, limitLength } = props; return ( - + {inputLength}/{limitLength} ); } const Styled = { - Container: styled.div` - color: ${theme.colors.gray2}; + Container: styled.div<{ inputLength: number; limitLength: number }>` + color: ${(props) => + props.inputLength > props.limitLength ? theme.colors.warning_red : theme.colors.gray2}; ${theme.fonts.body12}; padding-left: 1rem; diff --git a/components/Common/Input/TextareaBox.tsx b/components/Common/Input/TextareaBox.tsx index 7f3d16e6..6c58e128 100644 --- a/components/Common/Input/TextareaBox.tsx +++ b/components/Common/Input/TextareaBox.tsx @@ -35,11 +35,12 @@ const Styled = { justify-content: space-between; `, - Textarea: styled.textarea` + Textarea: styled.textarea<{ readOnly?: boolean }>` width: 100%; height: 10.5rem; ${theme.fonts.body12}; + color: ${(props) => (props.readOnly ? theme.colors.gray1 : theme.colors.dark_blue)}; resize: none; `, diff --git a/components/Common/Modal/BankInput.tsx b/components/Common/Modal/BankInput.tsx index 8c0aba84..d23cb153 100644 --- a/components/Common/Modal/BankInput.tsx +++ b/components/Common/Modal/BankInput.tsx @@ -5,7 +5,7 @@ import styled from 'styled-components'; import { UseFormReturn } from 'react-hook-form'; -import { WishesDataInputType } from '@/types/wishesType'; +import { MainProgressDataType, WishesDataInputType } from '@/types/wishesType'; import { ArrowDownIc } from '@/public/assets/icons'; import Image from 'next/image'; @@ -18,6 +18,7 @@ import { validation } from '@/validation/input'; interface BankInputProps { methods: UseFormReturn; + progressData?: MainProgressDataType; } export default function BankInput(props: BankInputProps) { @@ -39,7 +40,6 @@ export default function BankInput(props: BankInputProps) { boxType="inputBox--large" placeholder="은행 선택" register={methods.register('bank')} - readOnly > 더 보기 diff --git a/components/Main/MainCenterContent.tsx b/components/Main/MainCenterContent.tsx index 178e3b7e..bb789f24 100644 --- a/components/Main/MainCenterContent.tsx +++ b/components/Main/MainCenterContent.tsx @@ -15,8 +15,6 @@ import { convertMoneyText } from '@/utils/common/convertMoneyText'; export default function MainCenterContent() { const { progressData } = useGetMainProgressData(); - console.log(progressData); - const ChatImg = () => { if (!progressData) { return MainChatImg; diff --git a/components/Main/MainTopContent.tsx b/components/Main/MainTopContent.tsx index 16115e51..243c203a 100644 --- a/components/Main/MainTopContent.tsx +++ b/components/Main/MainTopContent.tsx @@ -24,8 +24,8 @@ export default function MainTopContent() { return 'D-Day'; } else { return progressData.dayCount < 0 - ? `D${progressData?.dayCount}` - : `D+${progressData?.dayCount}`; + ? `D+${Math.abs(progressData?.dayCount)}` + : `D-${progressData?.dayCount}`; } }; diff --git a/components/Mypage/EditWishes/index.tsx b/components/Mypage/EditWishes/index.tsx index 81f442f5..1322d963 100644 --- a/components/Mypage/EditWishes/index.tsx +++ b/components/Mypage/EditWishes/index.tsx @@ -2,12 +2,11 @@ import Button from '@/components/Common/Button'; import Calendar from '@/components/Common/Calendar/Calendar'; import InputContainer from '@/components/Common/Input/InputContainer'; import TextareaBox from '@/components/Common/Input/TextareaBox'; -import UploadTypeToggleBtn from '@/components/Common/UploadTypeToggleBtn'; + import ItemLink from '@/components/Wishes/WishesForm/ItemLink'; import theme from '@/styles/theme'; import styled from 'styled-components'; import { useEffect, useState } from 'react'; -import { convertMoneyText } from '@/utils/common/convertMoneyText'; import UploadPresent from '@/components/Wishes/WishesForm/UploadPresent'; import Input from '@/components/Common/Input/Input'; import useUploadItemInfo from '@/hooks/wishes/useUploadItemInfo'; @@ -23,10 +22,14 @@ import SiteList from '@/components/Wishes/WishesForm/SiteList'; import { usePutUserAccount } from '@/hooks/queries/user'; import { LIMIT_TEXT } from '@/constant/limitText'; import { getDate } from '@/utils/common/getDate'; +import { validation } from '@/validation/input'; +import InputLength from '@/components/Common/Input/InputLength'; export default function EditWishesContainer() { const { imageFile, preSignedImageUrl, uploadImageFile } = useUploadItemInfo(); - const [isLinkLoadType, setIsLinkLoadType] = useState(true); //false : 링크 불러오기 true : 직접 + const [isLinkLoadType, setIsLinkLoadType] = useState(false); //false : 링크 불러오기 true : 직접 + + const [editState, setEditState] = useState(false); const methods = useForm({ defaultValues: { @@ -48,7 +51,6 @@ export default function EditWishesContainer() { const { wishesProgressData } = useGetWishesProgress(); const { progressData } = useGetMainProgressData(); - const { handlePutUserAccount } = usePutUserAccount(methods); const { handlePutProgressWishes } = usePutProgressWishes(methods); @@ -72,20 +74,46 @@ export default function EditWishesContainer() { } }, [wishesProgressData]); - const handleLoadTypeToggle = (state: boolean) => { - setIsLinkLoadType(state); + useEffect(() => { + if ( + methods.getValues('initial').length !== 0 && + methods.getValues('initial').length <= 15 && + methods.getValues('imageUrl') && + methods.getValues('price') !== '' && + Number(methods.getValues('price')) <= 12000000 && + methods.getValues('title').length <= 20 && + methods.getValues('hint').length !== 0 && + methods.getValues('hint').length <= 300 && + methods.getValues('name') && + methods.getValues('bank') && + methods.getValues('account') && + methods.getValues('phone') && + validation.isCorrectPhoneNumber(methods.getValues('phone')) + ) { + setEditState(true); + } else { + setEditState(false); + } + }, [methods.watch()]); + + const handleClickFn = () => { + if (!editState) return; + handlePutUserAccount(); + handlePutProgressWishes(); }; + console.log(progressData); + return ( <> 소원링크 정보 수정하기 - + /> */} {isLinkLoadType ? ( @@ -99,16 +127,31 @@ export default function EditWishesContainer() { preSignedImageUrl={preSignedImageUrl} uploadImageFile={uploadImageFile} methods={methods} + progressStatus={progressData?.status} /> )} - + + + - + + + @@ -126,7 +169,7 @@ export default function EditWishesContainer() { {/* BankInfo */} - + @@ -143,17 +186,15 @@ export default function EditWishesContainer() { inputLength={methods.watch('hint').length} limitLength={LIMIT_TEXT.DESCRIPTION} register={methods.register('hint')} + readOnly={progressData?.status === 'WHILE'} /> diff --git a/components/Mypage/index.tsx b/components/Mypage/index.tsx index b99efa1d..020731e1 100644 --- a/components/Mypage/index.tsx +++ b/components/Mypage/index.tsx @@ -23,8 +23,6 @@ export default function MyPageContainer() { const { progressData } = useGetMainProgressData(); const { handlePatchProgressWishes } = usePatchProgressWishes(); - console.log(); - useEffect(() => { setNicknameState(loginUserInfo.nickName); }, [loginUserInfo]); diff --git a/components/Wishes/WishesForm/UploadPresent.tsx b/components/Wishes/WishesForm/UploadPresent.tsx index 2fd53a44..2cd9cda1 100644 --- a/components/Wishes/WishesForm/UploadPresent.tsx +++ b/components/Wishes/WishesForm/UploadPresent.tsx @@ -18,10 +18,11 @@ interface UploadPresentProps { preSignedImageUrl: string; uploadImageFile: (e: ChangeEvent) => void; methods: UseFormReturn; + progressStatus?: 'WHILE' | 'BEFORE' | 'END'; } export default function UploadPresent(props: UploadPresentProps) { - const { imageFile, preSignedImageUrl, uploadImageFile, methods } = props; + const { imageFile, preSignedImageUrl, uploadImageFile, methods, progressStatus } = props; useEffect(() => { if (preSignedImageUrl) methods.setValue('imageUrl', preSignedImageUrl); @@ -58,6 +59,7 @@ export default function UploadPresent(props: UploadPresentProps) { boxType="inputBox--large" placeholder="ex. 12,000,000" register={methods.register('price', { required: true })} + readOnly={progressStatus === 'WHILE'} > { if ( methods.getValues('title') && + methods.getValues('title').length <= 20 && methods.getValues('hint').length !== 0 && methods.getValues('hint').length <= 300 ) { From 0cf0c7b830d74309eeb92cb1ce90c214ccc0515e Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 22:08:00 +0900 Subject: [PATCH 5/6] =?UTF-8?q?[=20fix=20]=20=EC=98=88=EC=83=81=EA=B8=88?= =?UTF-8?q?=EC=95=A1=20=ED=81=B4=EB=A6=AD=20=EC=8B=9C=20=EC=BC=80=EC=9D=B4?= =?UTF-8?q?=ED=81=AC=20=EB=AA=A8=EC=95=84=EB=B3=B4=EA=B8=B0=EB=A1=9C=20?= =?UTF-8?q?=EC=97=B0=EA=B2=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/Main/MainCenterContent.tsx | 9 +++++++-- components/Mypage/Letters/CakeListButton.tsx | 14 +++++--------- components/Mypage/Letters/[id].tsx | 6 +++--- pages/mypage/letters/[id].tsx | 2 +- 4 files changed, 16 insertions(+), 15 deletions(-) diff --git a/components/Main/MainCenterContent.tsx b/components/Main/MainCenterContent.tsx index bb789f24..30a5b750 100644 --- a/components/Main/MainCenterContent.tsx +++ b/components/Main/MainCenterContent.tsx @@ -11,6 +11,7 @@ import { import theme from '@/styles/theme'; import { useGetMainProgressData } from '@/hooks/queries/wishes'; import { convertMoneyText } from '@/utils/common/convertMoneyText'; +import router from 'next/router'; export default function MainCenterContent() { const { progressData } = useGetMainProgressData(); @@ -29,6 +30,10 @@ export default function MainCenterContent() { } }; + const handleMoveLetterPage = () => { + progressData && router.push(`mypage/letters/${progressData?.wishId}`); + }; + return ( @@ -53,12 +58,12 @@ export default function MainCenterContent() { 총 ???개 ) : ( - <> +
{'예상 케이크 금액 >\n'} {`총 ${convertMoneyText( progressData?.price.toString() || '0', )}원`} - +
)}
diff --git a/components/Mypage/Letters/CakeListButton.tsx b/components/Mypage/Letters/CakeListButton.tsx index 05f7d60a..611b911d 100644 --- a/components/Mypage/Letters/CakeListButton.tsx +++ b/components/Mypage/Letters/CakeListButton.tsx @@ -17,8 +17,8 @@ export default function CakeListButton(props: CakeListButtonProps) { return ( {image && 케이크 이미지} - {/* */} - + + {cakeName} X {cakeNum}개 @@ -43,14 +43,10 @@ const Styled = { margin: 0 0 1rem; `, - // TextContainer: styled.div<{ fonts: string; fontColor: string }>` - // padding: 0.2rem 0.5rem 0 1rem; - // ${(props) => props.fonts} - - // `, - - TextContainer: styled.div<{ fontColor: string }>` + TextContainer: styled.div<{ fonts: string; fontColor: string }>` + width: 30rem; padding: 0.2rem 0.5rem 0 1rem; + ${theme.fonts.button18} `, NumText: styled.span` diff --git a/components/Mypage/Letters/[id].tsx b/components/Mypage/Letters/[id].tsx index 8a065bb6..88e8e1ac 100644 --- a/components/Mypage/Letters/[id].tsx +++ b/components/Mypage/Letters/[id].tsx @@ -53,7 +53,6 @@ export default function LettersContainer() { + ); From 8a9d92fde9708ac1141495194a780b5b89e7b0b3 Mon Sep 17 00:00:00 2001 From: myeongheonhong Date: Sun, 24 Dec 2023 22:36:58 +0900 Subject: [PATCH 6/6] =?UTF-8?q?[=20fix=20]=20=EC=8A=A4=ED=83=80=EC=9D=BC?= =?UTF-8?q?=20=EA=B4=80=EB=A0=A8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/Cakes/CakesForm.tsx | 5 ++++- components/Common/Box/ImageBox.tsx | 2 +- components/Common/Input/Input.tsx | 9 ++++++--- components/Common/Input/TextareaBox.tsx | 14 ++++++++++---- components/Mypage/EditWishes/index.tsx | 6 +++--- components/Mypage/Letters/CakeListButton.tsx | 12 +++++------- components/Mypage/Letters/LettersMain.tsx | 2 -- components/Mypage/Letters/[id].tsx | 1 - components/Wishes/Common/WishesStepBtn.tsx | 3 ++- components/Wishes/WishesForm/Preview.tsx | 19 +++++++++++++++++-- .../Wishes/WishesForm/UploadPresent.tsx | 2 +- components/Wishes/WishesForm/WisehsStep2.tsx | 4 ++-- components/Wishes/WishesForm/WishesStep1.tsx | 1 + 13 files changed, 52 insertions(+), 28 deletions(-) diff --git a/components/Cakes/CakesForm.tsx b/components/Cakes/CakesForm.tsx index 026cfb9f..40aa8a9e 100644 --- a/components/Cakes/CakesForm.tsx +++ b/components/Cakes/CakesForm.tsx @@ -126,7 +126,10 @@ const Styled = { HintBox: styled(StyledBox)` width: 100%; - height: 12.6rem; + min-height: 12.6rem; + max-height: 16rem; + + overflow: scroll; ${theme.fonts.body14}; diff --git a/components/Common/Box/ImageBox.tsx b/components/Common/Box/ImageBox.tsx index 65a20dd6..52cc9f56 100644 --- a/components/Common/Box/ImageBox.tsx +++ b/components/Common/Box/ImageBox.tsx @@ -15,7 +15,7 @@ export default function ImageBox(props: PropsWithChildren) { return {children}; } -const StyledImageBox = styled(StyledBox)` +export const StyledImageBox = styled(StyledBox)` width: 100%; height: 15rem; diff --git a/components/Common/Input/Input.tsx b/components/Common/Input/Input.tsx index 4a51e993..3a55f83e 100644 --- a/components/Common/Input/Input.tsx +++ b/components/Common/Input/Input.tsx @@ -15,12 +15,14 @@ interface InputProps { inputType?: HTMLInputTypeAttribute; placeholder?: string; readOnly?: boolean; + disabled?: boolean; register: UseFormRegisterReturn; errors?: FieldError; } export default function Input(props: PropsWithChildren) { - const { width, inputType, boxType, placeholder, readOnly, register, errors, children } = props; + const { width, inputType, boxType, placeholder, readOnly, disabled, register, errors, children } = + props; return ( <> @@ -30,6 +32,7 @@ export default function Input(props: PropsWithChildren) { pattern={inputType === 'number' ? '\\d*' : undefined} placeholder={placeholder} readOnly={readOnly} + disabled={disabled} {...register} /> {children} @@ -39,10 +42,10 @@ export default function Input(props: PropsWithChildren) { ); } -export const StyledInput = styled.input<{ readOnly?: boolean }>` +export const StyledInput = styled.input<{ disabled?: boolean }>` width: 100%; height: 100%; ${theme.fonts.body12}; - color: ${(props) => (props.readOnly ? theme.colors.gray1 : theme.colors.dark_blue)}; + color: ${(props) => (props.disabled ? theme.colors.gray1 : theme.colors.dark_blue)}; `; diff --git a/components/Common/Input/TextareaBox.tsx b/components/Common/Input/TextareaBox.tsx index 6c58e128..e1e50d8d 100644 --- a/components/Common/Input/TextareaBox.tsx +++ b/components/Common/Input/TextareaBox.tsx @@ -12,15 +12,21 @@ interface TextareaBoxProps { inputLength?: number; limitLength?: number; readOnly?: boolean; + disabled?: boolean; register: UseFormRegisterReturn; } export default function TextareaBox(props: TextareaBoxProps) { - const { placeholder, inputLength, limitLength, readOnly, register } = props; + const { placeholder, inputLength, limitLength, readOnly, disabled, register } = props; return ( - + {limitLength && } @@ -35,12 +41,12 @@ const Styled = { justify-content: space-between; `, - Textarea: styled.textarea<{ readOnly?: boolean }>` + Textarea: styled.textarea<{ disabled?: boolean }>` width: 100%; height: 10.5rem; ${theme.fonts.body12}; - color: ${(props) => (props.readOnly ? theme.colors.gray1 : theme.colors.dark_blue)}; + color: ${(props) => (props.disabled ? theme.colors.gray1 : theme.colors.dark_blue)}; resize: none; `, diff --git a/components/Mypage/EditWishes/index.tsx b/components/Mypage/EditWishes/index.tsx index 1322d963..fdc1e934 100644 --- a/components/Mypage/EditWishes/index.tsx +++ b/components/Mypage/EditWishes/index.tsx @@ -137,7 +137,7 @@ export default function EditWishesContainer() { boxType="inputBox--large" placeholder="ex. 애플워치 -> ㅇㅍㅇㅊ" register={methods.register('initial')} - readOnly={progressData?.status === 'WHILE'} + disabled={progressData?.status === 'WHILE'} > @@ -148,7 +148,7 @@ export default function EditWishesContainer() { boxType="inputBox--large" placeholder="ex. ㅇㅇ이의 앙큼 벌스데이" register={methods.register('title')} - readOnly={progressData?.status === 'WHILE'} + disabled={progressData?.status === 'WHILE'} > @@ -186,7 +186,7 @@ export default function EditWishesContainer() { inputLength={methods.watch('hint').length} limitLength={LIMIT_TEXT.DESCRIPTION} register={methods.register('hint')} - readOnly={progressData?.status === 'WHILE'} + disabled={progressData?.status === 'WHILE'} />
diff --git a/components/Mypage/Letters/CakeListButton.tsx b/components/Mypage/Letters/CakeListButton.tsx index 611b911d..c388d4e4 100644 --- a/components/Mypage/Letters/CakeListButton.tsx +++ b/components/Mypage/Letters/CakeListButton.tsx @@ -5,20 +5,18 @@ import Image, { StaticImageData } from 'next/image'; interface CakeListButtonProps { image?: string | StaticImageData; backgroundColor: string; - fontColor: string; - fonts: string; handleClick?: () => void; cakeName?: string; cakeNum?: number; } export default function CakeListButton(props: CakeListButtonProps) { - const { image, backgroundColor, fonts, fontColor, handleClick, cakeName, cakeNum } = props; + const { image, backgroundColor, handleClick, cakeName, cakeNum } = props; return ( {image && 케이크 이미지} - + {cakeName} X {cakeNum}개 @@ -43,10 +41,10 @@ const Styled = { margin: 0 0 1rem; `, - TextContainer: styled.div<{ fonts: string; fontColor: string }>` - width: 30rem; + TextContainer: styled.div` padding: 0.2rem 0.5rem 0 1rem; - ${theme.fonts.button18} + margin-left: 2rem; + ${theme.fonts.button18}; `, NumText: styled.span` diff --git a/components/Mypage/Letters/LettersMain.tsx b/components/Mypage/Letters/LettersMain.tsx index b0912ca5..164ae6cb 100644 --- a/components/Mypage/Letters/LettersMain.tsx +++ b/components/Mypage/Letters/LettersMain.tsx @@ -76,8 +76,6 @@ export default function LettersMainContainer() { : undefined } backgroundColor={theme.colors.pastel_blue} - fontColor={theme.colors.gray4} - fonts={theme.fonts.button18} image={cake.smallImage} cakeName={cake.name} cakeNum={getCakeNum(cake.cakeNumber, cakesCount)} diff --git a/components/Mypage/Letters/[id].tsx b/components/Mypage/Letters/[id].tsx index 88e8e1ac..a6fdb2a3 100644 --- a/components/Mypage/Letters/[id].tsx +++ b/components/Mypage/Letters/[id].tsx @@ -52,7 +52,6 @@ export default function LettersContainer() { <> { if (handleClickFn) handleClickFn(); - wishesStep.handleNextStep(); + + wishesStep.nextState && wishesStep.handleNextStep(); }; return ( diff --git a/components/Wishes/WishesForm/Preview.tsx b/components/Wishes/WishesForm/Preview.tsx index c037214b..3a90a53c 100644 --- a/components/Wishes/WishesForm/Preview.tsx +++ b/components/Wishes/WishesForm/Preview.tsx @@ -1,5 +1,4 @@ import InputContainer from '@/components/Common/Input/InputContainer'; -import TextareaBox from '@/components/Common/Input/TextareaBox'; import styled from 'styled-components'; import theme from '@/styles/theme'; import { convertMoneyText } from '@/utils/common/convertMoneyText'; @@ -13,6 +12,8 @@ import WishesStepBtn from '../Common/WishesStepBtn'; import { ColorSystemType } from '@/types/common/box/boxStyleType'; import { useEffect } from 'react'; import { usePostWishes } from '@/hooks/queries/wishes'; +import ImageBox, { StyledImageBox } from '@/components/Common/Box/ImageBox'; +import { StyledBox } from '@/components/Common/Box'; interface PreviewProps { methods: UseFormReturn; @@ -56,7 +57,9 @@ export default function Preview(props: PreviewProps) {
- + + {methods.getValues('hint')} + @@ -101,4 +104,16 @@ const Styled = { ButtonWrapper: styled.div` padding-bottom: 4.6rem; `, + + PreviewBox: styled(StyledBox)` + width: 100%; + height: 15rem; + + padding: 1rem 1rem 1rem 1.2rem; + + ${theme.fonts.body14} + border: 0.1rem solid ${theme.colors.main_blue}; + + overflow: scroll; + `, }; diff --git a/components/Wishes/WishesForm/UploadPresent.tsx b/components/Wishes/WishesForm/UploadPresent.tsx index 2cd9cda1..6397f537 100644 --- a/components/Wishes/WishesForm/UploadPresent.tsx +++ b/components/Wishes/WishesForm/UploadPresent.tsx @@ -59,7 +59,7 @@ export default function UploadPresent(props: UploadPresentProps) { boxType="inputBox--large" placeholder="ex. 12,000,000" register={methods.register('price', { required: true })} - readOnly={progressStatus === 'WHILE'} + disabled={progressStatus === 'WHILE'} > + <>
@@ -73,7 +73,7 @@ export default function WishesStep2(props: WishesStep2Props) { - + ); } diff --git a/components/Wishes/WishesForm/WishesStep1.tsx b/components/Wishes/WishesForm/WishesStep1.tsx index 70625d16..44f83a28 100644 --- a/components/Wishes/WishesForm/WishesStep1.tsx +++ b/components/Wishes/WishesForm/WishesStep1.tsx @@ -59,6 +59,7 @@ export default function WishesStep1(props: PropsWithChildren) methods.getValues('initial').length <= 15 && imageFile && methods.getValues('price') !== '' && + Number(methods.getValues('price')) > 0 && Number(methods.getValues('price')) <= 12000000 ) { wishesStep.changeNextState(true);