team-1/frontend/src/lib/components/SuggestionList.svelte

65 lines
3.2 KiB
Svelte
Raw Normal View History

2025-08-01 21:10:03 +02:00
<script lang="ts">
2025-08-02 02:12:41 +02:00
import type { Suggestion } from "$lib/types"
2025-08-02 08:31:31 +02:00
import { ThumbsUp, ThumbsDown } from "@lucide/svelte"
2025-08-02 11:51:51 +02:00
import { onMount } from "svelte"
2025-08-02 05:16:37 +02:00
let { suggestions = $bindable(), roomId }: { suggestions: Suggestion[]; roomId: string } = $props()
2025-08-02 02:12:41 +02:00
2025-08-02 11:51:51 +02:00
let picked_suggestions: string[] = $state([])
2025-08-02 12:47:16 +02:00
async function vote(amount: number, songId: string) {
2025-08-02 11:51:51 +02:00
if (picked_suggestions.includes(songId)) return console.log("rejecting vote")
2025-08-02 02:12:41 +02:00
await fetch(`/api/song/voting?room=${roomId}&song=${songId}&increment=${amount}`, { method: "POST" })
2025-08-02 11:51:51 +02:00
picked_suggestions.push(songId)
console.log("accepted vote")
sessionStorage.setItem("picked_suggestions", JSON.stringify(picked_suggestions))
2025-08-02 02:12:41 +02:00
}
2025-08-02 11:51:51 +02:00
onMount(() => {
picked_suggestions = JSON.parse(sessionStorage.getItem("picked_suggestions") ?? "[]")
})
2025-08-01 21:10:03 +02:00
</script>
<div class="flex h-full w-full flex-col items-center gap-2 overflow-y-auto">
2025-08-02 04:34:45 +02:00
{#if suggestions.length == 0}
2025-08-02 10:50:35 +02:00
<p>No suggestions yet! Try to add a new one using the Add button</p>
2025-08-02 04:34:45 +02:00
{/if}
2025-08-02 12:47:16 +02:00
{#each suggestions as sug}
2025-08-02 10:50:35 +02:00
<div
class="flex h-[80px] w-full flex-row gap-2 rounded-md border-dark-pine-muted bg-light-pine-overlay p-2 shadow-md duration-100 hover:bg-dark-pine-base/20 dark:bg-dark-pine-overlay hover:dark:bg-light-pine-base/20"
>
<div class="flex w-3/4 flex-row items-center gap-2">
<img
class="w-[60px] min-w-[60px] rounded"
alt="Song cover"
src={sug.image_id != ""
? `https://lastfm.freetls.fastly.net/i/u/174s/${sug.image_id}.png`
: "https://s2.qwant.com/thumbr/474x474/f/6/b50687db1ebb262ac78b98a8f3c56a1e62235aaeebe0346dd27d4fbf1edec8/OIP.kXN41HyriW5dLTkjm0QQoAHaHa.jpg?u=https%3A%2F%2Ftse.mm.bing.net%2Fth%2Fid%2FOIP.kXN41HyriW5dLTkjm0QQoAHaHa%3Fpid%3DApi&q=0&b=1&p=0&a=0"}
/>
2025-08-02 10:50:35 +02:00
<div class="h-fit w-fit flex-col text-white">
2025-08-02 08:31:31 +02:00
<b>{sug.title}</b>
2025-08-02 04:34:45 +02:00
<p>{sug.artist}</p>
</div>
</div>
<div class="flex w-1/4 flex-row items-center justify-center gap-2">
<button
2025-08-02 11:51:51 +02:00
class={!picked_suggestions.includes(sug.uuid) ? "text-light-pine-green duration-100 hover:scale-150 dark:text-dark-pine-green" : "text-light-pine-muted dark:text-dark-pine-muted"}
disabled={!!picked_suggestions.includes(sug.uuid)}
2025-08-02 10:50:35 +02:00
onclick={async () => {
2025-08-02 12:47:16 +02:00
await vote(1, sug.uuid)
2025-08-02 08:31:31 +02:00
}}><ThumbsUp /></button
>
2025-08-02 11:51:51 +02:00
<p class="font-semibold text-light-pine-text dark:text-dark-pine-text">{sug.upvote}</p>
<button
2025-08-02 11:51:51 +02:00
class={!picked_suggestions.includes(sug.uuid) ? "text-light-pine-red duration-100 hover:scale-150 dark:text-dark-pine-red" : "text-light-pine-muted dark:text-dark-pine-muted"}
disabled={!!picked_suggestions.includes(sug.uuid)}
2025-08-02 10:50:35 +02:00
onclick={async () => {
2025-08-02 12:47:16 +02:00
await vote(-1, sug.uuid)
2025-08-02 08:31:31 +02:00
}}><ThumbsDown /></button
>
</div>
</div>
{/each}
</div>