@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.
- package/directive/ScrollCheckDirective.d.ts +11 -3
- package/esm2020/directive/ScrollCheckDirective.mjs +52 -17
- package/fesm2015/ts-core-angular.mjs +51 -16
- package/fesm2015/ts-core-angular.mjs.map +1 -1
- package/fesm2020/ts-core-angular.mjs +51 -16
- package/fesm2020/ts-core-angular.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -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
|
|
9
|
+
private element;
|
|
10
|
+
private isTop;
|
|
11
|
+
private isBottom;
|
|
8
12
|
private isExceedLimit;
|
|
13
|
+
offset: number;
|
|
9
14
|
constructor(element: ElementRef);
|
|
10
|
-
protected check()
|
|
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.
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
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
|
-
//
|
|
54
|
+
// Private Properties
|
|
33
55
|
//
|
|
34
56
|
//--------------------------------------------------------------------------
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
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: {
|
|
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,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ScrollCheckDirective.js","sourceRoot":"","sources":["../../../src/directive/ScrollCheckDirective.ts"],"names":[],"mappings":"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","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.
|
|
2957
|
-
|
|
2958
|
-
|
|
2959
|
-
|
|
2960
|
-
|
|
2961
|
-
|
|
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
|
-
//
|
|
2988
|
+
// Private Properties
|
|
2967
2989
|
//
|
|
2968
2990
|
//--------------------------------------------------------------------------
|
|
2969
|
-
|
|
2970
|
-
|
|
2971
|
-
|
|
2972
|
-
|
|
2973
|
-
|
|
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: {
|
|
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']
|