|
|
@ -14,6 +14,16 @@ |
|
|
|
})(function (angular, Sortable) { |
|
|
|
})(function (angular, Sortable) { |
|
|
|
'use strict'; |
|
|
|
'use strict'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* @typedef {Object} ngSortEvent |
|
|
|
|
|
|
|
* @property {*} model List item |
|
|
|
|
|
|
|
* @property {Object|Array} models List of items |
|
|
|
|
|
|
|
* @property {number} oldIndex before sort |
|
|
|
|
|
|
|
* @property {number} newIndex after sort |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
angular.module('ng-sortable', []) |
|
|
|
angular.module('ng-sortable', []) |
|
|
|
.constant('$version', '0.3.5') |
|
|
|
.constant('$version', '0.3.5') |
|
|
|
.directive('ngSortable', ['$parse', function ($parse) { |
|
|
|
.directive('ngSortable', ['$parse', function ($parse) { |
|
|
@ -29,6 +39,11 @@ |
|
|
|
); |
|
|
|
); |
|
|
|
})[0]; |
|
|
|
})[0]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!ngRepeat) { |
|
|
|
|
|
|
|
// Without ng-repeat
|
|
|
|
|
|
|
|
return null; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// tests: http://jsbin.com/kosubutilo/1/edit?js,output
|
|
|
|
// tests: http://jsbin.com/kosubutilo/1/edit?js,output
|
|
|
|
ngRepeat = ngRepeat.nodeValue.match(/ngRepeat:\s*(?:\(.*?,\s*)?([^\s)]+)[\s)]+in\s+([^\s|]+)/); |
|
|
|
ngRepeat = ngRepeat.nodeValue.match(/ngRepeat:\s*(?:\(.*?,\s*)?([^\s)]+)[\s)]+in\s+([^\s|]+)/); |
|
|
|
|
|
|
|
|
|
|
@ -58,12 +73,25 @@ |
|
|
|
; |
|
|
|
; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
'Start End Add Update Remove Sort'.split(' ').forEach(function (name) { |
|
|
|
function _emitEvent(/**Event*/evt, /*Mixed*/item) { |
|
|
|
options['on' + name] = options['on' + name] || function () {}; |
|
|
|
var name = 'on' + evt.type.charAt(0).toUpperCase() + evt.type.substr(1); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* jshint expr:true */ |
|
|
|
|
|
|
|
options[name] && options[name]({ |
|
|
|
|
|
|
|
model: item, |
|
|
|
|
|
|
|
models: source && source.items(), |
|
|
|
|
|
|
|
oldIndex: evt.oldIndex, |
|
|
|
|
|
|
|
newIndex: evt.newIndex |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function _sync(/**Event*/evt) { |
|
|
|
|
|
|
|
if (!source) { |
|
|
|
|
|
|
|
// Without ng-repeat
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function _sync(evt) { |
|
|
|
|
|
|
|
var oldIndex = evt.oldIndex, |
|
|
|
var oldIndex = evt.oldIndex, |
|
|
|
newIndex = evt.newIndex, |
|
|
|
newIndex = evt.newIndex, |
|
|
|
items = source.items(); |
|
|
|
items = source.items(); |
|
|
@ -101,27 +129,27 @@ |
|
|
|
}, { |
|
|
|
}, { |
|
|
|
onStart: function (/**Event*/evt) { |
|
|
|
onStart: function (/**Event*/evt) { |
|
|
|
nextSibling = evt.item.nextSibling; |
|
|
|
nextSibling = evt.item.nextSibling; |
|
|
|
options.onStart(source.items()); |
|
|
|
_emitEvent(evt); |
|
|
|
scope.$apply(); |
|
|
|
scope.$apply(); |
|
|
|
}, |
|
|
|
}, |
|
|
|
onEnd: function () { |
|
|
|
onEnd: function (/**Event*/evt) { |
|
|
|
options.onEnd(source.items()); |
|
|
|
_emitEvent(evt, removed); |
|
|
|
scope.$apply(); |
|
|
|
scope.$apply(); |
|
|
|
}, |
|
|
|
}, |
|
|
|
onAdd: function (/**Event*/evt) { |
|
|
|
onAdd: function (/**Event*/evt) { |
|
|
|
_sync(evt); |
|
|
|
_sync(evt); |
|
|
|
options.onAdd(source.items(), removed); |
|
|
|
_emitEvent(evt, removed); |
|
|
|
scope.$apply(); |
|
|
|
scope.$apply(); |
|
|
|
}, |
|
|
|
}, |
|
|
|
onUpdate: function (/**Event*/evt) { |
|
|
|
onUpdate: function (/**Event*/evt) { |
|
|
|
_sync(evt); |
|
|
|
_sync(evt); |
|
|
|
options.onUpdate(source.items(), source.item(evt.item)); |
|
|
|
_emitEvent(evt, source && source.item(evt.item)); |
|
|
|
}, |
|
|
|
}, |
|
|
|
onRemove: function () { |
|
|
|
onRemove: function (/**Event*/evt) { |
|
|
|
options.onRemove(source.items(), removed); |
|
|
|
_emitEvent(evt, removed); |
|
|
|
}, |
|
|
|
}, |
|
|
|
onSort: function () { |
|
|
|
onSort: function (/**Event*/evt) { |
|
|
|
options.onSort(source.items()); |
|
|
|
_emitEvent(evt, source && source.item(evt.item)); |
|
|
|
} |
|
|
|
} |
|
|
|
})); |
|
|
|
})); |
|
|
|
|
|
|
|
|
|
|
|