Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sul-dlss/Nestable
Drag & drop hierarchical list with mouse and touch compatibility
https://github.com/sul-dlss/Nestable
Last synced: about 1 month ago
JSON representation
Drag & drop hierarchical list with mouse and touch compatibility
- Host: GitHub
- URL: https://github.com/sul-dlss/Nestable
- Owner: sul-dlss
- Fork: true (dbushell/Nestable)
- Created: 2014-02-10T23:38:54.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2016-02-13T17:02:12.000Z (almost 9 years ago)
- Last Synced: 2024-08-01T12:33:30.770Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 144 KB
- Stars: 1
- Watchers: 11
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-starred - sul-dlss/Nestable - Drag & drop hierarchical list with mouse and touch compatibility (others)
README
Nestable
========## The plan
**lukasoppermann:** I am working on making this plugin better (merged some very sensible pull-requests) and [minified.js](https://github.com/timjansen/minified.js) compatible. If I get it working I will try to remove even the minified requirement to have it be js only. But I am not sure if this is achievable with the time I can spend on it.
### Drag & drop hierarchical list with mouse and touch compatibility
[**Try Nestable Demo**](http://lukasoppermann.github.com/Nestable/)
Nestable is an experimental example and not under active development. If it suits your requirements feel free to expand upon it!
## Usage
Write your nested HTML lists like so:
```html
Item 1
Item 2
Item 3
Item 4
Item 5
```Then activate with jQuery like so:
```javascript
$('.dd').nestable({ /* config options */ });
```### Events
The `change` event is fired when items are reordered.
```javascript
$('.dd').on('change', function() {
/* on change event */
});
```The `expand/collapse` event is fired when an item group is expanded or collapsed.
```javascript
$('.dd-item').on('expand', function() {
/* on expand event */
});$('.dd-item').on('collapse', function() {
/* on collapse event */
});
```### Methods
You can get a serialised object with all `data-*` attributes for each item.
```javascript
$('.dd').nestable('serialize');
```The serialised JSON for the example above would be:
```javascript
[{"id":1},{"id":2},{"id":3,"children":[{"id":4},{"id":5}]}]
```You can deactivate the plugin by running
```javascript
$('.dd').nestable('destroy');
```### Configuration
You can change the follow options:
* `maxDepth` number of levels an item can be nested (default `5`)
* `group` group ID to allow dragging between lists (default `0`)These advanced config options are also available:
* `listNodeName` The HTML element to create for lists (default `'ol'`)
* `itemNodeName` The HTML element to create for list items (default `'li'`)
* `rootClass` The class of the root element `.nestable()` was used on (default `'dd'`)
* `listClass` The class of all list elements (default `'dd-list'`)
* `itemClass` The class of all list item elements (default `'dd-item'`)
* `dragClass` The class applied to the list element that is being dragged (default `'dd-dragel'`)
* `handleClass` The class of the content element inside each list item (default `'dd-handle'`)
* `collapsedClass` The class applied to lists that have been collapsed (default `'dd-collapsed'`)
* `placeClass` The class of the placeholder element (default `'dd-placeholder'`)
* `emptyClass` The class used for empty list placeholder elements (default `'dd-empty'`)
* `expandBtnHTML` The HTML text used to generate a list item expand button (default `'Expand>'`)
* `collapseBtnHTML` The HTML text used to generate a list item collapse button (default `'Collapse'`)
* `dropCallback` The callback method which is called when an item has been successfully moved. It has 1 argument: object with all details (default `null`)`dropCallback` details object:
* `sourceId` - id of moved element
* `destId` - id of destination parent or null if element was moved directly as root
* `sourceEl` - whole moved element if you want to gather additional info about it
* `destParent` - whole destination parent element (if root, then it returns direct container)
* `destRoot` - contains destination group where element was dropped
* `sourceRoot` - contains source group where element belonged to before user started dragging it**Inspect the [Nestable Demo](http://lukasoppermann.github.com/Nestable/) for guidance.**
**Author**
David Bushell [http://dbushell.com](http://dbushell.com/) [@dbushell](http://twitter.com/dbushell/)**Contributor**
Lukas Oppermann [http://vea.re](http://vea.re/) [@lukasoppermann](http://twitter.com/lukasoppermann/)Copyright © 2012-2013 David Bushell | BSD & MIT license