enzostvs's picture
enzostvs HF staff
refacto models + community
eb29a95
raw
history blame
3.25 kB
<script lang="ts">
import { get } from 'svelte/store';
import { userStore } from "$lib/stores/use-user";
import Input from "$lib/components/fields/Input.svelte";
import Button from "$lib/components/Button.svelte";
let user = get(userStore);
export let onClose: () => void;
let model = {
id: '',
title: '',
image: '',
}
let error = {
id: '',
title: '',
image: ''
}
const handleSubmit = async () => {
fetch('/api/models/submit', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify(model),
})
.then(response => response.json())
.then(data => {
if (data.error) {
error = data.error;
} else {
console.log('Success:', data);
error = {
id: '',
title: '',
image: ''
}
}
})
}
</script>
<div class="grid grid-cols-1 gap-8">
{#if user?.picture}
<div class="flex items-center justify-start gap-3">
<img src={user.picture} alt="User avatar" class="w-8 h-8 rounded-full border border-white inline-block" />
<div class="w-full text-left text-white">
<p class="text-base font-semibold">{user?.name}</p>
<p class="text-xs leading-none text-neutral-400">{user?.preferred_username}</p>
</div>
</div>
{:else}
<p class="bg-yellow-500/40 rounded-full text-xs text-yellow-400 px-3 py-1 font-semibold max-w-max">
You need to be logged in to submit a model.
</p>
{/if}
<header>
<p class="text-white font-semibold text-lg">
Submit a Model
</p>
<p class="text-neutral-300 text-base mt-1">
Submit a model to the LoRA Studio. You can submit a model by providing a link to the model.
</p>
</header>
<main class="grid grid-cols-1 gap-6">
<div>
<p class="text-xs uppercase text-neutral-400 font-semibold mb-2">
HuggingFace model URL
<span class="text-red-500">*</span>
</p>
<Input
value={model.id}
placeholder="{`${user?.preferred_username ?? 'enzostvs'}/`}"
prefix="huggingface.co/"
onChange={(value) => model.id = value}
/>
{#if error.id}
<p class="text-xs text-red-500 mt-1">
{error.id}
</p>
{/if}
</div>
<div>
<p class="text-xs uppercase text-neutral-400 font-semibold mb-2">
Title
<span class="text-red-500">*</span>
</p>
<Input
value={model.title}
placeholder="Simpson style"
onChange={(value) => model.title = value}
/>
</div>
<div>
<p class="text-xs uppercase text-neutral-400 font-semibold mb-2">
Thumbnail image
<span class="text-red-500">*</span>
</p>
<Input
value={model.image}
placeholder="https://"
onChange={(value) => model.image = value}
/>
{#if error.image}
<p class="text-xs text-red-500 mt-1">
{error.image}
</p>
{/if}
</div>
</main>
<footer class="flex items-center justify-end gap-3">
<Button theme="dark" size="md" onClick={onClose}>Cancel</Button>
<Button theme="blue" size="md" onClick={handleSubmit}>Submit</Button>
</footer>
</div>