summaryrefslogtreecommitdiff
path: root/client/src/components/LeaderBoard.svelte
diff options
context:
space:
mode:
authorElizabeth Hunt <elizabeth.hunt@simponic.xyz>2023-07-19 20:38:24 -0700
committerElizabeth Hunt <elizabeth.hunt@simponic.xyz>2023-07-19 20:38:24 -0700
commit0fd9fb097552686f2257c1aa689d797e80057bd1 (patch)
treeb8d0367bf7b62c049af60ace301ce1cffc08d821 /client/src/components/LeaderBoard.svelte
downloadjumpstorm-0fd9fb097552686f2257c1aa689d797e80057bd1.tar.gz
jumpstorm-0fd9fb097552686f2257c1aa689d797e80057bd1.zip
initial commit
Diffstat (limited to 'client/src/components/LeaderBoard.svelte')
-rw-r--r--client/src/components/LeaderBoard.svelte25
1 files changed, 25 insertions, 0 deletions
diff --git a/client/src/components/LeaderBoard.svelte b/client/src/components/LeaderBoard.svelte
new file mode 100644
index 0000000..d6e4ce3
--- /dev/null
+++ b/client/src/components/LeaderBoard.svelte
@@ -0,0 +1,25 @@
+<script lang="ts">
+ import { type LeaderBoardEntry } from "../../lib/interfaces";
+ import LeaderBoardCard from "./LeaderBoardCard.svelte";
+
+ const MAX_ENTRIES = 8;
+
+ export let entries: LeaderBoardEntry[] = [];
+</script>
+
+<div class="leaderboard">
+ {#each entries
+ .sort((a, b) => b.score - a.score)
+ .slice(0, MAX_ENTRIES) as entry}
+ <LeaderBoardCard {entry} />
+ {/each}
+</div>
+
+<style>
+ .leaderboard {
+ display: grid;
+ grid-template-columns: repeat(4, 1fr);
+ grid-template-rows: repeat(2, 1fr);
+ gap: 10px;
+ }
+</style>