aboutsummaryrefslogtreecommitdiffstats
path: root/catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js
diff options
context:
space:
mode:
authorMichael Lando <ml636r@att.com>2017-06-09 03:19:04 +0300
committerMichael Lando <ml636r@att.com>2017-06-09 03:19:04 +0300
commited64b5edff15e702493df21aa3230b81593e6133 (patch)
treea4cb01fdaccc34930a8db403a3097c0d1e40914b /catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js
parent280f8015d06af1f41a3ef12e8300801c7a5e0d54 (diff)
[SDC-29] catalog 1707 rebase commit.
Change-Id: I43c3dc5cf44abf5da817649bc738938a3e8388c1 Signed-off-by: Michael Lando <ml636r@att.com>
Diffstat (limited to 'catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js')
-rw-r--r--catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js209
1 files changed, 0 insertions, 209 deletions
diff --git a/catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js b/catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js
deleted file mode 100644
index 0585004832..0000000000
--- a/catalog-ui/app/third-party/ng-infinite-scroll/build/ng-infinite-scroll.js
+++ /dev/null
@@ -1,209 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-
-/* ng-infinite-scroll - v1.3.0 - 2016-06-30 */
-angular.module('infinite-scroll', []).value('THROTTLE_MILLISECONDS', null).directive('infiniteScroll', [
- '$rootScope', '$window', '$interval', 'THROTTLE_MILLISECONDS', function($rootScope, $window, $interval, THROTTLE_MILLISECONDS) {
- return {
- scope: {
- infiniteScroll: '&',
- infiniteScrollContainer: '=',
- infiniteScrollDistance: '=',
- infiniteScrollDisabled: '=',
- infiniteScrollUseDocumentBottom: '=',
- infiniteScrollListenForEvent: '@'
- },
- link: function(scope, elem, attrs) {
- var changeContainer, checkInterval, checkWhenEnabled, container, handleInfiniteScrollContainer, handleInfiniteScrollDisabled, handleInfiniteScrollDistance, handleInfiniteScrollUseDocumentBottom, handler, height, immediateCheck, offsetTop, pageYOffset, scrollDistance, scrollEnabled, throttle, unregisterEventListener, useDocumentBottom, windowElement;
- windowElement = angular.element($window);
- scrollDistance = null;
- scrollEnabled = null;
- checkWhenEnabled = null;
- container = null;
- immediateCheck = true;
- useDocumentBottom = false;
- unregisterEventListener = null;
- checkInterval = false;
- height = function(elem) {
- elem = elem[0] || elem;
- if (isNaN(elem.offsetHeight)) {
- return elem.document.documentElement.clientHeight;
- } else {
- return elem.offsetHeight;
- }
- };
- offsetTop = function(elem) {
- if (!elem[0].getBoundingClientRect || elem.css('none')) {
- return;
- }
- return elem[0].getBoundingClientRect().top + pageYOffset(elem);
- };
- pageYOffset = function(elem) {
- elem = elem[0] || elem;
- if (isNaN(window.pageYOffset)) {
- return elem.document.documentElement.scrollTop;
- } else {
- return elem.ownerDocument.defaultView.pageYOffset;
- }
- };
- handler = function() {
- var containerBottom, containerTopOffset, elementBottom, remaining, shouldScroll;
- if (container === windowElement) {
- containerBottom = height(container) + pageYOffset(container[0].document.documentElement);
- elementBottom = offsetTop(elem) + height(elem);
- } else {
- containerBottom = height(container);
- containerTopOffset = 0;
- if (offsetTop(container) !== void 0) {
- containerTopOffset = offsetTop(container);
- }
- elementBottom = offsetTop(elem) - containerTopOffset + height(elem);
- }
- if (useDocumentBottom) {
- elementBottom = height((elem[0].ownerDocument || elem[0].document).documentElement);
- }
- remaining = elementBottom - containerBottom;
- shouldScroll = remaining <= height(container) * scrollDistance + 1;
- if (shouldScroll) {
- checkWhenEnabled = true;
- if (scrollEnabled) {
- if (scope.$$phase || $rootScope.$$phase) {
- return scope.infiniteScroll();
- } else {
- return scope.$apply(scope.infiniteScroll);
- }
- }
- } else {
- if (checkInterval) {
- $interval.cancel(checkInterval);
- }
- return checkWhenEnabled = false;
- }
- };
- throttle = function(func, wait) {
- var later, previous, timeout;
- timeout = null;
- previous = 0;
- later = function() {
- previous = new Date().getTime();
- $interval.cancel(timeout);
- timeout = null;
- return func.call();
- };
- return function() {
- var now, remaining;
- now = new Date().getTime();
- remaining = wait - (now - previous);
- if (remaining <= 0) {
- $interval.cancel(timeout);
- timeout = null;
- previous = now;
- return func.call();
- } else {
- if (!timeout) {
- return timeout = $interval(later, remaining, 1);
- }
- }
- };
- };
- if (THROTTLE_MILLISECONDS != null) {
- handler = throttle(handler, THROTTLE_MILLISECONDS);
- }
- scope.$on('$destroy', function() {
- container.unbind('scroll', handler);
- if (unregisterEventListener != null) {
- unregisterEventListener();
- unregisterEventListener = null;
- }
- if (checkInterval) {
- return $interval.cancel(checkInterval);
- }
- });
- handleInfiniteScrollDistance = function(v) {
- return scrollDistance = parseFloat(v) || 0;
- };
- scope.$watch('infiniteScrollDistance', handleInfiniteScrollDistance);
- handleInfiniteScrollDistance(scope.infiniteScrollDistance);
- handleInfiniteScrollDisabled = function(v) {
- scrollEnabled = !v;
- if (scrollEnabled && checkWhenEnabled) {
- checkWhenEnabled = false;
- return handler();
- }
- };
- scope.$watch('infiniteScrollDisabled', handleInfiniteScrollDisabled);
- handleInfiniteScrollDisabled(scope.infiniteScrollDisabled);
- handleInfiniteScrollUseDocumentBottom = function(v) {
- return useDocumentBottom = v;
- };
- scope.$watch('infiniteScrollUseDocumentBottom', handleInfiniteScrollUseDocumentBottom);
- handleInfiniteScrollUseDocumentBottom(scope.infiniteScrollUseDocumentBottom);
- changeContainer = function(newContainer) {
- if (container != null) {
- container.unbind('scroll', handler);
- }
- container = newContainer;
- if (newContainer != null) {
- return container.bind('scroll', handler);
- }
- };
- changeContainer(windowElement);
- if (scope.infiniteScrollListenForEvent) {
- unregisterEventListener = $rootScope.$on(scope.infiniteScrollListenForEvent, handler);
- }
- handleInfiniteScrollContainer = function(newContainer) {
- if ((newContainer == null) || newContainer.length === 0) {
- return;
- }
- if (newContainer.nodeType && newContainer.nodeType === 1) {
- newContainer = angular.element(newContainer);
- } else if (typeof newContainer.append === 'function') {
- newContainer = angular.element(newContainer[newContainer.length - 1]);
- } else if (typeof newContainer === 'string') {
- newContainer = angular.element(document.querySelector(newContainer));
- }
- if (newContainer != null) {
- return changeContainer(newContainer);
- } else {
- throw new Error("invalid infinite-scroll-container attribute.");
- }
- };
- scope.$watch('infiniteScrollContainer', handleInfiniteScrollContainer);
- handleInfiniteScrollContainer(scope.infiniteScrollContainer || []);
- if (attrs.infiniteScrollParent != null) {
- changeContainer(angular.element(elem.parent()));
- }
- if (attrs.infiniteScrollImmediateCheck != null) {
- immediateCheck = scope.$eval(attrs.infiniteScrollImmediateCheck);
- }
- return checkInterval = $interval((function() {
- if (immediateCheck) {
- handler();
- }
- return $interval.cancel(checkInterval);
- }));
- }
- };
- }
-]);
-
-if (typeof module !== "undefined" && typeof exports !== "undefined" && module.exports === exports) {
- module.exports = 'infinite-scroll';
-}