From ed4788123b399f5968bea8b69c0932d46c566610 Mon Sep 17 00:00:00 2001 From: Samuel ROZE Date: Wed, 14 May 2014 17:45:34 +0200 Subject: [PATCH] Release 1.1.1 --- bower.json | 2 +- build/ng-infinite-scroll.js | 27 +++++++++++++++++++-------- build/ng-infinite-scroll.min.js | 4 ++-- package.json | 2 +- 4 files changed, 23 insertions(+), 12 deletions(-) diff --git a/bower.json b/bower.json index f4061ab..ef199a3 100644 --- a/bower.json +++ b/bower.json @@ -1,6 +1,6 @@ { "name": "ngInfiniteScroll", - "version": "1.1.0", + "version": "1.1.1", "main": "build/ng-infinite-scroll.js", "dependencies": { "angular": ">=1.1.3" diff --git a/build/ng-infinite-scroll.js b/build/ng-infinite-scroll.js index 57f9411..19a0dea 100644 --- a/build/ng-infinite-scroll.js +++ b/build/ng-infinite-scroll.js @@ -1,4 +1,4 @@ -/* ng-infinite-scroll - v1.1.0 - 2014-04-03 */ +/* ng-infinite-scroll - v1.1.1 - 2014-05-14 */ var mod; mod = angular.module('infinite-scroll', []); @@ -23,20 +23,31 @@ mod.directive('infiniteScroll', [ container = null; immediateCheck = true; handler = function() { - var containerBottom, elementBottom, remaining, shouldScroll; + var containerBottom, containerTopOffset, elementBottom, remaining, shouldScroll; if (container === $window) { containerBottom = container.height() + container.scrollTop(); elementBottom = elem.offset().top + elem.height(); } else { containerBottom = container.height(); - elementBottom = elem.offset().top - container.offset().top + elem.height(); + containerTopOffset = 0; + if (container.offset() !== void 0) { + containerTopOffset = container.offset().top; + } + elementBottom = elem.offset().top - containerTopOffset + elem.height(); } remaining = elementBottom - containerBottom; shouldScroll = remaining <= container.height() * scrollDistance + 1; - if (shouldScroll && scrollEnabled) { - return scope.infiniteScroll(); - } else if (shouldScroll) { - return checkWhenEnabled = true; + if (shouldScroll) { + checkWhenEnabled = true; + if (scrollEnabled) { + if (scope.$$phase || $rootScope.$$phase) { + return scope.infiniteScroll(); + } else { + return scope.$apply(scope.infiniteScroll); + } + } + } else { + return checkWhenEnabled = false; } }; throttle = function(func, wait) { @@ -92,7 +103,7 @@ mod.directive('infiniteScroll', [ if (container != null) { container.off('scroll', handler); } - container = newContainer; + container = typeof newContainer.last === 'function' ? newContainer.last() : newContainer; if (newContainer != null) { return container.on('scroll', handler); } diff --git a/build/ng-infinite-scroll.min.js b/build/ng-infinite-scroll.min.js index 82bac8c..5ac7ec2 100644 --- a/build/ng-infinite-scroll.min.js +++ b/build/ng-infinite-scroll.min.js @@ -1,2 +1,2 @@ -/* ng-infinite-scroll - v1.1.0 - 2014-04-03 */ -var mod;mod=angular.module("infinite-scroll",[]),mod.value("THROTTLE_MILLISECONDS",null),mod.directive("infiniteScroll",["$rootScope","$window","$timeout","THROTTLE_MILLISECONDS",function(n,i,l,e){return{scope:{infiniteScroll:"&",infiniteScrollContainer:"=",infiniteScrollDistance:"=",infiniteScrollDisabled:"="},link:function(n,t,o){var r,c,u,a,f,S,d,s,h,m,v;return i=angular.element(i),h=null,m=null,c=null,u=null,s=!0,d=function(){var l,e,o,r;return u===i?(l=u.height()+u.scrollTop(),e=t.offset().top+t.height()):(l=u.height(),e=t.offset().top-u.offset().top+t.height()),o=e-l,r=u.height()*h+1>=o,r&&m?n.infiniteScroll():r?c=!0:void 0},v=function(n,i){var e,t,o;return o=null,t=0,e=function(){var i;return t=(new Date).getTime(),l.cancel(o),o=null,n.call(),i=null},function(){var r,c;return r=(new Date).getTime(),c=i-(r-t),0>=c?(clearTimeout(o),l.cancel(o),o=null,t=r,n.call()):o?void 0:o=l(e,c)}},null!=e&&(d=v(d,e)),n.$on("$destroy",function(){return u.off("scroll",d)}),S=function(n){return h=parseInt(n,10)||0},n.$watch("infiniteScrollDistance",S),S(n.infiniteScrollDistance),f=function(n){return m=!n,m&&c?(c=!1,d()):void 0},n.$watch("infiniteScrollDisabled",f),f(n.infiniteScrollDisabled),r=function(n){return null!=u&&u.off("scroll",d),u=n,null!=n?u.on("scroll",d):void 0},r(i),a=function(n){if(null!=n&&0!==n.length){if(n=angular.element(n),null!=n)return r(n);throw new Exception("invalid infinite-scroll-container attribute.")}},n.$watch("infiniteScrollContainer",a),a(n.infiniteScrollContainer||[]),null!=o.infiniteScrollParent&&r(angular.element(t.parent())),null!=o.infiniteScrollImmediateCheck&&(s=n.$eval(o.infiniteScrollImmediateCheck)),l(function(){return s?d():void 0},0)}}}]); \ No newline at end of file +/* ng-infinite-scroll - v1.1.1 - 2014-05-14 */ +var mod;mod=angular.module("infinite-scroll",[]),mod.value("THROTTLE_MILLISECONDS",null),mod.directive("infiniteScroll",["$rootScope","$window","$timeout","THROTTLE_MILLISECONDS",function(n,i,l,e){return{scope:{infiniteScroll:"&",infiniteScrollContainer:"=",infiniteScrollDistance:"=",infiniteScrollDisabled:"="},link:function(t,o,r){var c,u,a,f,s,S,d,h,m,v,p;return i=angular.element(i),m=null,v=null,u=null,a=null,h=!0,d=function(){var l,e,r,c,f;return a===i?(l=a.height()+a.scrollTop(),r=o.offset().top+o.height()):(l=a.height(),e=0,void 0!==a.offset()&&(e=a.offset().top),r=o.offset().top-e+o.height()),c=r-l,f=a.height()*m+1>=c,f?(u=!0,v?t.$$phase||n.$$phase?t.infiniteScroll():t.$apply(t.infiniteScroll):void 0):u=!1},p=function(n,i){var e,t,o;return o=null,t=0,e=function(){var i;return t=(new Date).getTime(),l.cancel(o),o=null,n.call(),i=null},function(){var r,c;return r=(new Date).getTime(),c=i-(r-t),0>=c?(clearTimeout(o),l.cancel(o),o=null,t=r,n.call()):o?void 0:o=l(e,c)}},null!=e&&(d=p(d,e)),t.$on("$destroy",function(){return a.off("scroll",d)}),S=function(n){return m=parseInt(n,10)||0},t.$watch("infiniteScrollDistance",S),S(t.infiniteScrollDistance),s=function(n){return v=!n,v&&u?(u=!1,d()):void 0},t.$watch("infiniteScrollDisabled",s),s(t.infiniteScrollDisabled),c=function(n){return null!=a&&a.off("scroll",d),a="function"==typeof n.last?n.last():n,null!=n?a.on("scroll",d):void 0},c(i),f=function(n){if(null!=n&&0!==n.length){if(n=angular.element(n),null!=n)return c(n);throw new Exception("invalid infinite-scroll-container attribute.")}},t.$watch("infiniteScrollContainer",f),f(t.infiniteScrollContainer||[]),null!=r.infiniteScrollParent&&c(angular.element(o.parent())),null!=r.infiniteScrollImmediateCheck&&(h=t.$eval(r.infiniteScrollImmediateCheck)),l(function(){return h?d():void 0},0)}}}]); \ No newline at end of file diff --git a/package.json b/package.json index 9bc0902..94e0d15 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "ng-infinite-scroll", - "version": "1.1.0", + "version": "1.1.1", "description": "Infinite scrolling for AngularJS", "repository": { "type": "git",