Skip to content

Commit

Permalink
refactor: refresh leaderboard
Browse files Browse the repository at this point in the history
- delete: promise.all to fetch town&user leaderboard
- remove: throttled refresh
  • Loading branch information
jongwooha98 committed Dec 19, 2021
1 parent dd331c5 commit 4240840
Show file tree
Hide file tree
Showing 3 changed files with 92 additions and 75 deletions.
42 changes: 22 additions & 20 deletions src/hooks/useLeaderboard.ts
Original file line number Diff line number Diff line change
Expand Up @@ -83,40 +83,42 @@ export const useLeaderboard = () => {
[minigameApi.gameUserApi]
);

const updateLeaderboard = useCallback(
const updateUserLeaderboard = useCallback(
async ({
gameType,
size,
}: {
gameType: 'GAME_KARROT' | 'GAME_2048';
size: number;
}) => {
try {
getTownLeaderboard({ gameType }).then((response) => {
if (response) setTownLeaderboard(response);
});
getUserLeaderboard({ gameType, size }).then((response) => {
if (response) setUserLeaderboard(response);
});
// const [townLeaderboard, userLeaderboard] = await Promise.all([
// getTownLeaderboard({ gameType }),
// getUserLeaderboard({ gameType, size }),
// ]);
// if (userLeaderboard && townLeaderboard) {
// setTownLeaderboard(townLeaderboard);
// setUserLeaderboard(userLeaderboard);
const response = await getUserLeaderboard({ gameType, size });
if (response) {
setUserLeaderboard(response);
return response;
} else {
return null;
}
},
[getUserLeaderboard]
);

// }
} catch (error) {
console.error(error);
const updateTownLeaderboard = useCallback(
async ({ gameType }: { gameType: 'GAME_KARROT' | 'GAME_2048' }) => {
const response = await getTownLeaderboard({ gameType });
if (response) {
setTownLeaderboard(response);
return response;
} else {
return null;
}
},
[getTownLeaderboard, getUserLeaderboard]
[getTownLeaderboard]
);

return {
townLeaderboard,
userLeaderboard,
updateLeaderboard,
updateUserLeaderboard,
updateTownLeaderboard,
};
};
119 changes: 67 additions & 52 deletions src/pages/Game2048/Home/Home.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import {
} from '../Leaderboard/Highlight';
import { ActiveUserCount } from 'components/ActiveUserCount';
import { useMyGame2048Data } from '../hooks';
import { useThrottledCallback } from 'use-debounce/lib';
// import { useThrottledCallback } from 'use-debounce/lib';
import { navHeight, PageContainer, pageHeight } from 'styles';
import ReactModal from 'react-modal';
import { CommentModal, Share } from './Modal';
Expand All @@ -43,8 +43,12 @@ export const Home: React.FC = () => {
const { isInWebEnvironment, handleThirdPartyAgreement } = useMini();
const { user, town } = useUser();
const { rank, gameType } = useMyGame2048Data();
const { townLeaderboard, userLeaderboard, updateLeaderboard } =
useLeaderboard();
const {
townLeaderboard,
userLeaderboard,
updateTownLeaderboard,
updateUserLeaderboard,
} = useLeaderboard();
const { updateMyGameData } = useMyGameData();
const [isFirstInTown, setIsFirstInTown] = useState<boolean>(false);
const [isRanked, setIsRanked] = useState<boolean>(
Expand Down Expand Up @@ -137,7 +141,7 @@ export const Home: React.FC = () => {
townLeaderboard,
myTownId,
}: {
townLeaderboard: TownLeaderboardType[];
townLeaderboard: TownLeaderboardType[] | null;
myTownId: string;
}) => {
if (townLeaderboard) {
Expand All @@ -159,66 +163,73 @@ export const Home: React.FC = () => {
);

// refresh leaderboard
const handleRefresh = useCallback(async () => {
try {
if (accessToken) {
const response = await updateMyGameData({ gameType: gameType });
if (response) {
console.log(response);
setMyData({
rank: response.rank,
score: response.score,
});
updateLeaderboard({
gameType: 'GAME_2048',
size: 100,
}).then(() => {
const handleRefresh = useCallback(
async ({
gameType,
size,
}: {
gameType: 'GAME_KARROT' | 'GAME_2048';
size: number;
}) => {
try {
if (accessToken) {
const response = await updateMyGameData({ gameType: gameType });
if (response) {
setMyData({
rank: response.rank,
score: response.score,
});
updateUserLeaderboard({ gameType, size });
updateTownLeaderboard({
gameType,
}).then((response) => {
updateMyTownData({
townLeaderboard: response,
myTownId: town.id!,
});
});
}
} else {
updateUserLeaderboard({ gameType, size });
updateTownLeaderboard({
gameType,
}).then((response) => {
updateMyTownData({
townLeaderboard: townLeaderboard,
townLeaderboard: response,
myTownId: town.id!,
});
});
}
} else {
updateLeaderboard({
gameType: 'GAME_2048',
size: 100,
} catch (error) {
console.error(error);
updateUserLeaderboard({ gameType, size });
updateTownLeaderboard({
gameType,
}).then((response) => {
updateMyTownData({
townLeaderboard: townLeaderboard,
townLeaderboard: response,
myTownId: town.id!,
});
});
}
} catch (error) {
console.error(error);
updateLeaderboard({
gameType: 'GAME_2048',
size: 100,
}).then((response) => {
updateMyTownData({
townLeaderboard: townLeaderboard,
myTownId: town.id!,
});
});
}
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [
accessToken,
gameType,
town.id,

updateLeaderboard,
updateMyGameData,
updateMyTownData,
]);
// eslint-disable-next-line react-hooks/exhaustive-deps
},
[
accessToken,
town.id,
updateMyGameData,
updateMyTownData,
updateTownLeaderboard,
updateUserLeaderboard,
]
);

// Throttle refresh for 5 seconds
const throttledRefresh = useThrottledCallback(handleRefresh, 3000);
// const throttledRefresh = useThrottledCallback(()=>handleRefresh, 3000);

useEffect(() => {
if (isTop) {
handleRefresh();
handleRefresh({ gameType: 'GAME_2048', size: 100 });
}
if (rank !== 0) {
setIsRanked(true);
Expand Down Expand Up @@ -302,9 +313,11 @@ export const Home: React.FC = () => {
>
<PullToRefresh
onPull={(dispose) => {
throttledRefresh()!.then(() => {
dispose();
});
handleRefresh({ gameType: 'GAME_2048', size: 100 })?.then(
() => {
dispose();
}
);
}}
className={css`
--kf_pulltorefresh_backgroundColor: transparent;
Expand Down Expand Up @@ -394,7 +407,9 @@ export const Home: React.FC = () => {
>
<CommentModal
setIsCommentModalOpen={setIsCommentModalOpen}
handleRefresh={handleRefresh}
handleRefresh={() =>
handleRefresh({ gameType: 'GAME_2048', size: 100 })
}
/>
</ReactModal>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ type Props = {
};
export const LeaderboardTabs: React.FC<Props> = (props) => {
const { isTop } = useCurrentScreen();
const [activeTabKey, setActiveTabKey] = useState<string>('district');
const [activeTabKey, setActiveTabKey] = useState<string>('town');
const handleTabChange = (key: string) => {
if (isTop) {
setActiveTabKey(key);
Expand All @@ -37,7 +37,7 @@ export const LeaderboardTabs: React.FC<Props> = (props) => {
activeTabKey={activeTabKey}
tabs={[
{
key: 'district',
key: 'town',
buttonLabel: '지역',
component: useCallback(
() => (
Expand All @@ -50,7 +50,7 @@ export const LeaderboardTabs: React.FC<Props> = (props) => {
),
},
{
key: 'individual',
key: 'user',
buttonLabel: '개인',
component: useCallback(
() => (
Expand Down

0 comments on commit 4240840

Please sign in to comment.