UNPKG

angular2-infinite-scroll

Version:
128 lines 18.1 kB
"use strict"; var core_1 = require('@angular/core'); var position_resolver_1 = require('./position-resolver'); var scroll_register_1 = require('./scroll-register'); var scroll_resolver_1 = require('./scroll-resolver'); var InfiniteScroll = (function () { function InfiniteScroll(element, zone, positionResolverFactory, scrollRegister, scrollerResolver) { this.element = element; this.zone = zone; this.positionResolverFactory = positionResolverFactory; this.scrollRegister = scrollRegister; this.scrollerResolver = scrollerResolver; this.scrolled = new core_1.EventEmitter(); this.scrolledUp = new core_1.EventEmitter(); this._distanceDown = 2; this._distanceUp = 1.5; this._throttle = 300; this._disabled = false; this._container = null; this.scrollWindow = true; this._immediate = false; this._horizontal = false; this._alwaysCallback = false; this.throttleType = 'throttle'; } Object.defineProperty(InfiniteScroll.prototype, "debounce", { set: function (value) { this.throttleType = value === '' || !!value ? 'debounce' : 'throttle'; }, enumerable: true, configurable: true }); InfiniteScroll.prototype.ngOnInit = function () { var _this = this; if (typeof window !== 'undefined') { var containerElement = this.resolveContainerElement(); var positionResolver_1 = this.positionResolverFactory.create({ windowElement: containerElement, horizontal: this._horizontal }); var options = { container: positionResolver_1.container, throttleType: this.throttleType, throttleDuration: this._throttle, filterBefore: function () { return !_this._disabled; }, mergeMap: function () { return positionResolver_1.calculatePoints(_this.element); }, scrollHandler: function (container) { return _this.handleOnScroll(container); } }; this.disposeScroller = this.scrollRegister.attachEvent(options); } }; InfiniteScroll.prototype.handleOnScroll = function (container) { var scrollResolverConfig = { distance: { down: this._distanceDown, up: this._distanceUp } }; var scrollStats = this.scrollerResolver.getScrollStats(container, scrollResolverConfig); if (this.shouldTriggerEvents(scrollStats.shouldScroll)) { var infiniteScrollEvent = { currentScrollPosition: container.scrolledUntilNow }; if (scrollStats.isScrollingDown) { this.onScrollDown(infiniteScrollEvent); } else { this.onScrollUp(infiniteScrollEvent); } } }; InfiniteScroll.prototype.shouldTriggerEvents = function (shouldScroll) { return (this._alwaysCallback || shouldScroll) && !this._disabled; }; InfiniteScroll.prototype.ngOnDestroy = function () { if (this.disposeScroller) { this.disposeScroller.unsubscribe(); } }; InfiniteScroll.prototype.onScrollDown = function (data) { var _this = this; if (data === void 0) { data = { currentScrollPosition: 0 }; } this.zone.run(function () { return _this.scrolled.emit(data); }); }; InfiniteScroll.prototype.onScrollUp = function (data) { var _this = this; if (data === void 0) { data = { currentScrollPosition: 0 }; } this.zone.run(function () { return _this.scrolledUp.emit(data); }); }; InfiniteScroll.prototype.resolveContainerElement = function () { if (this._container) { return typeof (this._container) === 'string' ? window.document.querySelector(this._container) : this._container; } else { return this.scrollWindow ? window : this.element; } }; InfiniteScroll.decorators = [ { type: core_1.Directive, args: [{ selector: '[infinite-scroll]' },] }, ]; /** @nocollapse */ InfiniteScroll.ctorParameters = function () { return [ { type: core_1.ElementRef, }, { type: core_1.NgZone, }, { type: position_resolver_1.PositionResolverFactory, }, { type: scroll_register_1.ScrollRegister, }, { type: scroll_resolver_1.ScrollResolver, }, ]; }; InfiniteScroll.propDecorators = { 'scrolled': [{ type: core_1.Output },], 'scrolledUp': [{ type: core_1.Output },], '_distanceDown': [{ type: core_1.Input, args: ['infiniteScrollDistance',] },], '_distanceUp': [{ type: core_1.Input, args: ['infiniteScrollUpDistance',] },], '_throttle': [{ type: core_1.Input, args: ['infiniteScrollThrottle',] },], '_disabled': [{ type: core_1.Input, args: ['infiniteScrollDisabled',] },], '_container': [{ type: core_1.Input, args: ['infiniteScrollContainer',] },], 'scrollWindow': [{ type: core_1.Input, args: ['scrollWindow',] },], '_immediate': [{ type: core_1.Input, args: ['immediateCheck',] },], '_horizontal': [{ type: core_1.Input, args: ['horizontal',] },], '_alwaysCallback': [{ type: core_1.Input, args: ['alwaysCallback',] },], 'debounce': [{ type: core_1.Input },], }; return InfiniteScroll; }()); exports.InfiniteScroll = InfiniteScroll; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll.js","sourceRoot":"","sources":["infinite-scroll.ts"],"names":[],"mappings":"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","sourcesContent":["import { InfiniteScrollEvent, ScrollStats, PositionStats } from './models';\nimport {\n  Directive, ElementRef, Input, Output,\n  EventEmitter, OnDestroy, OnInit,\n  SimpleChanges, NgZone\n} from '@angular/core';\nimport { PositionResolverFactory } from './position-resolver';\nimport { ScrollRegister, ScrollRegisterConfig } from './scroll-register';\nimport { ScrollResolver } from './scroll-resolver';\nimport { Subscription } from 'rxjs/Rx';\n\n\n\nexport class InfiniteScroll implements OnDestroy, OnInit {\n   scrolled = new EventEmitter<InfiniteScrollEvent>();\n   scrolledUp = new EventEmitter<InfiniteScrollEvent>();\n\n   _distanceDown: number = 2;\n   _distanceUp: number = 1.5;\n   _throttle: number = 300;\n   _disabled: boolean = false;\n   _container: any = null;\n   scrollWindow: boolean = true;\n   _immediate: boolean = false;\n   _horizontal: boolean = false;\n   _alwaysCallback: boolean = false;\n  \n  set debounce(value: string | boolean) {\n    this.throttleType = value === '' || !!value ? 'debounce' : 'throttle';\n  }\n\n  private throttleType: string = 'throttle';\n  private disposeScroller: Subscription;\n\n  constructor(\n    private element: ElementRef,\n    private zone: NgZone,\n    private positionResolverFactory: PositionResolverFactory,\n    private scrollRegister: ScrollRegister,\n    private scrollerResolver: ScrollResolver\n  ) {}\n\n  ngOnInit() {\n    if (typeof window !== 'undefined') {\n      const containerElement = this.resolveContainerElement();\n      const positionResolver = this.positionResolverFactory.create({\n        windowElement: containerElement,\n        horizontal: this._horizontal\n      });\n      const options: ScrollRegisterConfig = {\n        container: positionResolver.container,\n        throttleType: this.throttleType,\n        throttleDuration: this._throttle,\n        filterBefore: () => !this._disabled,\n        mergeMap: () => positionResolver.calculatePoints(this.element),\n        scrollHandler: (container: PositionStats) => this.handleOnScroll(container)\n      };\n      this.disposeScroller = this.scrollRegister.attachEvent(options);\n    }\n  }\n\n  handleOnScroll(container: PositionStats) {\n    const scrollResolverConfig = {\n      distance: {\n        down: this._distanceDown,\n        up: this._distanceUp\n      }\n    };\n    const scrollStats: ScrollStats = this.scrollerResolver.getScrollStats(container, scrollResolverConfig);\n    if (this.shouldTriggerEvents(scrollStats.shouldScroll)) {\n      const infiniteScrollEvent: InfiniteScrollEvent = {\n        currentScrollPosition: container.scrolledUntilNow\n      };\n      if (scrollStats.isScrollingDown) {\n        this.onScrollDown(infiniteScrollEvent);\n      } else {\n        this.onScrollUp(infiniteScrollEvent);\n      }\n    }\n  }\n\n  shouldTriggerEvents(shouldScroll: boolean) {\n    return (this._alwaysCallback || shouldScroll) && !this._disabled;\n  }\n\n  ngOnDestroy () {\n    if (this.disposeScroller) {\n      this.disposeScroller.unsubscribe();\n    }\n  }\n\n  onScrollDown(data: InfiniteScrollEvent = { currentScrollPosition: 0 }) {\n    this.zone.run(() => this.scrolled.emit(data));\n  }\n\n  onScrollUp(data: InfiniteScrollEvent = { currentScrollPosition: 0 }) {\n    this.zone.run(() => this.scrolledUp.emit(data));\n  }\n\n  private resolveContainerElement(): any {\n    if (this._container) {\n      return typeof(this._container) === 'string' ?  window.document.querySelector(this._container) : this._container;\n    } else {\n      return this.scrollWindow ? window : this.element;\n    }\n  }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Directive, args: [{\n  selector: '[infinite-scroll]'\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: () => ({type: any, decorators?: DecoratorInvocation[]}|null)[] = () => [\n{type: ElementRef, },\n{type: NgZone, },\n{type: PositionResolverFactory, },\n{type: ScrollRegister, },\n{type: ScrollResolver, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'scrolled': [{ type: Output },],\n'scrolledUp': [{ type: Output },],\n'_distanceDown': [{ type: Input, args: ['infiniteScrollDistance', ] },],\n'_distanceUp': [{ type: Input, args: ['infiniteScrollUpDistance', ] },],\n'_throttle': [{ type: Input, args: ['infiniteScrollThrottle', ] },],\n'_disabled': [{ type: Input, args: ['infiniteScrollDisabled', ] },],\n'_container': [{ type: Input, args: ['infiniteScrollContainer', ] },],\n'scrollWindow': [{ type: Input, args: ['scrollWindow', ] },],\n'_immediate': [{ type: Input, args: ['immediateCheck', ] },],\n'_horizontal': [{ type: Input, args: ['horizontal', ] },],\n'_alwaysCallback': [{ type: Input, args: ['alwaysCallback', ] },],\n'debounce': [{ type: Input },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}