Skip to content

Commit

Permalink
fix: 나눔 목록 조회 무한 스크롤 적용
Browse files Browse the repository at this point in the history
  • Loading branch information
hyeseon-han committed Feb 23, 2024
1 parent f51ea86 commit 076b029
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 50 deletions.
12 changes: 10 additions & 2 deletions src/hooks/queries/queryKeys.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import type { FriendshipSortType } from '@/types/friendship';
import type {
FriendshipSortType,
ShareSortType,
ShareStatusType,
} from '@/types/friendship';

export const queryKeys = {
MY_FRIDGE_LIST: () => ['my_fridge_list'],
Expand All @@ -8,7 +12,11 @@ export const queryKeys = {
INGREDIENT_ID: (id: number) => ['ingredient', id],
INGREDIENTS: () => ['my-ingredient'],
KAKAO: () => ['kakao'],
SHARES: () => ['shares'],
SHARES: (sort: ShareSortType, status: ShareStatusType) => [
'shares',
sort,
status,
],
ME: () => ['my-info'],
FRIENDSHIPS: (sort: FriendshipSortType) => ['friendship', sort],
DELETE_FRIENDSHIP: () => ['deleteFriendship'],
Expand Down
17 changes: 14 additions & 3 deletions src/hooks/queries/share/useGetShares.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,18 @@
import { type ShareStatusType, type ShareSortType } from '@/types/friendship';
import { queryKeys } from '../queryKeys';
import { useBaseQuery } from '../useBaseQuery';
import { useBaseInfiniteQuery } from '../useBaseInfiniteQuery';

const useGetShares = () =>
useBaseQuery<ShareData[]>(queryKeys.SHARES(), '/shares', true);
const useGetShares = ({
sort,
status,
}: {
sort: ShareSortType;
status: ShareStatusType;
}) =>
useBaseInfiniteQuery<ShareData[]>({
queryKey: queryKeys.SHARES(sort, status),
url: '/shares',
params: { sort, status },
});

export default useGetShares;
86 changes: 41 additions & 45 deletions src/pages/share/index.tsx
Original file line number Diff line number Diff line change
@@ -1,63 +1,55 @@
import { RadioButtonField, SortButton, TabButton } from '@/components/atoms';
import Header from '@/components/organisms/Header';
import ShareListItem from '@/components/organisms/ShareListItem';
import { type NextPage } from 'next';
import { useState } from 'react';
import {
Modal,
ModalOverlay,
ModalBody,
ModalContent,
ModalOverlay,
useDisclosure,
} from '@chakra-ui/react';
import { PlusIcon } from '@/assets/icons';
import { type SortLabel, type TabLabel } from '@/types/common';
import dayjs from 'dayjs';
import { RadioButtonField, SortButton, TabButton } from '@/components/atoms';
import type { ShareSortType, ShareStatusType } from '@/types/friendship';
import type { SortLabel, TabLabel } from '@/types/common';
import { useRef, useState } from 'react';

import Header from '@/components/organisms/Header';
import Link from 'next/link';
import { useGetShares } from '@/hooks/queries/share';
import type { NextPage } from 'next';
import { PlusIcon } from '@/assets/icons';
import ShareListItem from '@/components/organisms/ShareListItem';
import { SuspenseFallback } from '@/components/templates';
import { useGetShares } from '@/hooks/queries/share';
import { useObserver } from '@/hooks/useObserver';

const TABS: TabLabel[] = [
{ label: '나눔 신청', value: 'enroll' },
{ label: '나눔 중', value: 'proceeding' },
{ label: '나눔 완료', value: 'complete' },
{ label: '나눔 신청', value: 'SHARE_START' },
{ label: '나눔 중', value: 'SHARE_IN_PROGRESS' },
{ label: '나눔 완료', value: 'SHARE_END' },
];

const SORT_TYPES: SortLabel[] = [
{ label: '최신순', value: 'latest' },
{ label: '마감순', value: 'earliest' },
{ label: '최신순', value: 'registeredDate' },
{ label: '마감순', value: 'dueDate' },
];

const MOCK_DATA = {
count: 2,
data: [
{
id: 1,
thumbnail: null,
title: '사과 받아갈 사람',
location: '공덕역',
date: dayjs('2024-12-14 10:35'),
},
{
id: 2,
thumbnail: null,
title: '사과 받아갈 사람',
location: '디지털미디어시티역',
date: dayjs('2024-12-14 10:35'),
},
],
};

const SharePage: NextPage = () => {
const [curTab, setCurTab] = useState<TabLabel>(TABS[0]);
const [curSortType, setCurSortType] = useState<SortLabel>(SORT_TYPES[0]);
const { isOpen, onOpen, onClose } = useDisclosure();
const { data } = useGetShares();
console.log(data?.data);
const bottom = useRef<HTMLDivElement>(null);
const { data, fetchNextPage, isFetchingNextPage } = useGetShares({
sort: curSortType.value as ShareSortType,
status: curTab.value as ShareStatusType,
});

if (!data?.data) {
return <SuspenseFallback />;
}
const onIntersect: IntersectionObserverCallback = ([entry]) => {
if (entry.isIntersecting) {
void fetchNextPage();
}
};

useObserver({
target: bottom,
onIntersect,
});

return (
<>
Expand All @@ -78,16 +70,20 @@ const SharePage: NextPage = () => {
</div>
<div className="h-[1px] mt-[-1px] bg-gray1" />
<div className="flex justify-between px-[20px] py-[18px] bg-white body1-medium">
<p className="body1-medium">{MOCK_DATA.count}</p>
<p className="body1-medium">{data?.pages[0].totalElements}</p>
<SortButton label={curSortType.label} onClick={onOpen} />
</div>
</div>

<div className="pt-[128px] px-[20px]">
{data?.data.map((ele) => (
<ShareListItem key={ele.shareId} data={ele} />
))}
<div className="flex flex-col flex-1 overflow-y-auto pt-[128px] px-[20px]">
{data?.pages.map((page) =>
page.content.map((ele: ShareData) => (
<ShareListItem key={ele.shareId} data={ele} />
)),
)}
{isFetchingNextPage ? <SuspenseFallback /> : <div ref={bottom} />}
</div>

<div className="flex justify-end pr-[20px]">
<Link
href={'/add-share'}
Expand Down

0 comments on commit 076b029

Please sign in to comment.