diff options
author | Kegan Dougal <kegan@matrix.org> | 2014-08-15 17:42:02 +0100 |
---|---|---|
committer | Kegan Dougal <kegan@matrix.org> | 2014-08-15 17:42:11 +0100 |
commit | 5b817ecd44ac5672da2042bb72ba8cf6e8d911f1 (patch) | |
tree | 6b2891b92de5f94f0959907d03b44f0dd3eff7c1 /webclient/js/ng-infinite-scroll-matrix.js | |
parent | When new invites come down, update the My Rooms list. Added hacks to make the... (diff) | |
download | synapse-5b817ecd44ac5672da2042bb72ba8cf6e8d911f1.tar.xz |
Added infinite scrolling. It's sliiiightly buggy in that it jumps down the list a bit, but it is overall working pretty well. Added ng-infinite-scroll-matrix.js and jquery-1.8.3 as deps.
Diffstat (limited to 'webclient/js/ng-infinite-scroll-matrix.js')
-rw-r--r-- | webclient/js/ng-infinite-scroll-matrix.js | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/webclient/js/ng-infinite-scroll-matrix.js b/webclient/js/ng-infinite-scroll-matrix.js new file mode 100644 index 0000000000..045ec8d93e --- /dev/null +++ b/webclient/js/ng-infinite-scroll-matrix.js @@ -0,0 +1,63 @@ +/* ng-infinite-scroll - v1.0.0 - 2013-02-23 + Matrix: Modified to support scrolling UP to get infinite loading and to listen + to scroll events on the PARENT element, not the window. +*/ +var mod; + +mod = angular.module('infinite-scroll', []); + +mod.directive('infiniteScroll', [ + '$rootScope', '$window', '$timeout', function($rootScope, $window, $timeout) { + return { + link: function(scope, elem, attrs) { + var checkWhenEnabled, handler, scrollDistance, scrollEnabled; + $window = angular.element($window); + scrollDistance = 0; + if (attrs.infiniteScrollDistance != null) { + scope.$watch(attrs.infiniteScrollDistance, function(value) { + return scrollDistance = parseInt(value, 10); + }); + } + scrollEnabled = true; + checkWhenEnabled = false; + if (attrs.infiniteScrollDisabled != null) { + scope.$watch(attrs.infiniteScrollDisabled, function(value) { + scrollEnabled = !value; + if (scrollEnabled && checkWhenEnabled) { + checkWhenEnabled = false; + return handler(); + } + }); + } + handler = function() { + var elementTop, remaining, shouldScroll, windowTop; + windowTop = 0; + elementTop = elem.offset().top; + shouldScroll = elementTop >= 0; // top of list is at the top of the window or further down the page + if (shouldScroll && scrollEnabled) { + if ($rootScope.$$phase) { + return scope.$eval(attrs.infiniteScroll); + } else { + return scope.$apply(attrs.infiniteScroll); + } + } else if (shouldScroll) { + return checkWhenEnabled = true; + } + }; + elem.parent().on('scroll', handler); + scope.$on('$destroy', function() { + return elem.parent().off('scroll', handler); + }); + return $timeout((function() { + if (attrs.infiniteScrollImmediateCheck) { + if (scope.$eval(attrs.infiniteScrollImmediateCheck)) { + return handler(); + } + } else { + return handler(); + } + }), 0); + } + }; + } +]); |