Skip to content

Commit

Permalink
feat: tanstack query v5 (#98)
Browse files Browse the repository at this point in the history
공지사항 부분부터 점진적 적용
  • Loading branch information
tooooo1 authored Sep 14, 2024
1 parent 4d8c45a commit d7c78f5
Show file tree
Hide file tree
Showing 4 changed files with 62 additions and 62 deletions.
Binary file modified bun.lockb
Binary file not shown.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
"@emotion/react": "^11.13.3",
"@emotion/styled": "^11.13.0",
"@mui/material": "^6.0.1",
"@tanstack/react-query": "^5.56.2",
"axios": "^1.7.5",
"jwt-decode": "^3.1.2",
"react": "^18.3.1",
Expand Down
35 changes: 18 additions & 17 deletions src/main.tsx
Original file line number Diff line number Diff line change
@@ -1,29 +1,28 @@
import './styles/globalStyle.css';

import {
QueryClient as QueryClient5,
QueryClientProvider as QueryClientProvider5,
} from '@tanstack/react-query';
import axios from 'axios';
import AsyncBoundary from 'components/AsyncBoundary';
import { CACHE_TIME } from 'constants/cacheTime';
import { BadGateway } from 'pages';
import React from 'react';
import ReactDOM from 'react-dom/client';
import { initialize } from 'react-ga';
import { QueryClient, QueryClientProvider } from 'react-query';
import {
QueryClient as QueryClient4,
QueryClientProvider as QueryClientProvider4,
} from 'react-query';
import { ReactQueryDevtools } from 'react-query/devtools';
import { RecoilRoot } from 'recoil';

import App from './App';

initialize('G-KG7KQ8K3GP');

export const queryClient = new QueryClient({
defaultOptions: {
queries: {
refetchOnWindowFocus: false,
cacheTime: CACHE_TIME.MINUTE_5,
staleTime: CACHE_TIME.MINUTE_5,
},
},
});
export const queryClient = new QueryClient4();
const queryClient5 = new QueryClient5();
const PROXY_URL = window.location.hostname === 'localhost' ? '/api' : '/proxy';

axios.defaults.baseURL = PROXY_URL;
Expand All @@ -32,12 +31,14 @@ axios.defaults.withCredentials = true;
ReactDOM.createRoot(document.getElementById('root')!).render(
<React.StrictMode>
<AsyncBoundary pendingFallback={<></>} rejectedFallback={() => <BadGateway />}>
<QueryClientProvider client={queryClient}>
<RecoilRoot>
<App />
<ReactQueryDevtools />
</RecoilRoot>
</QueryClientProvider>
<QueryClientProvider4 client={queryClient}>
<QueryClientProvider5 client={queryClient5}>
<RecoilRoot>
<App />
<ReactQueryDevtools />
</RecoilRoot>
</QueryClientProvider5>
</QueryClientProvider4>
</AsyncBoundary>
</React.StrictMode>,
);
88 changes: 43 additions & 45 deletions src/pages/Notice.tsx
Original file line number Diff line number Diff line change
@@ -1,70 +1,66 @@
import styled from '@emotion/styled';
import { useInfiniteQuery } from '@tanstack/react-query';
import { Notice as Notices } from 'api';
import { Spinner } from 'components';
import { Fragment, useEffect } from 'react';
import { useEffect } from 'react';
import { useInView } from 'react-intersection-observer';
import { useInfiniteQuery } from 'react-query';
import { useNavigate } from 'react-router-dom';
import { type NoticeItem } from 'types/notice';

const Item = ({ notice }: { notice: NoticeItem }) => {
const Notice = () => {
const navigate = useNavigate();
const toDetail = () => navigate(`/notice/detail?id=${notice.id}`);

return (
<NoticeWrap onClick={toDetail}>
<Title>{notice.title}</Title>
<Option>{notice.modifiedDate.slice(0, 10)}</Option>
</NoticeWrap>
);
};

export const NoticeContainer = () => {
const notice = Notices();
const { ref, inView } = useInView();
const { data, isLoading, fetchNextPage, isFetchingNextPage } = useInfiniteQuery(
['notice'],
() => notice.list(),
{
getNextPageParam: (lastPage) => {
if (lastPage && !lastPage.isLast) return lastPage.nextPage;
},

const { data, isLoading, fetchNextPage, isFetchingNextPage } = useInfiniteQuery({
queryKey: ['notice'],
queryFn: () => notice.list(),
getNextPageParam: (lastPage) => {
if (lastPage && !lastPage.isLast) return lastPage.nextPage;

return undefined;
},
);
initialData: undefined,
initialPageParam: 1,
});

useEffect(() => {
if (inView) {
fetchNextPage();
}
}, [inView, fetchNextPage]);
if (isLoading || data === undefined) return <Spinner id="notice" />;
if (data.pages.length === 0) return <NoNotice>아직 공지사항이 없어요.</NoNotice>;

return (
<>
{data.pages.map((page, index) => (
<Fragment key={index}>
{page?.data.data.map((notice) => <Item key={notice.id} notice={notice} />)}
</Fragment>
))}
<div ref={ref} style={{ marginBottom: '10px' }}>
{isFetchingNextPage ? <Spinner /> : null}
</div>
</>
);
};

const Notice = () => {
return (
<AppContainer>
<AppTitle>공지사항</AppTitle>
<NoticeContainer />
{isLoading || data === undefined ? (
<Spinner id="notice" />
) : data.pages.length === 0 ? (
<NoNotice>아직 공지사항이 없어요.</NoNotice>
) : (
<NoticeUl>
{data.pages.map((page) =>
page?.data.data.map((notice) => (
<NoticeWrap
key={notice.id}
onClick={() => navigate(`/notice/detail?id=${notice.id}`)}
>
<Title>{notice.title}</Title>
<Option>{notice.modifiedDate.slice(0, 10)}</Option>
</NoticeWrap>
)),
)}
<li ref={ref} style={{ marginBottom: '10px' }}>
{isFetchingNextPage ? <Spinner /> : null}
</li>
</NoticeUl>
)}
</AppContainer>
);
};

export default Notice;

const AppContainer = styled.div`
const AppContainer = styled.section`
display: flex;
flex-direction: column;
align-items: center;
Expand All @@ -85,7 +81,6 @@ const AppTitle = styled.div`
display: flex;
width: 100%;
font-size: 1.5rem;
font-weight: 600;
padding-top: 5rem;
padding-bottom: 1rem;
Expand All @@ -102,11 +97,14 @@ const Option = styled.div`
padding: 0.5rem 0;
font-size: 0.8rem;
color: #a3a3a3;
font-weight: 300;
`;

const NoticeWrap = styled.div`
const NoticeUl = styled.ul`
width: 100%;
`;

const NoticeWrap = styled.li`
width: 100%;
border: 1.5px solid #f1f1f1;
padding: 1.5rem 1.5rem;
Expand Down

0 comments on commit d7c78f5

Please sign in to comment.