diff options
| author | Adam <[email protected]> | 2026-02-12 09:49:14 -0600 |
|---|---|---|
| committer | GitHub <[email protected]> | 2026-02-12 09:49:14 -0600 |
| commit | ff4414bb152acfddb5c0eb073c38bedc1df4ae14 (patch) | |
| tree | 78381c67d21ef6f089647f6b19e7aa2976840dbc /packages/app/src/utils | |
| parent | 56ad2db02055955f926fda0e4a89055b22ead6f9 (diff) | |
| download | opencode-ff4414bb152acfddb5c0eb073c38bedc1df4ae14.tar.gz opencode-ff4414bb152acfddb5c0eb073c38bedc1df4ae14.zip | |
chore: refactor packages/app files (#13236)
Co-authored-by: opencode-agent[bot] <opencode-agent[bot]@users.noreply.github.com>
Co-authored-by: Frank <[email protected]>
Diffstat (limited to 'packages/app/src/utils')
| -rw-r--r-- | packages/app/src/utils/solid-dnd.tsx | 78 |
1 files changed, 36 insertions, 42 deletions
diff --git a/packages/app/src/utils/solid-dnd.tsx b/packages/app/src/utils/solid-dnd.tsx index a634be4b4..8e30a033a 100644 --- a/packages/app/src/utils/solid-dnd.tsx +++ b/packages/app/src/utils/solid-dnd.tsx @@ -1,55 +1,49 @@ import { useDragDropContext } from "@thisbeyond/solid-dnd" -import { JSXElement } from "solid-js" import type { Transformer } from "@thisbeyond/solid-dnd" +import { createRoot, onCleanup, type JSXElement } from "solid-js" + +type DragEvent = { draggable?: { id?: unknown } } + +const isDragEvent = (event: unknown): event is DragEvent => { + if (typeof event !== "object" || event === null) return false + return "draggable" in event +} export const getDraggableId = (event: unknown): string | undefined => { - if (typeof event !== "object" || event === null) return undefined - if (!("draggable" in event)) return undefined - const draggable = (event as { draggable?: { id?: unknown } }).draggable + if (!isDragEvent(event)) return undefined + const draggable = event.draggable if (!draggable) return undefined return typeof draggable.id === "string" ? draggable.id : undefined } -export const ConstrainDragXAxis = (): JSXElement => { - const context = useDragDropContext() - if (!context) return <></> - const [, { onDragStart, onDragEnd, addTransformer, removeTransformer }] = context - const transformer: Transformer = { - id: "constrain-x-axis", - order: 100, - callback: (transform) => ({ ...transform, x: 0 }), - } - onDragStart((event) => { - const id = getDraggableId(event) - if (!id) return - addTransformer("draggables", id, transformer) - }) - onDragEnd((event) => { - const id = getDraggableId(event) - if (!id) return - removeTransformer("draggables", id, transformer.id) - }) - return <></> -} +const createTransformer = (id: string, axis: "x" | "y"): Transformer => ({ + id, + order: 100, + callback: (transform) => (axis === "x" ? { ...transform, x: 0 } : { ...transform, y: 0 }), +}) -export const ConstrainDragYAxis = (): JSXElement => { +const createAxisConstraint = (axis: "x" | "y", transformerId: string) => (): JSXElement => { const context = useDragDropContext() - if (!context) return <></> + if (!context) return null const [, { onDragStart, onDragEnd, addTransformer, removeTransformer }] = context - const transformer: Transformer = { - id: "constrain-y-axis", - order: 100, - callback: (transform) => ({ ...transform, y: 0 }), - } - onDragStart((event) => { - const id = getDraggableId(event) - if (!id) return - addTransformer("draggables", id, transformer) - }) - onDragEnd((event) => { - const id = getDraggableId(event) - if (!id) return - removeTransformer("draggables", id, transformer.id) + const transformer = createTransformer(transformerId, axis) + const dispose = createRoot((dispose) => { + onDragStart((event) => { + const id = getDraggableId(event) + if (!id) return + addTransformer("draggables", id, transformer) + }) + onDragEnd((event) => { + const id = getDraggableId(event) + if (!id) return + removeTransformer("draggables", id, transformer.id) + }) + return dispose }) - return <></> + onCleanup(dispose) + return null } + +export const ConstrainDragXAxis = createAxisConstraint("x", "constrain-x-axis") + +export const ConstrainDragYAxis = createAxisConstraint("y", "constrain-y-axis") |
