DraggableDragItem
DraggableDragItem class instance holds all the information about a drag item. All the drag items are available via the items
property of the DraggableDrag instance.
Properties
data
type data = { [key: string]: any };
A key value object of custom data, which can be used to store any additional information needed to perform custom logic during the drag. You can utilize this store in your custom plugins and modifiers for example.
When drag ends this data (and the whole DraggableDragItem
instance) is discarded, so you don't have to worry about cleaning up the data.
element
type element = HTMLElement | SVGSVGElement;
The dragged element. Read-only.
elementContainer
type elementContainer = HTMLElement;
The dragged element's original parent node before the drag starts. Read-only.
elementOffsetContainer
type elementOffsetContainer = HTMLElement | SVGSVGElement | Window | Document;
The dragged element's original offset container. Read-only.
dragContainer
type dragContainer = HTMLElement;
The dragged element's parent node during the drag. Read-only.
dragOffsetContainer
type dragOffsetContainer = HTMLElement | SVGSVGElement | Window | Document;
The dragged element's offset container during the drag. Read-only.
elementTransformMatrix
type elementMatrix = DOMMatrix;
The dragged element's original computed transform and all the individual transforms (translate, rotate and scale) combined into one matrix. Read-only.
elementOffsetMatrix
type elementOffsetMatrix = DOMMatrix;
The dragged element's original computed individual transforms (translate, rotate and scale) combined into one matrix and inversed. This is needed for offsetting the individual transforms when computing the element's transform during drag. Read-only.
frozenStyles
type frozenStyles = CSSProperties | null;
A key value object of the frozen CSS properties and their frozen values. These are the values that are forced on the dragged element for the duration of the drag. Read-only.
unfrozenStyles
type unfrozenStyles = CSSProperties | null;
A key value object of the frozen CSS properties and their unfrozen (original) values. These are the values that are restored to the dragged element after the drag ends. Read-only.
clientRect
type clientRect = { width: number; height: number; left: number; top: number };
Cached bounding client rect of the dragged element. The width
and height
of this object can be updated using the updateSize
method. The left
and top
are automatically updated whenever position changes. Read-only.
position
type position = { x: number; y: number };
The dragged element's relative viewport position. This is always {x: 0, y: 0}
on drag start and, by default, only updated when the sensor moves. Modifiers might affect this value during start, move and end phases.
In practice this value will tell you how many (untransformed) pixels the element has moved in the viewport's scope and to which directions. E.g. {x: -100, y: 50}
would mean that the element has moved 100 pixels to the left and 50 pixels down from the original position.
Read-only.
containerOffset
type containerOffset = { x: number; y: number };
The offset between elementOffsetContainer
and dragOffsetContainer
. The offset value is computed so that transforms are fully ignored. This offset is used to correct the element's position when/if it is reparented to the dragContainer
. Read-only.
alignmentOffset
type alignmentOffset = { x: number; y: number };
Keeps track of any unintended drift between the dragged element's position and the sensor's position. For example, this is used to correct the element's position when the element's parent is scrolled or when align
method is used. Read-only.
Methods
getContainerMatrix
type getContainerMatrix = () => [DOMMatrix, DOMMatrix];
Returns the world transform matrix of the elementContainer
, which is computed and cached at the start of the drag. The first matrix in the returned array is the world transform matrix and the second matrix is the inverse of the world transform matrix.
getDragContainerMatrix
type getDragContainerMatrix = () => [DOMMatrix, DOMMatrix];
Returns the world transform matrix of the dragContainer
, which is computed and cached at the start of the drag. The first matrix in the returned array is the world transform matrix and the second matrix is the inverse of the world transform matrix.
updateSize
type updateSize = (dimensions?: { width: number; height: number }) => void;
// Usage: Compute and update the item's size
dragItem.updateSize();
// Usage: Update the item's size to specific dimensions
dragItem.updateSize({ width: 100, height: 100 });
Update the item's size. This method is useful when the item's size changes during the drag process. If the dimensions argument is not provided, the method will compute the new size based on the element's bounding client rect. Otherwise, the method will update the item's size to the provided dimensions.