]> git.r.bdr.sh - rbdr/canvas/blobdiff - src/lib/components/sensor.svelte
Partially render the boxes
[rbdr/canvas] / src / lib / components / sensor.svelte
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..3b7dfc2724643f177dff50bc18ed73b2d6a27a44 100644 (file)
@@ -0,0 +1,33 @@
+<script>
+  import { browser } from '$app/env';
+  import { maxSize } from '$lib/config';
+  import { canvas } from '$lib/stores/canvas';
+  import { sensor } from '$lib/stores/widgets';
+
+  const kSensorSize = 2;
+
+  let left;
+  let right;
+  let top;
+  let bottom;
+
+  let timer;
+  const fetchItems = function fetchItems( left, top, right, bottom ) {
+    clearTimeout(timer);
+               timer = setTimeout(() => {
+      sensor.set({ left, top, right, bottom });
+               }, 50);
+  }
+
+  $: {
+    if (browser) {
+      left = $canvas.x - window.screen.width * kSensorSize;
+      top = $canvas.y - window.screen.height * kSensorSize;
+      right = $canvas.x + window.screen.width * kSensorSize;
+      bottom = $canvas.y + window.screen.height * kSensorSize;
+
+      fetchItems(left, top, right, bottom);
+    }
+  }
+
+</script>