Cleanup
This commit is contained in:
parent
61940705b9
commit
b4fed6a02f
|
@ -1,166 +0,0 @@
|
||||||
<script>
|
|
||||||
import { onDestroy, getContext } from "svelte"
|
|
||||||
import { builderStore, componentStore, screenStore } from "@/stores"
|
|
||||||
import { Utils, memo } from "@budibase/frontend-core"
|
|
||||||
import { GridRowHeight } from "@/constants"
|
|
||||||
import { GridParams, getGridVar, Devices } from "@/utils/grid"
|
|
||||||
|
|
||||||
const context = getContext("context")
|
|
||||||
|
|
||||||
// Smallest possible 1x1 transparent GIF
|
|
||||||
const ghost = new Image(1, 1)
|
|
||||||
ghost.src =
|
|
||||||
""
|
|
||||||
|
|
||||||
let dragInfo
|
|
||||||
let styles = memo()
|
|
||||||
|
|
||||||
$: placeholderID = findPlaceholderID($screenStore.activeScreen)
|
|
||||||
$: handleNewPlaceholderID(placeholderID)
|
|
||||||
|
|
||||||
// Grid CSS variables
|
|
||||||
$: device = $context.device.mobile ? Devices.Mobile : Devices.Desktop
|
|
||||||
$: vars = {
|
|
||||||
colStart: getGridVar(device, GridParams.ColStart),
|
|
||||||
colEnd: getGridVar(device, GridParams.ColEnd),
|
|
||||||
rowStart: getGridVar(device, GridParams.RowStart),
|
|
||||||
rowEnd: getGridVar(device, GridParams.RowEnd),
|
|
||||||
}
|
|
||||||
|
|
||||||
// Some memoisation of primitive types for performance
|
|
||||||
$: id = dragInfo?.id
|
|
||||||
|
|
||||||
// Set ephemeral styles
|
|
||||||
$: instance = componentStore.actions.getComponentInstance(id)
|
|
||||||
$: $instance?.setEphemeralStyles($styles)
|
|
||||||
|
|
||||||
const findPlaceholderID = screen => {
|
|
||||||
return screen?.props?._children?.find(c => c._placeholder)?._id
|
|
||||||
}
|
|
||||||
|
|
||||||
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms))
|
|
||||||
|
|
||||||
const handleNewPlaceholderID = async placeholderID => {
|
|
||||||
if (!placeholderID) {
|
|
||||||
stopDragging()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
await sleep(100)
|
|
||||||
onDragStart(placeholderID)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sugar for a combination of both min and max
|
|
||||||
const minMax = (value, min, max) => Math.min(max, Math.max(min, value))
|
|
||||||
|
|
||||||
const processEvent = Utils.domDebounce((mouseX, mouseY) => {
|
|
||||||
if (!dragInfo?.grid) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
const { grid, domGrid } = dragInfo
|
|
||||||
const { startX, startY, rowStart, rowEnd, colStart, colEnd } = grid
|
|
||||||
if (!domGrid) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
const cols = parseInt(domGrid.dataset.cols)
|
|
||||||
const colSize = parseInt(domGrid.dataset.colSize)
|
|
||||||
const diffX = mouseX - startX
|
|
||||||
let deltaX = Math.round(diffX / colSize)
|
|
||||||
const diffY = mouseY - startY
|
|
||||||
let deltaY = Math.round(diffY / GridRowHeight)
|
|
||||||
deltaX = minMax(deltaX, 1 - colStart, cols + 1 - colEnd)
|
|
||||||
deltaY = Math.max(deltaY, 1 - rowStart)
|
|
||||||
const newStyles = {
|
|
||||||
[vars.colStart]: colStart + deltaX,
|
|
||||||
[vars.colEnd]: colEnd + deltaX,
|
|
||||||
[vars.rowStart]: rowStart + deltaY,
|
|
||||||
[vars.rowEnd]: rowEnd + deltaY,
|
|
||||||
opacity: 1,
|
|
||||||
}
|
|
||||||
styles.set(newStyles)
|
|
||||||
})
|
|
||||||
|
|
||||||
const handleEvent = e => {
|
|
||||||
e.preventDefault()
|
|
||||||
e.stopPropagation()
|
|
||||||
processEvent(e.clientX, e.clientY)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Callback when initially starting a drag on a draggable component
|
|
||||||
const onDragStart = id => {
|
|
||||||
console.log("DRAG START", id)
|
|
||||||
// Find grid parent and read from DOM
|
|
||||||
const domComponent = document.getElementsByClassName(id)[0]
|
|
||||||
const domGrid = domComponent?.closest(".grid")
|
|
||||||
if (!domGrid) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
const styles = getComputedStyle(domComponent)
|
|
||||||
const bounds = domComponent.getBoundingClientRect()
|
|
||||||
|
|
||||||
// Show as active
|
|
||||||
domComponent.classList.add("dragging")
|
|
||||||
domGrid.classList.add("highlight")
|
|
||||||
builderStore.actions.selectComponent(id)
|
|
||||||
|
|
||||||
// Update state
|
|
||||||
dragInfo = {
|
|
||||||
domComponent,
|
|
||||||
domGrid,
|
|
||||||
id,
|
|
||||||
gridId: domGrid.parentNode.dataset.id,
|
|
||||||
grid: {
|
|
||||||
startX: bounds.left + bounds.width / 2,
|
|
||||||
startY: bounds.top + bounds.height / 2,
|
|
||||||
rowStart: parseInt(styles["grid-row-start"]),
|
|
||||||
rowEnd: parseInt(styles["grid-row-end"]),
|
|
||||||
colStart: parseInt(styles["grid-column-start"]),
|
|
||||||
colEnd: parseInt(styles["grid-column-end"]),
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add event handler to clear all drag state when dragging ends
|
|
||||||
document.addEventListener("dragover", onDrag, false)
|
|
||||||
|
|
||||||
// Add event handler to clear all drag state when dragging ends
|
|
||||||
document.addEventListener("dragEnd", stopDragging, false)
|
|
||||||
document.addEventListener("drop", stopDragging, false)
|
|
||||||
}
|
|
||||||
|
|
||||||
const onDrag = e => {
|
|
||||||
if (!dragInfo) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
handleEvent(e)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Callback when drag stops (whether dropped or not)
|
|
||||||
const stopDragging = async () => {
|
|
||||||
if (!dragInfo) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
console.log("END")
|
|
||||||
const { id, domGrid, domComponent } = dragInfo
|
|
||||||
|
|
||||||
// Reset DOM
|
|
||||||
domComponent.classList.remove("dragging")
|
|
||||||
domGrid.classList.remove("highlight")
|
|
||||||
document.removeEventListener("dragover", onDrag, false)
|
|
||||||
document.removeEventListener("dragend", stopDragging, false)
|
|
||||||
document.removeEventListener("drop", stopDragging, false)
|
|
||||||
|
|
||||||
// Save changes
|
|
||||||
if ($styles) {
|
|
||||||
builderStore.actions.updateStyles($styles, id)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reset state
|
|
||||||
dragInfo = null
|
|
||||||
styles.set(null)
|
|
||||||
}
|
|
||||||
|
|
||||||
onDestroy(() => {
|
|
||||||
document.removeEventListener("dragover", onDrag, false)
|
|
||||||
document.removeEventListener("dragend", stopDragging, false)
|
|
||||||
document.removeEventListener("drop", stopDragging, false)
|
|
||||||
})
|
|
||||||
</script>
|
|
Loading…
Reference in New Issue