File size: 2,109 Bytes
a084673
 
 
 
 
98b0aa6
a084673
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e71d24a
a084673
e71d24a
 
 
 
a084673
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<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/models/Card.svelte";
	import Input from "$lib/components/fields/Input.svelte";
	import Radio from "$lib/components/fields/Radio.svelte";
	import { MODELS_FILTER_OPTIONS } from "$lib/utils/index.js";
	import GoTop from "$lib/components/GoTop.svelte";

	export let data;

	let form = {
		filter: "hot",
		page: "0",
	}

	$: elementScroll = browser ? document?.getElementById('app') : undefined;

	const fetchMore = async () => {
		form = {...form, page: (Number(form.page) + 1).toString()};
		const request = await fetch(`/api/community?${new URLSearchParams(form)}`);
		const response = await request.json();
		data = {...data, cards: [...data.cards, ...response.cards ]};
	}
</script>

<svelte:head>
	<title>Explore Models</title>
	<meta name="description" content="Svelte demo app" />
</svelte:head>

<h1 class="text-white font-semibold text-2xl">
  Explore Models
</h1>
<div class="flex items-center justify-between mt-5">
	<Radio options={MODELS_FILTER_OPTIONS} value="{form.filter}" onChange={(filter) => form = {...form, filter }} />
	<div class="items-center justify-end gap-5 hidden lg:flex">
		<Button icon="ic:round-plus" theme="dark" size="lg">Create</Button>
		<Button icon="octicon:upload-16" theme="blue" size="lg">Upload model</Button>
	</div>
	<div class="items-center justify-end gap-3 flex lg:hidden">
		<Button icon="ic:round-plus" theme="dark" size="md">Create</Button>
		<Button icon="octicon:upload-16" theme="blue" size="md">Upload model</Button>
	</div>
</div>
<div class="mt-5 max-w-sm">
	<Input placeholder="Search a model" />
</div>
<div class="mx-auto grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 2xl:grid-cols-5 gap-5 mt-8 lg:mt-10">
	{#each data.cards as card}
		<Card card={card} />
	{/each}
	<InfiniteScroll
		elementScroll="{elementScroll ?? undefined}"
		threshold={100}
		hasMore={data.total_items > data.cards.length}
		on:loadMore={fetchMore}
	/>
	<GoTop />
</div>