Spaces:
Running
on
CPU Upgrade
Running
on
CPU Upgrade
<script lang="ts"> | |
import { browser } from "$app/environment"; | |
import InfiniteScroll from "svelte-infinite-scroll"; | |
import Button from "$lib/components/Button.svelte"; | |
import Card from "$lib/components/community/Card.svelte"; | |
import Input from "$lib/components/fields/Input.svelte"; | |
import Radio from "$lib/components/fields/Radio.svelte"; | |
import { COMMUNITY_FILTER_OPTIONS } from "$lib/utils/index.js"; | |
import GoTop from "$lib/components/GoTop.svelte"; | |
import GalleryDrawer from "$lib/components/community/drawer/Drawer.svelte"; | |
import { userStore } from "$lib/stores/use-user"; | |
import { onMount } from "svelte"; | |
import type { CommunityCard } from "$lib/type"; | |
let data: { | |
cards: CommunityCard[], | |
total_items: number, | |
} = { | |
cards: [], | |
total_items: 0, | |
} | |
let form = { | |
filter: "new", | |
page: "0", | |
search: "" | |
} | |
onMount(() => { | |
refetch(false); | |
}); | |
$: elementScroll = browser ? document?.getElementById('app') : undefined; | |
const handleFetchMore = async () => { | |
form = {...form, page: (Number(form.page) + 1).toString()}; | |
refetch(true); | |
} | |
const handleChangeFilter = async (filter: string) => { | |
form = { ...form, filter, page: (0).toString()}; | |
refetch(false) | |
} | |
let timeout: any; | |
const handleChangeSearch = async (search: string) => { | |
clearTimeout(timeout); | |
form = { ...form, search, page: (0).toString()}; | |
timeout = setTimeout(() => refetch(false), 500); | |
} | |
const refetch = async (add: boolean) => { | |
const request = await fetch(`/api/community?${new URLSearchParams(form)}`); | |
const response = await request.json(); | |
if (add) data = {...data, cards: [...data.cards, ...response.cards ]}; | |
else data = response; | |
} | |
</script> | |
<svelte:head> | |
<title>Community Gallery</title> | |
<meta name="description" content="Svelte demo app" /> | |
</svelte:head> | |
<main class="px-6 py-10 lg:px-10 lg:py-12"> | |
<h1 class="text-white font-semibold text-2xl"> | |
Community Gallery ({data.total_items}) | |
</h1> | |
<div class="flex items-start sm:items-center justify-between mt-5 flex-col sm:flex-row gap-5 sm:justify-between"> | |
<Radio options={COMMUNITY_FILTER_OPTIONS} value="{form.filter}" onChange={handleChangeFilter} /> | |
<div class="items-center justify-end gap-5 hidden lg:flex"> | |
<!-- <UserIsLogged> --> | |
<Button icon="ic:round-plus" disabled={true} theme="dark" size="lg">Upload own Image</Button> | |
<!-- </UserIsLogged> --> | |
<Button icon="fluent:glance-horizontal-sparkles-16-filled" href="/generate" theme="pink" size="lg">Generate</Button> | |
</div> | |
<div class="items-center justify-end gap-3 flex lg:hidden"> | |
<!-- <UserIsLogged> --> | |
<Button icon="ic:round-plus" disabled={true} theme="dark" size="md">Upload own Image</Button> | |
<!-- </UserIsLogged> --> | |
<Button icon="fluent:glance-horizontal-sparkles-16-filled" href="/generate" theme="pink" size="md">Generate</Button> | |
</div> | |
</div> | |
<div class="mt-5 max-w-sm"> | |
<Input value={form.search} placeholder="Search an image" onChange={handleChangeSearch} /> | |
</div> | |
<!-- mx-auto grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-3 xl:grid-cols-4 3xl:grid-cols-5 gap-5 mt-8 lg:mt-10 --> | |
<div class="mx-auto flex flex-wrap gap-5 mt-8 lg:mt-10 justify-center md:justify-start"> | |
{#each data.cards as card} | |
<Card card={card} form={form} displayDelete={$userStore?.is_admin} /> | |
{/each} | |
<InfiniteScroll | |
elementScroll="{elementScroll ?? undefined}" | |
threshold={100} | |
hasMore={data.total_items > data.cards.length} | |
on:loadMore={handleFetchMore} | |
/> | |
<GoTop /> | |
</div> | |
<!-- <GalleryViewer form={form} /> --> | |
<GalleryDrawer form={form} /> | |
</main> |