From fc79664ccdcb4b87e6cbbd889d1e02a548aca925 Mon Sep 17 00:00:00 2001 From: JunSeong Date: Tue, 22 Oct 2024 06:41:19 +0900 Subject: [PATCH] =?UTF-8?q?[FE]=20BUG:=20=EC=9D=BC=EC=A0=95=20=EB=B3=80?= =?UTF-8?q?=EA=B2=BD=20=EC=8B=9C=20=EC=9B=90=EB=9E=98=20=EB=82=A0=EC=A7=9C?= =?UTF-8?q?=EB=8F=84=20=EC=84=A0=ED=83=9D=20=EA=B0=80=EB=8A=A5=ED=95=98?= =?UTF-8?q?=EA=B2=8C=20=EB=B3=80=EA=B2=BD=20#1691?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../EditStatusModal/EditStatusModal.tsx | 34 +++++++++++++------ 1 file changed, 23 insertions(+), 11 deletions(-) diff --git a/frontend/src/Presentation/components/Modals/EditStatusModal/EditStatusModal.tsx b/frontend/src/Presentation/components/Modals/EditStatusModal/EditStatusModal.tsx index 9d0be4144..37c44b8d4 100644 --- a/frontend/src/Presentation/components/Modals/EditStatusModal/EditStatusModal.tsx +++ b/frontend/src/Presentation/components/Modals/EditStatusModal/EditStatusModal.tsx @@ -1,9 +1,14 @@ -import { format, startOfMonth, endOfMonth, differenceInDays, addDays } from "date-fns"; +import { + addDays, + differenceInDays, + endOfMonth, + format, + startOfMonth, +} from "date-fns"; import { useEffect, useState } from "react"; import { useRecoilState, useSetRecoilState } from "recoil"; import styled from "styled-components"; import Button from "@/Cabinet/components/Common/Button"; -import { IPresentationScheduleDetailInfo } from "@/Presentation/types/dto/presentation.dto"; import Dropdown, { IDropdownOptions, IDropdownProps, @@ -17,6 +22,7 @@ import { currentPresentationState, isCurrentModalState, } from "@/Presentation/recoil/atoms"; +import { IPresentationScheduleDetailInfo } from "@/Presentation/types/dto/presentation.dto"; import { PresentationLocation, PresentationStatusType, @@ -25,9 +31,7 @@ import { axiosGetInvalidDates, axiosUpdatePresentationStatus, } from "@/Presentation/api/axios/axios.custom"; -import { - filterInvalidDates, -} from "@/Presentation/utils/dateUtils"; +import { filterInvalidDates } from "@/Presentation/utils/dateUtils"; interface EditStatusModalProps { list: IPresentationScheduleDetailInfo[] | null; @@ -88,9 +92,12 @@ const EditStatusModal = ({ list, closeModal }: EditStatusModalProps) => { setIsLocationDropdownOpen(false); }, }; + const datesDropdownProps = { options: datesDropdownOptions, - defaultValue: datesDropdownOptions[0]?.name, + defaultValue: currentPresentation?.dateTime + ? format(currentPresentation?.dateTime, "M월 d일") + : "", defaultImageSrc: "", onChangeValue: (val: string) => { setPresentationDate(val); @@ -102,6 +109,7 @@ const EditStatusModal = ({ list, closeModal }: EditStatusModalProps) => { setIsLocationDropdownOpen(false); }, }; + const locationDropdownProps = { options: floorOptions, defaultValue: @@ -122,14 +130,14 @@ const EditStatusModal = ({ list, closeModal }: EditStatusModalProps) => { const tryEditPresentationStatus = async (e: React.MouseEvent) => { if (!currentPresentation || !currentPresentation.id) return; - const data = new Date(presentationDate); + const date = new Date(presentationDate); // NOTE: Date 객체의 시간은 UTC 기준이므로 한국 시간 (GMT + 9) 으로 변환, 이후 발표 시작 시간인 14시를 더해줌 - data.setHours(9 + 14); + date.setHours(9 + 14); try { await axiosUpdatePresentationStatus( currentPresentation.id, - data.toISOString(), + date.toISOString(), presentationStatus, location ); @@ -146,7 +154,11 @@ const EditStatusModal = ({ list, closeModal }: EditStatusModalProps) => { const getInvalidDates = async () => { try { const response = await axiosGetInvalidDates(); - setInvalidDates(response.data.invalidDateList); + setInvalidDates( + response.data.invalidDateList.filter( + (date: string) => date !== currentPresentation?.dateTime + ) + ); } catch (error: any) { setModalTitle(error.response.data.message); setHasErrorOnResponse(true); @@ -165,7 +177,7 @@ const EditStatusModal = ({ list, closeModal }: EditStatusModalProps) => { result.push(currentDate); } return result; - } + }; useEffect(() => { getInvalidDates();