UNPKG

18.1 kBJavaScriptView Raw
1"use strict";
2var core_1 = require('@angular/core');
3var position_resolver_1 = require('./position-resolver');
4var scroll_register_1 = require('./scroll-register');
5var scroll_resolver_1 = require('./scroll-resolver');
6var InfiniteScroll = (function () {
7 function InfiniteScroll(element, zone, positionResolverFactory, scrollRegister, scrollerResolver) {
8 this.element = element;
9 this.zone = zone;
10 this.positionResolverFactory = positionResolverFactory;
11 this.scrollRegister = scrollRegister;
12 this.scrollerResolver = scrollerResolver;
13 this.scrolled = new core_1.EventEmitter();
14 this.scrolledUp = new core_1.EventEmitter();
15 this._distanceDown = 2;
16 this._distanceUp = 1.5;
17 this._throttle = 300;
18 this._disabled = false;
19 this._container = null;
20 this.scrollWindow = true;
21 this._immediate = false;
22 this._horizontal = false;
23 this._alwaysCallback = false;
24 this.throttleType = 'throttle';
25 }
26 Object.defineProperty(InfiniteScroll.prototype, "debounce", {
27 set: function (value) {
28 this.throttleType = value === '' || !!value ? 'debounce' : 'throttle';
29 },
30 enumerable: true,
31 configurable: true
32 });
33 InfiniteScroll.prototype.ngOnInit = function () {
34 var _this = this;
35 if (typeof window !== 'undefined') {
36 var containerElement = this.resolveContainerElement();
37 var positionResolver_1 = this.positionResolverFactory.create({
38 windowElement: containerElement,
39 horizontal: this._horizontal
40 });
41 var options = {
42 container: positionResolver_1.container,
43 throttleType: this.throttleType,
44 throttleDuration: this._throttle,
45 filterBefore: function () { return !_this._disabled; },
46 mergeMap: function () { return positionResolver_1.calculatePoints(_this.element); },
47 scrollHandler: function (container) { return _this.handleOnScroll(container); }
48 };
49 this.disposeScroller = this.scrollRegister.attachEvent(options);
50 }
51 };
52 InfiniteScroll.prototype.handleOnScroll = function (container) {
53 var scrollResolverConfig = {
54 distance: {
55 down: this._distanceDown,
56 up: this._distanceUp
57 }
58 };
59 var scrollStats = this.scrollerResolver.getScrollStats(container, scrollResolverConfig);
60 if (this.shouldTriggerEvents(scrollStats.shouldScroll)) {
61 var infiniteScrollEvent = {
62 currentScrollPosition: container.scrolledUntilNow
63 };
64 if (scrollStats.isScrollingDown) {
65 this.onScrollDown(infiniteScrollEvent);
66 }
67 else {
68 this.onScrollUp(infiniteScrollEvent);
69 }
70 }
71 };
72 InfiniteScroll.prototype.shouldTriggerEvents = function (shouldScroll) {
73 return (this._alwaysCallback || shouldScroll) && !this._disabled;
74 };
75 InfiniteScroll.prototype.ngOnDestroy = function () {
76 if (this.disposeScroller) {
77 this.disposeScroller.unsubscribe();
78 }
79 };
80 InfiniteScroll.prototype.onScrollDown = function (data) {
81 var _this = this;
82 if (data === void 0) { data = { currentScrollPosition: 0 }; }
83 this.zone.run(function () { return _this.scrolled.emit(data); });
84 };
85 InfiniteScroll.prototype.onScrollUp = function (data) {
86 var _this = this;
87 if (data === void 0) { data = { currentScrollPosition: 0 }; }
88 this.zone.run(function () { return _this.scrolledUp.emit(data); });
89 };
90 InfiniteScroll.prototype.resolveContainerElement = function () {
91 if (this._container) {
92 return typeof (this._container) === 'string' ? window.document.querySelector(this._container) : this._container;
93 }
94 else {
95 return this.scrollWindow ? window : this.element;
96 }
97 };
98 InfiniteScroll.decorators = [
99 { type: core_1.Directive, args: [{
100 selector: '[infinite-scroll]'
101 },] },
102 ];
103 /** @nocollapse */
104 InfiniteScroll.ctorParameters = function () { return [
105 { type: core_1.ElementRef, },
106 { type: core_1.NgZone, },
107 { type: position_resolver_1.PositionResolverFactory, },
108 { type: scroll_register_1.ScrollRegister, },
109 { type: scroll_resolver_1.ScrollResolver, },
110 ]; };
111 InfiniteScroll.propDecorators = {
112 'scrolled': [{ type: core_1.Output },],
113 'scrolledUp': [{ type: core_1.Output },],
114 '_distanceDown': [{ type: core_1.Input, args: ['infiniteScrollDistance',] },],
115 '_distanceUp': [{ type: core_1.Input, args: ['infiniteScrollUpDistance',] },],
116 '_throttle': [{ type: core_1.Input, args: ['infiniteScrollThrottle',] },],
117 '_disabled': [{ type: core_1.Input, args: ['infiniteScrollDisabled',] },],
118 '_container': [{ type: core_1.Input, args: ['infiniteScrollContainer',] },],
119 'scrollWindow': [{ type: core_1.Input, args: ['scrollWindow',] },],
120 '_immediate': [{ type: core_1.Input, args: ['immediateCheck',] },],
121 '_horizontal': [{ type: core_1.Input, args: ['horizontal',] },],
122 '_alwaysCallback': [{ type: core_1.Input, args: ['alwaysCallback',] },],
123 'debounce': [{ type: core_1.Input },],
124 };
125 return InfiniteScroll;
126}());
127exports.InfiniteScroll = InfiniteScroll;
128//# 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"]}
\No newline at end of file