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>