nestedSortable is currently maintained at ilikenwf/nestedSortable. Please go there.
DEVELOPER NEEDED
I'm sorry to say that I am not able to keep the pace developing this project anymore. I know how much nestedSortable is important for web applications, and I still can't understand why it's not part of jQuery-UI. I also think the base of the plugin is very strong, and deserves much more attention and involvement. If anybody is willing to take this project, please say so here.
Thank you.
nestedSortable is a jQuery plugin that extends jQuery Sortable UI functionalities to nested lists.
Note: Version 2.0 is published in branch '2.0alpha' and is ready for testing! At the moment it has only been tested in Firefox and Chrome, if you work with IE feel free to give it a shot and let me know if something goes wrong.
toArray
method)<ol class="sortable">
<li><div>Some content</div></li>
<li>
<div>Some content</div>
<ol>
<li><div>Some sub-item content</div></li>
<li><div>Some sub-item content</div></li>
</ol>
</li>
<li><div>Some content</div></li>
</ol>
$(document).ready(function(){
$('.sortable').nestedSortable({
handle: 'div',
items: 'li',
toleranceElement: '> div'
});
});
Please note: every <li>
must have either one or two direct children, the first one being a container element (such as <div>
in the above example), and the (optional) second one being the nested list. The container element has to be set as the 'toleranceElement' in the options, and this, or one of its children, as the 'handle'.
Also, the default list type is <ol>
.
setName[n] => { 'item_id': itemId, 'parent_id': parentId, 'depth': depth, 'left': left, 'right': right, }It accepts the same options as the original Sortable method (attribute and expression) plus the custom startDepthCount, that sets the starting depth number (default is 0).
'0' ... 'id' => itemId '1' ... 'id' => itemId 'children' ... '0' ... 'id' => itemId '1' ... 'id' => itemId '2' ... 'id' => itemIdSimilarly to
toArray
, it accepts attribute and expression options.nestedSortable doesn't work properly with connected draggables, because of the way Draggable simulates Sortable mouseStart
and mouseStop
events. This bug might or might not be fixed some time in the future (it's not specific to this plugin).
jQuery 1.4+
jQuery UI Sortable 1.8+
Tested with: IE 6/7/8, Firefox 3.6/4, Chrome, Safari 3
This work is licensed under the MIT License.
This work is pizzaware. If it saved your life, or you just feel good at heart, please consider offering me a pizza. This can be done in two ways: (1) follow this link to donate through paypal; (2) send me cash via traditional mail to my home address in Italy. Is the second method legal? It is in Italy if you use Posta assicurata. You should check with your local laws if you live elsewhere.