diff options
author | Erik Johnston <erik@matrix.org> | 2014-08-15 17:50:27 +0100 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2014-08-15 17:50:27 +0100 |
commit | 7f5c7ddea9db879e500a48b47ad4f782d2d8416b (patch) | |
tree | 3332c614902b5641451da530ac9d2a3bed538a15 /webclient/js/ng-infinite-scroll-matrix.js | |
parent | Fix some of the tests to reflect changes in the storage layer. (diff) | |
parent | Get presence for members when you enter a room (it was coming down but wasn't... (diff) | |
download | synapse-7f5c7ddea9db879e500a48b47ad4f782d2d8416b.tar.xz |
Merge branch 'master' of github.com:matrix-org/synapse into sql_refactor
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); + } + }; + } +]); |