Skip to content
Please note that GitHub no longer supports Internet Explorer.

We recommend upgrading to the latest Microsoft Edge, Google Chrome, or Firefox.

Learn more
The JavaScript Drag & Drop library your grandparents warned you about.
Branch: master
Clone or download
beefchimi Merge pull request #315 from richardkmichael/droppable-documentation
Improve Droppable documentation and example
Latest commit 88f7853 Jan 15, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci
.github Enable CLA Bot (again) Oct 18, 2018
.vscode VSCode workspace settings and extension recommendations Apr 4, 2018
examples fix ssh url for threads Dec 14, 2018
scripts Extract mirror logic into mirror plugin Jun 14, 2018
src Improve the Droppable documentation and example. Jan 14, 2019
.babelrc
.editorconfig VSCode workspace settings and extension recommendations Apr 4, 2018
.eslintrc.js
.gitignore Adds codecov integration Mar 2, 2018
.nvmrc update to node 10 + deps Jun 9, 2018
.prettierrc setup prettier and fix all files Mar 23, 2018
AUTHORS make authors file Oct 2, 2017
CHANGELOG.md v1.0.0-beta.8 Sep 7, 2018
CODE_OF_CONDUCT.md
CONTRIBUTING.md Adds docblock section to CONTRIBUTING.md document Mar 2, 2018
LICENSE.md
README.md fix mirror event link in main readme Sep 25, 2018
config.json
esdoc.json Change esdoc config Jan 16, 2018
index.d.ts
package.json Add TypeScript type definitions Dec 21, 2018
yarn.lock

README.md

CircleCI npm version codecov Greenkeeper badge

Currently in beta! While Draggable is very close to a full release, the API is still subject to change. We keep an updated CHANGELOG with every release, so when upgrading from a previous version, please check and see what has changed.

Get complete control over drag and drop behaviour with Draggable! Draggable abstracts native browser events into a comprehensive API to create a custom drag and drop experience. Draggable comes with additional modules: Sortable, Droppable, Swappable. Draggable itself does not perform any sorting behaviour while dragging, but does the heavy lifting, e.g. creates mirror, emits events, manages sensor events, makes elements draggable.

The additional modules are built on top of Draggable and therefore provide a similar API interface, for more information read the documentation below.

Features

  • Works with native drag, mouse, touch and force touch events
  • Can extend dragging behaviour by hooking into draggables event life cycle
  • Can extend drag detection by adding sensors to draggable
  • The library is targeted ES6 first

Table of Contents

Install

You can install the library via npm.

npm install @shopify/draggable --save

or via yarn:

yarn add @shopify/draggable

or via CDN

<!-- Entire bundle -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/draggable.bundle.js"></script>
<!-- legacy bundle for older browsers (IE11) -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/draggable.bundle.legacy.js"></script>
<!-- Draggable only -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/draggable.js"></script>
<!-- Sortable only -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/sortable.js"></script>
<!-- Droppable only -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/droppable.js"></script>
<!-- Swappable only -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/swappable.js"></script>
<!-- Plugins only -->
<script src="https://cdn.jsdelivr.net/npm/@shopify/draggable@1.0.0-beta.8/lib/plugins.js"></script>

Browser Compatibility

Chrome Firefox IE Opera Safari Edge
Latest ✔ Latest ✔ 11+ ✔ Latest ✔ Latest ✔ Latest ✔

Bundle sizes

Package name ES6 bundle sizes ES5 bundle sizes
draggable.bundle.js ~11kb ~19.2kb
draggable.bundle.legacy.js ~19.2kb ~25.63kb
draggable.js ~8.06kb ~15.36kb
sortable.js ~8.93kb ~16.51kb
swappable.js ~8.56kb ~16.14kb
droppable.js ~8.8kb ~16.55kb
plugins.js ~2.37kb ~8.76kb
plugins/collidable.js ~1.45kb ~7.81kb
plugins/snappable.js ~1.19kb ~6.94kb
plugins/swap-animation.js ~1kb ~6.65kb

Documentation

You can find the documentation for each module within their respective directories.

Running examples

To run the examples project locally, simply run the following from the draggable root:

yarn && yarn start

This will start a server that hosts the contents of examples/. It also watches for file changes from both src/ and examples/src and reloads the browser.

Contributing

Contributions are more than welcome, the code base is still new and needs more love.

For more information, please checkout the contributing document.

Roadmap

We are currently working on v1.0.0-beta.8. Check out the project board to see tasks and follow progress on the release. Any Pull Requests should be pointed against the feature branch v1.0.0-beta.8.

Related resources

Copyright

Copyright (c) 2018 Shopify. See LICENSE.md for further details.

You can’t perform that action at this time.