From 9896822827f89a8e190bee582b60836abfc32177 Mon Sep 17 00:00:00 2001 From: Ethan Davidson <31261035+EthanThatOneKid@users.noreply.github.com> Date: Sun, 15 Oct 2023 21:53:46 -0700 Subject: [PATCH] refactor `executeDailyWebhook` logic --- api/dailies.ts | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/api/dailies.ts b/api/dailies.ts index a8323ac..e692555 100644 --- a/api/dailies.ts +++ b/api/dailies.ts @@ -80,6 +80,8 @@ async function executeDailyWebhook( ): Promise { // Get the daily question. const question = await lcClient.getDailyQuestion(); + const questionDate = new Date(`${question.date} GMT`); + const isSunday = questionDate.getDay() === 0; // Get the stored season. const storedSeason = seasonID @@ -87,21 +89,18 @@ async function executeDailyWebhook( : await leaderboardClient.getLatestSeason(); // If the season is ongoing, then sync it. - const referenceDate = new Date(`${question.date} GMT`); - const syncedSeason = ( - storedSeason && - leaderboard.checkDateInWeek( - new Date(storedSeason.start_date).getTime(), - referenceDate.getTime(), - ) - ) + const referenceDate = new Date(); + const isLatestSeason = storedSeason && leaderboard.checkDateInWeek( + new Date(storedSeason.start_date).getTime(), + referenceDate.getTime(), + ); + const syncedSeason = isLatestSeason ? await leaderboardClient .sync(storedSeason.id) .then((response) => response.season) : null; // Format the webhook embed. - const isSunday = new Date(question.date).getDay() === 0; const embeds = makeDailyWebhookEmbeds({ question, season: isSunday ? (syncedSeason ?? storedSeason) : null,