From 1e4796b5e80437fec59ae336b4327eb047843021 Mon Sep 17 00:00:00 2001 From: ad-chaos Date: Mon, 9 Oct 2023 17:47:28 +0530 Subject: [PATCH] bunch of simplifications --- src/routes/+page.js | 14 +++ src/routes/+page.svelte | 156 ++++++++++++++------------------- src/routes/Background.svelte | 6 +- src/routes/[slug]/+page.js | 30 +++---- src/routes/[slug]/+page.svelte | 2 +- 5 files changed, 93 insertions(+), 115 deletions(-) create mode 100644 src/routes/+page.js diff --git a/src/routes/+page.js b/src/routes/+page.js new file mode 100644 index 0000000..5f3cc24 --- /dev/null +++ b/src/routes/+page.js @@ -0,0 +1,14 @@ +export async function load({ fetch, depends }) { + depends("leaderboard"); + const leaderboard = await fetch( + `https://hacknight.navinshrinivas.com/leaderboard_mat` + ) + .then((response) => response.json()) + .catch((e) => { + throw new Error(e.status, "Reddy Anna Is Not Talking"); + }); + + return { + leaderboard + }; +} diff --git a/src/routes/+page.svelte b/src/routes/+page.svelte index ca8543a..3c7918a 100644 --- a/src/routes/+page.svelte +++ b/src/routes/+page.svelte @@ -3,36 +3,16 @@ import Card from "./Card.svelte"; import CardRow from "./CardRow.svelte"; import { onMount } from "svelte"; - let innerWidth = 0; - - let leaderboard; - let oldLeaderboard = []; - const fetchLeaderboardData = async () => { - try { - const response = await fetch( - "https://hacknight.navinshrinivas.com/leaderboard_mat" - ); - if (!response.ok) { - throw new Error("Reddy Anna Is Not Talking"); - } else { - let json_response = await response.json(); + import { invalidate } from "$app/navigation"; - json_response.sort((a, b) => b.Current_bounty - a.Current_bounty); - if (JSON.stringify(json_response) != JSON.stringify(oldLeaderboard)) { - leaderboard = json_response; - oldLeaderboard = leaderboard; - } - } - } catch (err) { - console.log(err); - } - }; + export let data; + let innerWidth = 0; - leaderboard = fetchLeaderboardData(); + let leaderboard = data.leaderboard; onMount(() => { - setInterval(async () => { - await fetchLeaderboardData(); + setInterval(() => { + invalidate("leaderboard"); }, 5000); }); @@ -41,9 +21,7 @@
{#key leaderboard} - {#await leaderboard then} - - {/await} + {/key}
- {#key leaderboard} - {#await leaderboard} -
loading...
- {:then} +
+ {#if innerWidth <= 672} + {#each leaderboard as person, i} + + {/each} + {:else} + {#if innerWidth >= 1440} + + {:else} + + {/if}
- {#if innerWidth <= 672} - {#each leaderboard as person, i} + {#if innerWidth >= 1440} + + + {:else} + + + {/if} +
+ +
+ {#each leaderboard as person, i} + {#if ![0, 1, 2].includes(i)} - {/each} - {:else} - {#if innerWidth >= 1440} - - {:else} - {/if} -
- {#if innerWidth >= 1440} - - - {:else} - - - {/if} -
- -
- {#each leaderboard as person, i} - {#if ![0, 1, 2].includes(i)} - - {/if} - {/each} -
- {/if} + {/each}
- {/await} - {/key} + {/if} +