From 5e5ec149138e799c35b932e09c5d67a0e41bc2e5 Mon Sep 17 00:00:00 2001 From: Harang Date: Sat, 16 Mar 2024 11:26:07 +0900 Subject: [PATCH] =?UTF-8?q?feat:=20=EC=A0=80=EC=9E=A5=ED=95=9C=20=EC=9E=A5?= =?UTF-8?q?=EC=86=8C=20=EB=AA=A9=EB=A1=9D=20SavedPlace=20=EC=BB=B4?= =?UTF-8?q?=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EA=B5=AC=ED=98=84=20(#286)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 로그인 한 사용자 > 저장한 장소 목록이 메뉴 바텀시트에 노출 --- .../map/MenuBottomSheet/index.module.scss | 5 +- src/components/map/MenuBottomSheet/index.tsx | 63 +++++----- .../map/SavedPlaces/index.module.scss | 90 ++++++++++++++ src/components/map/SavedPlaces/index.tsx | 113 ++++++++++++++++++ 4 files changed, 241 insertions(+), 30 deletions(-) create mode 100644 src/components/map/SavedPlaces/index.module.scss create mode 100644 src/components/map/SavedPlaces/index.tsx diff --git a/src/components/map/MenuBottomSheet/index.module.scss b/src/components/map/MenuBottomSheet/index.module.scss index 08e32771..c39d74f5 100644 --- a/src/components/map/MenuBottomSheet/index.module.scss +++ b/src/components/map/MenuBottomSheet/index.module.scss @@ -4,14 +4,14 @@ display: flex; flex-direction: column; gap: 24px; - padding: 8px 24px 80px; + padding: 0 0 80px; height: 100%; .loginMenu { display: flex; flex-direction: row; gap: 16px; - padding: 8px 0; + padding: 16px 24px; align-items: center; border: none; background-color: color("white/primary"); @@ -63,6 +63,7 @@ .contents { display: flex; padding: 64px 24px; + margin: 0 24px; justify-content: center; align-items: center; border-radius: 12px; diff --git a/src/components/map/MenuBottomSheet/index.tsx b/src/components/map/MenuBottomSheet/index.tsx index d0071cad..c4f09c23 100644 --- a/src/components/map/MenuBottomSheet/index.tsx +++ b/src/components/map/MenuBottomSheet/index.tsx @@ -12,6 +12,8 @@ import { ChevronRightIcon } from '@/lib/assets/icons'; import { User } from '@/lib/types/auth'; import useToastStore from '@/stores/toast'; +import SavedPlaces from '../SavedPlaces'; + import styles from './index.module.scss'; type Props = { @@ -63,38 +65,43 @@ function MenuBottomSheet({ onToggleMenu, user }: Props) { >
{user ? ( -
-
- {user?.profile_image_url ? ( - {user.email} - ) : ( - profile - )} -
{user.nickname}
+ <> +
+
+ {user?.profile_image_url ? ( + {user.email} + ) : ( + profile + )} +
{user.nickname}
+
+
- -
+ + ) : ( - +
+ some contents..
- - + )} -
- some contents.. -
이용약관 • diff --git a/src/components/map/SavedPlaces/index.module.scss b/src/components/map/SavedPlaces/index.module.scss new file mode 100644 index 00000000..766ba4f3 --- /dev/null +++ b/src/components/map/SavedPlaces/index.module.scss @@ -0,0 +1,90 @@ +@import "/src/styles/main"; + +.savedPlacesWrapper { + margin: 0; + padding: 0; + list-style: none; + display: flex; + flex-direction: column; + width: 100%; + + .savedPlaceItem { + width: 100%; + padding: 24px; + display: flex; + flex-direction: column; + gap: 16px; + + &:not(:last-of-type) { + border-bottom: 1px solid color('gray/tertiary'); + } + + .photos { + display: flex; + flex-flow: row nowrap; + gap: 12px; + overflow-y: auto; + margin-right: -24px; + + .photo { + border-radius: 8px; + min-width: 160px; + min-height: 160px; + + &:last-of-type { + margin-right: 24px; + } + } + } + + .placeInfoWrapper { + display: flex; + flex-direction: column; + gap: 6px; + width: 100%; + + .placeName { + display: flex; + flex-direction: row; + width: 100%; + justify-content: space-between; + align-items: center; + + @include text('title 1/600', 'black/default'); + } + + .placeRatingWrapper { + display: flex; + flex-direction: row; + align-items: center; + gap: 4px; + + .placeRating { + @include text('title 3/600', 'black/default'); + } + + .placeUserRatingsTotal { + @include text('title 3/500', 'black/secondary'); + } + } + + .addressInfo { + display: flex; + flex-direction: row; + gap: 6px; + + @include text('title 3/500', 'black/secondary'); + + .nation, .distance { + min-width: fit-content; + } + + .address { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + } + } + } + } +} diff --git a/src/components/map/SavedPlaces/index.tsx b/src/components/map/SavedPlaces/index.tsx new file mode 100644 index 00000000..5618e008 --- /dev/null +++ b/src/components/map/SavedPlaces/index.tsx @@ -0,0 +1,113 @@ +import Image from 'next/image'; + +import { checkNumber } from '@nf-team/core'; + +import Button from '@/components/common/Button'; +import StarRating from '@/components/common/StarRating'; +import { ArchiveSolidIcon } from '@/lib/assets/icons'; + +import styles from './index.module.scss'; + +// NOTE - 임시 데이터 +const mockSavedPlaces = [ + { + id: 'ChIJaVDnv46RQTURWuJE01tjUGk', + name: '하카타라멘 신신 텐진본점', + rating: 4.2, + user_ratings_total: 5598, + nation: '일본', + address: '3 Chome-2-19 Tenjin, Chuo Ward, Fukuoka, 810-0001', + distance: '5km', + photoUrls: [ + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZC8FXvzKF21twvZieHl8ZHnXyU-kOrGopGj7C4tmbXabX9cdMGSiJh5el-l9NN2GNxkaDcnHIm7oi23yOZBw1jL6ydwteSHguJd5koq-16YN0XOyAypdk6AT6cnkYiqAeEVOUNrl9x_k1EDF8R_Wf0xC57Vw_M8i4STK2yNHkrzOm_&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbWe0tjd-C--ZT-vZhAbSVbTLYB7FauODAdUaB1M6LrTQ-gX8I1X61kfCIkAHoAlFjN8irDkE9a7R9E_rlfcNbosuToo0NsmlKXXvgoL6qfdIlkULdeZwgYdb2uvbNwPZ-vEGHl-Jqzbm1ugevdhRWU53xzQa7ry91mY4AP74wfkDTb&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJay_jbLePKR4uuuhLi7uNpmxH_G1zoMUExg2YRAI1V-8PQWQnIZjy2hSAcKoqsPkM5tnA0ve0VmNhffvYFTjxMz0qHjHXWDKlKugIGjQwMXLBOQpVl_D0V0xhsRAuze8IudCp8pwxQrVVpxtup0eP6QXYIBXaCmuEoCq-md9LP01sU&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJapRNGuJLGDiqAZOoLaj9B6Vx9H9KlLXmgdhpzRGdgWm55Nq5Mu8uYTVHKFQQmARhByly9XMIhXgI_ZCveAlyfamVU2I0ijw3VUyrvJDigRSo6TRioE5vId6joK2KTRGBTCmzx8S7d8_ZdhTLOb0rLUW7C0FQBQAUHiEDyaxTbavWDL&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYBPRRrJTBFBvKwTVkRZERSPRlEnK2lE1ckCXV63WbbbOerg-Mfpb9vHLRSyzKYV6M6P7r0vHjmyHBEzmb2hsBe2GlSLEuP0Ka228FuHEFSMz6T5miiW6Y9Mz8JmjkHSlpNZkQYbKQyXLoK7unkeYBqbGbs5P8JJwMsVa-gBgzs-cs&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbpJQlsYUN7EJGmu5pfx6Ok7Lh2s981wWKUO_oL6Pd6ChApFsk7wA_B0YNaprrVfaHLBNmuu62W1W3lJQyqkaVYMcLVai13OoseveFJRNZfbTtXPslX2QbJ4g2IGVmfyEbREsZtHY0xFLDxbd5yR8akq1xyHJk_mltiXNEQjT7El4zS&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ6m4smpK2kpix1_Ja9EY0Yr8ak4NUT6CjLal238GmDnr7hFLBaPxnS57JNP8S1y-HdgWrRps9-5BDlQPlqDcz8KkaAt5DtfkaXGD9XzHO1Ng6-DQjkjRxcCSSvm0pApkq5lepF-bE82egbw6hVRvPQH6WB0ND_qaJFbaNJOXDxdciw&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbRprvESUMTjVM6OefYgM4Gc0AlixsOJr6ie8Sbe-4TgH_K4d16-L1MLE6SFiRgRP4Rpji_d_jt7-pemM71aARpslu5Q-7oFSqU7p_i4HGvFIYuhopIGsxK0nMddzP2Zt7haREWtQqRJ5-697ab0T-Ap9l--fNnfcw5kQK5cwnvxI1d&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ3QbrQ4HM--SCosdmNG5CSLRuCKcuHTxKGJT3z6id5u_yDigoG2Uj5DC2zgy02HqNBDOYsGUChPkobOGSVer32ygCQsRwpaJQFmHbpA2bF_chsldgezbRm4_vZ4QOBwiOmVTTIneCN6ac0au52T9aGntTStBh_eeBqj9KAmARRE7Df&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYef3EojHmg5Lx6Pk-3QxIIMsgYpxHrG6esj5bM_S_CewOhDojsMcB1mLIJmcsw5vC1XpNZPKOzXISbaAZURP4k7tw-TAsQhKmaN7Gsz2AYYHuyAvDs_ajPyp55RE9AJkw7vsJv2M4r3jYF9spSKyajOr8vvZFEZdoB-UPKidJmf0rX&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + ], + }, + { + id: '2', + name: '하카타라멘 신신 텐진본점', + rating: 4.2, + user_ratings_total: 5598, + nation: '일본', + address: '3 Chome-2-19 Tenjin, Chuo Ward, Fukuoka, 810-0001', + distance: '5km', + photoUrls: [ + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZC8FXvzKF21twvZieHl8ZHnXyU-kOrGopGj7C4tmbXabX9cdMGSiJh5el-l9NN2GNxkaDcnHIm7oi23yOZBw1jL6ydwteSHguJd5koq-16YN0XOyAypdk6AT6cnkYiqAeEVOUNrl9x_k1EDF8R_Wf0xC57Vw_M8i4STK2yNHkrzOm_&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbWe0tjd-C--ZT-vZhAbSVbTLYB7FauODAdUaB1M6LrTQ-gX8I1X61kfCIkAHoAlFjN8irDkE9a7R9E_rlfcNbosuToo0NsmlKXXvgoL6qfdIlkULdeZwgYdb2uvbNwPZ-vEGHl-Jqzbm1ugevdhRWU53xzQa7ry91mY4AP74wfkDTb&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJay_jbLePKR4uuuhLi7uNpmxH_G1zoMUExg2YRAI1V-8PQWQnIZjy2hSAcKoqsPkM5tnA0ve0VmNhffvYFTjxMz0qHjHXWDKlKugIGjQwMXLBOQpVl_D0V0xhsRAuze8IudCp8pwxQrVVpxtup0eP6QXYIBXaCmuEoCq-md9LP01sU&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJapRNGuJLGDiqAZOoLaj9B6Vx9H9KlLXmgdhpzRGdgWm55Nq5Mu8uYTVHKFQQmARhByly9XMIhXgI_ZCveAlyfamVU2I0ijw3VUyrvJDigRSo6TRioE5vId6joK2KTRGBTCmzx8S7d8_ZdhTLOb0rLUW7C0FQBQAUHiEDyaxTbavWDL&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYBPRRrJTBFBvKwTVkRZERSPRlEnK2lE1ckCXV63WbbbOerg-Mfpb9vHLRSyzKYV6M6P7r0vHjmyHBEzmb2hsBe2GlSLEuP0Ka228FuHEFSMz6T5miiW6Y9Mz8JmjkHSlpNZkQYbKQyXLoK7unkeYBqbGbs5P8JJwMsVa-gBgzs-cs&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbpJQlsYUN7EJGmu5pfx6Ok7Lh2s981wWKUO_oL6Pd6ChApFsk7wA_B0YNaprrVfaHLBNmuu62W1W3lJQyqkaVYMcLVai13OoseveFJRNZfbTtXPslX2QbJ4g2IGVmfyEbREsZtHY0xFLDxbd5yR8akq1xyHJk_mltiXNEQjT7El4zS&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ6m4smpK2kpix1_Ja9EY0Yr8ak4NUT6CjLal238GmDnr7hFLBaPxnS57JNP8S1y-HdgWrRps9-5BDlQPlqDcz8KkaAt5DtfkaXGD9XzHO1Ng6-DQjkjRxcCSSvm0pApkq5lepF-bE82egbw6hVRvPQH6WB0ND_qaJFbaNJOXDxdciw&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbRprvESUMTjVM6OefYgM4Gc0AlixsOJr6ie8Sbe-4TgH_K4d16-L1MLE6SFiRgRP4Rpji_d_jt7-pemM71aARpslu5Q-7oFSqU7p_i4HGvFIYuhopIGsxK0nMddzP2Zt7haREWtQqRJ5-697ab0T-Ap9l--fNnfcw5kQK5cwnvxI1d&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ3QbrQ4HM--SCosdmNG5CSLRuCKcuHTxKGJT3z6id5u_yDigoG2Uj5DC2zgy02HqNBDOYsGUChPkobOGSVer32ygCQsRwpaJQFmHbpA2bF_chsldgezbRm4_vZ4QOBwiOmVTTIneCN6ac0au52T9aGntTStBh_eeBqj9KAmARRE7Df&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYef3EojHmg5Lx6Pk-3QxIIMsgYpxHrG6esj5bM_S_CewOhDojsMcB1mLIJmcsw5vC1XpNZPKOzXISbaAZURP4k7tw-TAsQhKmaN7Gsz2AYYHuyAvDs_ajPyp55RE9AJkw7vsJv2M4r3jYF9spSKyajOr8vvZFEZdoB-UPKidJmf0rX&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + ], + }, { + id: '3', + name: '하카타라멘 신신 텐진본점', + rating: 4.2, + user_ratings_total: 5598, + nation: '일본', + address: '3 Chome-2-19 Tenjin, Chuo Ward, Fukuoka, 810-0001', + distance: '5km', + photoUrls: [ + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZC8FXvzKF21twvZieHl8ZHnXyU-kOrGopGj7C4tmbXabX9cdMGSiJh5el-l9NN2GNxkaDcnHIm7oi23yOZBw1jL6ydwteSHguJd5koq-16YN0XOyAypdk6AT6cnkYiqAeEVOUNrl9x_k1EDF8R_Wf0xC57Vw_M8i4STK2yNHkrzOm_&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbWe0tjd-C--ZT-vZhAbSVbTLYB7FauODAdUaB1M6LrTQ-gX8I1X61kfCIkAHoAlFjN8irDkE9a7R9E_rlfcNbosuToo0NsmlKXXvgoL6qfdIlkULdeZwgYdb2uvbNwPZ-vEGHl-Jqzbm1ugevdhRWU53xzQa7ry91mY4AP74wfkDTb&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJay_jbLePKR4uuuhLi7uNpmxH_G1zoMUExg2YRAI1V-8PQWQnIZjy2hSAcKoqsPkM5tnA0ve0VmNhffvYFTjxMz0qHjHXWDKlKugIGjQwMXLBOQpVl_D0V0xhsRAuze8IudCp8pwxQrVVpxtup0eP6QXYIBXaCmuEoCq-md9LP01sU&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJapRNGuJLGDiqAZOoLaj9B6Vx9H9KlLXmgdhpzRGdgWm55Nq5Mu8uYTVHKFQQmARhByly9XMIhXgI_ZCveAlyfamVU2I0ijw3VUyrvJDigRSo6TRioE5vId6joK2KTRGBTCmzx8S7d8_ZdhTLOb0rLUW7C0FQBQAUHiEDyaxTbavWDL&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYBPRRrJTBFBvKwTVkRZERSPRlEnK2lE1ckCXV63WbbbOerg-Mfpb9vHLRSyzKYV6M6P7r0vHjmyHBEzmb2hsBe2GlSLEuP0Ka228FuHEFSMz6T5miiW6Y9Mz8JmjkHSlpNZkQYbKQyXLoK7unkeYBqbGbs5P8JJwMsVa-gBgzs-cs&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbpJQlsYUN7EJGmu5pfx6Ok7Lh2s981wWKUO_oL6Pd6ChApFsk7wA_B0YNaprrVfaHLBNmuu62W1W3lJQyqkaVYMcLVai13OoseveFJRNZfbTtXPslX2QbJ4g2IGVmfyEbREsZtHY0xFLDxbd5yR8akq1xyHJk_mltiXNEQjT7El4zS&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ6m4smpK2kpix1_Ja9EY0Yr8ak4NUT6CjLal238GmDnr7hFLBaPxnS57JNP8S1y-HdgWrRps9-5BDlQPlqDcz8KkaAt5DtfkaXGD9XzHO1Ng6-DQjkjRxcCSSvm0pApkq5lepF-bE82egbw6hVRvPQH6WB0ND_qaJFbaNJOXDxdciw&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJbRprvESUMTjVM6OefYgM4Gc0AlixsOJr6ie8Sbe-4TgH_K4d16-L1MLE6SFiRgRP4Rpji_d_jt7-pemM71aARpslu5Q-7oFSqU7p_i4HGvFIYuhopIGsxK0nMddzP2Zt7haREWtQqRJ5-697ab0T-Ap9l--fNnfcw5kQK5cwnvxI1d&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJZ3QbrQ4HM--SCosdmNG5CSLRuCKcuHTxKGJT3z6id5u_yDigoG2Uj5DC2zgy02HqNBDOYsGUChPkobOGSVer32ygCQsRwpaJQFmHbpA2bF_chsldgezbRm4_vZ4QOBwiOmVTTIneCN6ac0au52T9aGntTStBh_eeBqj9KAmARRE7Df&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + 'https://maps.googleapis.com/maps/api/place/photo?maxwidth=320&photoreference=ATplDJYef3EojHmg5Lx6Pk-3QxIIMsgYpxHrG6esj5bM_S_CewOhDojsMcB1mLIJmcsw5vC1XpNZPKOzXISbaAZURP4k7tw-TAsQhKmaN7Gsz2AYYHuyAvDs_ajPyp55RE9AJkw7vsJv2M4r3jYF9spSKyajOr8vvZFEZdoB-UPKidJmf0rX&key=AIzaSyCffnehwypiJPvue78phUakY-w37xoFINw', + ], + }, +]; + +function SavedPlaces() { + return ( +
    + {mockSavedPlaces.map(({ + id, photoUrls, name, rating, user_ratings_total, nation, address, distance, + }) => ( +
  • +
    + {photoUrls.map((photo, index) => ( + {`${name}-image-${index}`} + ))} +
    +
    +
    +
    {name}
    +
    +
    +
    {rating}
    + +
    {`(${checkNumber(user_ratings_total)})`}
    +
    +
    +
    {nation}
    +
    +
    {address}
    +
    +
    {distance}
    +
    +
    +
  • + ))} +
+ ); +} + +export default SavedPlaces;