Spaces:
Build error
Build error
File size: 1,580 Bytes
838b286 |
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 63 64 |
<script lang="ts">
import { IMAGES_LIST } from '../data';
import { selectedImageBlob, generateHuman } from '$lib/store';
import { base } from '$app/paths';
const submit = async (e: Event) => {
e.preventDefault();
const src = IMAGES_LIST[parseInt((e.target as HTMLInputElement).value)];
if (src) {
const blob = await fetch(base + src).then((res) => res.blob());
$selectedImageBlob = blob;
}
};
</script>
<div>
<h4 class="font-bold mt-6 mb-2 my-6 leading-6">Select a Template</h4>
<form on:input={submit}>
<div class="samples ">
{#each IMAGES_LIST as file_name, id}
<div class="snap-always snap-start">
<input
type="radio"
name="samples"
id="sample-{id}"
value={id}
disabled={$generateHuman === true}
/>
<label for="sample-{id}">
<img src={base + file_name} alt={file_name} />
</label>
</div>
{/each}
</div>
</form>
</div>
<style lang="postcss" scoped>
form {
@apply overflow-hidden w-full;
}
.samples {
@apply flex overflow-x-scroll flex-nowrap snap-x snap-mandatory gap-1 scrollbar-hide;
}
input[type='radio'] {
@apply disabled:opacity-50 opacity-0 w-0 h-0 absolute hidden;
}
input[type='radio']:active ~ label {
}
input[type='radio']:checked ~ label {
@apply outline outline-2 outline-yellow-500;
}
input[type='radio']:disabled + label {
@apply opacity-50;
}
label {
@apply cursor-pointer flex transition-all duration-200 ease-in-out
hover:outline outline-offset-[-2px] outline-2 outline-yellow-500;
}
img {
@apply max-h-24 max-w-none;
}
</style>
|