Spaces:
Runtime error
Runtime error
File size: 1,302 Bytes
66ed450 4346adf 304976c 66ed450 32561d8 423b87b d11af81 7d4e291 dc37474 8239db2 7cb7420 e5b9b7e 7cb7420 66ed450 95be2ae d11af81 304976c 95be2ae 8239db2 95be2ae 4346adf 304976c 66ed450 4346adf 66ed450 |
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 |
<script lang="ts">
import LoadingIcon from '$lib/Icons/LoadingIcon.svelte';
import type { ZoomTransform } from 'd3-zoom';
export let transform: ZoomTransform;
export let color = '';
export let position = { x: 0, y: 0 };
export let prompt = '';
export let loadingState = '';
export let interactive = false;
export let isDragging = false;
export let isLoading = false;
$: coord = {
x: transform.applyX(position.x),
y: transform.applyY(position.y)
};
</script>
<div
class="frame {isDragging ? 'cursor-grabbing' : 'cursor-grab'}"
style={`transform: translateX(${coord.x}px) translateY(${coord.y}px) scale(${transform.k}); border-color: ${color};`}
>
<div class={!interactive ? 'pointer-events-none touch-none' : ''}>
{#if loadingState}
<div class="col-span-2 row-start-1">
<span class="text-white drop-shadow-lg">{loadingState}</span>
</div>
{/if}
{#if isLoading}
<div class="col-start-2 row-start-2">
<LoadingIcon />
</div>
{/if}
<h2 class="text-lg">Click to paint</h2>
<div class="absolute bottom-0 font-bold text-lg">{prompt}</div>
</div>
</div>
<style lang="postcss" scoped>
.frame {
@apply absolute top-0 left-0 grid grid-cols-3 grid-rows-3 border-2 border-spacing-3 border-sky-500 w-[512px] h-[512px];
transform-origin: 0 0;
}
</style>
|