dragee v1.3.0
Dragee
A lightweight, dependency-free JavaScript library for drag and drop, sortable lists, and target-based interactions.
Installation
npm install dragee
Core Components
Draggable
The base class for making elements draggable.
import { Draggable } from 'dragee';
const element = document.getElementById('draggable');
const calculusFx = (x) => {
x = x / 100;
return (x * Math.sin(x * x) + 1) * 10 + 80;
};
new Draggable(element, {
bound: (point, size) => {
const retPoint = point.clone();
retPoint.y = calculusFx(point.x);
return retPoint;
},
position: new Point(210, calculusFx(210))
});
// Events
draggable.on('drag:start', (event) => console.log('Started dragging'));
draggable.on('drag:move', (event) => console.log('Dragging'));
draggable.on('drag:end', (event) => console.log('Finished dragging'));
Predefined Bounding Functions
Dragee provides several predefined bounding functions to constrain draggable movement:
// Bound to element's boundaries
BoundToElement.bounding(element, container)
// Bound to specific rectangle
BoundToRectangle.bounding(rectangle)
// Bound to vertical line with Y-axis constraints
BoundToLineX.bounding(x, startY, endY)
// Bound to horizontal line with X-axis constraints
BoundToLineY.bounding(y, startX, endX)
// Bound to line between two points
BoundToLine.bounding(startPoint, endPoint)
// Bound to circle
BoundToCircle.bounding(center, radius)
// Bound to arc
BoundToArc.bounding(center, radius, startAngle, endAngle)
Sortable
Two types of sortable lists are available:
List
Basic sortable list implementation.
import { Draggable, List } from 'dragee';
const gridContainer = document.querySelector('.grid-container');
const gridItems = gridContainer.querySelectorAll('.grid-item');
const gridDraggables = Array.from(gridItems).map(item =>
new Draggable(item, {
container: gridContainer,
nativeDragAndDrop: true
})
);
new List(gridDraggables)
BubblingList
Vertical sortable list that uses bubbling algorithm for smooth and natural sorting behavior.
import { Draggable, BubblingList } from 'dragee';
const listContainer = document.querySelector('.sortable-demo-list');
const listItems = listContainer.querySelectorAll('.items')
const draggableItems = Array.from(listItems).map(item => {
new Draggable(item, {
container: listContainer,
nativeDragAndDrop: true,
emulateNativeDragAndDropOnTouch: true
})
});
new BubblingList(draggableItems);
Targets
Target areas for draggable elements.
import { Target, FloatLeftStrategy, transformedSpaceDistanceFactory } from 'dragee'
const target = new Target(element, draggables, {
timeEnd: 200,
timeExcange: 400,
parent: parentElement,
strategy: new FloatLeftStrategy(
() => target.getRectangle()
{
radius: 80,
getDistance: transformedSpaceDistanceFactory({ x: 1, y: 4 }),
removable: true
}
)
});
Target Strategies
FloatLeftStrategy
Orders draggables from top to bottom, positioning them on the left side of the target area.
new Target(element, draggables, {
strategy: new FloatLeftStrategy(
() => target.getRectangle(),
{
radius: 80,
getDistance: transformedSpaceDistanceFactory({ x: 1, y: 4 })
}
)
});
FloatRightStrategy
Orders draggables from top to bottom, positioning them on the right side of the target area.
new Target(element, draggables, {
strategy: new FloatRightStrategy(
() => target.getRectangle(),
{
radius: 80,
getDistance: transformedSpaceDistanceFactory({ x: 1, y: 4 })
}
)
});
NotCrossingStrategy
A free-form positioning strategy that prevents draggables from overlapping. Items can be placed anywhere within the target area but will maintain their own space without intersecting with other items.
new Target(element, draggables, {
strategy: new NotCrossingStrategy(
() => target.getRectangle()
)
});
4 months ago
5 months ago
5 months ago
6 months ago
10 months ago
1 year ago
1 year ago
1 year ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago