@ts-core/angular 13.1.30 → 13.1.31

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,14 +2,22 @@ import { ElementRef, EventEmitter } from '@angular/core';
2
2
  import { DestroyableContainer } from '@ts-core/common';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class ScrollCheckDirective extends DestroyableContainer {
5
+ top: EventEmitter<boolean>;
6
+ bottom: EventEmitter<boolean>;
5
7
  limitExceed: EventEmitter<boolean>;
6
8
  private _scrollLimit;
7
- private _scrollValue;
9
+ private element;
10
+ private isTop;
11
+ private isBottom;
8
12
  private isExceedLimit;
13
+ offset: number;
9
14
  constructor(element: ElementRef);
10
- protected check(): void;
15
+ protected check: () => void;
16
+ protected get scrollValue(): number;
17
+ protected get scrollHeight(): number;
18
+ protected get clientHeight(): number;
11
19
  set scrollLimit(value: number);
12
20
  get scrollLimit(): number;
13
21
  static ɵfac: i0.ɵɵFactoryDeclaration<ScrollCheckDirective, never>;
14
- static ɵdir: i0.ɵɵDirectiveDeclaration<ScrollCheckDirective, "[vi-scroll-check]", never, { "scrollLimit": "vi-scroll-check"; }, { "limitExceed": "limitExceed"; }, never>;
22
+ static ɵdir: i0.ɵɵDirectiveDeclaration<ScrollCheckDirective, "[vi-scroll-check]", never, { "offset": "offset"; "scrollLimit": "vi-scroll-check"; }, { "top": "top"; "bottom": "bottom"; "limitExceed": "limitExceed"; }, never>;
15
23
  }
@@ -17,27 +17,56 @@ export class ScrollCheckDirective extends DestroyableContainer {
17
17
  // Properties
18
18
  //
19
19
  //--------------------------------------------------------------------------
20
+ this.top = new EventEmitter();
21
+ this.bottom = new EventEmitter();
20
22
  this.limitExceed = new EventEmitter();
23
+ this.isTop = false;
24
+ this.isBottom = false;
21
25
  this.isExceedLimit = false;
22
- this._scrollValue = element.nativeElement.scrollTop;
23
- fromEvent(element.nativeElement, 'scroll')
24
- .pipe(debounceTime(DateUtil.MILISECONDS_SECOND / 10), takeUntil(this.destroyed))
25
- .subscribe(() => {
26
- this._scrollValue = element.nativeElement.scrollTop;
27
- this.check();
28
- });
26
+ this.offset = 50;
27
+ //--------------------------------------------------------------------------
28
+ //
29
+ // Protected Methods
30
+ //
31
+ //--------------------------------------------------------------------------
32
+ this.check = () => {
33
+ let value = this.scrollValue >= this.scrollLimit;
34
+ if (value !== this.isExceedLimit) {
35
+ this.isExceedLimit = value;
36
+ this.limitExceed.emit(this.isExceedLimit);
37
+ }
38
+ value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;
39
+ if (value != this.isBottom) {
40
+ this.bottom.next(value);
41
+ }
42
+ value = this.scrollValue < this.offset;
43
+ if (value != this.isTop) {
44
+ this.top.next(value);
45
+ }
46
+ };
47
+ this.element = element.nativeElement;
48
+ fromEvent(this.element, 'scroll')
49
+ .pipe(debounceTime(DateUtil.MILLISECONDS_SECOND / 10), takeUntil(this.destroyed))
50
+ .subscribe(this.check);
29
51
  }
30
52
  //--------------------------------------------------------------------------
31
53
  //
32
- // Protected Methods
54
+ // Private Properties
33
55
  //
34
56
  //--------------------------------------------------------------------------
35
- check() {
36
- let value = this._scrollValue >= this.scrollLimit;
37
- if (value !== this.isExceedLimit) {
38
- this.isExceedLimit = value;
39
- this.limitExceed.emit(this.isExceedLimit);
40
- }
57
+ // --------------------------------------------------------------------------
58
+ //
59
+ // Private Properties
60
+ //
61
+ // --------------------------------------------------------------------------
62
+ get scrollValue() {
63
+ return this.element.scrollTop;
64
+ }
65
+ get scrollHeight() {
66
+ return this.element.scrollHeight;
67
+ }
68
+ get clientHeight() {
69
+ return this.element.clientHeight;
41
70
  }
42
71
  //--------------------------------------------------------------------------
43
72
  //
@@ -56,16 +85,22 @@ export class ScrollCheckDirective extends DestroyableContainer {
56
85
  }
57
86
  }
58
87
  ScrollCheckDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
59
- ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
88
+ ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { offset: "offset", scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { top: "top", bottom: "bottom", limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
60
89
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, decorators: [{
61
90
  type: Directive,
62
91
  args: [{
63
92
  selector: '[vi-scroll-check]'
64
93
  }]
65
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { limitExceed: [{
94
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { top: [{
95
+ type: Output
96
+ }], bottom: [{
97
+ type: Output
98
+ }], limitExceed: [{
66
99
  type: Output
100
+ }], offset: [{
101
+ type: Input
67
102
  }], scrollLimit: [{
68
103
  type: Input,
69
104
  args: ['vi-scroll-check']
70
105
  }] } });
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2Nyb2xsQ2hlY2tEaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGlyZWN0aXZlL1Njcm9sbENoZWNrRGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRTNDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakMsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSy9DLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxvQkFBb0I7SUFjMUQsNEVBQTRFO0lBQzVFLEVBQUU7SUFDRixjQUFjO0lBQ2QsRUFBRTtJQUNGLDRFQUE0RTtJQUU1RSxZQUFZLE9BQW1CO1FBQzNCLEtBQUssRUFBRSxDQUFDO1FBcEJaLDRFQUE0RTtRQUM1RSxFQUFFO1FBQ0YsYUFBYTtRQUNiLEVBQUU7UUFDRiw0RUFBNEU7UUFHckUsZ0JBQVcsR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUl2RCxrQkFBYSxHQUFZLEtBQUssQ0FBQztRQVduQyxJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO1FBQ3BELFNBQVMsQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLFFBQVEsQ0FBQzthQUNyQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsR0FBRyxFQUFFLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2FBQy9FLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDWixJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO1lBQ3BELElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCw0RUFBNEU7SUFDNUUsRUFBRTtJQUNGLG9CQUFvQjtJQUNwQixFQUFFO0lBQ0YsNEVBQTRFO0lBRWxFLEtBQUs7UUFDWCxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDbEQsSUFBSSxLQUFLLEtBQUssSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUM5QixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztZQUMzQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7U0FDN0M7SUFDTCxDQUFDO0lBRUQsNEVBQTRFO0lBQzVFLEVBQUU7SUFDRixvQkFBb0I7SUFDcEIsRUFBRTtJQUNGLDRFQUE0RTtJQUU1RSxJQUNXLFdBQVcsQ0FBQyxLQUFhO1FBQ2hDLElBQUksS0FBSyxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDNUIsT0FBTztTQUNWO1FBQ0QsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7UUFDMUIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFDRCxJQUFXLFdBQVc7UUFDbEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzdCLENBQUM7O2tIQTlEUSxvQkFBb0I7c0dBQXBCLG9CQUFvQjs0RkFBcEIsb0JBQW9CO2tCQUhoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxtQkFBbUI7aUJBQ2hDO2lHQVNVLFdBQVc7c0JBRGpCLE1BQU07Z0JBOENJLFdBQVc7c0JBRHJCLEtBQUs7dUJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERlc3Ryb3lhYmxlQ29udGFpbmVyIH0gZnJvbSAnQHRzLWNvcmUvY29tbW9uJztcbmltcG9ydCB7IERhdGVVdGlsIH0gZnJvbSAnQHRzLWNvcmUvY29tbW9uJztcbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IGZyb21FdmVudCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGVib3VuY2VUaW1lLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdmktc2Nyb2xsLWNoZWNrXSdcbn0pXG5leHBvcnQgY2xhc3MgU2Nyb2xsQ2hlY2tEaXJlY3RpdmUgZXh0ZW5kcyBEZXN0cm95YWJsZUNvbnRhaW5lciB7XG4gICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICAgIC8vXG4gICAgLy9cdFByb3BlcnRpZXNcbiAgICAvL1xuICAgIC8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBsaW1pdEV4Y2VlZDogRXZlbnRFbWl0dGVyPGJvb2xlYW4+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgcHJpdmF0ZSBfc2Nyb2xsTGltaXQ6IG51bWJlcjtcbiAgICBwcml2YXRlIF9zY3JvbGxWYWx1ZTogbnVtYmVyO1xuICAgIHByaXZhdGUgaXNFeGNlZWRMaW1pdDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICAgIC8vXG4gICAgLy9cdENvbnN0cnVjdG9yXG4gICAgLy9cbiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbiAgICBjb25zdHJ1Y3RvcihlbGVtZW50OiBFbGVtZW50UmVmKSB7XG4gICAgICAgIHN1cGVyKCk7XG5cbiAgICAgICAgdGhpcy5fc2Nyb2xsVmFsdWUgPSBlbGVtZW50Lm5hdGl2ZUVsZW1lbnQuc2Nyb2xsVG9wO1xuICAgICAgICBmcm9tRXZlbnQoZWxlbWVudC5uYXRpdmVFbGVtZW50LCAnc2Nyb2xsJylcbiAgICAgICAgICAgIC5waXBlKGRlYm91bmNlVGltZShEYXRlVXRpbC5NSUxJU0VDT05EU19TRUNPTkQgLyAxMCksIHRha2VVbnRpbCh0aGlzLmRlc3Ryb3llZCkpXG4gICAgICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLl9zY3JvbGxWYWx1ZSA9IGVsZW1lbnQubmF0aXZlRWxlbWVudC5zY3JvbGxUb3A7XG4gICAgICAgICAgICAgICAgdGhpcy5jaGVjaygpO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICAgIC8vXG4gICAgLy9cdFByb3RlY3RlZCBNZXRob2RzXG4gICAgLy9cbiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbiAgICBwcm90ZWN0ZWQgY2hlY2soKTogdm9pZCB7XG4gICAgICAgIGxldCB2YWx1ZSA9IHRoaXMuX3Njcm9sbFZhbHVlID49IHRoaXMuc2Nyb2xsTGltaXQ7XG4gICAgICAgIGlmICh2YWx1ZSAhPT0gdGhpcy5pc0V4Y2VlZExpbWl0KSB7XG4gICAgICAgICAgICB0aGlzLmlzRXhjZWVkTGltaXQgPSB2YWx1ZTtcbiAgICAgICAgICAgIHRoaXMubGltaXRFeGNlZWQuZW1pdCh0aGlzLmlzRXhjZWVkTGltaXQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICAgIC8vXG4gICAgLy9cdFB1YmxpYyBQcm9wZXJ0aWVzXG4gICAgLy9cbiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbiAgICBASW5wdXQoJ3ZpLXNjcm9sbC1jaGVjaycpXG4gICAgcHVibGljIHNldCBzY3JvbGxMaW1pdCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgICAgIGlmICh2YWx1ZSA9PSB0aGlzLl9zY3JvbGxMaW1pdCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuX3Njcm9sbExpbWl0ID0gdmFsdWU7XG4gICAgICAgIHRoaXMuY2hlY2soKTtcbiAgICB9XG4gICAgcHVibGljIGdldCBzY3JvbGxMaW1pdCgpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gdGhpcy5fc2Nyb2xsTGltaXQ7XG4gICAgfVxufVxuIl19
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ScrollCheckDirective.js","sourceRoot":"","sources":["../../../src/directive/ScrollCheckDirective.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AAK/C,MAAM,OAAO,oBAAqB,SAAQ,oBAAoB;IAyB1D,4EAA4E;IAC5E,EAAE;IACF,cAAc;IACd,EAAE;IACF,4EAA4E;IAE5E,YAAY,OAAmB;QAC3B,KAAK,EAAE,CAAC;QA/BZ,4EAA4E;QAC5E,EAAE;QACF,aAAa;QACb,EAAE;QACF,4EAA4E;QAGrE,QAAG,GAA0B,IAAI,YAAY,EAAE,CAAC;QAEhD,WAAM,GAA0B,IAAI,YAAY,EAAE,CAAC;QAEnD,gBAAW,GAA0B,IAAI,YAAY,EAAE,CAAC;QAMvD,UAAK,GAAY,KAAK,CAAC;QACvB,aAAQ,GAAY,KAAK,CAAC;QAC1B,kBAAa,GAAY,KAAK,CAAC;QAGhC,WAAM,GAAW,EAAE,CAAC;QAiB3B,4EAA4E;QAC5E,EAAE;QACF,oBAAoB;QACpB,EAAE;QACF,4EAA4E;QAElE,UAAK,GAAG,GAAS,EAAE;YACzB,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC;YACjD,IAAI,KAAK,KAAK,IAAI,CAAC,aAAa,EAAE;gBAC9B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aAC7C;YAED,KAAK,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;YAC/E,IAAI,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC3B;YAED,KAAK,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC;YACvC,IAAI,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE;gBACrB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACxB;QACL,CAAC,CAAC;QA7BE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC;QAErC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;aAC5B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,mBAAmB,GAAG,EAAE,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAChF,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IA0BD,4EAA4E;IAC5E,EAAE;IACF,qBAAqB;IACrB,EAAE;IACF,4EAA4E;IAE5E,6EAA6E;IAC7E,EAAE;IACF,qBAAqB;IACrB,EAAE;IACF,6EAA6E;IAE7E,IAAc,WAAW;QACrB,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;IAClC,CAAC;IACD,IAAc,YAAY;QACtB,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACrC,CAAC;IACD,IAAc,YAAY;QACtB,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACrC,CAAC;IAED,4EAA4E;IAC5E,EAAE;IACF,oBAAoB;IACpB,EAAE;IACF,4EAA4E;IAE5E,IACW,WAAW,CAAC,KAAa;QAChC,IAAI,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE;YAC5B,OAAO;SACV;QACD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IACD,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;;kHAtGQ,oBAAoB;sGAApB,oBAAoB;4FAApB,oBAAoB;kBAHhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,mBAAmB;iBAChC;iGASU,GAAG;sBADT,MAAM;gBAGA,MAAM;sBADZ,MAAM;gBAGA,WAAW;sBADjB,MAAM;gBAYA,MAAM;sBADZ,KAAK;gBAuEK,WAAW;sBADrB,KAAK;uBAAC,iBAAiB","sourcesContent":["import { Directive, ElementRef, Input, EventEmitter, Output } from '@angular/core';\nimport { DestroyableContainer } from '@ts-core/common';\nimport { DateUtil } from '@ts-core/common';\nimport * as _ from 'lodash';\nimport { fromEvent } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs';\n\n@Directive({\n    selector: '[vi-scroll-check]'\n})\nexport class ScrollCheckDirective extends DestroyableContainer {\n    //--------------------------------------------------------------------------\n    //\n    //\tProperties\n    //\n    //--------------------------------------------------------------------------\n\n    @Output()\n    public top: EventEmitter<boolean> = new EventEmitter();\n    @Output()\n    public bottom: EventEmitter<boolean> = new EventEmitter();\n    @Output()\n    public limitExceed: EventEmitter<boolean> = new EventEmitter();\n\n    private _scrollLimit: number;\n\n    private element: HTMLElement;\n\n    private isTop: boolean = false;\n    private isBottom: boolean = false;\n    private isExceedLimit: boolean = false;\n\n    @Input()\n    public offset: number = 50;\n\n    //--------------------------------------------------------------------------\n    //\n    //\tConstructor\n    //\n    //--------------------------------------------------------------------------\n\n    constructor(element: ElementRef) {\n        super();\n        this.element = element.nativeElement;\n\n        fromEvent(this.element, 'scroll')\n            .pipe(debounceTime(DateUtil.MILLISECONDS_SECOND / 10), takeUntil(this.destroyed))\n            .subscribe(this.check);\n    }\n\n    //--------------------------------------------------------------------------\n    //\n    //\tProtected Methods\n    //\n    //--------------------------------------------------------------------------\n\n    protected check = (): void => {\n        let value = this.scrollValue >= this.scrollLimit;\n        if (value !== this.isExceedLimit) {\n            this.isExceedLimit = value;\n            this.limitExceed.emit(this.isExceedLimit);\n        }\n\n        value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;\n        if (value != this.isBottom) {\n            this.bottom.next(value);\n        }\n\n        value = this.scrollValue < this.offset;\n        if (value != this.isTop) {\n            this.top.next(value);\n        }\n    };\n\n    //--------------------------------------------------------------------------\n    //\n    //\tPrivate Properties\n    //\n    //--------------------------------------------------------------------------\n\n    // --------------------------------------------------------------------------\n    //\n    //\tPrivate Properties\n    //\n    // --------------------------------------------------------------------------\n\n    protected get scrollValue(): number {\n        return this.element.scrollTop;\n    }\n    protected get scrollHeight() {\n        return this.element.scrollHeight;\n    }\n    protected get clientHeight(): number {\n        return this.element.clientHeight;\n    }\n\n    //--------------------------------------------------------------------------\n    //\n    //\tPublic Properties\n    //\n    //--------------------------------------------------------------------------\n\n    @Input('vi-scroll-check')\n    public set scrollLimit(value: number) {\n        if (value == this._scrollLimit) {\n            return;\n        }\n        this._scrollLimit = value;\n        this.check();\n    }\n    public get scrollLimit(): number {\n        return this._scrollLimit;\n    }\n}\n"]}
@@ -2951,27 +2951,56 @@ class ScrollCheckDirective extends DestroyableContainer {
2951
2951
  // Properties
2952
2952
  //
2953
2953
  //--------------------------------------------------------------------------
2954
+ this.top = new EventEmitter();
2955
+ this.bottom = new EventEmitter();
2954
2956
  this.limitExceed = new EventEmitter();
2957
+ this.isTop = false;
2958
+ this.isBottom = false;
2955
2959
  this.isExceedLimit = false;
2956
- this._scrollValue = element.nativeElement.scrollTop;
2957
- fromEvent(element.nativeElement, 'scroll')
2958
- .pipe(debounceTime(DateUtil.MILISECONDS_SECOND / 10), takeUntil(this.destroyed))
2959
- .subscribe(() => {
2960
- this._scrollValue = element.nativeElement.scrollTop;
2961
- this.check();
2962
- });
2960
+ this.offset = 50;
2961
+ //--------------------------------------------------------------------------
2962
+ //
2963
+ // Protected Methods
2964
+ //
2965
+ //--------------------------------------------------------------------------
2966
+ this.check = () => {
2967
+ let value = this.scrollValue >= this.scrollLimit;
2968
+ if (value !== this.isExceedLimit) {
2969
+ this.isExceedLimit = value;
2970
+ this.limitExceed.emit(this.isExceedLimit);
2971
+ }
2972
+ value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;
2973
+ if (value != this.isBottom) {
2974
+ this.bottom.next(value);
2975
+ }
2976
+ value = this.scrollValue < this.offset;
2977
+ if (value != this.isTop) {
2978
+ this.top.next(value);
2979
+ }
2980
+ };
2981
+ this.element = element.nativeElement;
2982
+ fromEvent(this.element, 'scroll')
2983
+ .pipe(debounceTime(DateUtil.MILLISECONDS_SECOND / 10), takeUntil(this.destroyed))
2984
+ .subscribe(this.check);
2963
2985
  }
2964
2986
  //--------------------------------------------------------------------------
2965
2987
  //
2966
- // Protected Methods
2988
+ // Private Properties
2967
2989
  //
2968
2990
  //--------------------------------------------------------------------------
2969
- check() {
2970
- let value = this._scrollValue >= this.scrollLimit;
2971
- if (value !== this.isExceedLimit) {
2972
- this.isExceedLimit = value;
2973
- this.limitExceed.emit(this.isExceedLimit);
2974
- }
2991
+ // --------------------------------------------------------------------------
2992
+ //
2993
+ // Private Properties
2994
+ //
2995
+ // --------------------------------------------------------------------------
2996
+ get scrollValue() {
2997
+ return this.element.scrollTop;
2998
+ }
2999
+ get scrollHeight() {
3000
+ return this.element.scrollHeight;
3001
+ }
3002
+ get clientHeight() {
3003
+ return this.element.clientHeight;
2975
3004
  }
2976
3005
  //--------------------------------------------------------------------------
2977
3006
  //
@@ -2990,14 +3019,20 @@ class ScrollCheckDirective extends DestroyableContainer {
2990
3019
  }
2991
3020
  }
2992
3021
  ScrollCheckDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
2993
- ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
3022
+ ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { offset: "offset", scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { top: "top", bottom: "bottom", limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
2994
3023
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, decorators: [{
2995
3024
  type: Directive,
2996
3025
  args: [{
2997
3026
  selector: '[vi-scroll-check]'
2998
3027
  }]
2999
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { limitExceed: [{
3028
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { top: [{
3000
3029
  type: Output
3030
+ }], bottom: [{
3031
+ type: Output
3032
+ }], limitExceed: [{
3033
+ type: Output
3034
+ }], offset: [{
3035
+ type: Input
3001
3036
  }], scrollLimit: [{
3002
3037
  type: Input,
3003
3038
  args: ['vi-scroll-check']