Very simple jquery-ui like sortable that does not require jquery-ui... Look further to see the features that are not implemented yet :)
Demo: http://sebastien.chartier.pro/angular-sortable
Plunker: http://plnkr.co/edit/L33H0T?p=preview
I am trying to make the best sortable directive for Angular.js, your contribution is very welcome :)
I figured out that when we detect that the order should be updated, instead of proceeding to complex DOM manipulations, updating the referenced array would produce the same result, the "Angular" way (this is my personal opinion)...
bower install angular-sortable --save
<ul ng-sortable="items">
<li ng-repeat="item in items" class="sortable-element" ng-style="{backgroundColor: item.color}">
{{item.name}}, {{item.profession}}
</li>
</ul>
IMPORTANT: Sortable elements are identified with the class "sortable-element".
Options are defined as tag attributes:
- ng-sortable (required) : The value for this attribute must be the same list used by the inner ng-repeat that create the sortable elements.
- ng-sortable-on-change (optional)
- ng-sortable-on-dragstart (optional)
- ng-sortable-on-dragend (optional)
- ng-sortable-on-drag (optional)
HTML:
<ul ng-sortable="items"
ng-sortable-on-change="onItemsChange"
ng-sortable-on-dragstart="onItemsDragstart"
ng-sortable-on-dragend="onItemsDragend"
ng-sortable-on-drag="onItemsDrag">
<li ng-repeat="item in items" class="sortable-element" ng-style="{backgroundColor: item.color}">
{{item.name}}, {{item.profession}}
</li>
</ul>
Controller
$scope.onItemsDrag = function(event) {
// Do whatever you want here...
console.log('onItemsDrag');
};
$scope.onItemsDragstart = function(event) {
// Do whatever you want here...
console.log('onItemsDragstart');
};
$scope.onItemsDragend = function(event) {
// Do whatever you want here...
console.log('onItemsDragend');
};
$scope.onItemsChange = function(fromIdx, toIdx) {
// Do whatever you want here...
console.log('onItemsChange');
};
- Connect list: Sort items from one list into another and vice versa (http://jqueryui.com/sortable/#connect-lists).
- Delay start: Prevent accidental sorting either by delay (time) or distance (http://jqueryui.com/sortable/#delay-start).
- Handle empty lists: Prevent all items in a list from being dropped into a separate, empty list using the dropOnEmpty option set to false (http://jqueryui.com/sortable/#empty-lists).
- Include exclude items: Specify which items are eligible to sort by passing a jQuery selector into the items option (http://jqueryui.com/sortable/#items).
- Should we integrate with Bootstrap or keep styling to a minimum?
Your ideas are welcome, don't hesitate to contact me at [email protected] :)