From 5b4737f6288460725ee1f992a744e7e6edecb4b3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20G=C3=B3is?= Date: Tue, 21 Jul 2015 14:42:33 +0100 Subject: [PATCH] Update ng-sortable.js --- ng-sortable.js | 59 +++++++++++++++++++++++++------------------------- 1 file changed, 30 insertions(+), 29 deletions(-) diff --git a/ng-sortable.js b/ng-sortable.js index 4f0b8c5..642340e 100644 --- a/ng-sortable.js +++ b/ng-sortable.js @@ -31,35 +31,6 @@ var removed, nextSibling; - function getSource(el) { - var scope = angular.element(el).scope(); - var ngRepeat = [].filter.call(el.childNodes, function (node) { - return ( - (node.nodeType === 8) && - (node.nodeValue.indexOf('ngRepeat:') !== -1) - ); - })[0]; - - if (!ngRepeat) { - // Without ng-repeat - return null; - } - - // tests: http://jsbin.com/kosubutilo/1/edit?js,output - ngRepeat = ngRepeat.nodeValue.match(/ngRepeat:\s*(?:\(.*?,\s*)?([^\s)]+)[\s)]+in\s+([^\s|]+)/); - - var itemExpr = $parse(ngRepeat[1]); - var itemsExpr = $parse(ngRepeat[2]); - - return { - item: function (el) { - return itemExpr(angular.element(el).scope()); - }, - items: function () { - return itemsExpr(scope); - } - }; - } // Export @@ -67,6 +38,36 @@ restrict: 'AC', scope: { ngSortable: "=?" }, link: function (scope, $el, attrs) { + + function getSource(el) { + var ngRepeat = [].filter.call(el.childNodes, function (node) { + return ( + (node.nodeType === 8) && + (node.nodeValue.indexOf('ngRepeat:') !== -1) + ); + })[0]; + + if (!ngRepeat) { + // Without ng-repeat + return null; + } + + // tests: http://jsbin.com/kosubutilo/1/edit?js,output + ngRepeat = ngRepeat.nodeValue.match(/ngRepeat:\s*(?:\(.*?,\s*)?([^\s)]+)[\s)]+in\s+([^\s|]+)/); + + var itemExpr = $parse(ngRepeat[1]); + var itemsExpr = $parse(ngRepeat[2]); + + return { + item: function (el) { + return itemExpr(angular.element(el).scope()); + }, + items: function () { + return itemsExpr(scope); + } + }; + } + var el = $el[0], options = angular.extend(scope.ngSortable || {}, ngSortableConfig), source = getSource(el),