Files
gpx.studio/website/src/lib/components/Resizer.svelte

49 lines
1.5 KiB
Svelte
Raw Normal View History

2024-06-25 16:06:11 +02:00
<script lang="ts">
2025-06-21 21:07:36 +02:00
let {
orientation = 'col',
after = $bindable(),
minAfter = 0,
maxAfter = Number.MAX_SAFE_INTEGER,
}: {
orientation?: 'col' | 'row';
after: number;
minAfter?: number;
maxAfter?: number;
} = $props();
2024-06-25 16:06:11 +02:00
function handleMouseDown(event: PointerEvent) {
const startX = event.clientX;
const startY = event.clientY;
const startAfter = after;
2024-06-25 16:06:11 +02:00
const handleMouseMove = (event: PointerEvent) => {
const newAfter =
startAfter +
(orientation === 'col' ? startX - event.clientX : startY - event.clientY);
if (newAfter >= minAfter && newAfter <= maxAfter) {
after = newAfter;
} else if (newAfter < minAfter && after !== minAfter) {
after = minAfter;
} else if (newAfter > maxAfter && after !== maxAfter) {
after = maxAfter;
}
};
2024-06-25 16:06:11 +02:00
const handleMouseUp = () => {
window.removeEventListener('pointermove', handleMouseMove);
window.removeEventListener('pointerup', handleMouseUp);
};
2024-06-25 16:06:11 +02:00
window.addEventListener('pointermove', handleMouseMove);
window.addEventListener('pointerup', handleMouseUp);
}
2024-06-25 16:06:11 +02:00
</script>
2025-06-21 21:07:36 +02:00
<!-- svelte-ignore a11y_no_static_element_interactions -->
2024-06-25 16:06:11 +02:00
<div
class="{orientation === 'col'
? 'w-1 h-full cursor-col-resize border-l'
: 'w-full h-1 cursor-row-resize border-t'} {orientation}"
2025-06-21 21:07:36 +02:00
onpointerdown={handleMouseDown}
2025-06-08 16:32:41 +02:00
></div>