Skip to content

Commit

Permalink
Feature/#381 - 자잘한 UI 에러 수정 (#385)
Browse files Browse the repository at this point in the history
  • Loading branch information
baegyeong authored Dec 5, 2024
2 parents db28e9f + 6c8265d commit 366abf8
Show file tree
Hide file tree
Showing 17 changed files with 79 additions and 53 deletions.
1 change: 1 addition & 0 deletions packages/frontend/src/apis/queries/alarm/useGetAlarm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,5 +14,6 @@ export const useGetAlarm = ({ isLoggedIn }: { isLoggedIn: boolean }) => {
queryFn: getAlarm,
enabled: isLoggedIn,
staleTime: 1000 * 60 * 5,
select: (data) => data.reverse(),
});
};
10 changes: 7 additions & 3 deletions packages/frontend/src/apis/queries/alarm/usePostCreateAlarm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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'],
});
},
});
};
5 changes: 3 additions & 2 deletions packages/frontend/src/apis/queries/chat/useGetChatList.ts
Original file line number Diff line number Diff line change
@@ -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';
Expand Down Expand Up @@ -26,7 +26,7 @@ export const useGetChatList = ({
pageSize,
order,
}: GetChatListRequest) => {
return useSuspenseInfiniteQuery({
return useInfiniteQuery({
queryKey: ['chatList', stockId, order],
queryFn: ({ pageParam }) =>
getChatList({
Expand All @@ -47,5 +47,6 @@ export const useGetChatList = ({
pageParams: [...data.pageParams],
}),
staleTime: 1000 * 60 * 3,
placeholderData: keepPreviousData,
});
};
Original file line number Diff line number Diff line change
Expand Up @@ -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,
});
Expand Down
4 changes: 1 addition & 3 deletions packages/frontend/src/apis/queries/user/usePatchUserTheme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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'] }),
});
};
Original file line number Diff line number Diff line change
Expand Up @@ -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'] }),
});
};
1 change: 1 addition & 0 deletions packages/frontend/src/components/lottie/dark-skeleton.json
Original file line number Diff line number Diff line change
@@ -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":[]}
1 change: 1 addition & 0 deletions packages/frontend/src/hooks/useSubscribeAlarm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down
16 changes: 10 additions & 6 deletions packages/frontend/src/pages/login/Login.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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 (
<div className="flex h-[calc(100vh-8rem)] flex-col items-center justify-center">
Expand All @@ -24,12 +31,9 @@ export const Login = () => {
<span>구글 로그인</span>
</Button>
</Link>
<Link to="/">
<Link to="/" reloadDocument>
<Button
onClick={() => {
refetch();
queryClient.invalidateQueries({ queryKey: ['loginStatus'] });
}}
onClick={() => refetch()}
className="h-10 w-full dark:bg-black"
>
게스트로 로그인
Expand Down
7 changes: 4 additions & 3 deletions packages/frontend/src/pages/stock-detail/AddAlarmForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,16 @@ export const AddAlarmForm = ({ className }: AddAlarmFormProps) => {
endDate: null,
});

const handleSubmit = (event: FormEvent<HTMLFormElement>) => {
const handleSubmit = async (event: FormEvent<HTMLFormElement>) => {
event.preventDefault();

if (!isLoggedIn) {
alert('로그인 후 이용 가능해요.');
return;
}

subscribeAlarm();
await subscribeAlarm();

const { option, value, endDate } = alarmInfo;

const requestData: PostCreateAlarmRequest = {
Expand All @@ -50,7 +51,7 @@ export const AddAlarmForm = ({ className }: AddAlarmFormProps) => {
alarmExpiredDate: endDate,
};

mutate(requestData, {
await mutate(requestData, {
onSuccess: () => {
alert('알림이 등록되었어요!');
setAlarmInfo({
Expand Down
4 changes: 3 additions & 1 deletion packages/frontend/src/pages/stock-detail/ChatPanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,9 @@ export const ChatPanel = ({ isOwnerStock }: ChatPanelProps) => {
<div className="border-light-gray display-medium12 text-dark-gray flex items-center justify-between gap-1 border-b-2 pb-2">
<span>{isConnected ? '🟢 접속 중' : '❌ 연결 끊김'}</span>
<div className="flex items-center gap-2" onClick={handleOrderType}>
<p>{order === 'latest' ? '최신순' : '좋아요순'}</p>
<span className="cursor-pointer">
{order === 'latest' ? '최신순' : '좋아요순'}
</span>
<DownArrow
className={cn(
'cursor-pointer',
Expand Down
12 changes: 8 additions & 4 deletions packages/frontend/src/pages/stock-detail/StockDetail.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,20 @@
import { lazy, Suspense } from 'react';
import { Suspense } from 'react';
import { ErrorBoundary } from 'react-error-boundary';
import { useParams } from 'react-router-dom';
import { StockDetailHeader } from './components';
import { AddAlarmForm, ChatPanel, NotificationPanel, TradingChart } from '.';
import {
AddAlarmForm,
ChatPanel,
NotificationPanel,
TradingChart,
StockMetricsPanel,
} from '.';
import {
useGetOwnership,
useGetStockDetail,
} from '@/apis/queries/stock-detail';
import { Loader } from '@/components/ui/loader';

const StockMetricsPanel = lazy(() => import('./StockMetricsPanel'));

export const StockDetail = () => {
const { stockId = '' } = useParams();

Expand Down
23 changes: 14 additions & 9 deletions packages/frontend/src/pages/stock-detail/StockMetricsPanel.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,23 @@
import { useEffect, useState } from 'react';
import { useContext, useEffect, useState } from 'react';
import Lottie from 'react-lottie-player';
import { useParams } from 'react-router-dom';
import { MetricItem, Title } from './components';
import darkSkeleton from '@/components/lottie/dark-skeleton.json';
import skeleton from '@/components/lottie/skeleton.json';
import { METRICS_DATA } from '@/constants/metricDetail';
import { ThemeContext } from '@/contexts/theme';
import { socketStock } from '@/sockets/config';
import { useWebsocket } from '@/sockets/useWebsocket';
import { type StockMetricsPanelProps } from '@/types/metrics';
import { cn } from '@/utils/cn';

interface RealTimeStockData {
price: number;
change: number;
volume: number;
}

const StockMetricsPanel = ({
export const StockMetricsPanel = ({
eps,
high52w,
low52w,
Expand All @@ -23,6 +26,7 @@ const StockMetricsPanel = ({
}: Partial<StockMetricsPanelProps>) => {
const { stockId } = useParams();
const { isConnected } = useWebsocket(socketStock);
const { theme } = useContext(ThemeContext);
const [realTimeData, setRealTimeData] = useState<RealTimeStockData>({
price: 0,
change: 0,
Expand Down Expand Up @@ -60,11 +64,14 @@ const StockMetricsPanel = ({
return (
<article className="flex flex-1 flex-col gap-10 rounded-md bg-white p-6 shadow">
{!price || !change || !volume ? (
<section className="grid w-9/12 grid-cols-2 grid-rows-2">
<Lottie animationData={skeleton} play className="w-64" />
<Lottie animationData={skeleton} play className="w-64" />
<Lottie animationData={skeleton} play className="w-64" />
<Lottie animationData={skeleton} play className="w-64" />
<section className="grid w-9/12 lg:grid-cols-2 lg:grid-rows-2">
{Array.from({ length: 4 }, () => (
<Lottie
animationData={theme === 'light' ? skeleton : darkSkeleton}
play
className={cn(theme === 'light' ? 'w-64' : 'w-36')}
/>
))}
</section>
) : (
Object.values(metricsData).map((section) => (
Expand All @@ -86,5 +93,3 @@ const StockMetricsPanel = ({
</article>
);
};

export default StockMetricsPanel;
15 changes: 10 additions & 5 deletions packages/frontend/src/pages/stock-detail/TradingChart.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,14 @@ export const TradingChart = () => {
timeunit,
});

const { priceDtoList: priceData = [], volumeDtoList: volumeData = [] } =
data || {};
const chart = useChart({ priceData, volumeData, containerRef });
const allPriceData = data?.pages.flatMap((page) => page.priceDtoList) ?? [];
const allVolumeData = data?.pages.flatMap((page) => page.volumeDtoList) ?? [];

const chart = useChart({
priceData: allPriceData,
volumeData: allVolumeData,
containerRef,
});

const fetchGraphData = useCallback(
async (logicalRange: LogicalRange | null) => {
Expand Down Expand Up @@ -56,7 +61,7 @@ export const TradingChart = () => {
useChartResize({ containerRef, chart });

return (
<div className="flex min-h-[35rem] flex-col">
<div className="flex h-[30rem] flex-col xl:h-full">
<section className="flex justify-end gap-5">
{TIME_UNIT.map((option) => (
<RadioButton
Expand All @@ -70,7 +75,7 @@ export const TradingChart = () => {
</RadioButton>
))}
</section>
<div ref={containerRef} className="min-h-0 w-full flex-1" />
<div ref={containerRef} className="h-0 w-full flex-grow" />
</div>
);
};
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ export const StockDetailHeader = ({
const { mutate: postStockUser } = usePostStockUser({
onSuccess: () => {
setUserStatus(UserStatus.OWNERSHIP);
queryClient.invalidateQueries({ queryKey: ['userStock'] });
queryClient.invalidateQueries({ queryKey: ['loginStatus'] });
queryClient.invalidateQueries({ queryKey: ['stockOwnership', stockId] });
},
Expand All @@ -54,6 +55,7 @@ export const StockDetailHeader = ({
const { mutate: deleteStockUser } = useDeleteStockUser({
onSuccess: () => {
setUserStatus(UserStatus.NOT_OWNERSHIP);
queryClient.invalidateQueries({ queryKey: ['userStock'] });
queryClient.invalidateQueries({ queryKey: ['loginStatus'] });
queryClient.invalidateQueries({ queryKey: ['stockOwnership', stockId] });
},
Expand Down
11 changes: 7 additions & 4 deletions packages/frontend/src/pages/stocks/StockRankingTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,17 @@ const StockRankingTable = () => {
<tr className="display-medium12 text-dark-gray border-light-gray border-b text-left [&>*]:p-4 [&>*]:py-3">
<th>종목</th>
<th className="text-right">현재가</th>
<th className="flex items-center justify-end gap-1 text-right">
<p>등락률({sortType === 'increase' ? '상승순' : '하락순'})</p>
<th
className="flex cursor-pointer items-center justify-end gap-1 text-right"
onClick={handleSortType}
>
<span>
등락률({sortType === 'increase' ? '상승순' : '하락순'})
</span>
<DownArrow
className={cn(
'cursor-pointer',
sortType === 'increase' ? 'rotate-0' : 'rotate-180',
)}
onClick={handleSortType}
/>
</th>
<th className="hidden lg:table-cell lg:text-right">거래대금</th>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,15 +26,15 @@ export const StockIndexCard = ({
<div className="text-gray flex flex-col gap-3 xl:grid xl:grid-cols-2 xl:grid-rows-2 [&_div]:flex [&_div]:gap-4">
<div>
<span className="display-bold14">시가</span>
<span className="display-medium14">{open?.toLocaleString()}</span>
<span className="display-medium14">{open?.toLocaleString()}</span>
</div>
<div>
<span className="display-bold14">고가</span>
<span className="display-medium14">{high?.toLocaleString()}</span>
<span className="display-medium14">{high?.toLocaleString()}</span>
</div>
<div>
<span className="display-bold14">저가</span>
<span className="display-medium14">{low?.toLocaleString()}</span>
<span className="display-medium14">{low?.toLocaleString()}</span>
</div>
</div>
</div>
Expand Down

0 comments on commit 366abf8

Please sign in to comment.