From b17412a46653bcdfa2a23f612df5ae38b9cdedd0 Mon Sep 17 00:00:00 2001 From: heejung0413 Date: Fri, 19 Apr 2024 16:30:00 +0900 Subject: [PATCH 1/5] =?UTF-8?q?=EA=B8=B4=EA=B8=89)=20fix:=20team=20type=20?= =?UTF-8?q?=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/@types/@asConst.ts | 2 +- src/api/@types/Retrospectives.ts | 3 +- src/api/@types/Section.ts | 14 ++-- src/api/__mock__/retrospective.ts | 9 +-- src/api/services/Section.ts | 2 +- src/components/writeRetro/layout/AddTask.tsx | 64 ++++++++++++------- .../writeRetro/revise/ReviseSetting.tsx | 2 +- src/pages/RetroTeamPage.tsx | 14 ++-- src/pages/RevisePage.tsx | 4 +- 9 files changed, 68 insertions(+), 46 deletions(-) diff --git a/src/api/@types/@asConst.ts b/src/api/@types/@asConst.ts index fb8c695..d04de52 100644 --- a/src/api/@types/@asConst.ts +++ b/src/api/@types/@asConst.ts @@ -13,7 +13,7 @@ export const Status = { export const RetrospectiveType = { TEAM: 'TEAM', PERSONAL: 'PERSONAL', -}; +} as const; export const Template = { 1: 'Keep', diff --git a/src/api/@types/Retrospectives.ts b/src/api/@types/Retrospectives.ts index 204458b..6357c5c 100644 --- a/src/api/@types/Retrospectives.ts +++ b/src/api/@types/Retrospectives.ts @@ -15,8 +15,9 @@ export interface RetrospectiveData { retrospectiveId: number; title: string; templateId: number; - teamId: number; + type: keyof TRetrospective; userId: number; + leaderName: string; description: string; status: keyof TStatus; thumbnail: string; diff --git a/src/api/@types/Section.ts b/src/api/@types/Section.ts index 16e87cc..cdf39ba 100644 --- a/src/api/@types/Section.ts +++ b/src/api/@types/Section.ts @@ -35,12 +35,14 @@ export interface CreateSectionRequest { export interface PostSectionResponse { code: number; message: string; - data: { - id: number; - userId: number; - retrospectiveId: number; - sectionContent: string; - }; + data: PostSectionData; +} + +export interface PostSectionData { + id: number; + userId: number; + retrospectiveId: number; + sectionContent: string; } //patch diff --git a/src/api/__mock__/retrospective.ts b/src/api/__mock__/retrospective.ts index d3690c9..939dea6 100644 --- a/src/api/__mock__/retrospective.ts +++ b/src/api/__mock__/retrospective.ts @@ -25,10 +25,11 @@ export const MockOnlyGetRetrospective: onlyGetRetrospectiveResponse = { retrospectiveId: 1, title: 'heeeeee', templateId: 2, - teamId: 1, - userId: 1, - description: 'heeee', - status: Status.COMPLETED, + type: 'TEAM', + userId: 0, + leaderName: 'string', + description: 'string', + status: Status.NOT_STARTED, thumbnail: '3fa85f64-5717-4562-b3fc-2c963f66afa6', }, }; diff --git a/src/api/services/Section.ts b/src/api/services/Section.ts index 1653a17..d57420a 100644 --- a/src/api/services/Section.ts +++ b/src/api/services/Section.ts @@ -25,7 +25,7 @@ export const SectionServices: SectionClient = { }, create: async (request: CreateSectionRequest): Promise => { try { - const response = await axiosInstance.post(`${ROUTE}/`, request); + const response = await axiosInstance.post(`${ROUTE}`, request); return response.data; } catch (error) { throw new Error(error as string); diff --git a/src/components/writeRetro/layout/AddTask.tsx b/src/components/writeRetro/layout/AddTask.tsx index b8ca9f3..e1a091d 100644 --- a/src/components/writeRetro/layout/AddTask.tsx +++ b/src/components/writeRetro/layout/AddTask.tsx @@ -1,35 +1,47 @@ -import { ChangeEvent, FC, useState } from 'react'; +import { FC, useState } from 'react'; import { AiFillPlusCircle } from 'react-icons/ai'; +import { PostSectionData } from '@/api/@types/Section'; +import { SectionServices } from '@/api/services/Section'; +import { useCustomToast } from '@/hooks/useCustomToast'; import * as S from '@/styles/writeRetroStyles/Layout.style'; -// interface Props { -// retro: RetrospectiveData; -// template: TemplateNameData[]; -// } +interface Props { + retrospectiveId: number | undefined; + template: number; +} -export const AddTask: FC = () => { +export const AddTask: FC = ({ retrospectiveId, template }) => { const [isVisible, setIsVisible] = useState(false); - const [value, setValue] = useState(''); + const [result, setResult] = useState(); + const toast = useCustomToast(); + const [content, setContent] = useState(''); const handleClick = () => { setIsVisible(isVisible => !isVisible); }; - // const handleAddSection = async () => { - // try{ - // const data = await SectionServices.create({ retrospectiveId: retro.retrospectiveId, - // templateSectionId: template; - // sectionContent: string; - // }}) - // } - // } - - const handleChange = (e: ChangeEvent) => { - setValue(e.target.value); - e.target.style.height = 'auto'; - e.target.style.height = `${e.target.scrollHeight}px`; + const handleAddSection = async () => { + try { + if (retrospectiveId) { + const data = await SectionServices.create({ + retrospectiveId: retrospectiveId, + templateSectionId: template.valueOf(), + sectionContent: content, + }); + setResult(data.data); + console.log(result); + } + } catch (e) { + toast.error(e); + } }; + // const handleChange = (e: ChangeEvent) => { + // setValue(e.target.value); + // e.target.style.height = 'auto'; + // e.target.style.height = `${e.target.scrollHeight}px`; + // }; + return ( <> {/* AddTaskButton */} @@ -39,11 +51,19 @@ export const AddTask: FC = () => { + {/* AddTaskInput */} {isVisible && ( - - 확인 + setContent(e.target.value)} + placeholder="내용을 입력해주세요" + rows={1} + > + + 확인 + )} diff --git a/src/components/writeRetro/revise/ReviseSetting.tsx b/src/components/writeRetro/revise/ReviseSetting.tsx index 33004fa..fed5dea 100644 --- a/src/components/writeRetro/revise/ReviseSetting.tsx +++ b/src/components/writeRetro/revise/ReviseSetting.tsx @@ -149,7 +149,7 @@ const ReviseSetting: FC = ({ retro }) => { 회고 유형 변경 불가 - {retro.teamId !== null ? '팀' : '개인'} + {retro.type === 'TEAM' ? '팀' : '개인'} {/* 회고 템플릿 유형 */} diff --git a/src/pages/RetroTeamPage.tsx b/src/pages/RetroTeamPage.tsx index ca0d3f2..b398f81 100644 --- a/src/pages/RetroTeamPage.tsx +++ b/src/pages/RetroTeamPage.tsx @@ -30,18 +30,18 @@ const RetroTeamPage = () => { const fetchRetrospective = async () => { try { const data = await RetrospectiveService.onlyGet({ retrospectiveId: retrospectiveId }); + console.log('retro.data', data.data); setRetro(data.data); + console.log('retro', retro); } catch (e) { toast.error(e); } }; - const FetchSection = async () => { + const fetchSection = async () => { try { const data = await SectionServices.get({ retrospectiveId: retrospectiveId, teamId: teamId }); - console.log(data.data); setSection(data.data); - console.log('section', section); } catch (e) { toast.error(e); } @@ -60,12 +60,10 @@ const RetroTeamPage = () => { }; useEffect(() => { - FetchSection(); + fetchSection(); fetchRetrospective(); fetchTemplate(); - }, []); - - if (!section) return; + }, [retro?.status, template?.values, section]); return ( @@ -91,7 +89,7 @@ const RetroTeamPage = () => { .map(section => ( ))} - + )) : PersonalSectionTitleName.map(title => ( diff --git a/src/pages/RevisePage.tsx b/src/pages/RevisePage.tsx index 21142b0..3d59a5e 100644 --- a/src/pages/RevisePage.tsx +++ b/src/pages/RevisePage.tsx @@ -64,7 +64,7 @@ const RetroRevisePage = () => { 회고 설정 - {retro.teamId !== null ? 팀원 관리 : null} + {retro.type === 'TEAM' ? 팀원 관리 : null} @@ -72,7 +72,7 @@ const RetroRevisePage = () => { - {retro.teamId !== null ? : } + {retro.type === 'TEAM' ? : } From 27d0e34496585a8b0e0841ba0839ed8efec06c00 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B3=B5=EC=A0=95=EB=AF=BC?= <102538362+jeongmin59@users.noreply.github.com> Date: Sat, 20 Apr 2024 00:15:40 +0900 Subject: [PATCH 2/5] =?UTF-8?q?:bug:=20Fix:=20=EB=82=A0=EC=A7=9C=20?= =?UTF-8?q?=EC=84=A0=ED=83=9D=EC=97=90=20=EB=94=B0=EB=A5=B8=20status=20?= =?UTF-8?q?=EB=B3=80=ED=99=94=20=EC=88=98=EC=A0=95=20=EC=99=84=EB=A3=8C=20?= =?UTF-8?q?(#177)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/@types/Retrospectives.ts | 2 +- .../createRetro/CreateButtonBox.tsx | 6 +++- .../createRetro/modal/CreateModal.tsx | 36 ++++++++++++++----- .../createRetro/modal/StartDateCalender.tsx | 27 +++++--------- 4 files changed, 42 insertions(+), 29 deletions(-) diff --git a/src/api/@types/Retrospectives.ts b/src/api/@types/Retrospectives.ts index 6357c5c..2d30cf3 100644 --- a/src/api/@types/Retrospectives.ts +++ b/src/api/@types/Retrospectives.ts @@ -64,7 +64,7 @@ export interface PostRetrospectivesRequest { templateId: number; status: keyof TStatus; thumbnail: string | null; - startDate: string; + startDate: Date | string; description: string; } diff --git a/src/components/createRetro/CreateButtonBox.tsx b/src/components/createRetro/CreateButtonBox.tsx index 466ade1..7bb88a7 100644 --- a/src/components/createRetro/CreateButtonBox.tsx +++ b/src/components/createRetro/CreateButtonBox.tsx @@ -1,5 +1,6 @@ import React, { useState } from 'react'; import { useDisclosure } from '@chakra-ui/react'; +import { TStatus } from '@/api/@types/@asConst'; import PersonalRetroCreateButton from '@/components/createRetro/PersonalRetroCreateButton'; import TeamRetroCreateButton from '@/components/createRetro/TeamRetroCreateButton'; import CreateModal from '@/components/createRetro/modal/CreateModal'; @@ -9,16 +10,19 @@ const CreateButtonBox: React.FC = () => { const { isOpen, onOpen, onClose } = useDisclosure(); const [templateId, setTemplateId] = useState(null); const [type, setType] = useState<'TEAM' | 'PERSONAL'>('TEAM'); + const [status, setStatus] = useState('NOT_STARTED'); const handleTeamButtonClick = () => { setTemplateId(1); setType('TEAM'); // TEAM으로 type 설정 + setStatus('NOT_STARTED'); // 초기 상태 onOpen(); }; const handlePersonalButtonClick = () => { setTemplateId(2); setType('PERSONAL'); // PERSONAL로 type 설정 + setStatus('NOT_STARTED'); // 초기 상태 onOpen(); }; @@ -32,7 +36,7 @@ const CreateButtonBox: React.FC = () => { - + ); }; diff --git a/src/components/createRetro/modal/CreateModal.tsx b/src/components/createRetro/modal/CreateModal.tsx index 5db3192..0cd91b5 100644 --- a/src/components/createRetro/modal/CreateModal.tsx +++ b/src/components/createRetro/modal/CreateModal.tsx @@ -9,7 +9,7 @@ import { ModalCloseButton, Button, } from '@chakra-ui/react'; -import { Status, TRetrospective } from '@/api/@types/@asConst'; +import { TRetrospective, TStatus } from '@/api/@types/@asConst'; import { PostRetrospectivesRequest } from '@/api/@types/Retrospectives'; import postImageToS3 from '@/api/imageApi/postImageToS3'; import postRetrospective from '@/api/retrospectivesApi/postRetrospective'; @@ -25,9 +25,10 @@ interface CreateModalProps { onClose: () => void; templateId: number | null; type: keyof TRetrospective; + status: keyof TStatus; } -const CreateModal: React.FC = ({ isOpen, onClose, templateId, type }) => { +const CreateModal: React.FC = ({ isOpen, onClose, templateId, type, status }) => { const size = 'xl'; const navigate = useNavigate(); const [requestData, setRequestData] = useState({ @@ -35,9 +36,9 @@ const CreateModal: React.FC = ({ isOpen, onClose, templateId, type: type, userId: 1, templateId: templateId || 1, - status: Status.NOT_STARTED, + status: status, thumbnail: null, - startDate: '', + startDate: new Date(), description: '', }); @@ -46,15 +47,30 @@ const CreateModal: React.FC = ({ isOpen, onClose, templateId, ...prevData, templateId: templateId || 1, // templateId가 변경될 때마다 업데이트 type: type, + status: status, })); - }, [templateId, type]); + }, [templateId, type, status]); const handleCreateClick = async () => { try { + let calculatedStatus: keyof TStatus = 'NOT_STARTED'; // 기본값은 'NOT_STARTED'로 설정 + + // startDate 값이 오늘 이전이면 'IN_PROGRESS'로 설정 + const today = new Date(); + const startedDate = new Date(requestData.startDate); + // console.log(startedDate); + if (startedDate <= today) { + calculatedStatus = 'IN_PROGRESS'; + } + + const isoDateString = startedDate.toISOString(); + // console.log(isoDateString); + // 회고 생성 요청 전송 const retrospectiveResponse = await postRetrospective({ ...requestData, - status: Status.NOT_STARTED, + startDate: isoDateString, + status: calculatedStatus, // 계산된 status 값으로 설정 thumbnail: requestData.thumbnail || null, // thumbnail이 없으면 null을 전송 }); @@ -79,6 +95,11 @@ const CreateModal: React.FC = ({ isOpen, onClose, templateId, setRequestData({ ...requestData, templateId: selectedTemplateId }); }; + const handleStartDateChange = (startDate: Date) => { + console.log('startDate:', startDate); // startDate를 콘솔에 출력 + setRequestData({ ...requestData, startDate }); // startDate 상태 업데이트 + }; + return ( @@ -95,8 +116,7 @@ const CreateModal: React.FC = ({ isOpen, onClose, templateId, setRequestData({ ...requestData, title })} /> - - setRequestData({ ...requestData, startDate })} /> + diff --git a/src/components/createRetro/modal/StartDateCalender.tsx b/src/components/createRetro/modal/StartDateCalender.tsx index 76e482a..ed83313 100644 --- a/src/components/createRetro/modal/StartDateCalender.tsx +++ b/src/components/createRetro/modal/StartDateCalender.tsx @@ -1,31 +1,20 @@ -import React, { useState } from 'react'; -import { ko } from 'date-fns/locale/ko'; +import React from 'react'; +import { Input } from '@chakra-ui/react'; import 'react-datepicker/dist/react-datepicker.css'; -import * as S from '@/styles/createRetro/modal/StartDateCalendar.style'; import '@/styles/createRetro/modal/Calendar.css'; interface StartDateCalendarProps { - onDateChange: (dateString: string) => void; + onDateChange: (date: Date) => void; } const StartDateCalendar: React.FC = ({ onDateChange }) => { - const [selectedDate, setSelectedDate] = useState(new Date()); - - const handleDateChange = (date: Date) => { - setSelectedDate(date); - const isoDateString = date.toISOString(); // 백엔드 request body에 보낼 날짜 타입 - onDateChange(isoDateString); + const handleChange = (event: React.ChangeEvent) => { + const dateString = event.target.value; // 사용자가 입력한 날짜 문자열 + const selectedDate = new Date(dateString); // 문자열을 Date 객체로 변환 + onDateChange(selectedDate); // 부모 컴포넌트로 전달 }; - return ( - - ); + return ; }; export default StartDateCalendar; From 041b3975d0b07ff3748437dceec270bc56ede424 Mon Sep 17 00:00:00 2001 From: sunflower888 <84950772+sunflower888@users.noreply.github.com> Date: Sat, 20 Apr 2024 01:59:10 +0900 Subject: [PATCH 3/5] =?UTF-8?q?:sparkles:=20Feat=20:=20Survey=20API=20?= =?UTF-8?q?=EC=97=B0=EA=B2=B0=20(#180)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: geumbin --- src/api/@types/Survey.ts | 15 + src/api/axiosConfig.tsx | 2 +- src/api/survey/postSurvey.tsx | 13 + src/components/survey/AgeInput.tsx | 34 +- src/components/survey/CityRadio.tsx | 51 +- src/components/survey/GenderRadio.tsx | 19 +- src/components/survey/JobSelect.tsx | 19 +- src/components/survey/PathRadio.tsx | 42 +- src/components/survey/PurposeCheckbox.tsx | 102 ++- src/pages/SurveyPage.tsx | 86 +- yarn.lock | 926 ++++++++-------------- 11 files changed, 637 insertions(+), 672 deletions(-) create mode 100644 src/api/@types/Survey.ts create mode 100644 src/api/survey/postSurvey.tsx diff --git a/src/api/@types/Survey.ts b/src/api/@types/Survey.ts new file mode 100644 index 0000000..c5c02db --- /dev/null +++ b/src/api/@types/Survey.ts @@ -0,0 +1,15 @@ +// post +export interface PostSurveyRequest { + age: number; + gender: string; + occupation: string; + region: string; + source: string; + purpose: string; +} + +export interface PostSurveyResponse { + code: number; + message: string; + data: string; +} diff --git a/src/api/axiosConfig.tsx b/src/api/axiosConfig.tsx index 27b7b2b..e8d84d7 100644 --- a/src/api/axiosConfig.tsx +++ b/src/api/axiosConfig.tsx @@ -65,7 +65,7 @@ axiosInstance.interceptors.request.use( // 헤더에 토큰 추가 config.headers.Authorization = `Bearer ${authToken}`; - // console.log('헤더에 토큰 추가 확인', config.headers.Authorization); + console.log('헤더에 토큰 추가 확인', config.headers.Authorization); return config; } catch (err) { console.error('에러', err); diff --git a/src/api/survey/postSurvey.tsx b/src/api/survey/postSurvey.tsx new file mode 100644 index 0000000..ace0538 --- /dev/null +++ b/src/api/survey/postSurvey.tsx @@ -0,0 +1,13 @@ +import { PostSurveyRequest, PostSurveyResponse } from '../@types/Survey'; +import axiosInstance from '../axiosConfig'; + +// post 요청 +export const PostSurvey = async (requestData: PostSurveyRequest): Promise => { + try { + const response = await axiosInstance.post('/surveys/response', requestData); + console.log('설문조사 전송 성공', response.data); + return response.data; + } catch (error) { + throw new Error('실패'); + } +}; diff --git a/src/components/survey/AgeInput.tsx b/src/components/survey/AgeInput.tsx index 5f9d47c..2a182b8 100644 --- a/src/components/survey/AgeInput.tsx +++ b/src/components/survey/AgeInput.tsx @@ -1,4 +1,4 @@ -import React from 'react'; +import React, { useState } from 'react'; import { NumberInput, NumberInputField, @@ -9,7 +9,31 @@ import { } from '@chakra-ui/react'; import * as S from '@/styles/survey/AgeInput.style'; -const AgeInput: React.FC = () => { +interface Age { + onAgeChange: (age: string) => void; +} + +const AgeInput: React.FC = ({ onAgeChange }) => { + const [age, setAge] = useState(''); + + const handleAgeChange = (event: React.ChangeEvent) => { + const newAge = event.target.value; + setAge(newAge); + onAgeChange(newAge); + }; + + const handleIncrement = () => { + const incrementedAge = parseInt(age) + 1; + setAge(String(incrementedAge)); + onAgeChange(String(incrementedAge)); + }; + + const handleDecrement = () => { + const decrementedAge = parseInt(age) - 1; + setAge(String(decrementedAge)); + onAgeChange(String(decrementedAge)); + }; + return ( <> @@ -17,10 +41,10 @@ const AgeInput: React.FC = () => { - + - - + + diff --git a/src/components/survey/CityRadio.tsx b/src/components/survey/CityRadio.tsx index 55d631a..18e1d4b 100644 --- a/src/components/survey/CityRadio.tsx +++ b/src/components/survey/CityRadio.tsx @@ -2,74 +2,83 @@ import React, { useState } from 'react'; import { Radio, RadioGroup, Stack, Text } from '@chakra-ui/react'; import * as S from '@/styles/survey/CityRadio.style'; -const CityRadio: React.FC = () => { - const [value, setValue] = useState('1'); +interface City { + onCityChange: (city: string) => void; +} + +const CityRadio: React.FC = ({ onCityChange }) => { + const [city, setCity] = useState('서울'); + const handleCityChange = (event: React.ChangeEvent) => { + const newCity = event.target.value; + setCity(newCity); + onCityChange(newCity); + }; return ( <> 귀하가 현재 거주하는 지역은 무엇입니까? - + - + 서울 - + 경기 - + 인천 - + 대전 - + 세종 - + 충남 - + 충북 - + 광주 - + 전남 - + 전북 - + 대구 - + 경북 - + 부산 - + 울산 - + 경남 - + 강원 - + 제주 - + 해외 diff --git a/src/components/survey/GenderRadio.tsx b/src/components/survey/GenderRadio.tsx index 5d7162a..88958ab 100644 --- a/src/components/survey/GenderRadio.tsx +++ b/src/components/survey/GenderRadio.tsx @@ -2,20 +2,29 @@ import React, { useState } from 'react'; import { Radio, RadioGroup, Stack, Text } from '@chakra-ui/react'; import * as S from '@/styles/survey/GenderRadio.style'; -const GenderRadio: React.FC = () => { - const [value, setValue] = useState('1'); +interface Gender { + onGenderChange: (age: string) => void; +} + +const GenderRadio: React.FC = ({ onGenderChange }) => { + const [gender, setGender] = useState('female'); + const handleGenderChange = (event: React.ChangeEvent) => { + const newGender = event.target.value; + setGender(newGender); + onGenderChange(newGender); + }; return ( <> 귀하의 성별은 어떻게 되십니까? - + - + 여성 - + 남성 diff --git a/src/components/survey/JobSelect.tsx b/src/components/survey/JobSelect.tsx index 988627f..44770ed 100644 --- a/src/components/survey/JobSelect.tsx +++ b/src/components/survey/JobSelect.tsx @@ -1,14 +1,25 @@ -import React from 'react'; +import React, { useState } from 'react'; import { Select, Text } from '@chakra-ui/react'; import * as S from '@/styles/survey/JobSelect.style'; -const JobSelect: React.FC = () => { +interface Job { + onJobChange: (job: string) => void; +} + +const JobSelect: React.FC = ({ onJobChange }) => { + const [job, setJob] = useState(''); + const handleJobChange = (event: React.ChangeEvent) => { + const newJob = event.target.value; + setJob(newJob); + onJobChange(newJob); + }; + return ( <> 귀하의 현재 직업은 무엇입니까? - @@ -22,7 +33,7 @@ const JobSelect: React.FC = () => { - + diff --git a/src/components/survey/PathRadio.tsx b/src/components/survey/PathRadio.tsx index c4cb7ac..9c5176a 100644 --- a/src/components/survey/PathRadio.tsx +++ b/src/components/survey/PathRadio.tsx @@ -2,38 +2,60 @@ import React, { useState } from 'react'; import { Radio, RadioGroup, Stack, Input, Text } from '@chakra-ui/react'; import * as S from '@/styles/survey/PathRadio.style'; -const PathRadio: React.FC = () => { - const [value, setValue] = useState('1'); +interface Path { + onPathChange: (path: string) => void; +} + +const PathRadio: React.FC = ({ onPathChange }) => { + const [path, setPath] = useState('블라인드'); + const [inputValue, setInputValue] = useState(''); // 입력값 상태 추가 + + const handlePathChange = (event: React.ChangeEvent) => { + const newPath = event.target.value; + setPath(newPath); + onPathChange(newPath); + }; + + const handleInputChange = (event: React.ChangeEvent) => { + setInputValue(event.target.value); + setPath('기타'); // 입력값이 변할 때, 경로를 '기타'로 설정 + onPathChange(event.target.value); // 경로를 '기타'로 설정 + }; return ( <> Past-Forward 서비스를 알게 된 경로는 무엇입니까? - + - + 블라인드 - + 에브리타임 - + 카카오톡 - + 인스타그램 - + 슬랙 - + 기타 - + diff --git a/src/components/survey/PurposeCheckbox.tsx b/src/components/survey/PurposeCheckbox.tsx index b03e6c5..bf76002 100644 --- a/src/components/survey/PurposeCheckbox.tsx +++ b/src/components/survey/PurposeCheckbox.tsx @@ -1,8 +1,38 @@ -import React from 'react'; +import React, { useState } from 'react'; import { Checkbox, Stack, Input, Text } from '@chakra-ui/react'; import * as S from '@/styles/survey/PurposeCheckbox.style'; -const PurposeCheckbox: React.FC = () => { +interface Purpose { + onPurposeChange: (purpose: string) => void; + onOtherPurposeChange: (otherPurpose: string) => void; + // onPurposeChange: (purpose: string[]) => void; +} + +const PurposeCheckbox: React.FC = ({ onPurposeChange, onOtherPurposeChange }) => { + const [checkedPurposes, setCheckedPurposes] = useState([]); + + const handlePurposeChange = (event: React.ChangeEvent) => { + const isChecked = event.target.checked; + const purpose = event.target.value; + let updatedPurposes: string[]; + + if (isChecked) { + updatedPurposes = [...checkedPurposes, purpose]; // 체크된 경우 배열에 추가 + } else { + updatedPurposes = checkedPurposes.filter(item => item !== purpose); // 체크 해제된 경우 배열에서 제거 + } + + setCheckedPurposes(updatedPurposes); // 최종 업데이트 한번만 수행 + onPurposeChange(updatedPurposes.join(', ')); // 선택된 목적들을 문자열로 변환하여 전달 + }; + + const [otherPurpose, setOtherPurpose] = useState(''); + const handleOtherPurposeChange = (event: React.ChangeEvent) => { + const newOtherPurpose = event.target.value; + setOtherPurpose(newOtherPurpose); + onOtherPurposeChange(newOtherPurpose); + }; + return ( <> @@ -11,15 +41,30 @@ const PurposeCheckbox: React.FC = () => { - 업무 목적 - 개인 발전 - 팀 협업 - 프로젝트 관리 - 학습 및 개선 + + 업무 목적 + + + 개인 발전 + + + 팀 협업 + + + 프로젝트 관리 + + + 학습 및 개선 + 기타 - + @@ -29,3 +74,44 @@ const PurposeCheckbox: React.FC = () => { }; export default PurposeCheckbox; + +// import React from 'react'; +// import { Checkbox, Stack, Input, Text } from '@chakra-ui/react'; +// import * as S from '@/styles/survey/PurposeCheckbox.style'; + +// interface Purpose { +// onPurposeChange: (city: string) => void; +// } + +// const PurposeCheckbox: React.FC = ({ onPurposeChange }) => { +// const [purpose, setPurpose] = useState('서울'); +// const handlePurposeChange = (event: React.ChangeEvent) => { +// const newPurpose = event.target.value; +// setPurpose(newPurpose); +// onPurposeChange(newPurpose); +// }; + +// return ( +// <> +// +// Past-Forward 서비스를 알게 된 경로는 무엇입니까? +// (복수 선택 가능) +// +// +// +// 업무 목적 +// 개인 발전 +// 팀 협업 +// 프로젝트 관리 +// 학습 및 개선 +// +// +// 기타 +// +// +// +// +// +// +// ); +// }; diff --git a/src/pages/SurveyPage.tsx b/src/pages/SurveyPage.tsx index 0710627..7e3403d 100644 --- a/src/pages/SurveyPage.tsx +++ b/src/pages/SurveyPage.tsx @@ -1,5 +1,6 @@ -import React, { useEffect } from 'react'; +import React, { useState, useEffect } from 'react'; import { Text, Button, Divider } from '@chakra-ui/react'; +// import { PostSurvey } from '@/api/survey/postSurvey'; import AgeInput from '@/components/survey/AgeInput'; import CityRadio from '@/components/survey/CityRadio'; import GenderRadio from '@/components/survey/GenderRadio'; @@ -12,6 +13,75 @@ const SurveyPage: React.FC = () => { useEffect(() => { localStorage.setItem('surveyVisited', 'true'); }, []); + + const handleSurveyButtonClick = () => { + handleSurvey(); + }; + + const handleSurvey = async () => { + try { + // + path 기타 + purpose 기타 + purpose 복수 답안 + 직업 value + console.log( + '나이는:', + age, + '/성별은:', + gender, + '/직업은:', + job, + '/지역은:', + city, + '/경로는:', + path, + '/목적은(복수선택):', + purpose, + '/기타 목적은:', + otherPurpose, + ); + // const SurveyRequest = await PostSurvey({ + // age: age, + // gender: gender, + // occupation: job, + // region: city, + // source: path, + // purpose: purpose, + // otherPurpose: otherPurpose + // }); + // console.log('설문조사 전송 성공', SurveyRequest); + // alert('설문조사가 전송되었습니다.'); + } catch (error) { + console.error('실패입니다.', error); + } + }; + + const [age, setAge] = useState(''); + const [gender, setGender] = useState('female'); + const [job, setJob] = useState(''); + const [city, setCity] = useState('서울'); + const [path, setPath] = useState(''); + const [purpose, setPurpose] = useState(); + const [otherPurpose, setOtherPurpose] = useState(); + + const handleAgeChange = (age: string) => { + setAge(age); + }; + const handleGenderChange = (gender: string) => { + setGender(gender); + }; + const handleJobChange = (job: string) => { + setJob(job); + }; + const handleCityChange = (city: string) => { + setCity(city); + }; + const handlePathChange = (path: string) => { + setPath(path); + }; + const handlePurposeChange = (purpose: string) => { + setPurpose(purpose); + }; + const handleOtherPurposeChange = (otherPurpose: string) => { + setOtherPurpose(otherPurpose); + }; return ( <> @@ -19,18 +89,18 @@ const SurveyPage: React.FC = () => { 설문조사 - + - + - + - + - + - - diff --git a/yarn.lock b/yarn.lock index 0ca6a8d..c66fe10 100644 --- a/yarn.lock +++ b/yarn.lock @@ -56,14 +56,14 @@ "@aws-amplify/api-rest" "4.0.27" tslib "^2.5.0" -"@aws-amplify/auth@^6.0.27", "@aws-amplify/auth@6.0.27": +"@aws-amplify/auth@6.0.27", "@aws-amplify/auth@^6.0.27": version "6.0.27" resolved "https://registry.npmjs.org/@aws-amplify/auth/-/auth-6.0.27.tgz" integrity sha512-qhoPTPuvErX7EIDcwM0u8Jt4PipJcohc9Y+veEm9sV9SP2Sop37RubpiaDaQhXnFcKvB0wTYknUTZvs3TujHRw== dependencies: tslib "^2.5.0" -"@aws-amplify/core@^6.0.0", "@aws-amplify/core@6.0.27": +"@aws-amplify/core@6.0.27": version "6.0.27" resolved "https://registry.npmjs.org/@aws-amplify/core/-/core-6.0.27.tgz" integrity sha512-S3IF2s6Qo+PGOXkWt0BiWwCHajImBJUhfcLi65D63mBi92gIL07310u5EZj+2RC4NzO/eSVNt3FNGR7EYCLAng== @@ -157,21 +157,6 @@ style-dictionary "3.9.1" tslib "^2.5.2" -"@aws-cdk/asset-awscli-v1@^2.2.202": - version "2.2.202" - resolved "https://registry.npmjs.org/@aws-cdk/asset-awscli-v1/-/asset-awscli-v1-2.2.202.tgz" - integrity sha512-JqlF0D4+EVugnG5dAsNZMqhu3HW7ehOXm5SDMxMbXNDMdsF0pxtQKNHRl52z1U9igsHmaFpUgSGjbhAJ+0JONg== - -"@aws-cdk/asset-kubectl-v20@^2.1.2": - version "2.1.2" - resolved "https://registry.npmjs.org/@aws-cdk/asset-kubectl-v20/-/asset-kubectl-v20-2.1.2.tgz" - integrity sha512-3M2tELJOxQv0apCIiuKQ4pAbncz9GuLwnKFqxifWfe77wuMxyTRPmxssYHs42ePqzap1LT6GDcPygGs+hHstLg== - -"@aws-cdk/asset-node-proxy-agent-v6@^2.0.1": - version "2.0.3" - resolved "https://registry.npmjs.org/@aws-cdk/asset-node-proxy-agent-v6/-/asset-node-proxy-agent-v6-2.0.3.tgz" - integrity sha512-twhuEG+JPOYCYPx/xy5uH2+VUsIEhPTzDY0F1KuB+ocjWWB/KEDiOVL19nHvbPCB6fhWnkykXEMJ4HHcKvjtvg== - "@aws-crypto/crc32@3.0.0": version "3.0.0" resolved "https://registry.npmjs.org/@aws-crypto/crc32/-/crc32-3.0.0.tgz" @@ -202,7 +187,7 @@ "@aws-sdk/util-utf8-browser" "^3.0.0" tslib "^1.11.1" -"@aws-crypto/sha256-js@^3.0.0", "@aws-crypto/sha256-js@3.0.0": +"@aws-crypto/sha256-js@3.0.0", "@aws-crypto/sha256-js@^3.0.0": version "3.0.0" resolved "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-3.0.0.tgz" integrity sha512-PnNN7os0+yd1XvXAy23CFOmTbMaDxgxXtTKHybrJ39Y8kGzBATgBFibWJKH6BhytLI/Zyszs87xCOBNyBig6vQ== @@ -638,14 +623,6 @@ "@smithy/util-utf8" "^2.0.0" tslib "^2.5.0" -"@aws-sdk/types@^3.222.0", "@aws-sdk/types@3.398.0": - version "3.398.0" - resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.398.0.tgz" - integrity sha512-r44fkS+vsEgKCuEuTV+TIk0t0m5ZlXHNjSDYEUvzLStbbfUFiNus/YG4UCa0wOk9R7VuQI67badsvvPeVPCGDQ== - dependencies: - "@smithy/types" "^2.2.2" - tslib "^2.5.0" - "@aws-sdk/types@3.387.0": version "3.387.0" resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.387.0.tgz" @@ -654,6 +631,14 @@ "@smithy/types" "^2.1.0" tslib "^2.5.0" +"@aws-sdk/types@3.398.0", "@aws-sdk/types@^3.222.0": + version "3.398.0" + resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.398.0.tgz" + integrity sha512-r44fkS+vsEgKCuEuTV+TIk0t0m5ZlXHNjSDYEUvzLStbbfUFiNus/YG4UCa0wOk9R7VuQI67badsvvPeVPCGDQ== + dependencies: + "@smithy/types" "^2.2.2" + tslib "^2.5.0" + "@aws-sdk/util-endpoints@3.398.0": version "3.398.0" resolved "https://registry.npmjs.org/@aws-sdk/util-endpoints/-/util-endpoints-3.398.0.tgz" @@ -709,7 +694,7 @@ resolved "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz" integrity sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw== -"@babel/core@^7.0.0", "@babel/core@^7.0.0-0", "@babel/core@^7.0.0-0 || ^8.0.0-0 <8.0.0", "@babel/core@^7.12.0", "@babel/core@^7.13.0", "@babel/core@^7.21.3", "@babel/core@^7.23.9", "@babel/core@^7.4.0 || ^8.0.0-0 <8.0.0": +"@babel/core@^7.21.3", "@babel/core@^7.23.9": version "7.23.9" resolved "https://registry.npmjs.org/@babel/core/-/core-7.23.9.tgz" integrity sha512-5q0175NOjddqpvvzU+kDiSOAk4PfdO6FvwCWoQ6RO7rTzEe8vlo+4HVfcnAREhD4npMs0e9uZypjTwzZPCf/cw== @@ -1667,28 +1652,7 @@ resolved "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz" integrity sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA== -"@babel/runtime@^7.0.0": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.12.0": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.12.13": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.12.5": +"@babel/runtime@^7.0.0", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.18.3", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.4", "@babel/runtime@^7.8.7": version "7.23.9" resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== @@ -1702,34 +1666,6 @@ dependencies: regenerator-runtime "^0.14.0" -"@babel/runtime@^7.18.3": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.5.5": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.8.4": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.8.7": - version "7.23.9" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz" - integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== - dependencies: - regenerator-runtime "^0.14.0" - "@babel/template@^7.22.15", "@babel/template@^7.23.9": version "7.23.9" resolved "https://registry.npmjs.org/@babel/template/-/template-7.23.9.tgz" @@ -1764,9 +1700,6 @@ "@babel/helper-validator-identifier" "^7.22.20" to-fast-properties "^2.0.0" -"@balena/dockerignore@^1.0.2": - version "1.0.2" - "@bundled-es-modules/cookie@^2.0.0": version "2.0.0" resolved "https://registry.npmjs.org/@bundled-es-modules/cookie/-/cookie-2.0.0.tgz" @@ -2439,7 +2372,7 @@ "@chakra-ui/react-context" "2.1.0" "@chakra-ui/shared-utils" "2.0.5" -"@chakra-ui/styled-system@>=2.0.0", "@chakra-ui/styled-system@>=2.8.0", "@chakra-ui/styled-system@2.9.2": +"@chakra-ui/styled-system@2.9.2": version "2.9.2" resolved "https://registry.npmjs.org/@chakra-ui/styled-system/-/styled-system-2.9.2.tgz" integrity sha512-To/Z92oHpIE+4nk11uVMWqo2GGRS86coeMmjxtpnErmWRdLcp1WVCVRAvn+ZwpLiNR+reWFr2FFqJRsREuZdAg== @@ -2456,7 +2389,7 @@ "@chakra-ui/checkbox" "2.3.2" "@chakra-ui/shared-utils" "2.0.5" -"@chakra-ui/system@>=2.0.0", "@chakra-ui/system@2.6.2": +"@chakra-ui/system@2.6.2": version "2.6.2" resolved "https://registry.npmjs.org/@chakra-ui/system/-/system-2.6.2.tgz" integrity sha512-EGtpoEjLrUu4W1fHD+a62XR+hzC5YfsWm+6lO0Kybcga3yYEij9beegO0jZgug27V+Rf7vns95VPVP6mFd/DEQ== @@ -2637,7 +2570,7 @@ resolved "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.1.tgz" integrity sha512-gJB6HLm5rYwSLI6PQa+X1t5CFGrv1J1TWG+sOyMCeKz2ojaj6Fnl/rZEspogG+cvqbt4AE/2eIyD2QfLKTBNlQ== -"@emotion/is-prop-valid@*", "@emotion/is-prop-valid@^1.2.1", "@emotion/is-prop-valid@1.2.1": +"@emotion/is-prop-valid@1.2.1", "@emotion/is-prop-valid@^1.2.1": version "1.2.1" resolved "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.2.1.tgz" integrity sha512-61Mf7Ufx4aDxx1xlDeOm8aFFigGHE4z+0sKCa+IHCeZKiyP9RLD0Mmx7m8b9/Cf37f7NAvQOOJAbQQGVr5uERw== @@ -2649,7 +2582,7 @@ resolved "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.1.tgz" integrity sha512-W2P2c/VRW1/1tLox0mVUalvnWXxavmv/Oum2aPsRcoDJuob75FC3Y8FbpfLwUegRcxINtGUMPq0tFCvYNTBXNA== -"@emotion/react@^11.0.0", "@emotion/react@^11.0.0-rc.0", "@emotion/react@^11.11.4", "@emotion/react@^11.8.1", "@emotion/react@>=10.0.35": +"@emotion/react@^11.11.4", "@emotion/react@^11.8.1": version "11.11.4" resolved "https://registry.npmjs.org/@emotion/react/-/react-11.11.4.tgz" integrity sha512-t8AjMlF0gHpvvxk5mAtCqR4vmxiGHCeJBaQO6gncUSdklELOgtwjerNY2yuJNfwnc6vi16U/+uMF+afIawJ9iw== @@ -2679,7 +2612,7 @@ resolved "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.2.2.tgz" integrity sha512-0QBtGvaqtWi+nx6doRwDdBIzhNdZrXUppvTM4dtZZWEGTXL/XE/yJxLMGlDT1Gt+UHH5IX1n+jkXyytE/av7OA== -"@emotion/styled@^11.0.0", "@emotion/styled@^11.11.0": +"@emotion/styled@^11.11.0": version "11.11.0" resolved "https://registry.npmjs.org/@emotion/styled/-/styled-11.11.0.tgz" integrity sha512-hM5Nnvu9P3midq5aaXj4I+lnSfNi7Pmd4EWk1fOZ3pxookaQTNew6bp4JaCBYM4HVFZF9g7UjJmsUmC2JlxOng== @@ -2691,16 +2624,16 @@ "@emotion/use-insertion-effect-with-fallbacks" "^1.0.1" "@emotion/utils" "^1.2.1" -"@emotion/unitless@^0.8.1": - version "0.8.1" - resolved "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.1.tgz" - integrity sha512-KOEGMu6dmJZtpadb476IsZBclKvILjopjUii3V+7MnXIQCYh8W3NgNcgwo21n9LXZX6EDIKvqfjYxXebDwxKmQ== - "@emotion/unitless@0.8.0": version "0.8.0" resolved "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.0.tgz" integrity sha512-VINS5vEYAscRl2ZUDiT3uMPlrFQupiKgHz5AA4bCH1miKBg4qtwkim1qPmJj/4WG6TreYMY111rEFsjupcOKHw== +"@emotion/unitless@^0.8.1": + version "0.8.1" + resolved "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.1.tgz" + integrity sha512-KOEGMu6dmJZtpadb476IsZBclKvILjopjUii3V+7MnXIQCYh8W3NgNcgwo21n9LXZX6EDIKvqfjYxXebDwxKmQ== + "@emotion/use-insertion-effect-with-fallbacks@^1.0.1": version "1.0.1" resolved "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.0.1.tgz" @@ -2775,13 +2708,6 @@ "@floating-ui/core" "^1.0.0" "@floating-ui/utils" "^0.2.0" -"@floating-ui/react-dom@^2.0.8": - version "2.0.8" - resolved "https://registry.npmjs.org/@floating-ui/react-dom/-/react-dom-2.0.8.tgz" - integrity sha512-HOdqOt3R3OGeTKidaLvJKcgg75S6tibQ3Tif4eyd91QnIJWr0NLvoXFpJA/j8HqkFSL68GDca9AuyWEHlhyClw== - dependencies: - "@floating-ui/dom" "^1.6.1" - "@floating-ui/react-dom@0.7.2": version "0.7.2" resolved "https://registry.npmjs.org/@floating-ui/react-dom/-/react-dom-0.7.2.tgz" @@ -2790,6 +2716,13 @@ "@floating-ui/dom" "^0.5.3" use-isomorphic-layout-effect "^1.1.1" +"@floating-ui/react-dom@^2.0.8": + version "2.0.8" + resolved "https://registry.npmjs.org/@floating-ui/react-dom/-/react-dom-2.0.8.tgz" + integrity sha512-HOdqOt3R3OGeTKidaLvJKcgg75S6tibQ3Tif4eyd91QnIJWr0NLvoXFpJA/j8HqkFSL68GDca9AuyWEHlhyClw== + dependencies: + "@floating-ui/dom" "^1.6.1" + "@floating-ui/react@^0.26.2": version "0.26.9" resolved "https://registry.npmjs.org/@floating-ui/react/-/react-0.26.9.tgz" @@ -2900,14 +2833,6 @@ resolved "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz" integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== -"@jridgewell/trace-mapping@^0.3.17", "@jridgewell/trace-mapping@^0.3.20", "@jridgewell/trace-mapping@^0.3.9": - version "0.3.23" - resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.23.tgz" - integrity sha512-9/4foRoUKp8s96tSkh8DlAAc5A0Ty8vLXld+l9gjKKY6ckwI8G15f0hskGmuLZu78ZlGa1vtsfOa+lnB4vG6Jg== - dependencies: - "@jridgewell/resolve-uri" "^3.1.0" - "@jridgewell/sourcemap-codec" "^1.4.14" - "@jridgewell/trace-mapping@0.3.9": version "0.3.9" resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz" @@ -2916,6 +2841,14 @@ "@jridgewell/resolve-uri" "^3.0.3" "@jridgewell/sourcemap-codec" "^1.4.10" +"@jridgewell/trace-mapping@^0.3.17", "@jridgewell/trace-mapping@^0.3.20", "@jridgewell/trace-mapping@^0.3.9": + version "0.3.23" + resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.23.tgz" + integrity sha512-9/4foRoUKp8s96tSkh8DlAAc5A0Ty8vLXld+l9gjKKY6ckwI8G15f0hskGmuLZu78ZlGa1vtsfOa+lnB4vG6Jg== + dependencies: + "@jridgewell/resolve-uri" "^3.1.0" + "@jridgewell/sourcemap-codec" "^1.4.14" + "@leichtgewicht/ip-codec@^2.0.1": version "2.0.4" resolved "https://registry.npmjs.org/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz" @@ -2946,7 +2879,7 @@ "@nodelib/fs.stat" "2.0.5" run-parallel "^1.1.9" -"@nodelib/fs.stat@^2.0.2", "@nodelib/fs.stat@2.0.5": +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": version "2.0.5" resolved "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz" integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== @@ -2987,7 +2920,7 @@ resolved "https://registry.npmjs.org/@pkgr/core/-/core-0.1.1.tgz" integrity sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA== -"@popperjs/core@^2.11.8", "@popperjs/core@^2.9.3": +"@popperjs/core@^2.9.3": version "2.11.8" resolved "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz" integrity sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A== @@ -3623,13 +3556,6 @@ "@smithy/types" "^2.12.0" tslib "^2.6.2" -"@smithy/util-hex-encoding@^2.2.0": - version "2.2.0" - resolved "https://registry.npmjs.org/@smithy/util-hex-encoding/-/util-hex-encoding-2.2.0.tgz" - integrity sha512-7iKXR+/4TpLK194pVjKiasIyqMtTYJsgKgM242Y9uzt5dhHnUDvMNb+3xIhRJ9QhvqGii/5cRUt4fJn3dtXNHQ== - dependencies: - tslib "^2.6.2" - "@smithy/util-hex-encoding@2.0.0": version "2.0.0" resolved "https://registry.npmjs.org/@smithy/util-hex-encoding/-/util-hex-encoding-2.0.0.tgz" @@ -3637,6 +3563,13 @@ dependencies: tslib "^2.5.0" +"@smithy/util-hex-encoding@^2.2.0": + version "2.2.0" + resolved "https://registry.npmjs.org/@smithy/util-hex-encoding/-/util-hex-encoding-2.2.0.tgz" + integrity sha512-7iKXR+/4TpLK194pVjKiasIyqMtTYJsgKgM242Y9uzt5dhHnUDvMNb+3xIhRJ9QhvqGii/5cRUt4fJn3dtXNHQ== + dependencies: + tslib "^2.6.2" + "@smithy/util-middleware@^2.0.0", "@smithy/util-middleware@^2.2.0": version "2.2.0" resolved "https://registry.npmjs.org/@smithy/util-middleware/-/util-middleware-2.2.0.tgz" @@ -3675,14 +3608,6 @@ dependencies: tslib "^2.6.2" -"@smithy/util-utf8@^2.0.0", "@smithy/util-utf8@^2.3.0": - version "2.3.0" - resolved "https://registry.npmjs.org/@smithy/util-utf8/-/util-utf8-2.3.0.tgz" - integrity sha512-R8Rdn8Hy72KKcebgLiv8jQcQkXoLMOGGv5uI1/k0l+snqkOzQ1R0ChUBCxWMlBsFMekWjq0wRudIweFs7sKT5A== - dependencies: - "@smithy/util-buffer-from" "^2.2.0" - tslib "^2.6.2" - "@smithy/util-utf8@2.0.0": version "2.0.0" resolved "https://registry.npmjs.org/@smithy/util-utf8/-/util-utf8-2.0.0.tgz" @@ -3691,6 +3616,14 @@ "@smithy/util-buffer-from" "^2.0.0" tslib "^2.5.0" +"@smithy/util-utf8@^2.0.0", "@smithy/util-utf8@^2.3.0": + version "2.3.0" + resolved "https://registry.npmjs.org/@smithy/util-utf8/-/util-utf8-2.3.0.tgz" + integrity sha512-R8Rdn8Hy72KKcebgLiv8jQcQkXoLMOGGv5uI1/k0l+snqkOzQ1R0ChUBCxWMlBsFMekWjq0wRudIweFs7sKT5A== + dependencies: + "@smithy/util-buffer-from" "^2.2.0" + tslib "^2.6.2" + "@smithy/util-waiter@^2.0.5": version "2.2.0" resolved "https://registry.npmjs.org/@smithy/util-waiter/-/util-waiter-2.2.0.tgz" @@ -3770,7 +3703,7 @@ glob "^8.0.3" snake-case "^3.0.4" -"@svgr/core@*", "@svgr/core@8.1.0": +"@svgr/core@8.1.0": version "8.1.0" resolved "https://registry.npmjs.org/@svgr/core/-/core-8.1.0.tgz" integrity sha512-8QqtOQT5ACVlmsvKOJNEaWmRPmcojMOzCz4Hs2BGG/toAp/K38LcsMRyLp349glq5AzJbCEeimEoxaX6v/fLrA== @@ -3884,7 +3817,7 @@ "@types/eslint" "*" "@types/estree" "*" -"@types/eslint@*", "@types/eslint@>=8.0.0": +"@types/eslint@*": version "8.56.3" resolved "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.3.tgz" integrity sha512-PvSf1wfv2wJpVIFUMSb+i4PvqNYkB9Rkp9ZDO3oaWzq4SKhsQk4mrMBr3ZH06I0hKrVGLBacmgl8JM4WVjb9dg== @@ -3907,7 +3840,7 @@ "@types/range-parser" "*" "@types/send" "*" -"@types/express@*", "@types/express@^4.17.13", "@types/express@^4.17.21": +"@types/express@*", "@types/express@^4.17.21": version "4.17.21" resolved "https://registry.npmjs.org/@types/express/-/express-4.17.21.tgz" integrity sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ== @@ -4051,7 +3984,7 @@ dependencies: "@types/react" "*" -"@types/react@*", "@types/react@^16.8.0 || ^17.0.0 || ^18.0.0", "@types/react@^16.9.0 || ^17.0.0 || ^18.0.0", "@types/react@^18.2.58": +"@types/react@*", "@types/react@^18.2.58": version "18.2.58" resolved "https://registry.npmjs.org/@types/react/-/react-18.2.58.tgz" integrity sha512-TaGvMNhxvG2Q0K0aYxiKfNDS5m5ZsoIBBbtfUorxdH4NGSXIlYvZxLJI+9Dd3KjeB3780bciLyAb7ylO8pLhPw== @@ -4138,7 +4071,7 @@ dependencies: "@types/node" "*" -"@typescript-eslint/eslint-plugin@^7.0.2", "@typescript-eslint/eslint-plugin@6 - 7": +"@typescript-eslint/eslint-plugin@^7.0.2": version "7.0.2" resolved "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.0.2.tgz" integrity sha512-/XtVZJtbaphtdrWjr+CJclaCVGPtOdBpFEnvtNf/jRV0IiEemRrL0qABex/nEt8isYcnFacm3nPHYQwL+Wb7qg== @@ -4155,7 +4088,7 @@ semver "^7.5.4" ts-api-utils "^1.0.1" -"@typescript-eslint/parser@^7.0.0", "@typescript-eslint/parser@^7.0.2": +"@typescript-eslint/parser@^7.0.2": version "7.0.2" resolved "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.0.2.tgz" integrity sha512-GdwfDglCxSmU+QTS9vhz2Sop46ebNCXpPPvsByK7hu0rFGRHL+AusKQJ7SoN+LbLh6APFpQwHKmDSwN35Z700Q== @@ -4229,7 +4162,7 @@ resolved "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz" integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== -"@webassemblyjs/ast@^1.11.5", "@webassemblyjs/ast@1.11.6": +"@webassemblyjs/ast@1.11.6", "@webassemblyjs/ast@^1.11.5": version "1.11.6" resolved "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.6.tgz" integrity sha512-IN1xI7PwOvLPgjcf180gC1bqn3q/QaOCwYUahIOhbYUu8KA/3tw2RT/T0Gidi1l7Hhj5D/INhJxiICObqpMu4Q== @@ -4330,7 +4263,7 @@ "@webassemblyjs/wasm-gen" "1.11.6" "@webassemblyjs/wasm-parser" "1.11.6" -"@webassemblyjs/wasm-parser@^1.11.5", "@webassemblyjs/wasm-parser@1.11.6": +"@webassemblyjs/wasm-parser@1.11.6", "@webassemblyjs/wasm-parser@^1.11.5": version "1.11.6" resolved "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.6.tgz" integrity sha512-6ZwPeGzMJM3Dqp3hCsLgESxBGtT/OeCvCZ4TA1JUPYgmhAx38tTPR9JaKy0S5H3evQpO/h2uWs2j6Yc/fjkpTQ== @@ -4428,7 +4361,7 @@ acorn@^3.0.0: resolved "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz" integrity sha512-OLUyIIZ7mF5oaAUT1w0TFqQS81q3saT46x8t7ukpPjMNk+nbs4ZHhs7ToV8EWnLYLepjETXd4XaCE4uxkMeqUw== -"acorn@^6.0.0 || ^7.0.0 || ^8.0.0", acorn@^8, acorn@^8.4.1, acorn@^8.7.1, acorn@^8.8.2, acorn@^8.9.0: +acorn@^8.4.1, acorn@^8.7.1, acorn@^8.8.2, acorn@^8.9.0: version "8.11.3" resolved "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz" integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== @@ -4452,7 +4385,7 @@ ajv-keywords@^5.1.0: dependencies: fast-deep-equal "^3.1.3" -ajv@^6.12.4, ajv@^6.12.5, ajv@^6.9.1: +ajv@^6.12.4, ajv@^6.12.5: version "6.12.6" resolved "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -4462,7 +4395,7 @@ ajv@^6.12.4, ajv@^6.12.5, ajv@^6.9.1: json-schema-traverse "^0.4.1" uri-js "^4.2.2" -ajv@^8.0.0, ajv@^8.8.2, ajv@^8.9.0: +ajv@^8.0.0, ajv@^8.9.0: version "8.12.0" resolved "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz" integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== @@ -4472,14 +4405,6 @@ ajv@^8.0.0, ajv@^8.8.2, ajv@^8.9.0: require-from-string "^2.0.2" uri-js "^4.2.2" -ajv@^8.0.1: - version "8.12.0" - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - align-text@^0.1.1, align-text@^0.1.3: version "0.1.4" resolved "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz" @@ -4547,12 +4472,7 @@ ansi-styles@^4.0.0, ansi-styles@^4.1.0: dependencies: color-convert "^2.0.1" -ansi-styles@^6.0.0: - version "6.2.1" - resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz" - integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug== - -ansi-styles@^6.1.0: +ansi-styles@^6.0.0, ansi-styles@^6.1.0: version "6.2.1" resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz" integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug== @@ -4755,9 +4675,6 @@ assign-symbols@^1.0.0: resolved "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz" integrity sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw== -astral-regex@^2.0.0: - version "2.0.0" - async-each@^1.0.0: version "1.0.6" resolved "https://registry.npmjs.org/async-each/-/async-each-1.0.6.tgz" @@ -4802,7 +4719,7 @@ available-typed-arrays@^1.0.6, available-typed-arrays@^1.0.7: dependencies: possible-typed-array-names "^1.0.0" -aws-amplify@^6.0.2, aws-amplify@^6.0.27: +aws-amplify@^6.0.27: version "6.0.28" resolved "https://registry.npmjs.org/aws-amplify/-/aws-amplify-6.0.28.tgz" integrity sha512-gxP/osZNDGb5skWUpka6XCTjAyMsWLMI6gGpIuehxzA4xZ8/V/lOcwy4yoY0UB6830zEh5Jw8AZOBBpBTgrdZQ== @@ -4816,26 +4733,6 @@ aws-amplify@^6.0.2, aws-amplify@^6.0.27: "@aws-amplify/storage" "6.0.27" tslib "^2.5.0" -aws-cdk-lib@^2.127.0: - version "2.137.0" - resolved "https://registry.npmjs.org/aws-cdk-lib/-/aws-cdk-lib-2.137.0.tgz" - integrity sha512-pD3AGdKBa8q1+vVWRabiDHuecVMlP8ERGPHc9Pb0dVlpbC/ODC6XXC1S0TAMsr0JI5Lh6pk4vL5cC+spsMeotw== - dependencies: - "@aws-cdk/asset-awscli-v1" "^2.2.202" - "@aws-cdk/asset-kubectl-v20" "^2.1.2" - "@aws-cdk/asset-node-proxy-agent-v6" "^2.0.1" - "@balena/dockerignore" "^1.0.2" - case "1.6.3" - fs-extra "^11.2.0" - ignore "^5.3.1" - jsonschema "^1.4.1" - mime-types "^2.1.35" - minimatch "^3.1.2" - punycode "^2.3.1" - semver "^7.6.0" - table "^6.8.2" - yaml "1.10.2" - axios@^1.6.8: version "1.6.8" resolved "https://registry.npmjs.org/axios/-/axios-1.6.8.tgz" @@ -5140,6 +5037,11 @@ balanced-match@^1.0.0: resolved "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== +base64-js@^1.0.2: + version "1.5.1" + resolved "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz" + integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + base@^0.11.1: version "0.11.2" resolved "https://registry.npmjs.org/base/-/base-0.11.2.tgz" @@ -5153,11 +5055,6 @@ base@^0.11.1: mixin-deep "^1.2.0" pascalcase "^0.1.1" -base64-js@^1.0.2: - version "1.5.1" - resolved "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz" - integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== - batch@0.6.1: version "0.6.1" resolved "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz" @@ -5292,7 +5189,7 @@ browserify-zlib@^0.1.4: dependencies: pako "~0.2.0" -browserslist@^4.21.10, browserslist@^4.22.2, browserslist@^4.22.3, "browserslist@>= 4.21.0": +browserslist@^4.21.10, browserslist@^4.22.2, browserslist@^4.22.3: version "4.23.0" resolved "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz" integrity sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ== @@ -5307,7 +5204,7 @@ buffer-from@^1.0.0: resolved "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz" integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== -buffer@^4.9.0, buffer@4.9.2: +buffer@4.9.2, buffer@^4.9.0: version "4.9.2" resolved "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz" integrity sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg== @@ -5411,9 +5308,6 @@ capital-case@^1.0.4: tslib "^2.0.3" upper-case-first "^2.0.2" -case@1.6.3: - version "1.6.3" - center-align@^0.1.1: version "0.1.3" resolved "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz" @@ -5422,6 +5316,11 @@ center-align@^0.1.1: align-text "^0.1.3" lazy-cache "^1.0.3" +chalk@5.3.0: + version "5.3.0" + resolved "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz" + integrity sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w== + chalk@^1.1.3: version "1.1.3" resolved "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz" @@ -5450,11 +5349,6 @@ chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: ansi-styles "^4.1.0" supports-color "^7.1.0" -chalk@5.3.0: - version "5.3.0" - resolved "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz" - integrity sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w== - change-case@^4.1.2: version "4.1.2" resolved "https://registry.npmjs.org/change-case/-/change-case-4.1.2.tgz" @@ -5626,16 +5520,16 @@ color-convert@^2.0.1: dependencies: color-name "~1.1.4" -color-name@~1.1.4: - version "1.1.4" - resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" - integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== - color-name@1.1.3: version "1.1.3" resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz" integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + color2k@^2.0.2: version "2.0.3" resolved "https://registry.npmjs.org/color2k/-/color2k-2.0.3.tgz" @@ -5653,6 +5547,11 @@ combined-stream@^1.0.8: dependencies: delayed-stream "~1.0.0" +commander@11.0.0: + version "11.0.0" + resolved "https://registry.npmjs.org/commander/-/commander-11.0.0.tgz" + integrity sha512-9HMlXtt/BNoYr8ooyjjNRdIilOTkVJXB+GhxMTtOKwk0R4j4lS4NpjuqmRxroBfnfTSHQIHQB7wryHhXarNjmQ== + commander@^10.0.1: version "10.0.1" resolved "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz" @@ -5678,11 +5577,6 @@ commander@^9.4.1: resolved "https://registry.npmjs.org/commander/-/commander-9.5.0.tgz" integrity sha512-KRs7WVDKg86PWiuAqhDrAQnTXZKraVcCc6vFdL14qrZ/DcWwuRo7VoiYXalXO7S5GKpqYiVEwCbgFDfxNHKJBQ== -commander@11.0.0: - version "11.0.0" - resolved "https://registry.npmjs.org/commander/-/commander-11.0.0.tgz" - integrity sha512-9HMlXtt/BNoYr8ooyjjNRdIilOTkVJXB+GhxMTtOKwk0R4j4lS4NpjuqmRxroBfnfTSHQIHQB7wryHhXarNjmQ== - common-path-prefix@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/common-path-prefix/-/common-path-prefix-3.0.0.tgz" @@ -5747,11 +5641,6 @@ constants-browserify@^1.0.0: resolved "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz" integrity sha512-xFxOwqIzR/e1k1gLiWEophSCMqXcwVHIH7akf7b/vxcUeGunlj3hvZaaqxwHsTgn+IndtkQJgSztIDWeumWJDQ== -constructs@^10.0.0: - version "10.3.0" - resolved "https://registry.npmjs.org/constructs/-/constructs-10.3.0.tgz" - integrity sha512-vbK8i3rIb/xwZxSpTjz3SagHn1qq9BChLEfy5Hf6fB3/2eFbrwt2n9kHwQcS0CPTRBesreeAcsJfMq2229FnbQ== - content-disposition@0.5.4: version "0.5.4" resolved "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz" @@ -5779,7 +5668,7 @@ cookie-signature@1.0.6: resolved "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== -cookie@^0.5.0, cookie@0.5.0: +cookie@0.5.0, cookie@^0.5.0: version "0.5.0" resolved "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz" integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== @@ -5953,16 +5842,16 @@ csso@^5.0.5: dependencies: css-tree "~2.2.0" -csstype@^3.0.2, csstype@^3.1.1, csstype@^3.1.2: - version "3.1.3" - resolved "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz" - integrity sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw== - csstype@3.1.2: version "3.1.2" resolved "https://registry.npmjs.org/csstype/-/csstype-3.1.2.tgz" integrity sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ== +csstype@^3.0.2, csstype@^3.1.1, csstype@^3.1.2: + version "3.1.3" + resolved "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz" + integrity sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw== + dashify@^2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/dashify/-/dashify-2.0.0.tgz" @@ -5978,26 +5867,19 @@ dayjs@^1.11.10: resolved "https://registry.npmjs.org/dayjs/-/dayjs-1.11.10.tgz" integrity sha512-vjAczensTgRcqDERK0SR2XMwsF/tSvnvlv6VcF2GIhg6Sx4yOIt/irsr1RDJsKiIyBzJDpCoXiWWq28MqH2cnQ== -debug@^2.2.0: - version "2.6.9" - resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - -debug@^2.3.3: +debug@2.6.9, debug@^2.2.0, debug@^2.3.3, debug@^2.6.8: version "2.6.9" resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== dependencies: ms "2.0.0" -debug@^2.6.8: - version "2.6.9" - resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== +debug@4.3.4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== dependencies: - ms "2.0.0" + ms "2.1.2" debug@^3.2.7: version "3.2.7" @@ -6006,20 +5888,6 @@ debug@^3.2.7: dependencies: ms "^2.1.1" -debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4, debug@4.3.4: - version "4.3.4" - resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" - integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== - dependencies: - ms "2.1.2" - -debug@2.6.9: - version "2.6.9" - resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - decamelize@^1.0.0, decamelize@^1.2.0: version "1.2.0" resolved "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz" @@ -6133,16 +6001,16 @@ delayed-stream@~1.0.0: resolved "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== -depd@~1.1.2: - version "1.1.2" - resolved "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz" - integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== - depd@2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz" integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== +depd@~1.1.2: + version "1.1.2" + resolved "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz" + integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== + destroy@1.2.0: version "1.2.0" resolved "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz" @@ -6372,12 +6240,7 @@ entities@^2.0.0: resolved "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz" integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== -entities@^4.2.0: - version "4.5.0" - resolved "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz" - integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== - -entities@^4.4.0: +entities@^4.2.0, entities@^4.4.0: version "4.5.0" resolved "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz" integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== @@ -6536,7 +6399,7 @@ escape-string-regexp@^4.0.0: resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz" integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== -eslint-config-prettier@*, eslint-config-prettier@^9.0.0: +eslint-config-prettier@^9.0.0: version "9.1.0" resolved "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz" integrity sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw== @@ -6637,14 +6500,6 @@ eslint-rule-composer@^0.3.0: resolved "https://registry.npmjs.org/eslint-rule-composer/-/eslint-rule-composer-0.3.0.tgz" integrity sha512-bt+Sh8CtDmn2OajxvNO+BX7Wn4CIWMpTRm3MaiKPCQcnnlm0CS2mhui6QaoeQugs+3Kj2ESKEEGJUdVafwhiCg== -eslint-scope@^7.2.2: - version "7.2.2" - resolved "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz" - integrity sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg== - dependencies: - esrecurse "^4.3.0" - estraverse "^5.2.0" - eslint-scope@5.1.1: version "5.1.1" resolved "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz" @@ -6653,14 +6508,22 @@ eslint-scope@5.1.1: esrecurse "^4.3.0" estraverse "^4.1.1" -eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1, eslint-visitor-keys@^3.4.3: - version "3.4.3" - resolved "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz" - integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== - -"eslint@^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8", "eslint@^3 || ^4 || ^5 || ^6 || ^7 || ^8", "eslint@^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0", "eslint@^6.0.0 || ^7.0.0 || >=8.0.0", "eslint@^7.0.0 || ^8.0.0", eslint@^8.50.0, eslint@^8.56.0, eslint@>=7, eslint@>=7.0.0, eslint@>=8.0.0, "eslint@6 || 7 || 8", eslint@8: - version "8.57.0" - resolved "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz" +eslint-scope@^7.2.2: + version "7.2.2" + resolved "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz" + integrity sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1, eslint-visitor-keys@^3.4.3: + version "3.4.3" + resolved "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz" + integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== + +eslint@^8.50.0: + version "8.57.0" + resolved "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz" integrity sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ== dependencies: "@eslint-community/eslint-utils" "^4.2.0" @@ -6765,21 +6628,6 @@ events@^3.2.0: resolved "https://registry.npmjs.org/events/-/events-3.3.0.tgz" integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== -execa@^5.0.0: - version "5.1.1" - resolved "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" - integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== - dependencies: - cross-spawn "^7.0.3" - get-stream "^6.0.0" - human-signals "^2.1.0" - is-stream "^2.0.0" - merge-stream "^2.0.0" - npm-run-path "^4.0.1" - onetime "^5.1.2" - signal-exit "^3.0.3" - strip-final-newline "^2.0.0" - execa@7.2.0: version "7.2.0" resolved "https://registry.npmjs.org/execa/-/execa-7.2.0.tgz" @@ -6795,6 +6643,21 @@ execa@7.2.0: signal-exit "^3.0.7" strip-final-newline "^3.0.0" +execa@^5.0.0: + version "5.1.1" + resolved "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" + integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + expand-brackets@^0.1.4: version "0.1.5" resolved "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz" @@ -6866,15 +6729,7 @@ extend-shallow@^2.0.1: dependencies: is-extendable "^0.1.0" -extend-shallow@^3.0.0: - version "3.0.2" - resolved "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz" - integrity sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q== - dependencies: - assign-symbols "^1.0.0" - is-extendable "^1.0.1" - -extend-shallow@^3.0.2: +extend-shallow@^3.0.0, extend-shallow@^3.0.2: version "3.0.2" resolved "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz" integrity sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q== @@ -6934,13 +6789,6 @@ fast-levenshtein@^2.0.6: resolved "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz" integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== -fast-xml-parser@^4.2.5: - version "4.3.6" - resolved "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-4.3.6.tgz" - integrity sha512-M2SovcRxD4+vC493Uc2GZVcZaj66CCJhWurC4viynVSTvrpErCShNcDz1lAho6n9REQKvL/ll4A4/fw6Y9z8nw== - dependencies: - strnum "^1.0.5" - fast-xml-parser@4.2.5: version "4.2.5" resolved "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-4.2.5.tgz" @@ -6948,6 +6796,13 @@ fast-xml-parser@4.2.5: dependencies: strnum "^1.0.5" +fast-xml-parser@^4.2.5: + version "4.3.6" + resolved "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-4.3.6.tgz" + integrity sha512-M2SovcRxD4+vC493Uc2GZVcZaj66CCJhWurC4viynVSTvrpErCShNcDz1lAho6n9REQKvL/ll4A4/fw6Y9z8nw== + dependencies: + strnum "^1.0.5" + fastest-levenshtein@^1.0.12: version "1.0.16" resolved "https://registry.npmjs.org/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz" @@ -7188,7 +7043,7 @@ fragment-cache@^0.2.1: dependencies: map-cache "^0.2.2" -framer-motion@^11.0.12, framer-motion@>=4.0.0: +framer-motion@^11.0.12: version "11.0.12" resolved "https://registry.npmjs.org/framer-motion/-/framer-motion-11.0.12.tgz" integrity sha512-1VW4pk+4EH8RwWHdqntWTwF9peranyHn/BczvMzF9TGh/FwMKxoRZzkig8Nak9BQA8GymfIyCGo5adXwRuXDXA== @@ -7216,13 +7071,6 @@ fs-extra@^10.0.0: jsonfile "^6.0.1" universalify "^2.0.0" -fs-extra@^11.2.0: - version "11.2.0" - dependencies: - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" @@ -7321,7 +7169,7 @@ glob-parent@^2.0.0: dependencies: is-glob "^2.0.0" -glob-parent@^5.1.2: +glob-parent@^5.1.2, glob-parent@~5.1.2: version "5.1.2" resolved "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== @@ -7335,13 +7183,6 @@ glob-parent@^6.0.2: dependencies: is-glob "^4.0.3" -glob-parent@~5.1.2: - version "5.1.2" - resolved "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" - integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== - dependencies: - is-glob "^4.0.1" - glob-to-regexp@^0.4.1: version "0.4.1" resolved "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz" @@ -7456,16 +7297,16 @@ graphemer@^1.4.0: resolved "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz" integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== -graphql@^16.8.1: - version "16.8.1" - resolved "https://registry.npmjs.org/graphql/-/graphql-16.8.1.tgz" - integrity sha512-59LZHPdGZVh695Ud9lRzPBVTtlX9ZCV150Er2W43ro37wVof0ctenSaskPPjN7lVTIN8mSZt8PHUNKZuNQUuxw== - graphql@15.8.0: version "15.8.0" resolved "https://registry.npmjs.org/graphql/-/graphql-15.8.0.tgz" integrity sha512-5gghUc24tP9HRznNpV2+FIoq3xKkj5dTQqf4v0CpdPbFVwFkWoxOM+o+2OC9ZSvjEMTjfmG9QT+gcvggTwW1zw== +graphql@^16.8.1: + version "16.8.1" + resolved "https://registry.npmjs.org/graphql/-/graphql-16.8.1.tgz" + integrity sha512-59LZHPdGZVh695Ud9lRzPBVTtlX9ZCV150Er2W43ro37wVof0ctenSaskPPjN7lVTIN8mSZt8PHUNKZuNQUuxw== + hamt_plus@1.0.2: version "1.0.2" resolved "https://registry.npmjs.org/hamt_plus/-/hamt_plus-1.0.2.tgz" @@ -7644,16 +7485,6 @@ http-deceiver@^1.2.7: resolved "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz" integrity sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw== -http-errors@~1.6.2: - version "1.6.3" - resolved "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz" - integrity sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A== - dependencies: - depd "~1.1.2" - inherits "2.0.3" - setprototypeof "1.1.0" - statuses ">= 1.4.0 < 2" - http-errors@2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz" @@ -7665,6 +7496,16 @@ http-errors@2.0.0: statuses "2.0.1" toidentifier "1.0.1" +http-errors@~1.6.2: + version "1.6.3" + resolved "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz" + integrity sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A== + dependencies: + depd "~1.1.2" + inherits "2.0.3" + setprototypeof "1.1.0" + statuses ">= 1.4.0 < 2" + http-parser-js@>=0.5.1: version "0.5.8" resolved "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz" @@ -7710,13 +7551,6 @@ husky@^9.0.11: resolved "https://registry.npmjs.org/husky/-/husky-9.0.11.tgz" integrity sha512-AB6lFlbwwyIqMdHYhwPe+kjOC3Oc5P3nThEoW/AaO2BX3vJDjWPFxYLxokUZOo6RNX20He3AaT8sESs9NJcmEw== -iconv-lite@^0.6.2: - version "0.6.3" - resolved "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz" - integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== - dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" - iconv-lite@0.4.24: version "0.4.24" resolved "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz" @@ -7724,6 +7558,13 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" +iconv-lite@^0.6.2: + version "0.6.3" + resolved "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz" + integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== + dependencies: + safer-buffer ">= 2.1.2 < 3.0.0" + icss-utils@^5.0.0, icss-utils@^5.1.0: version "5.1.0" resolved "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz" @@ -7744,9 +7585,6 @@ ignore@^5.2.0, ignore@^5.2.4: resolved "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz" integrity sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw== -ignore@^5.3.1: - version "5.3.1" - immer@9.0.6: version "9.0.6" resolved "https://registry.npmjs.org/immer/-/immer-9.0.6.tgz" @@ -7786,7 +7624,7 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3, inherits@2, inherits@2.0.4: +inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: version "2.0.4" resolved "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== @@ -7822,16 +7660,16 @@ invariant@^2.2.2, invariant@^2.2.4: dependencies: loose-envify "^1.0.0" -ipaddr.js@^2.1.0: - version "2.1.0" - resolved "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.1.0.tgz" - integrity sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ== - ipaddr.js@1.9.1: version "1.9.1" resolved "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz" integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== +ipaddr.js@^2.1.0: + version "2.1.0" + resolved "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.1.0.tgz" + integrity sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ== + is-accessor-descriptor@^1.0.1: version "1.0.1" resolved "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.1.tgz" @@ -8204,7 +8042,7 @@ is-wsl@^3.1.0: dependencies: is-inside-container "^1.0.0" -isarray@^1.0.0, isarray@~1.0.0, isarray@1.0.0: +isarray@1.0.0, isarray@^1.0.0, isarray@~1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== @@ -8356,9 +8194,6 @@ jsonfile@^6.0.1: optionalDependencies: graceful-fs "^4.1.6" -jsonschema@^1.4.1: - version "1.4.1" - "jsx-ast-utils@^2.4.1 || ^3.0.0": version "3.3.5" resolved "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz" @@ -8390,12 +8225,7 @@ kind-of@^4.0.0: dependencies: is-buffer "^1.1.5" -kind-of@^6.0.0: - version "6.0.3" - resolved "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz" - integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== - -kind-of@^6.0.2: +kind-of@^6.0.0, kind-of@^6.0.2: version "6.0.3" resolved "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz" integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== @@ -8524,10 +8354,7 @@ lodash.mergewith@4.6.2: resolved "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz" integrity sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ== -lodash.truncate@^4.4.2: - version "4.4.2" - -lodash@^4.17.15, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.4, lodash@4.17.21: +lodash@4.17.21, lodash@^4.17.15, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.4: version "4.17.21" resolved "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== @@ -8663,6 +8490,14 @@ methods@~1.1.2: resolved "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== +micromatch@4.0.5, micromatch@^4.0.0, micromatch@^4.0.2, micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + micromatch@^2.1.5: version "2.3.11" resolved "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz" @@ -8701,15 +8536,7 @@ micromatch@^3.1.10: snapdragon "^0.8.1" to-regex "^3.0.2" -micromatch@^4.0.0, micromatch@^4.0.2, micromatch@^4.0.4, micromatch@4.0.5: - version "4.0.5" - resolved "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz" - integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== - dependencies: - braces "^3.0.2" - picomatch "^2.3.1" - -"mime-db@>= 1.43.0 < 2", mime-db@1.52.0: +mime-db@1.52.0, "mime-db@>= 1.43.0 < 2": version "1.52.0" resolved "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz" integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== @@ -8721,11 +8548,6 @@ mime-types@^2.1.12, mime-types@^2.1.27, mime-types@^2.1.31, mime-types@~2.1.17, dependencies: mime-db "1.52.0" -mime-types@^2.1.35: - version "2.1.35" - dependencies: - mime-db "1.52.0" - mime@1.6.0: version "1.6.0" resolved "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz" @@ -8746,6 +8568,13 @@ minimalistic-assert@^1.0.0: resolved "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz" integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== +minimatch@9.0.3, minimatch@^9.0.1: + version "9.0.3" + resolved "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== + dependencies: + brace-expansion "^2.0.1" + minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" @@ -8760,20 +8589,6 @@ minimatch@^5.0.1: dependencies: brace-expansion "^2.0.1" -minimatch@^9.0.1: - version "9.0.3" - resolved "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz" - integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== - dependencies: - brace-expansion "^2.0.1" - -minimatch@9.0.3: - version "9.0.3" - resolved "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz" - integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== - dependencies: - brace-expansion "^2.0.1" - minimist@^1.2.0, minimist@^1.2.6: version "1.2.8" resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz" @@ -8809,16 +8624,16 @@ moment@^2.30.1: resolved "https://registry.npmjs.org/moment/-/moment-2.30.1.tgz" integrity sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how== -ms@^2.1.1, ms@2.1.2: - version "2.1.2" - resolved "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" - integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== - ms@2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== +ms@2.1.2, ms@^2.1.1: + version "2.1.2" + resolved "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + ms@2.1.3: version "2.1.3" resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" @@ -8964,12 +8779,7 @@ normalize-path@^2.0.0, normalize-path@^2.0.1: dependencies: remove-trailing-separator "^1.0.1" -normalize-path@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" - integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== - -normalize-path@~3.0.0: +normalize-path@^3.0.0, normalize-path@~3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== @@ -9358,16 +9168,16 @@ path-scurry@^1.10.2: lru-cache "^10.2.0" minipass "^5.0.0 || ^6.0.2 || ^7.0.0" -path-to-regexp@^6.2.0: - version "6.2.1" - resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz" - integrity sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw== - path-to-regexp@0.1.7: version "0.1.7" resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== +path-to-regexp@^6.2.0: + version "6.2.1" + resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz" + integrity sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw== + path-type@^4.0.0: version "4.0.0" resolved "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz" @@ -9485,15 +9295,6 @@ postcss-value-parser@^4.0.2, postcss-value-parser@^4.1.0, postcss-value-parser@^ resolved "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz" integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ== -postcss@^8.1.0, postcss@^8.4.33: - version "8.4.35" - resolved "https://registry.npmjs.org/postcss/-/postcss-8.4.35.tgz" - integrity sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA== - dependencies: - nanoid "^3.3.7" - picocolors "^1.0.0" - source-map-js "^1.0.2" - postcss@8.4.31: version "8.4.31" resolved "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz" @@ -9503,6 +9304,15 @@ postcss@8.4.31: picocolors "^1.0.0" source-map-js "^1.0.2" +postcss@^8.4.33: + version "8.4.35" + resolved "https://registry.npmjs.org/postcss/-/postcss-8.4.35.tgz" + integrity sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA== + dependencies: + nanoid "^3.3.7" + picocolors "^1.0.0" + source-map-js "^1.0.2" + prelude-ls@^1.2.1: version "1.2.1" resolved "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz" @@ -9525,7 +9335,7 @@ prettier@^2.8.7: resolved "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz" integrity sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q== -prettier@^3.2.5, prettier@>=3.0.0: +prettier@^3.2.5: version "3.2.5" resolved "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz" integrity sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A== @@ -9592,7 +9402,7 @@ punycode@^1.2.4, punycode@^1.4.1: resolved "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz" integrity sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ== -punycode@^2.1.0, punycode@^2.3.1: +punycode@^2.1.0: version "2.3.1" resolved "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz" integrity sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg== @@ -9612,13 +9422,6 @@ qrcode@1.5.0: pngjs "^5.0.0" yargs "^15.3.1" -qs@^6.11.2: - version "6.12.0" - resolved "https://registry.npmjs.org/qs/-/qs-6.12.0.tgz" - integrity sha512-trVZiI6RMOkO476zLGaBIzszOdFPnCCXHPG9kn0yuS1uz6xdVxPfZdB3vUig9pxPFDM9BRAgz/YUIVQ1/vuiUg== - dependencies: - side-channel "^1.0.6" - qs@6.11.0: version "6.11.0" resolved "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz" @@ -9626,6 +9429,13 @@ qs@6.11.0: dependencies: side-channel "^1.0.4" +qs@^6.11.2: + version "6.12.0" + resolved "https://registry.npmjs.org/qs/-/qs-6.12.0.tgz" + integrity sha512-trVZiI6RMOkO476zLGaBIzszOdFPnCCXHPG9kn0yuS1uz6xdVxPfZdB3vUig9pxPFDM9BRAgz/YUIVQ1/vuiUg== + dependencies: + side-channel "^1.0.6" + query-string@^9.0.0: version "9.0.0" resolved "https://registry.npmjs.org/query-string/-/query-string-9.0.0.tgz" @@ -9701,14 +9511,6 @@ react-datepicker@^6.4.0: prop-types "^15.7.2" react-onclickoutside "^6.13.0" -"react-dom@^15.5.x || ^16.x || ^17.x || ^18.x", "react-dom@^16.14.0 || ^17.0 || ^18.0", "react-dom@^16.8 || ^17.0 || ^18.0", "react-dom@^16.8.0 || ^17.0.0 || ^18.0.0", "react-dom@^16.9.0 || ^17 || ^18", react-dom@^18.0.0, react-dom@^18.2.0, "react-dom@>= 16.8.0", react-dom@>=16.6.0, react-dom@>=16.8, react-dom@>=16.8.0, react-dom@>=18: - version "18.2.0" - resolved "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz" - integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== - dependencies: - loose-envify "^1.1.0" - scheduler "^0.23.0" - react-dom@16.4.2: version "16.4.2" resolved "https://registry.npmjs.org/react-dom/-/react-dom-16.4.2.tgz" @@ -9719,16 +9521,24 @@ react-dom@16.4.2: object-assign "^4.1.1" prop-types "^15.6.0" -react-fast-compare@^2.0.1: - version "2.0.4" - resolved "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-2.0.4.tgz" - integrity sha512-suNP+J1VU1MWFKcyt7RtjiSWUjvidmQSlqu+eHslq+342xCbGTYmC0mEhPCOHxlW0CywylOC1u2DFAT+bv4dBw== +react-dom@^18.2.0: + version "18.2.0" + resolved "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz" + integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== + dependencies: + loose-envify "^1.1.0" + scheduler "^0.23.0" react-fast-compare@3.2.2: version "3.2.2" resolved "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-3.2.2.tgz" integrity sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ== +react-fast-compare@^2.0.1: + version "2.0.4" + resolved "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-2.0.4.tgz" + integrity sha512-suNP+J1VU1MWFKcyt7RtjiSWUjvidmQSlqu+eHslq+342xCbGTYmC0mEhPCOHxlW0CywylOC1u2DFAT+bv4dBw== + react-focus-lock@^2.9.4: version "2.11.2" resolved "https://registry.npmjs.org/react-focus-lock/-/react-focus-lock-2.11.2.tgz" @@ -9786,23 +9596,23 @@ react-remove-scroll-bar@^2.3.4: react-style-singleton "^2.2.1" tslib "^2.0.0" -react-remove-scroll@^2.5.6: - version "2.5.7" - resolved "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.7.tgz" - integrity sha512-FnrTWO4L7/Bhhf3CYBNArEG/yROV0tKmTv7/3h9QCFvH6sndeFf1wPqOcbFVu5VAulS5dV1wGT3GZZ/1GawqiA== +react-remove-scroll@2.5.4: + version "2.5.4" + resolved "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.4.tgz" + integrity sha512-xGVKJJr0SJGQVirVFAUZ2k1QLyO6m+2fy0l8Qawbp5Jgrv3DeLalrfMNBFSlmz5kriGGzsVBtGVnf4pTKIhhWA== dependencies: - react-remove-scroll-bar "^2.3.4" + react-remove-scroll-bar "^2.3.3" react-style-singleton "^2.2.1" tslib "^2.1.0" use-callback-ref "^1.3.0" use-sidecar "^1.1.2" -react-remove-scroll@2.5.4: - version "2.5.4" - resolved "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.4.tgz" - integrity sha512-xGVKJJr0SJGQVirVFAUZ2k1QLyO6m+2fy0l8Qawbp5Jgrv3DeLalrfMNBFSlmz5kriGGzsVBtGVnf4pTKIhhWA== +react-remove-scroll@^2.5.6: + version "2.5.7" + resolved "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.7.tgz" + integrity sha512-FnrTWO4L7/Bhhf3CYBNArEG/yROV0tKmTv7/3h9QCFvH6sndeFf1wPqOcbFVu5VAulS5dV1wGT3GZZ/1GawqiA== dependencies: - react-remove-scroll-bar "^2.3.3" + react-remove-scroll-bar "^2.3.4" react-style-singleton "^2.2.1" tslib "^2.1.0" use-callback-ref "^1.3.0" @@ -9857,14 +9667,7 @@ react-transition-group@^4.3.0: loose-envify "^1.4.0" prop-types "^15.6.2" -react@*, "react@^15.3.0 || ^16.0.0 || ^17.0.0 || ^18.0.0", "react@^15.5.x || ^16.x || ^17.x || ^18.x", "react@^16.14.0 || ^17.0 || ^18.0", "react@^16.8 || ^17.0 || ^18.0", "react@^16.8.0 || ^17 || ^18", "react@^16.8.0 || ^17.0.0 || ^18.0.0", "react@^16.9.0 || ^17 || ^18", react@^18.0.0, react@^18.2.0, "react@>= 16.8.0", react@>=16.13.1, react@>=16.6.0, react@>=16.8, react@>=16.8.0, react@>=16.8.6, react@>=18: - version "18.2.0" - resolved "https://registry.npmjs.org/react/-/react-18.2.0.tgz" - integrity sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ== - dependencies: - loose-envify "^1.1.0" - -react@^16.0.0, react@16.4.2: +react@16.4.2: version "16.4.2" resolved "https://registry.npmjs.org/react/-/react-16.4.2.tgz" integrity sha512-dMv7YrbxO4y2aqnvA7f/ik9ibeLSHQJTI6TrYAenPSaQ6OXfb+Oti+oJiy8WBxgRzlKatYqtCjphTgDSCEiWFg== @@ -9874,6 +9677,13 @@ react@^16.0.0, react@16.4.2: object-assign "^4.1.1" prop-types "^15.6.0" +react@^18.2.0: + version "18.2.0" + resolved "https://registry.npmjs.org/react/-/react-18.2.0.tgz" + integrity sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ== + dependencies: + loose-envify "^1.1.0" + readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.0.5, readable-stream@^2.3.6: version "2.3.8" resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz" @@ -10198,25 +10008,15 @@ safe-array-concat@^1.1.0: has-symbols "^1.0.3" isarray "^2.0.5" -safe-buffer@^5.1.0, safe-buffer@>=5.1.0, safe-buffer@~5.2.0, safe-buffer@5.2.1: - version "5.2.1" - resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" - integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== - -safe-buffer@~5.1.0: - version "5.1.2" - resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== - -safe-buffer@~5.1.1: +safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: version "5.1.2" resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -safe-buffer@5.1.2: - version "5.1.2" - resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== +safe-buffer@5.2.1, safe-buffer@>=5.1.0, safe-buffer@^5.1.0, safe-buffer@~5.2.0: + version "5.2.1" + resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== safe-regex-test@^1.0.3: version "1.0.3" @@ -10255,17 +10055,7 @@ schema-utils@^3.0.0, schema-utils@^3.1.1, schema-utils@^3.2.0: ajv "^6.12.5" ajv-keywords "^3.5.2" -schema-utils@^4.0.0: - version "4.2.0" - resolved "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz" - integrity sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw== - dependencies: - "@types/json-schema" "^7.0.9" - ajv "^8.9.0" - ajv-formats "^2.1.1" - ajv-keywords "^5.1.0" - -schema-utils@^4.2.0: +schema-utils@^4.0.0, schema-utils@^4.2.0: version "4.2.0" resolved "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz" integrity sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw== @@ -10293,25 +10083,13 @@ semver@^6.3.1: resolved "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz" integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== -semver@^7.3.4: - version "7.6.0" - resolved "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz" - integrity sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg== - dependencies: - lru-cache "^6.0.0" - -semver@^7.5.4: +semver@^7.3.4, semver@^7.5.4: version "7.6.0" resolved "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz" integrity sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg== dependencies: lru-cache "^6.0.0" -semver@^7.6.0: - version "7.6.0" - dependencies: - lru-cache "^6.0.0" - send@0.18.0: version "0.18.0" resolved "https://registry.npmjs.org/send/-/send-0.18.0.tgz" @@ -10471,12 +10249,7 @@ signal-exit@^3.0.2, signal-exit@^3.0.3, signal-exit@^3.0.7: resolved "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== -signal-exit@^4.0.1: - version "4.1.0" - resolved "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz" - integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== - -signal-exit@^4.1.0: +signal-exit@^4.0.1, signal-exit@^4.1.0: version "4.1.0" resolved "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz" integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== @@ -10486,13 +10259,6 @@ slash@^3.0.0: resolved "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== -slice-ansi@^4.0.0: - version "4.0.0" - dependencies: - ansi-styles "^4.0.0" - astral-regex "^2.0.0" - is-fullwidth-code-point "^3.0.0" - slice-ansi@^5.0.0: version "5.0.0" resolved "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz" @@ -10587,7 +10353,7 @@ source-map@^0.5.6, source-map@^0.5.7, source-map@~0.5.1: resolved "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz" integrity sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ== -source-map@^0.6.0: +source-map@^0.6.0, source-map@~0.6.0: version "0.6.1" resolved "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== @@ -10604,11 +10370,6 @@ source-map@~0.4.1: dependencies: amdefine ">=0.0.4" -source-map@~0.6.0: - version "0.6.1" - resolved "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" - integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== - spdy-transport@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz" @@ -10652,7 +10413,7 @@ static-extend@^0.1.1: define-property "^0.2.5" object-copy "^0.1.0" -statuses@^2.0.1, statuses@2.0.1: +statuses@2.0.1, statuses@^2.0.1: version "2.0.1" resolved "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz" integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== @@ -10686,40 +10447,12 @@ strict-event-emitter@^0.5.1: resolved "https://registry.npmjs.org/strict-event-emitter/-/strict-event-emitter-0.5.1.tgz" integrity sha512-vMgjE/GGEPEFnhFub6pa4FmJBRBVOLpIII2hvCZ8Kzb7K0hlHo7mQv6xYrBvCL2LtAIBwFUK8wvuJgTVSQ5MFQ== -string_decoder@^0.10.25: - version "0.10.31" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" - integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== - -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== - dependencies: - safe-buffer "~5.2.0" - -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== - dependencies: - safe-buffer "~5.1.0" - string-argv@0.3.2: version "0.3.2" resolved "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz" integrity sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q== -"string-width-cjs@npm:string-width@^4.2.0": - version "4.2.3" - resolved "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== - dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" - -string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +"string-width-cjs@npm:string-width@^4.2.0", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -10728,25 +10461,7 @@ string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" -string-width@^5.0.0: - version "5.1.2" - resolved "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz" - integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== - dependencies: - eastasianwidth "^0.2.0" - emoji-regex "^9.2.2" - strip-ansi "^7.0.1" - -string-width@^5.0.1: - version "5.1.2" - resolved "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz" - integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== - dependencies: - eastasianwidth "^0.2.0" - emoji-regex "^9.2.2" - strip-ansi "^7.0.1" - -string-width@^5.1.2: +string-width@^5.0.0, string-width@^5.0.1, string-width@^5.1.2: version "5.1.2" resolved "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz" integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== @@ -10797,7 +10512,26 @@ string.prototype.trimstart@^1.0.7: define-properties "^1.2.0" es-abstract "^1.22.1" -"strip-ansi-cjs@npm:strip-ansi@^6.0.1": +string_decoder@^0.10.25: + version "0.10.31" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" + integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== + +string_decoder@^1.1.1: + version "1.3.0" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" + integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== + dependencies: + safe-buffer "~5.2.0" + +string_decoder@~1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz" + integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== + dependencies: + safe-buffer "~5.1.0" + +"strip-ansi-cjs@npm:strip-ansi@^6.0.1", strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" resolved "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== @@ -10811,13 +10545,6 @@ strip-ansi@^3.0.0: dependencies: ansi-regex "^2.0.0" -strip-ansi@^6.0.0, strip-ansi@^6.0.1: - version "6.0.1" - resolved "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== - dependencies: - ansi-regex "^5.0.1" - strip-ansi@^7.0.1: version "7.1.0" resolved "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz" @@ -10870,7 +10597,7 @@ style-loader@^3.3.4: resolved "https://registry.npmjs.org/style-loader/-/style-loader-3.3.4.tgz" integrity sha512-0WqXzrsMTyb8yjZJHDqwmnwRJvhALK9LfRtRc6B4UTWe8AijYLZYZ9thuJTZc2VfQWINADW/j+LiJnfy2RoC1w== -styled-components@^6.1.8, "styled-components@>=4.0.0 || >=5.0.0 || >=6.0.0": +styled-components@^6.1.8: version "6.1.8" resolved "https://registry.npmjs.org/styled-components/-/styled-components-6.1.8.tgz" integrity sha512-PQ6Dn+QxlWyEGCKDS71NGsXoVLKfE1c3vApkvDYS5KAK+V8fNWGhbSUEo9Gg2iaID2tjLXegEW3bZDUGpofRWw== @@ -10969,15 +10696,6 @@ tabbable@^6.0.1: resolved "https://registry.npmjs.org/tabbable/-/tabbable-6.2.0.tgz" integrity sha512-Cat63mxsVJlzYvN51JmVXIgNoUokrIaT2zLclCXjRd8boZ0004U4KCs/sToJ75C6sdlByWxpYnb5Boif1VSFew== -table@^6.8.2: - version "6.8.2" - dependencies: - ajv "^8.0.1" - lodash.truncate "^4.4.2" - slice-ansi "^4.0.0" - string-width "^4.2.3" - strip-ansi "^6.0.1" - tapable@^0.1.8, tapable@~0.1.8: version "0.1.10" resolved "https://registry.npmjs.org/tapable/-/tapable-0.1.10.tgz" @@ -11153,16 +10871,6 @@ tsconfig-paths@^3.15.0: minimist "^1.2.6" strip-bom "^3.0.0" -tslib@^1.11.1: - version "1.14.1" - resolved "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" - integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== - -tslib@^2.0.0, tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.1, tslib@^2.4.0, tslib@^2.5.0, tslib@^2.5.2, tslib@^2.6.2: - version "2.6.2" - resolved "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz" - integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== - tslib@2.4.0: version "2.4.0" resolved "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz" @@ -11173,6 +10881,16 @@ tslib@2.5.0: resolved "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz" integrity sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg== +tslib@^1.11.1: + version "1.14.1" + resolved "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.0.0, tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.1, tslib@^2.4.0, tslib@^2.5.0, tslib@^2.5.2, tslib@^2.6.2: + version "2.6.2" + resolved "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== + tty-browserify@0.0.0: version "0.0.0" resolved "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz" @@ -11262,7 +10980,7 @@ typed-array-length@^1.0.4: is-typed-array "^1.1.13" possible-typed-array-names "^1.0.0" -typescript@*, typescript@^5.3.3, "typescript@>= 4.7.x", typescript@>=2.7, typescript@>=4.2.0, typescript@>=4.9.5: +typescript@^5.3.3: version "5.3.3" resolved "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz" integrity sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw== @@ -11345,7 +11063,7 @@ universalify@^2.0.0: resolved "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz" integrity sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw== -unpipe@~1.0.0, unpipe@1.0.0: +unpipe@1.0.0, unpipe@~1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== @@ -11503,7 +11221,7 @@ wbuf@^1.1.0, wbuf@^1.7.3: dependencies: minimalistic-assert "^1.0.0" -webpack-cli@^5.1.4, webpack-cli@5.x.x: +webpack-cli@^5.1.4: version "5.1.4" resolved "https://registry.npmjs.org/webpack-cli/-/webpack-cli-5.1.4.tgz" integrity sha512-pIDJHIEI9LR0yxHXQ+Qh95k2EvXpWzZ5l+d+jIo+RdSm9MiHfzazIxwwni/p7+x4eJZuvG1AJwgC4TNQ7NRgsg== @@ -11619,7 +11337,7 @@ webpack@^1.12.2: watchpack "^0.2.1" webpack-core "~0.6.9" -"webpack@^4 || ^5", "webpack@^4.0.0 || ^5.0.0", webpack@^5.0.0, webpack@^5.1.0, webpack@^5.20.0, webpack@^5.90.3, "webpack@>=4.0.0 <6.0.0", webpack@>=5, webpack@5.x.x: +webpack@^5.90.3: version "5.90.3" resolved "https://registry.npmjs.org/webpack/-/webpack-5.90.3.tgz" integrity sha512-h6uDYlWCctQRuXBs1oYpVe6sFcWedl0dpcVaTf/YF67J9bKvwJajFulMVSYKHrksMB3I/pIagRzDxwxkebuzKA== @@ -11649,7 +11367,7 @@ webpack@^1.12.2: watchpack "^2.4.0" webpack-sources "^3.2.3" -websocket-driver@^0.7.4, websocket-driver@>=0.5.1: +websocket-driver@>=0.5.1, websocket-driver@^0.7.4: version "0.7.4" resolved "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz" integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== @@ -11740,17 +11458,17 @@ window-size@0.1.0: resolved "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz" integrity sha512-1pTPQDKTdd61ozlKGNCjhNRd+KPmgLSGa3mZTHoOliaGcESD8G1PXhh7c1fgiPjVbNVfgy2Faw4BI8/m0cC8Mg== -wordwrap@~0.0.2: - version "0.0.3" - resolved "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz" - integrity sha512-1tMA907+V4QmxV7dbRvb4/8MaRALK6q9Abid3ndMYnbyo8piisCmeONVqVSXqQA3KaP4SLt5b7ud6E2sqP8TFw== - wordwrap@0.0.2: version "0.0.2" resolved "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz" integrity sha512-xSBsCeh+g+dinoBv3GAOWM4LcVVO68wLXRanibtBSdUvkGWQRGeE9P7IwU9EmDDi4jA6L44lz15CGMwdw9N5+Q== -"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": +wordwrap@~0.0.2: + version "0.0.3" + resolved "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz" + integrity sha512-1tMA907+V4QmxV7dbRvb4/8MaRALK6q9Abid3ndMYnbyo8piisCmeONVqVSXqQA3KaP4SLt5b7ud6E2sqP8TFw== + +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0", wrap-ansi@^7.0.0: version "7.0.0" resolved "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== @@ -11768,15 +11486,6 @@ wrap-ansi@^6.2.0: string-width "^4.1.0" strip-ansi "^6.0.0" -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - wrap-ansi@^8.0.1, wrap-ansi@^8.1.0: version "8.1.0" resolved "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz" @@ -11796,7 +11505,7 @@ ws@^8.16.0: resolved "https://registry.npmjs.org/ws/-/ws-8.16.0.tgz" integrity sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ== -xstate@^4.33.6, xstate@^4.37.2: +xstate@^4.33.6: version "4.38.3" resolved "https://registry.npmjs.org/xstate/-/xstate-4.38.3.tgz" integrity sha512-SH7nAaaPQx57dx6qvfcIgqKRXIh4L0A1iYEqim4s1u7c9VoCgzZc+63FY90AKU4ZzOC2cfJzTnpO4zK7fCUzzw== @@ -11826,19 +11535,16 @@ yallist@^4.0.0: resolved "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz" integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== -yaml@^1.10.0: - version "1.10.2" - resolved "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz" - integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== - -yaml@1.10.2: - version "1.10.2" - yaml@2.3.1: version "2.3.1" resolved "https://registry.npmjs.org/yaml/-/yaml-2.3.1.tgz" integrity sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ== +yaml@^1.10.0: + version "1.10.2" + resolved "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz" + integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== + yargs-parser@^18.1.2: version "18.1.3" resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz" From 78b0e3209903c2e015df56ae450d1a98160089ee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B3=B5=EC=A0=95=EB=AF=BC?= <102538362+jeongmin59@users.noreply.github.com> Date: Sat, 20 Apr 2024 02:49:19 +0900 Subject: [PATCH 4/5] =?UTF-8?q?:bug:=20Fix:=20=ED=8C=80=EC=9B=90=20?= =?UTF-8?q?=EC=B4=88=EB=8C=80=20=EC=88=98=EB=9D=BD=20api=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80=20=EB=B0=8F=20=ED=98=B8=EC=B6=9C=20=EB=A1=9C=EC=A7=81?= =?UTF-8?q?=20=EC=88=98=EC=A0=95=20=EC=99=84=EB=A3=8C=20(#182)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/App.tsx | 2 + src/api/@types/InviteTeam.ts | 7 +++ .../getInviteTeam.tsx | 4 +- src/api/inviteTeamApi/postInviteTeam.tsx | 16 ++++++ src/components/RetroList/ContentsList.tsx | 36 +++++++------ src/components/inviteTeam/AcceptInvite.tsx | 38 ++++++++++++++ src/components/inviteTeam/InviteTeam.tsx | 52 ------------------- src/components/inviteTeam/InviteTeamModal.tsx | 2 +- 8 files changed, 85 insertions(+), 72 deletions(-) rename src/api/{retrospectivesApi => inviteTeamApi}/getInviteTeam.tsx (76%) create mode 100644 src/api/inviteTeamApi/postInviteTeam.tsx create mode 100644 src/components/inviteTeam/AcceptInvite.tsx delete mode 100644 src/components/inviteTeam/InviteTeam.tsx diff --git a/src/App.tsx b/src/App.tsx index 8df4ed0..f0f7d8b 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -3,6 +3,7 @@ import { Navigate, useLocation } from 'react-router-dom'; import { BrowserRouter as Router, Route, Routes } from 'react-router-dom'; import { getCurrentUser } from 'aws-amplify/auth'; import { RecoilRoot } from 'recoil'; +import AcceptInvite from './components/inviteTeam/AcceptInvite'; import RetroTeamPage from './pages/RetroTeamPage'; import RetroRevisePage from './pages/RevisePage'; import MainLayout from '@/components/layout/MainLayout'; @@ -140,6 +141,7 @@ const App = () => { } /> + diff --git a/src/api/@types/InviteTeam.ts b/src/api/@types/InviteTeam.ts index 203f777..670852e 100644 --- a/src/api/@types/InviteTeam.ts +++ b/src/api/@types/InviteTeam.ts @@ -1,3 +1,4 @@ +// get export interface GetInviteTeamRequest { // teamId: number; } @@ -14,3 +15,9 @@ export interface InviteTeamData { expirationTime: string; qrCodeImage: string; } + +// post +export interface PostInviteTeamRequest { + invitationCode: string; +} +export interface PostInviteTeamResponse {} diff --git a/src/api/retrospectivesApi/getInviteTeam.tsx b/src/api/inviteTeamApi/getInviteTeam.tsx similarity index 76% rename from src/api/retrospectivesApi/getInviteTeam.tsx rename to src/api/inviteTeamApi/getInviteTeam.tsx index b041b9e..215651a 100644 --- a/src/api/retrospectivesApi/getInviteTeam.tsx +++ b/src/api/inviteTeamApi/getInviteTeam.tsx @@ -4,10 +4,10 @@ import axiosInstance from '../axiosConfig'; const getInviteTeam = async (teamId: GetInviteTeamRequest): Promise => { try { const response = await axiosInstance.get(`/teams/${teamId}/invitation-url`); - console.log('팀원 초대 호출 성공', response.data); + console.log('팀원 초대 링크 호출 성공', response.data); return response.data; } catch (error) { - throw new Error('팀원 초대 호출 실패'); + throw new Error('팀원 초대 링크 호출 실패'); } }; diff --git a/src/api/inviteTeamApi/postInviteTeam.tsx b/src/api/inviteTeamApi/postInviteTeam.tsx new file mode 100644 index 0000000..394bb16 --- /dev/null +++ b/src/api/inviteTeamApi/postInviteTeam.tsx @@ -0,0 +1,16 @@ +// import { PostInviteTeamRequest } from '../@types/InviteTeam'; +import axiosInstance from '../axiosConfig'; + +const postInviteTeam = async (invitationId: string) => { + try { + const response = await axiosInstance.post('/team/accept-invitation', { + invitationCode: invitationId, + }); + console.log('팀원 초대 성공', response.data); + return response.data; + } catch (error) { + throw new Error('팀원 초대 실패'); + } +}; + +export default postInviteTeam; diff --git a/src/components/RetroList/ContentsList.tsx b/src/components/RetroList/ContentsList.tsx index f1d96ba..d0d2439 100644 --- a/src/components/RetroList/ContentsList.tsx +++ b/src/components/RetroList/ContentsList.tsx @@ -84,7 +84,7 @@ const ContentList: React.FC = ({ data, viewMode, searchData, s
- navigate(`/section?retrospectiveId=${item.id}&teamId=${item.teamId}`)}> + navigate(`/sections?retrospectiveId=${item.id}&teamId=${item.teamId}`)}> {item.title}
@@ -95,14 +95,15 @@ const ContentList: React.FC = ({ data, viewMode, searchData, s /> openModalForItem(item.id)} - // onClick={() => { - // if(유저아이디 !== item.id) { // 수정 권한 없을 때(생성자가 아닐 때) - // openModalForItem(item.id) - // } else { - // navigate(`/revise?retrospectiveId=${item.id}&teamId=${item.teamId}`); - // } - // }} + // onClick={() => openModalForItem(item.id)} + onClick={() => { + if (item.userId === item.id) { + // 수정 권한 없을 때(생성자가 아닐 때 확인하고 고치기) + openModalForItem(item.id); + } else { + navigate(`/revise?retrospectiveId=${item.id}&teamId=${item.teamId}`); + } + }} /> @@ -175,14 +176,15 @@ const ContentList: React.FC = ({ data, viewMode, searchData, s openModalForItem(item.id)} - // onClick={() => { - // if(유저아이디 !== item.id) { // 수정 권한 없을 때(생성자가 아닐 때) - // openModalForItem(item.id) - // } else { - // navigate(`/revise?retrospectiveId=${item.id}&teamId=${item.teamId}`); - // } - // }} + // onClick={() => openModalForItem(item.id)} + onClick={() => { + if (item.userId === item.id) { + // 수정 권한 없을 때(생성자가 아닐 때 확인하고 고치기) + openModalForItem(item.id); + } else { + navigate(`/revise?retrospectiveId=${item.id}&teamId=${item.teamId}`); + } + }} /> diff --git a/src/components/inviteTeam/AcceptInvite.tsx b/src/components/inviteTeam/AcceptInvite.tsx new file mode 100644 index 0000000..bf8812b --- /dev/null +++ b/src/components/inviteTeam/AcceptInvite.tsx @@ -0,0 +1,38 @@ +import React, { useEffect, useState } from 'react'; +import { useParams, useNavigate } from 'react-router-dom'; +import postInviteTeam from '@/api/inviteTeamApi/postInviteTeam'; + +const AcceptInvite: React.FC = () => { + const { invitationId } = useParams<{ invitationId?: string }>(); + const navigate = useNavigate(); + const [inviteSuccess, setInviteSuccess] = useState(false); + + useEffect(() => { + const acceptInvitation = async () => { + try { + if (invitationId) { + await postInviteTeam(invitationId); + setInviteSuccess(true); // 초대 요청이 성공했을 때 상태를 true로 변경 + } else { + console.error('InvitationId 추출 실패'); + } + } catch (error) { + console.error('에러', error); + } + }; + + acceptInvitation(); + }, [invitationId]); + + useEffect(() => { + if (inviteSuccess) { + // 초대 성공 시 알림을 띄우고 retrolist 페이지로 navigate + alert('초대 성공했습니다!'); + navigate('/retrolist'); + } + }, [inviteSuccess, navigate]); + + return
초대를 수락하는 중...
; +}; + +export default AcceptInvite; diff --git a/src/components/inviteTeam/InviteTeam.tsx b/src/components/inviteTeam/InviteTeam.tsx deleted file mode 100644 index 11bc289..0000000 --- a/src/components/inviteTeam/InviteTeam.tsx +++ /dev/null @@ -1,52 +0,0 @@ -import React, { useState, useEffect } from 'react'; -import QRCode from 'qrcode.react'; -import { GetInviteTeamResponse, InviteTeamData } from '@/api/@types/InviteTeam'; -import getInviteTeam from '@/api/retrospectivesApi/getInviteTeam'; - -interface InviteTeamComponentProps { - teamId: number; -} - -const InviteTeamComponent: React.FC = ({ teamId }) => { - const [inviteData, setInviteData] = useState(null); - const [error, setError] = useState(''); - - useEffect(() => { - const fetchInviteData = async () => { - try { - const response: GetInviteTeamResponse = await getInviteTeam(teamId); - setInviteData(response.data); - } catch (error) { - console.error(error); - setError('팀원 초대 get 실패'); - } - }; - - fetchInviteData(); - }, [teamId]); // teamId가 변경될 때마다 호출 - - if (error) { - return
{error}
; - } - - if (!inviteData) { - return
로딩중...
; - } - - return ( -
-

초대 코드: {inviteData.invitationCode}

-

- 초대 URL:{' '} - - {inviteData.invitationUrl} - -

-

만료 시간: {inviteData.expirationTime}

- -

{inviteData.qrCodeImage}

-
- ); -}; - -export default InviteTeamComponent; diff --git a/src/components/inviteTeam/InviteTeamModal.tsx b/src/components/inviteTeam/InviteTeamModal.tsx index 796fb74..ad48fa7 100644 --- a/src/components/inviteTeam/InviteTeamModal.tsx +++ b/src/components/inviteTeam/InviteTeamModal.tsx @@ -19,7 +19,7 @@ import { } from '@chakra-ui/react'; import QRCode from 'qrcode.react'; import { GetInviteTeamResponse, InviteTeamData } from '@/api/@types/InviteTeam'; -import getInviteTeam from '@/api/retrospectivesApi/getInviteTeam'; +import getInviteTeam from '@/api/inviteTeamApi/getInviteTeam'; import * as S from '@/styles/inviteTeam/InviteTeamModal.style'; interface InviteTeamModalProps { From 93589e57666e378e6836fbd18e446778e37c96d6 Mon Sep 17 00:00:00 2001 From: heejung0413 Date: Sat, 20 Apr 2024 03:18:36 +0900 Subject: [PATCH 5/5] Squashed commit of the following: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit commit e9f4f7e467533ec4489496432e3f2605c7c0d965 Author: heejung0413 Date: Sat Apr 20 03:12:07 2024 +0900 fix: section 페이지 api 연결 commit 841bb55db166277cb07e8c64215bfa423f31af88 Author: heejung0413 Date: Sat Apr 20 00:20:27 2024 +0900 🐛Fix: 자잘한 api 수정(section 페이지 action item 추가, 따로 컴포넌트 설정) commit 40ba27f6e4af189c1d0c0f80c922694000945476 Author: heejung0413 Date: Fri Apr 19 17:32:57 2024 +0900 🐛Fix: section 페이지 api 연결 commit cd400034727c5f51793024d90b0308d3307afb5c Author: heejung0413 Date: Fri Apr 19 16:30:00 2024 +0900 긴급) fix: team type 수정 --- src/App.tsx | 12 +-- src/api/@types/Section.ts | 11 ++- src/api/__mock__/retrospectiveTemplate.ts | 9 -- src/api/client.ts | 4 - src/api/services/Retrospectives.ts | 9 +- src/api/services/Section.ts | 16 ++- .../writeRetro/revise/ManageTeamMembers.tsx | 19 ---- .../writeRetro/revise/RetroImageUploader.tsx | 2 +- .../writeRetro/revise/ReviseSetting.tsx | 31 +++--- .../writeRetro/task/ActionItemTask.tsx | 66 +++++++++++++ src/components/writeRetro/task/TeamTask.tsx | 99 ++++++++----------- .../task/taskMessage/TeamTaskMessage.tsx | 2 +- src/mocks/handlers.ts | 2 +- src/pages/RetroListPage.tsx | 6 +- src/pages/RetroPersonalPage.tsx | 74 -------------- src/pages/RevisePage.tsx | 18 ++-- .../{RetroTeamPage.tsx => SectionPage.tsx} | 49 +++++---- src/styles/RetroList/RetroListPage.style.ts | 4 +- src/styles/writeRetroStyles/Layout.style.ts | 6 ++ 19 files changed, 197 insertions(+), 242 deletions(-) delete mode 100644 src/api/__mock__/retrospectiveTemplate.ts create mode 100644 src/components/writeRetro/task/ActionItemTask.tsx delete mode 100644 src/pages/RetroPersonalPage.tsx rename src/pages/{RetroTeamPage.tsx => SectionPage.tsx} (71%) diff --git a/src/App.tsx b/src/App.tsx index f0f7d8b..da4f346 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -4,8 +4,8 @@ import { BrowserRouter as Router, Route, Routes } from 'react-router-dom'; import { getCurrentUser } from 'aws-amplify/auth'; import { RecoilRoot } from 'recoil'; import AcceptInvite from './components/inviteTeam/AcceptInvite'; -import RetroTeamPage from './pages/RetroTeamPage'; import RetroRevisePage from './pages/RevisePage'; +import RetroTeamPage from './pages/SectionPage'; import MainLayout from '@/components/layout/MainLayout'; import ProfileLayout from '@/components/layout/ProfileLayout'; import AuthPage from '@/pages/AuthPage'; @@ -99,14 +99,6 @@ const App = () => { } /> - {/* - - - } - /> */} { } /> - { } /> - {/* MainLayout */} }> } /> diff --git a/src/api/@types/Section.ts b/src/api/@types/Section.ts index cdf39ba..1846f7e 100644 --- a/src/api/@types/Section.ts +++ b/src/api/@types/Section.ts @@ -1,7 +1,11 @@ //get -export interface GetSectionRequest { +export interface TeamGetSectionRequest { + retrospectiveId: number; + teamId: number; +} + +export interface PersonalGetSectionRequest { retrospectiveId: number; - teamId: number | null; } export interface sectionData { @@ -85,7 +89,8 @@ export interface PostLikeSectionResponse { }; } export interface SectionClient { - get(request: GetSectionRequest): Promise; + TeamGet(request: TeamGetSectionRequest): Promise; + PersonalGet(request: PersonalGetSectionRequest): Promise; create(request: CreateSectionRequest): Promise; patch(request: PatchSectionRequest): Promise; delete(request: DeleteSectionRequest): Promise; diff --git a/src/api/__mock__/retrospectiveTemplate.ts b/src/api/__mock__/retrospectiveTemplate.ts deleted file mode 100644 index aa13607..0000000 --- a/src/api/__mock__/retrospectiveTemplate.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { RetrospectivesTemplateResponse } from '../@types/RetrospectiveTemplates'; - -export const mockRetrospectiveTemplate: RetrospectivesTemplateResponse[] = [ - // { id: 1, name: 'hee' }, - // { - // id: 2, - // name: 'jung', - // }, -]; diff --git a/src/api/client.ts b/src/api/client.ts index 1e0575d..00b30c9 100644 --- a/src/api/client.ts +++ b/src/api/client.ts @@ -6,7 +6,6 @@ import { unwrapResponse } from './interceptors/response'; // import { logAndProcessError, logResponse, unwrapResponse } from './interceptors/response'; // import { flow } from '@/utils/flow'; - export const mswInstance = axios.create({ baseURL: '/', timeout: 4000, @@ -20,10 +19,7 @@ export const mswInstance = axios.create({ // withCredentials: true, // }); - - axiosInstance.interceptors.request.use(logRequest); // axiosInstance.interceptors.response.use(flow([logResponse, unwrapResponse]), logAndProcessError); - mswInstance.interceptors.response.use(unwrapResponse); diff --git a/src/api/services/Retrospectives.ts b/src/api/services/Retrospectives.ts index aafe3fd..c130d58 100644 --- a/src/api/services/Retrospectives.ts +++ b/src/api/services/Retrospectives.ts @@ -9,7 +9,6 @@ import { RetrospectivesClient, } from '../@types/Retrospectives'; import axiosInstance from '../axiosConfig'; -import { mswInstance } from '../client'; const ROUTE = 'retrospectives'; @@ -32,7 +31,7 @@ export const RetrospectiveService: RetrospectivesClient = { }, get: async (request: GetRetrospectiveRequest): Promise => { try { - const response = await mswInstance.get(`${ROUTE}/`, { + const response = await axiosInstance.get(`${ROUTE}/`, { params: request, }); return response.data; @@ -43,12 +42,13 @@ export const RetrospectiveService: RetrospectivesClient = { delete: async ({ retrospectiveId }: DeleteRetrospectiveRequest): Promise => { try { - const response = await mswInstance.delete(`${ROUTE}/${retrospectiveId}`); + const response = await axiosInstance.delete(`${ROUTE}/${retrospectiveId}`); return response.data; } catch (error) { throw new Error(error as string); } }, + put: async ({ retrospectiveId }, ...request) => { try { const response = await axiosInstance.put(`${ROUTE}/${retrospectiveId}`, request); @@ -57,7 +57,8 @@ export const RetrospectiveService: RetrospectivesClient = { throw new Error(error as string); } }, + patch: async (retrospectiveId, ...request) => { - return await mswInstance.patch(`${ROUTE}/${retrospectiveId}/bookmark`, request); + return await axiosInstance.patch(`${ROUTE}/${retrospectiveId}/bookmark`, request); }, }; diff --git a/src/api/services/Section.ts b/src/api/services/Section.ts index d57420a..4bef268 100644 --- a/src/api/services/Section.ts +++ b/src/api/services/Section.ts @@ -2,20 +2,28 @@ import { CreateSectionRequest, DeleteSectionRequest, DeleteSectionResponse, - GetSectionRequest, + TeamGetSectionRequest, GetSectionResponse, PostLikeSectionResponse, PostLikesSectionRequest, PostSectionResponse, SectionClient, + PersonalGetSectionRequest, } from '../@types/Section'; import axiosInstance from '../axiosConfig'; -import { mswInstance } from '../client'; const ROUTE = 'sections'; export const SectionServices: SectionClient = { - get: async (request: GetSectionRequest): Promise => { + TeamGet: async (request: TeamGetSectionRequest): Promise => { + try { + const response = await axiosInstance.get(`${ROUTE}`, { params: request }); + return response.data; + } catch (error) { + throw new Error(error as string); + } + }, + PersonalGet: async (request: PersonalGetSectionRequest): Promise => { try { const response = await axiosInstance.get(`${ROUTE}`, { params: request }); return response.data; @@ -49,7 +57,7 @@ export const SectionServices: SectionClient = { }, likePost: async ({ sectionId }: PostLikesSectionRequest): Promise => { try { - const response = await mswInstance.post(`${ROUTE}/${sectionId}/likes`); + const response = await axiosInstance.post(`${ROUTE}/${sectionId}/likes`); return response.data; } catch (error) { throw new Error(error as string); diff --git a/src/components/writeRetro/revise/ManageTeamMembers.tsx b/src/components/writeRetro/revise/ManageTeamMembers.tsx index ce8b815..993f637 100644 --- a/src/components/writeRetro/revise/ManageTeamMembers.tsx +++ b/src/components/writeRetro/revise/ManageTeamMembers.tsx @@ -13,23 +13,10 @@ interface Props { } const ManageTeamMembers: FC = ({ members, teamId }) => { - // const [members, setMembers] = useState(); - // const toast = useCustomToast(); const [searchTerm, setSearchTerm] = useState(''); const [searchList, setSearchList] = useState(); const [isInviteModalOpen, setInviteModalOpen] = useState(false); - // const fetchTeamMembers = async () => { - // try { - // const data = await TeamControllerServices.TeamMemberGet({ teamId: teamId, retrospectiveId: retrospectiveId }); - // console.log('data.members', data); - // setMembers(data.data); - // console.log('members', members); - // } catch (e) { - // toast.error(e); - // } - // }; - const searchTeamMembers = (searchTerm: string) => { const filterData: TeamMembersData[] = []; @@ -42,12 +29,6 @@ const ManageTeamMembers: FC = ({ members, teamId }) => { }); }; - // useEffect(() => { - // fetchTeamMembers(); - // }, [teamId, retrospectiveId]); - - // if (!members) return; - return ( diff --git a/src/components/writeRetro/revise/RetroImageUploader.tsx b/src/components/writeRetro/revise/RetroImageUploader.tsx index fd0c7af..bc4959a 100644 --- a/src/components/writeRetro/revise/RetroImageUploader.tsx +++ b/src/components/writeRetro/revise/RetroImageUploader.tsx @@ -33,7 +33,7 @@ const RetroImageUploader: FC = ({ image, setImage }) => { {image ? ( ) : ( - + )}
diff --git a/src/components/writeRetro/revise/ReviseSetting.tsx b/src/components/writeRetro/revise/ReviseSetting.tsx index fed5dea..a79e8dd 100644 --- a/src/components/writeRetro/revise/ReviseSetting.tsx +++ b/src/components/writeRetro/revise/ReviseSetting.tsx @@ -32,16 +32,17 @@ import * as S from '@/styles/writeRetroStyles/ReviseLayout.style'; interface Props { retro: RetrospectiveData; + status: string | undefined; + setStatus: (status: string) => void; } -const ReviseSetting: FC = ({ retro }) => { +const ReviseSetting: FC = ({ retro, status, setStatus }) => { const { search } = useLocation(); const query = search.split(/[=,&]/); const retrospectiveId = Number(query[1]); const teamId = Number(query[3]); const [isChecked, setIsChecked] = useState(false); - const [status, setStatus] = useState(''); - // const [retroName, setRetroName] = useState(); + const [image, setImage] = useState(retro.thumbnail); const [title, setTitle] = useState(''); const [templateName, setTemplateName] = useState(); @@ -54,7 +55,6 @@ const ReviseSetting: FC = ({ retro }) => { try { const data = await postImageToS3({ filename: retro.thumbnail, method: 'GET' }); setImage(data.preSignedUrl); - console.log('image', image); } catch (e) { toast.error(e); } @@ -64,8 +64,7 @@ const ReviseSetting: FC = ({ retro }) => { const fetchRetrospectiveTemplate = async () => { try { if (retro) { - const data = await TeamControllerServices.TemplateNameGet({ templateId: 2 }); - console.log('retro.templateId', data); + const data = await TeamControllerServices.TemplateNameGet({ templateId: retro.templateId }); setTemplateName(data.data); } } catch (error) { @@ -76,12 +75,12 @@ const ReviseSetting: FC = ({ retro }) => { const handlePutRetrospective = async () => { try { const data = await RetrospectiveService.put({ - retrospectiveId: retrospectiveId, + retrospectiveId: 102, title: title, teamId: teamId, description: description, - status: 'COMPLETED', thumbnail: image, + status: 'COMPLETED', }); console.log('put data', data); navigate('/retrolist'); @@ -92,16 +91,18 @@ const ReviseSetting: FC = ({ retro }) => { }; const SwitchStatus = () => { - setIsChecked(!isChecked); + setIsChecked(true); if (retro) { if (isChecked) { toast.info('회고 완료 처리를 취소하였습니다.'); setStatus('COMPLETED'); + setIsChecked(false); console.log(status); } else { toast.success('해당 회고는 최종 완료 처리되었습니다.'); setStatus(retro.status); console.log(status); + setIsChecked(true); } } }; @@ -165,7 +166,9 @@ const ReviseSetting: FC = ({ retro }) => { -

{retro.userId}

+

+ {retro.leaderName ?? (회고 리더 이름없음)} +

{/* 회고 설명 */} @@ -197,13 +200,7 @@ const ReviseSetting: FC = ({ retro }) => { {/* save, cancel */} - + + + + + {/* TaskCenter */} @@ -107,28 +108,6 @@ const TeamTask: FC = ({ section }) => { - {section.sectionName === 'Action Items' && ( - -
- handleMouseEnter(selectedUserName || '')} - onMouseLeave={handleMouseLeave} - > - {selectedUserImg ? : 'M'} - {hoveredUser && {hoveredUser}} {/* 이름 : {name.username} */} - - {showPopup && ( - - )} -
- {section.username} -
- )} {/* TaskBottom */} @@ -144,7 +123,7 @@ const TeamTask: FC = ({ section }) => { {messaged ? : } - 4 + 0 {/* DaysLeft */} diff --git a/src/components/writeRetro/task/taskMessage/TeamTaskMessage.tsx b/src/components/writeRetro/task/taskMessage/TeamTaskMessage.tsx index 8fba36d..23b3686 100644 --- a/src/components/writeRetro/task/taskMessage/TeamTaskMessage.tsx +++ b/src/components/writeRetro/task/taskMessage/TeamTaskMessage.tsx @@ -23,7 +23,7 @@ const TeamTaskMessage: FC = ({ section }) => { {/* TaskMessageTop */} - 5개의 댓글 + 0개의 댓글 diff --git a/src/mocks/handlers.ts b/src/mocks/handlers.ts index 8f98188..65d120e 100644 --- a/src/mocks/handlers.ts +++ b/src/mocks/handlers.ts @@ -82,4 +82,4 @@ export const TeamHandlers: RequestHandler[] = [ return HttpResponse.json(mockMembers); }), ]; -export const mswWorker = setupWorker(...TeamHandlers, ...SectionHandlers); +export const mswWorker = setupWorker(); diff --git a/src/pages/RetroListPage.tsx b/src/pages/RetroListPage.tsx index b0cbc04..f04808d 100644 --- a/src/pages/RetroListPage.tsx +++ b/src/pages/RetroListPage.tsx @@ -85,7 +85,7 @@ const RetroListPage = () => { updatedDate: formatDate(item.updatedDate), })); setRetroData(rawData); - }, [data]); + }, [data.nodes]); // console.log(retroData); const handleContentsFilter = (filterType: string) => { @@ -180,11 +180,11 @@ const RetroListPage = () => { - + - + { - const [section, setSection] = useState(); - const toast = useCustomToast(); - const location = useLocation(); - console.log(location); - - const FetchSection = async () => { - try { - const data = await SectionServices.get({ - retrospectiveId: 1, - teamId: 2, - }); - if (!data) return; - if (data) { - setSection(data); - } - console.log('data', data.data); - } catch (e) { - toast.error(e); - } - }; - - useEffect(() => { - FetchSection(); - }, []); - - if (!section) return; - - return ( - - - <S.SectionBox> - <Flex flexDirection="column"> - <Flex> - <IoMdInformationCircle size={25} style={{ margin: 'auto 5px' }} /> - <p style={{ fontSize: '20px', margin: '5px' }}>수정을 원한다면, 해당 텍스트를 선택하세요!</p> - </Flex> - <Flex> - {PersonalSectionTitleName.map(title => ( - <S.FrameStyle> - <Label - labelName={title.title} - labelType="dark" - taskCount={mockSection.data.filter(data => data.sectionName === title.title).length} - /> - {section.data - .filter(key => key.sectionName === title.title) - .map(name => ( - <PersonalTask name={name} /> - ))} - </S.FrameStyle> - ))} - </Flex> - </Flex> - </S.SectionBox> - </S.Container> - ); -}; - -export default RetroPersonalPage; diff --git a/src/pages/RevisePage.tsx b/src/pages/RevisePage.tsx index 3d59a5e..8edef0a 100644 --- a/src/pages/RevisePage.tsx +++ b/src/pages/RevisePage.tsx @@ -20,14 +20,14 @@ const RetroRevisePage = () => { const teamId = Number(query[3]); const [retro, setRetro] = useState<RetrospectiveData>(); const [members, setMembers] = useState<TeamMembersData[]>(); - + const [status, setStatus] = useState<string>(); const toast = useCustomToast(); const FetchRetrospective = async () => { try { const data = await RetrospectiveService.onlyGet({ retrospectiveId: retrospectiveId }); setRetro(data.data); - console.log('retro', retro); + setStatus(retro?.status); } catch (e) { toast.error(e); } @@ -35,10 +35,11 @@ const RetroRevisePage = () => { const fetchTeamMembers = async () => { try { - const data = await TeamControllerServices.TeamMemberGet({ teamId: teamId, retrospectiveId: retrospectiveId }); - console.log('data.members', data); - setMembers(data.data); - console.log('members ----', members); + if (teamId) { + const data = await TeamControllerServices.TeamMemberGet({ teamId: teamId, retrospectiveId: retrospectiveId }); + setMembers(data.data); + } + return; } catch (e) { toast.error(e); } @@ -50,7 +51,6 @@ const RetroRevisePage = () => { }, [retro?.status]); if (!retro) return; - if (!members) return; return ( <> @@ -69,10 +69,10 @@ const RetroRevisePage = () => { <TabPanels> <TabPanel> - <ReviseSetting retro={retro} /> + <ReviseSetting retro={retro} status={status} setStatus={setStatus} /> </TabPanel> <TabPanel> - {retro.type === 'TEAM' ? <ManageTeamMembers members={members} teamId={teamId} /> : <NotTeamMemberModal />} + {members ? <ManageTeamMembers members={members} teamId={teamId} /> : <NotTeamMemberModal />} </TabPanel> </TabPanels> </Tabs> diff --git a/src/pages/RetroTeamPage.tsx b/src/pages/SectionPage.tsx similarity index 71% rename from src/pages/RetroTeamPage.tsx rename to src/pages/SectionPage.tsx index b398f81..4d6fa51 100644 --- a/src/pages/RetroTeamPage.tsx +++ b/src/pages/SectionPage.tsx @@ -21,7 +21,6 @@ const RetroTeamPage = () => { const query = search.split(/[=,&]/); const retrospectiveId = Number(query[1]); const teamId = Number(query[3]); - const [section, setSection] = useState<sectionData[]>([]); const [retro, setRetro] = useState<RetrospectiveData>(); const [template, setTemplate] = useState<TemplateNameData[]>(); @@ -40,8 +39,13 @@ const RetroTeamPage = () => { const fetchSection = async () => { try { - const data = await SectionServices.get({ retrospectiveId: retrospectiveId, teamId: teamId }); - setSection(data.data); + if (!teamId) { + const data = await SectionServices.PersonalGet({ retrospectiveId: retrospectiveId }); + setSection(data.data); + } else { + const data = await SectionServices.TeamGet({ retrospectiveId: retrospectiveId, teamId: teamId }); + setSection(data.data); + } } catch (e) { toast.error(e); } @@ -77,20 +81,24 @@ const RetroTeamPage = () => { <Flex> {template ? template.map(title => ( - <S.FrameStyle> - <Label - labelName={title.name} - labelType="dark" - taskCount={section.filter(data => data.sectionName === title.name).length} - /> + <> + <S.FrameStyle> + <Label + labelName={title.name} + labelType="dark" + taskCount={section.filter(data => data.sectionName === title.name).length} + /> - {section - .filter(key => key.sectionName === title.name) - .map(section => ( - <TeamTask section={section} /> - ))} - <AddTask template={title.id} retrospectiveId={retro?.retrospectiveId} /> - </S.FrameStyle> + <AddTask template={title.id} retrospectiveId={retro?.retrospectiveId} /> + {section + .filter(key => key.sectionName === title.name) + .map(section => ( + <> + <TeamTask section={section} /> + </> + ))} + </S.FrameStyle> + </> )) : PersonalSectionTitleName.map(title => ( <S.FrameStyle> @@ -99,13 +107,12 @@ const RetroTeamPage = () => { labelType="dark" taskCount={section.filter(data => data.sectionName === title.title).length} /> - {/* {section - .filter(key => key.sectionName === title.title) - .map(name => ( - <TeamTask name={name} /> - ))} */} </S.FrameStyle> ))} + <S.FrameStyle> + <Label labelName="Action Items" labelType="dark" taskCount={0} /> + <AddTask template={3} retrospectiveId={retro?.retrospectiveId} /> + </S.FrameStyle> </Flex> </Flex> </S.SectionBox> diff --git a/src/styles/RetroList/RetroListPage.style.ts b/src/styles/RetroList/RetroListPage.style.ts index 5233747..d310e7e 100644 --- a/src/styles/RetroList/RetroListPage.style.ts +++ b/src/styles/RetroList/RetroListPage.style.ts @@ -27,9 +27,11 @@ export const SortButtonContainer = styled.div` export const Box = styled.div` padding-left: 40px; padding-right: 40px; + margin: 0 auto; + width: 1000px; `; -export const ControBarContainer = styled.div` +export const ControlBarContainer = styled.div` margin-left: 50px; margin-right: 50px; margin-top: 15px; diff --git a/src/styles/writeRetroStyles/Layout.style.ts b/src/styles/writeRetroStyles/Layout.style.ts index ab8396e..9cf5618 100644 --- a/src/styles/writeRetroStyles/Layout.style.ts +++ b/src/styles/writeRetroStyles/Layout.style.ts @@ -492,3 +492,9 @@ export const ActionItemsUserImg = styled.img` width: 24px; height: 24px; `; + +export const DeleteSectionText = styled.p` + margin: 20px; + color: #111b47; + font-size: 15px; +`;