From 7d10e311257f3dc85a47ca25045f15b8f7cdc8fa Mon Sep 17 00:00:00 2001 From: Jungu Lee <100949102+jobkaeHenry@users.noreply.github.com> Date: Thu, 4 Jan 2024 22:22:40 +0900 Subject: [PATCH] =?UTF-8?q?New=20:=20=ED=99=88=ED=99=94=EB=A9=B4=20?= =?UTF-8?q?=EC=9D=B8=EA=B8=B0=EA=B2=8C=EC=8B=9C=EA=B8=80=20=ED=86=A0?= =?UTF-8?q?=EA=B8=80=20=EC=B6=94=EA=B0=80=20(#89)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../(protectedRoute)/edit-post/[pid]/page.tsx | 18 +++++++--- client/src/app/page.tsx | 10 ++---- .../components/CustomToggleButtonGroup.tsx | 2 +- .../src/components/layout/CustomContainer.tsx | 6 ++-- .../src/components/post/MainPagePostList.tsx | 32 +++++++++++++++++ .../post/useGetPostListInfiniteQuery.tsx | 36 ++++++++++++++++++- 6 files changed, 87 insertions(+), 17 deletions(-) create mode 100644 client/src/components/post/MainPagePostList.tsx diff --git a/client/src/app/(protectedRoute)/edit-post/[pid]/page.tsx b/client/src/app/(protectedRoute)/edit-post/[pid]/page.tsx index 29845a7..3e07de4 100644 --- a/client/src/app/(protectedRoute)/edit-post/[pid]/page.tsx +++ b/client/src/app/(protectedRoute)/edit-post/[pid]/page.tsx @@ -11,18 +11,26 @@ import CustomAppbar from "@/components/layout/CustomAppbar"; import CustomContainer from "@/components/layout/CustomContainer"; import useSubmitEditPostMutation from "@/queries/newPost/useSubmitEditPostMutation"; import PostEditor from "@/components/newpost/PostEditor"; -import useGetPostDetailQuery, { useInvalidatePostDetail } from "@/queries/post/useGetPostDetailQuery"; +import useGetPostDetailQuery, { + useInvalidatePostDetail, +} from "@/queries/post/useGetPostDetailQuery"; export default function EditPostPage({ params }: { params: { pid: string } }) { const { setLoading } = useGlobalLoadingStore(); const router = useRouter(); const invalidatePreviousPost = useInvalidatePostList(); - const invalidatePostDetail = useInvalidatePostDetail() + const invalidatePostDetail = useInvalidatePostDetail(); const { data: initialData } = useGetPostDetailQuery(params.pid); - const { alcoholName, alcoholNo, alcoholType, postContent, postAttachUrls,postNo } = - initialData; + const { + alcoholName, + alcoholNo, + alcoholType, + postContent, + postAttachUrls, + postNo, + } = initialData; const [formData, setFormData] = useState(); const [file, setFile] = useState(); @@ -31,7 +39,7 @@ export default function EditPostPage({ params }: { params: { pid: string } }) { onMutate: () => setLoading(true), onSuccess: () => { invalidatePreviousPost(); - invalidatePostDetail(String(postNo)) + invalidatePostDetail(String(postNo)); router.push(HOME); }, onSettled: () => setLoading(false), diff --git a/client/src/app/page.tsx b/client/src/app/page.tsx index 97bcbc3..7729366 100644 --- a/client/src/app/page.tsx +++ b/client/src/app/page.tsx @@ -1,6 +1,6 @@ "use server"; -import CustomContainer from "@/components/layout/CustomContainer"; -import PostCardList from "@/components/post/PostCardList"; + +import MainPagePostList from "@/components/post/MainPagePostList"; import { getPostListQueryFn } from "@/queries/post/useGetPostListInfiniteQuery"; import getTokenFromCookies from "@/utils/getTokenFromCookies"; @@ -13,9 +13,5 @@ export default async function Home() { headers: { Authorization: accessToken }, }); - return ( - - - - ); + return ; } diff --git a/client/src/components/CustomToggleButtonGroup.tsx b/client/src/components/CustomToggleButtonGroup.tsx index e042fc2..b23337d 100644 --- a/client/src/components/CustomToggleButtonGroup.tsx +++ b/client/src/components/CustomToggleButtonGroup.tsx @@ -32,7 +32,7 @@ const CustomToggleButtonGroup = ({ onChange(val); } }} - sx={{ backgroundColor: "background.paper",px:2, ...sx }} + sx={{ backgroundColor: "background.paper",px:2, borderRadius:0,...sx }} {...toggleBtnGroupProps} > {value.map((val, i) => { diff --git a/client/src/components/layout/CustomContainer.tsx b/client/src/components/layout/CustomContainer.tsx index ae95642..7c3d63b 100644 --- a/client/src/components/layout/CustomContainer.tsx +++ b/client/src/components/layout/CustomContainer.tsx @@ -2,17 +2,17 @@ import { appbarHeight, navbarHeight } from "@/const/uiSizes"; import { Container, ContainerProps, Paper } from "@mui/material"; interface CustomContainerInterface extends ContainerProps { - disableMt?: boolean; + mt?: number; } const CustomContainer = ({ sx, - disableMt, + mt, children, }: CustomContainerInterface) => { return ( { + const selectableList = ["전체 캐스크", "인기"]; + const [currentView, setCurrentView] = useState(selectableList[0]); + + return ( + <> + + + {currentView==="전체 캐스크"&&} + {currentView==="인기"&&} + + + ); +}; + +export default MainPagePostList; diff --git a/client/src/queries/post/useGetPostListInfiniteQuery.tsx b/client/src/queries/post/useGetPostListInfiniteQuery.tsx index e62f68f..615dbad 100644 --- a/client/src/queries/post/useGetPostListInfiniteQuery.tsx +++ b/client/src/queries/post/useGetPostListInfiniteQuery.tsx @@ -16,6 +16,9 @@ export const useGetPostListInfiniteQuery = ({ size, searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort, headers, }: UseGetPostListQueryInterface) => { @@ -23,6 +26,9 @@ export const useGetPostListInfiniteQuery = ({ queryKey: getPostListInfiniteQueryKey.byKeyword({ searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort, }), @@ -32,6 +38,9 @@ export const useGetPostListInfiniteQuery = ({ size, searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort, headers: headers?.Authorization ? headers @@ -61,6 +70,9 @@ export interface GetPostListOptions { sort?: string; searchKeyword?: string; searchUserNos?: string; + isLikedByMe?: boolean; + isCommentedByMe?: boolean; + searchAlcoholNos?: number; } /** * 서버응답값 + 무한스크롤을 위해 증강된 값 @@ -75,6 +87,9 @@ export const getPostListQueryFn = async ({ size = 10, searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort, headers, }: GetPostListOptions & { @@ -90,6 +105,9 @@ export const getPostListQueryFn = async ({ size, searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort: sort ?? "lastModifiedDate,desc", }, headers, @@ -105,6 +123,9 @@ export const getPostListQueryFn = async ({ export interface PostListInfiniteQueryKey { keyword?: string; userNo?: string; + isLikedByMe?: boolean; + isCommentedByMe?: boolean; + searchAlcoholNos?: number; sort?: string; } @@ -113,9 +134,22 @@ export const getPostListInfiniteQueryKey = { byKeyword: ({ searchKeyword, searchUserNos, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, sort, }: Omit) => - ["posts", { searchKeyword, searchUserNos, sort }] as const, + [ + "posts", + { + searchKeyword, + searchUserNos, + sort, + isLikedByMe, + isCommentedByMe, + searchAlcoholNos, + }, + ] as const, }; /**