This is a component, built using d3, that will take a html ul
and make it sortable using
drag and drop.
As an object that emits move
events
var List = require('draggable-list')
, d3 = require('d3')
var list = new List(document.querySelector('.draggable-list')) // Pass in a node that should
// have dnd to sort
list.on('move', function (node, newIndex, prevIndex) {
console.log(arguments)
})
Or using d3 conventions
var draggable = require('draggable-list')
, d3 = require('d3')
d3.selectAll('.draggable-list')
.call(draggable)
Elements can set a class of draggable-list-nodrag
to prevent dnd operations on that element.
Elements can set a class of draggable-list-lock
so the list item index is always maintained.
$ npm install draggable-list
$ npm test
ISC