diff --git a/packages/frontend/src/apis/queries/alarm/useGetAlarm.ts b/packages/frontend/src/apis/queries/alarm/useGetAlarm.ts index 0d45652d..b5168ef3 100644 --- a/packages/frontend/src/apis/queries/alarm/useGetAlarm.ts +++ b/packages/frontend/src/apis/queries/alarm/useGetAlarm.ts @@ -14,5 +14,6 @@ export const useGetAlarm = ({ isLoggedIn }: { isLoggedIn: boolean }) => { queryFn: getAlarm, enabled: isLoggedIn, staleTime: 1000 * 60 * 5, + select: (data) => data.reverse(), }); }; diff --git a/packages/frontend/src/apis/queries/alarm/usePostCreateAlarm.ts b/packages/frontend/src/apis/queries/alarm/usePostCreateAlarm.ts index 260cd5f2..9819bf4e 100644 --- a/packages/frontend/src/apis/queries/alarm/usePostCreateAlarm.ts +++ b/packages/frontend/src/apis/queries/alarm/usePostCreateAlarm.ts @@ -29,9 +29,13 @@ export const usePostCreateAlarm = () => { alarmExpiredDate, }: PostCreateAlarmRequest) => postCreateAlarm({ stockId, targetPrice, targetVolume, alarmExpiredDate }), - onSuccess: () => + onSuccess: () => { queryClient.invalidateQueries({ - queryKey: ['getStockAlarm', 'getAlarm'], - }), + queryKey: ['getStockAlarm'], + }); + queryClient.invalidateQueries({ + queryKey: ['getAlarm'], + }); + }, }); }; diff --git a/packages/frontend/src/apis/queries/chat/useGetChatList.ts b/packages/frontend/src/apis/queries/chat/useGetChatList.ts index 355c02cc..a2ca5100 100644 --- a/packages/frontend/src/apis/queries/chat/useGetChatList.ts +++ b/packages/frontend/src/apis/queries/chat/useGetChatList.ts @@ -1,4 +1,4 @@ -import { useSuspenseInfiniteQuery } from '@tanstack/react-query'; +import { keepPreviousData, useInfiniteQuery } from '@tanstack/react-query'; import { GetChatListRequest } from './schema'; import { get } from '@/apis/utils/get'; import { ChatDataResponse, ChatDataResponseSchema } from '@/sockets/schema'; @@ -26,7 +26,7 @@ export const useGetChatList = ({ pageSize, order, }: GetChatListRequest) => { - return useSuspenseInfiniteQuery({ + return useInfiniteQuery({ queryKey: ['chatList', stockId, order], queryFn: ({ pageParam }) => getChatList({ @@ -47,5 +47,6 @@ export const useGetChatList = ({ pageParams: [...data.pageParams], }), staleTime: 1000 * 60 * 3, + placeholderData: keepPreviousData, }); }; diff --git a/packages/frontend/src/apis/queries/stocks/useGetStocksPriceSeries.ts b/packages/frontend/src/apis/queries/stocks/useGetStocksPriceSeries.ts index eb6cef05..3146e203 100644 --- a/packages/frontend/src/apis/queries/stocks/useGetStocksPriceSeries.ts +++ b/packages/frontend/src/apis/queries/stocks/useGetStocksPriceSeries.ts @@ -41,14 +41,10 @@ export const useGetStocksPriceSeries = ({ : undefined, initialPageParam: { lastStartTime }, select: (data) => ({ - priceDtoList: [...data.pages] - .reverse() - .flatMap((page) => page.priceDtoList), - volumeDtoList: [...data.pages] - .reverse() - .flatMap((page) => page.volumeDtoList), + pages: [...data.pages].reverse(), + pageParams: [...data.pageParams].reverse(), }), - refetchOnWindowFocus: false, + // refetchOnWindowFocus: false, staleTime: 10 * 1000, placeholderData: keepPreviousData, }); diff --git a/packages/frontend/src/apis/queries/user/usePatchUserTheme.ts b/packages/frontend/src/apis/queries/user/usePatchUserTheme.ts index fe7daf12..c954d779 100644 --- a/packages/frontend/src/apis/queries/user/usePatchUserTheme.ts +++ b/packages/frontend/src/apis/queries/user/usePatchUserTheme.ts @@ -19,8 +19,6 @@ export const usePatchUserTheme = () => { return useMutation({ mutationKey: ['patchTheme'], mutationFn: ({ theme }: PatchUserThemeRequest) => patchUserTheme({ theme }), - onSuccess: () => { - queryClient.invalidateQueries({ queryKey: ['userTheme'] }); - }, + onSuccess: () => queryClient.invalidateQueries({ queryKey: ['userTheme'] }), }); }; diff --git a/packages/frontend/src/apis/queries/user/usePostUserNickname.ts b/packages/frontend/src/apis/queries/user/usePostUserNickname.ts index 084edb00..d1fa6b03 100644 --- a/packages/frontend/src/apis/queries/user/usePostUserNickname.ts +++ b/packages/frontend/src/apis/queries/user/usePostUserNickname.ts @@ -15,8 +15,6 @@ export const usePostUserNickname = ({ nickname }: { nickname: string }) => { return useMutation({ mutationKey: ['userNickname'], mutationFn: () => postUserNickname({ nickname }), - onSuccess: () => { - queryClient.invalidateQueries({ queryKey: ['userInfo'] }); - }, + onSuccess: () => queryClient.invalidateQueries({ queryKey: ['userInfo'] }), }); }; diff --git a/packages/frontend/src/components/lottie/dark-skeleton.json b/packages/frontend/src/components/lottie/dark-skeleton.json new file mode 100644 index 00000000..6d50ec36 --- /dev/null +++ b/packages/frontend/src/components/lottie/dark-skeleton.json @@ -0,0 +1 @@ +{"v":"4.8.0","meta":{"g":"LottieFiles AE ","a":"","k":"","d":"","tc":""},"fr":24,"ip":0,"op":48,"w":650,"h":611,"nm":"Artboard 1","ddd":0,"assets":[{"id":"image_0","w":650,"h":611,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"Artboard 1.png","cl":"png","refId":"image_0","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":24,"s":[14]},{"t":48,"s":[100]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[325,305.5,0],"ix":2},"a":{"a":0,"k":[325,305.5,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":48,"st":0,"bm":0}],"markers":[]} \ No newline at end of file diff --git a/packages/frontend/src/hooks/useSubscribeAlarm.ts b/packages/frontend/src/hooks/useSubscribeAlarm.ts index ea54ab99..cf1ea363 100644 --- a/packages/frontend/src/hooks/useSubscribeAlarm.ts +++ b/packages/frontend/src/hooks/useSubscribeAlarm.ts @@ -7,6 +7,7 @@ export const useSubscribeAlarm = () => { if ('Notification' in window && navigator.serviceWorker) { try { if (Notification.permission === 'default') { + alert('알림 허용을 먼저 해주세요.'); const permission = await Notification.requestPermission(); if (permission === 'granted') { const registration = await navigator.serviceWorker.ready; diff --git a/packages/frontend/src/pages/login/Login.tsx b/packages/frontend/src/pages/login/Login.tsx index 61ca861f..5b3e5ada 100644 --- a/packages/frontend/src/pages/login/Login.tsx +++ b/packages/frontend/src/pages/login/Login.tsx @@ -7,7 +7,14 @@ import { Button } from '@/components/ui/button'; const GOOGLE_LOGIN = '/api/auth/google/login'; export const Login = () => { const queryClient = useQueryClient(); - const { refetch } = useGetTestLogin({ password: 'test', username: 'test' }); + const { refetch, isSuccess } = useGetTestLogin({ + password: 'test', + username: 'test', + }); + + if (isSuccess) { + queryClient.invalidateQueries({ queryKey: ['loginStatus'] }); + } return (
@@ -24,12 +31,9 @@ export const Login = () => { 구글 로그인 - +