diff --git a/frontend/src/apis/checklist.ts b/frontend/src/apis/checklist.ts
index 91de2cf2e..8027445bb 100644
--- a/frontend/src/apis/checklist.ts
+++ b/frontend/src/apis/checklist.ts
@@ -30,7 +30,7 @@ export const getChecklists = async () => {
export const postChecklist = async (checklist: ChecklistPostForm) => {
checklist.room.structure = checklist.room.structure === 'NONE' ? undefined : checklist.room.structure;
checklist.room = mapObjUndefinedToNull(checklist.room);
- const response = await fetcher.post({ url: BASE_URL + ENDPOINT.CHECKLISTS, body: checklist });
+ const response = await fetcher.post({ url: BASE_URL + ENDPOINT.CHECKLISTS_V1, body: checklist });
return response;
};
diff --git a/frontend/src/apis/url.ts b/frontend/src/apis/url.ts
index 9c333cb7a..f5752eb54 100644
--- a/frontend/src/apis/url.ts
+++ b/frontend/src/apis/url.ts
@@ -6,6 +6,7 @@ export const BASE_URL = API_URL;
export const ENDPOINT = {
// checklist
CHECKLISTS: '/checklists',
+ CHECKLISTS_V1: '/v1/checklists',
CHECKLIST_QUESTION: '/checklists/questions',
CHECKLIST_ALL_QUESTION: '/custom-checklist/all',
CHECKLIST_CUSTOM: '/custom-checklist',
@@ -23,5 +24,5 @@ export const ENDPOINT = {
LOGOUT: '/oauth/logout',
USER_INFO: '/user/me',
//subway
- SUBWAY: (position: Position) => `/stations/nearest?latitude=${position.lat}&longitude=${position.lon}`,
+ SUBWAY: (position: Position) => `/stations/nearest?latitude=${position.latitude}&longitude=${position.longitude}`,
};
diff --git a/frontend/src/components/NewChecklist/AddressModal/RealTimeAddressModal.tsx b/frontend/src/components/NewChecklist/AddressModal/RealTimeAddressModal.tsx
index 2918ed58f..79884478d 100644
--- a/frontend/src/components/NewChecklist/AddressModal/RealTimeAddressModal.tsx
+++ b/frontend/src/components/NewChecklist/AddressModal/RealTimeAddressModal.tsx
@@ -14,7 +14,7 @@ import { title4 } from '@/styles/common';
import { Position } from '@/types/address';
const RealTimeAddressModal = () => {
- const DEFAULT_POSITION = { lat: 0, lon: 0 };
+ const DEFAULT_POSITION = { latitude: 0, longitude: 0 };
const roomInfoUnvalidatedActions = useStore(roomInfoNonValidatedStore, state => state.actions);
@@ -28,9 +28,10 @@ const RealTimeAddressModal = () => {
const { searchSubwayStationsByPosition } = useRoomInfoNonValidated();
const handleSubmitAddress = () => {
- if (position.lat && position.lon) {
+ if (position.latitude && position.longitude) {
roomInfoUnvalidatedActions.set('address', currentAddress);
roomInfoUnvalidatedActions.set('buildingName', currentBuildingName);
+ roomInfoUnvalidatedActions.set('position', position);
searchSubwayStationsByPosition(position);
closeModal();
diff --git a/frontend/src/components/_common/Map/AddressMap.tsx b/frontend/src/components/_common/Map/AddressMap.tsx
index e2cd3a519..e8530ec6a 100644
--- a/frontend/src/components/_common/Map/AddressMap.tsx
+++ b/frontend/src/components/_common/Map/AddressMap.tsx
@@ -23,7 +23,7 @@ const AddressMap = ({ location }: { location: string }) => {
kakao.maps.load(() => {
if (!mapContainerRef.current) return;
const mapOption = {
- center: new kakao.maps.LatLng(DEFAULT_POSITION.lat, DEFAULT_POSITION.lon),
+ center: new kakao.maps.LatLng(DEFAULT_POSITION.latitude, DEFAULT_POSITION.longitude),
level: 3,
};
// 지도 생성
diff --git a/frontend/src/components/_common/Map/RealTimeMap.tsx b/frontend/src/components/_common/Map/RealTimeMap.tsx
index 5a35205bb..c90817e83 100644
--- a/frontend/src/components/_common/Map/RealTimeMap.tsx
+++ b/frontend/src/components/_common/Map/RealTimeMap.tsx
@@ -44,7 +44,7 @@ const RealTimeMap = ({
mapRef.current = map;
/*마커 생성*/
- const marker = createMarker(kakao, map, new kakao.maps.LatLng(position.lat, position.lon));
+ const marker = createMarker(kakao, map, new kakao.maps.LatLng(position.latitude, position.longitude));
markerRef.current = marker;
/*인포윈도우 생성*/
@@ -55,7 +55,7 @@ const RealTimeMap = ({
kakao.maps.event.addListener(map, 'click', (mouseEvent: any) => {
const latlng = mouseEvent.latLng;
map.setCenter(latlng);
- setPosition({ lat: latlng.getLat(), lon: latlng.getLng() });
+ setPosition({ latitude: latlng.getLat(), longitude: latlng.getLng() });
if (markerRef.current) {
markerRef.current.setPosition(latlng);
@@ -66,13 +66,13 @@ const RealTimeMap = ({
/* 실시간 위치 찾기 */
const successGeolocation = (position: GeolocationPosition) => {
- const lat = position.coords.latitude;
- const lon = position.coords.longitude;
+ const latitude = position.coords.latitude;
+ const longitude = position.coords.longitude;
- const locPosition = new kakao.maps.LatLng(lat, lon);
+ const locPosition = new kakao.maps.LatLng(latitude, longitude);
const message = `이 위치가 맞나요?`;
- setPosition({ lat, lon });
+ setPosition({ latitude, longitude });
map.setCenter(locPosition);
setRealTimeLocationState('success');
@@ -121,7 +121,7 @@ const RealTimeMap = ({
if (markerRef.current && mapRef.current && realTimeLocationState !== 'loading') {
const { kakao } = window as any;
- const locPosition = new kakao.maps.LatLng(position.lat, position.lon);
+ const locPosition = new kakao.maps.LatLng(position.latitude, position.longitude);
markerRef.current.setPosition(locPosition);
mapRef.current.setCenter(locPosition);
diff --git a/frontend/src/constants/map.ts b/frontend/src/constants/map.ts
index 921b48b8a..b97497122 100644
--- a/frontend/src/constants/map.ts
+++ b/frontend/src/constants/map.ts
@@ -1,4 +1,6 @@
-export const DEFAULT_POSITION = {
- lat: 37.51524850249633,
- lon: 127.10305696808169,
+import { Position } from '@/types/address';
+
+export const DEFAULT_POSITION: Position = {
+ latitude: 37.5061912,
+ longitude: 127.0508228,
};
diff --git a/frontend/src/hooks/useMoveSection.ts b/frontend/src/hooks/useMoveSection.ts
index aace102e8..b861c16da 100644
--- a/frontend/src/hooks/useMoveSection.ts
+++ b/frontend/src/hooks/useMoveSection.ts
@@ -32,9 +32,10 @@ const useMoveSection = (sectionRefs: React.MutableRefObject<(HTMLElement | null)
const sectionHeight = sectionElement.offsetHeight;
const clickYPosition = event.clientY - sectionElement.getBoundingClientRect().top;
- if (clickYPosition < sectionHeight / 2) {
+ if (clickYPosition < sectionHeight * 0.2) {
scrollToPrevSection(index);
- } else {
+ }
+ if (clickYPosition > sectionHeight * 0.8) {
scrollToNextSection(index);
}
};
diff --git a/frontend/src/hooks/useMutateChecklist.ts b/frontend/src/hooks/useMutateChecklist.ts
index 147cdad31..bf3dd5b48 100644
--- a/frontend/src/hooks/useMutateChecklist.ts
+++ b/frontend/src/hooks/useMutateChecklist.ts
@@ -33,36 +33,14 @@ const useMutateChecklist = (
// 체크리스트 답변
const checklistCategoryQnA = useChecklistStore(state => state.checklistCategoryQnA);
- //스토어에서 actions을 제외한 values 만 꺼내오는 함수
- const roomInfoUnvalidatedValues = () => {
- const { actions, ...values } = roomInfoUnvalidated;
- void actions;
- return values;
- };
-
- const roomInfoUnvalidatedAnswer = roomInfoUnvalidatedValues();
-
- function removeKey(obj: T, key: K): Omit {
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
- const { [key]: _, ...rest } = obj;
- return rest;
- }
-
- //TODO: 나중에 해당 키 이름 수정
- const roomInfoUnvalidatedAnswerWithoutSubway = removeKey(roomInfoUnvalidatedAnswer, 'nearSubwayStation');
-
- const formattedUnvalidatedValues = {
- station: roomInfoUnvalidatedAnswer.nearSubwayStation[0]?.stationName,
- walkingTime: roomInfoUnvalidatedAnswer.nearSubwayStation[0]?.walkingTime,
- };
-
const postData = {
room: {
...roomInfoAnswer,
- ...{ ...roomInfoUnvalidatedAnswerWithoutSubway, ...formattedUnvalidatedValues },
+ ...roomInfoUnvalidatedActions.getFormValues(),
},
options: selectedOptions,
questions: transformQuestions(checklistCategoryQnA),
+ geolocation: roomInfoUnvalidated.position,
};
const putData = {
@@ -82,7 +60,6 @@ const useMutateChecklist = (
if (onSuccessCallback) {
onSuccessCallback();
}
-
const location = res.headers.get('location');
if (location) navigate(location);
},
diff --git a/frontend/src/hooks/useRoomInfoNonValidated.ts b/frontend/src/hooks/useRoomInfoNonValidated.ts
index be7c57066..b338e166b 100644
--- a/frontend/src/hooks/useRoomInfoNonValidated.ts
+++ b/frontend/src/hooks/useRoomInfoNonValidated.ts
@@ -2,6 +2,7 @@ import { useStore } from 'zustand';
import { getNearSubways } from '@/apis/subway';
import roomInfoNonValidatedStore from '@/store/roomInfoNonValidatedStore';
+import { Position } from '@/types/address';
/**
useRoomInfoNonValidated : 방 기본정보에서 인풋 형식이 아니고, 검증이 필요없는 필드에 대한
함수를 모아놓은 훅입니다. (주소, 지하철, 관리비, 방구조)
@@ -12,9 +13,10 @@ useRoomInfoNonValidated : 방 기본정보에서 인풋 형식이 아니고, 검
const useRoomInfoNonValidated = () => {
const roomInfoNonValidated = useStore(roomInfoNonValidatedStore, state => state.actions);
- const searchSubwayStationsByPosition = async ({ lat, lon }: { lat: number; lon: number }) => {
- const nearSubways = await getNearSubways({ lat, lon });
- roomInfoNonValidated.set('nearSubwayStation', nearSubways);
+ const searchSubwayStationsByPosition = async ({ latitude, longitude }: Position) => {
+ const nearSubways = await getNearSubways({ latitude, longitude });
+ roomInfoNonValidated.set('position', { latitude, longitude });
+ roomInfoNonValidated.set('nearSubwayStation', nearSubways.stations);
return nearSubways;
};
@@ -28,7 +30,7 @@ const useRoomInfoNonValidated = () => {
geocoder.addressSearch(address, function (result: any, status: any) {
/* 정상적으로 검색이 완료됐으면*/
if (status === kakao.maps.services.Status.OK) {
- return searchSubwayStationsByPosition({ lat: result[0].y, lon: result[0].x });
+ return searchSubwayStationsByPosition({ latitude: result[0].y, longitude: result[0].x });
}
});
});
diff --git a/frontend/src/mocks/handlers/subway.ts b/frontend/src/mocks/handlers/subway.ts
index 971f5a687..fe036fefe 100644
--- a/frontend/src/mocks/handlers/subway.ts
+++ b/frontend/src/mocks/handlers/subway.ts
@@ -4,7 +4,7 @@ import { BASE_URL, ENDPOINT } from '@/apis/url';
import { nearSubway } from '@/mocks/fixtures/subway';
export const SubwayHandlers = [
- http.get(BASE_URL + ENDPOINT.SUBWAY({ lat: 0, lon: 0 }), () => {
+ http.get(BASE_URL + ENDPOINT.SUBWAY({ latitude: 0, longitude: 0 }), () => {
return HttpResponse.json(nearSubway, { status: 200 });
}),
];
diff --git a/frontend/src/pages/ChecklistDetailPage.tsx b/frontend/src/pages/ChecklistDetailPage.tsx
index f40af7a95..ddd10202e 100644
--- a/frontend/src/pages/ChecklistDetailPage.tsx
+++ b/frontend/src/pages/ChecklistDetailPage.tsx
@@ -47,7 +47,7 @@ const ChecklistDetailPage = () => {
/* 정상적으로 검색이 완료됐으면*/
if (status === kakao.maps.services.Status.OK) {
const findSubway = async () => {
- const nearSubways = await getNearSubways({ lat: result[0].y, lon: result[0].x });
+ const nearSubways = await getNearSubways({ latitude: result[0].y, longitude: result[0].x });
setNearSubways(nearSubways);
};
findSubway();
diff --git a/frontend/src/pages/NewChecklistPage.tsx b/frontend/src/pages/NewChecklistPage.tsx
index ae6287a2b..c7fdd9a3c 100644
--- a/frontend/src/pages/NewChecklistPage.tsx
+++ b/frontend/src/pages/NewChecklistPage.tsx
@@ -1,4 +1,3 @@
-import { useNavigate } from 'react-router-dom';
import { useStore } from 'zustand';
import Button from '@/components/_common/Button/Button';
@@ -11,7 +10,6 @@ import MemoButton from '@/components/NewChecklist/MemoModal/MemoButton';
import MemoModal from '@/components/NewChecklist/MemoModal/MemoModal';
import NewChecklistContent from '@/components/NewChecklist/NewChecklistContent';
import SubmitModalWithSummary from '@/components/NewChecklist/SubmitModalWithSummary/SubmitModalWithSummary';
-import { ROUTE_PATH } from '@/constants/routePath';
import { DEFAULT_CHECKLIST_TAB_PAGE } from '@/constants/system';
import useChecklistTabs from '@/hooks/useChecklistTabs';
import useHandleTip from '@/hooks/useHandleTip';
@@ -23,7 +21,6 @@ import useChecklistStore from '@/store/useChecklistStore';
import useSelectedOptionStore from '@/store/useSelectedOptionStore';
const NewChecklistPage = () => {
- const navigate = useNavigate();
useChecklistTemplate(); // 체크리스트 질문 가져오기 및 준비
const { tabs } = useChecklistTabs();
@@ -45,13 +42,12 @@ const NewChecklistPage = () => {
// 로그인 요청 모달
const { isModalOpen: isLoginModalOpen, openModal: openLoginModal, closeModal: closeLoginModal } = useModal();
- const resetAndGoHome = () => {
+ const resetChecklist = () => {
roomInfoActions.resetAll();
roomInfoNonValidatedActions.resetAll();
checklistActions.reset();
selectedOptionActions.reset();
resetShowTip(); // 옵션의 팁박스 다시표시
- navigate(ROUTE_PATH.checklistList);
};
return (
@@ -75,7 +71,7 @@ const NewChecklistPage = () => {
@@ -90,7 +86,7 @@ const NewChecklistPage = () => {
}
isOpen={isAlertModalOpen}
onClose={closeAlertModal}
- handleApprove={resetAndGoHome}
+ handleApprove={resetChecklist}
approveButtonName="나가기"
/>
diff --git a/frontend/src/store/roomInfoNonValidatedStore.ts b/frontend/src/store/roomInfoNonValidatedStore.ts
index 1c635f530..77e93ee31 100644
--- a/frontend/src/store/roomInfoNonValidatedStore.ts
+++ b/frontend/src/store/roomInfoNonValidatedStore.ts
@@ -1,29 +1,40 @@
import { createStore } from 'zustand';
+import { DEFAULT_POSITION } from '@/constants/map';
+import { Position } from '@/types/address';
import { SubwayStation } from '@/types/subway';
interface States {
nearSubwayStation: SubwayStation[];
address: string;
buildingName: string;
+ position: Position;
}
interface Actions {
set: (name: T, value: States[T]) => void;
resetAll: () => void;
+ getFormValues: () => { address: string; buildingName: string };
}
const defaultStates = {
nearSubwayStation: [],
address: '',
buildingName: '',
+ position: DEFAULT_POSITION,
};
-const roomInfoNonValidatedStore = createStore()(set => ({
+const roomInfoNonValidatedStore = createStore()((set, get) => ({
...defaultStates,
actions: {
set: (name, value) => set({ [name]: value }),
resetAll: () => set(defaultStates),
+ getFormValues: () => {
+ return {
+ address: get().address,
+ buildingName: get().buildingName,
+ };
+ },
},
}));
diff --git a/frontend/src/types/address.ts b/frontend/src/types/address.ts
index ecf96b46d..fdc842894 100644
--- a/frontend/src/types/address.ts
+++ b/frontend/src/types/address.ts
@@ -5,8 +5,8 @@ export interface Address {
}
export interface Position {
- lat: number;
- lon: number;
+ latitude: number;
+ longitude: number;
}
export interface OpenOptions {
diff --git a/frontend/src/types/checklist.ts b/frontend/src/types/checklist.ts
index a64a4f7cf..d060060ee 100644
--- a/frontend/src/types/checklist.ts
+++ b/frontend/src/types/checklist.ts
@@ -1,3 +1,4 @@
+import { Position } from '@/types/address';
import { AnswerType } from '@/types/answer';
import { Category } from '@/types/category';
import { Option } from '@/types/option';
@@ -76,6 +77,7 @@ export interface ChecklistPostForm {
room: RoomInfo;
options: number[];
questions: AnswerPostForm[];
+ geolocation?: Position; //TODO: 나중에 지우기
}
export type MutateType = 'add' | 'edit';
diff --git a/frontend/src/utils/createKakaoMapElements.ts b/frontend/src/utils/createKakaoMapElements.ts
index 090835254..068af9982 100644
--- a/frontend/src/utils/createKakaoMapElements.ts
+++ b/frontend/src/utils/createKakaoMapElements.ts
@@ -1,4 +1,5 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
+
import { DEFAULT_POSITION } from '@/constants/map';
const createKakaoMapElements = () => {
@@ -6,7 +7,7 @@ const createKakaoMapElements = () => {
const container = document.getElementById('map');
if (!container) return;
- const center = new kakao.maps.LatLng(DEFAULT_POSITION.lat, DEFAULT_POSITION.lon);
+ const center = new kakao.maps.LatLng(DEFAULT_POSITION.latitude, DEFAULT_POSITION.longitude);
const options = {
center,