@ts-core/angular 13.1.30 → 13.1.33
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 +12 -3
- package/esm2020/directive/ScrollCheckDirective.mjs +62 -17
- package/fesm2015/ts-core-angular.mjs +61 -16
- package/fesm2015/ts-core-angular.mjs.map +1 -1
- package/fesm2020/ts-core-angular.mjs +61 -16
- package/fesm2020/ts-core-angular.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -2,14 +2,23 @@ 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
|
+
delay: number;
|
|
14
|
+
offset: number;
|
|
9
15
|
constructor(element: ElementRef);
|
|
10
|
-
protected check()
|
|
16
|
+
protected check: () => void;
|
|
17
|
+
protected get scrollValue(): number;
|
|
18
|
+
protected get scrollHeight(): number;
|
|
19
|
+
protected get clientHeight(): number;
|
|
11
20
|
set scrollLimit(value: number);
|
|
12
21
|
get scrollLimit(): number;
|
|
13
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScrollCheckDirective, never>;
|
|
14
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<ScrollCheckDirective, "[vi-scroll-check]", never, { "scrollLimit": "vi-scroll-check"; }, { "limitExceed": "limitExceed"; }, never>;
|
|
23
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<ScrollCheckDirective, "[vi-scroll-check]", never, { "delay": "delay"; "offset": "offset"; "scrollLimit": "vi-scroll-check"; }, { "top": "top"; "bottom": "bottom"; "limitExceed": "limitExceed"; }, never>;
|
|
15
24
|
}
|
|
@@ -17,27 +17,64 @@ 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.delay = DateUtil.MILLISECONDS_SECOND / 10;
|
|
27
|
+
this.offset = 50;
|
|
28
|
+
//--------------------------------------------------------------------------
|
|
29
|
+
//
|
|
30
|
+
// Protected Methods
|
|
31
|
+
//
|
|
32
|
+
//--------------------------------------------------------------------------
|
|
33
|
+
this.check = () => {
|
|
34
|
+
let value = this.scrollValue >= this.scrollLimit;
|
|
35
|
+
if (value !== this.isExceedLimit) {
|
|
36
|
+
this.isExceedLimit = value;
|
|
37
|
+
this.limitExceed.emit(value);
|
|
38
|
+
}
|
|
39
|
+
value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;
|
|
40
|
+
this.bottom.next(value);
|
|
41
|
+
/*
|
|
42
|
+
if (value !== this.isBottom) {
|
|
43
|
+
this.isBottom = value;
|
|
44
|
+
this.bottom.next(value);
|
|
45
|
+
}
|
|
46
|
+
*/
|
|
47
|
+
value = this.scrollValue < this.offset;
|
|
48
|
+
this.top.next(value);
|
|
49
|
+
/*
|
|
50
|
+
if (value !== this.isTop) {
|
|
51
|
+
this.isTop = value;
|
|
52
|
+
this.top.next(value);
|
|
53
|
+
}
|
|
54
|
+
*/
|
|
55
|
+
};
|
|
56
|
+
this.delay = DateUtil.MILLISECONDS_SECOND / 10;
|
|
57
|
+
this.element = element.nativeElement;
|
|
58
|
+
fromEvent(this.element, 'scroll').pipe(debounceTime(this.delay), takeUntil(this.destroyed)).subscribe(this.check);
|
|
29
59
|
}
|
|
30
60
|
//--------------------------------------------------------------------------
|
|
31
61
|
//
|
|
32
|
-
//
|
|
62
|
+
// Private Properties
|
|
33
63
|
//
|
|
34
64
|
//--------------------------------------------------------------------------
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
65
|
+
// --------------------------------------------------------------------------
|
|
66
|
+
//
|
|
67
|
+
// Private Properties
|
|
68
|
+
//
|
|
69
|
+
// --------------------------------------------------------------------------
|
|
70
|
+
get scrollValue() {
|
|
71
|
+
return this.element.scrollTop;
|
|
72
|
+
}
|
|
73
|
+
get scrollHeight() {
|
|
74
|
+
return this.element.scrollHeight;
|
|
75
|
+
}
|
|
76
|
+
get clientHeight() {
|
|
77
|
+
return this.element.clientHeight;
|
|
41
78
|
}
|
|
42
79
|
//--------------------------------------------------------------------------
|
|
43
80
|
//
|
|
@@ -56,16 +93,24 @@ export class ScrollCheckDirective extends DestroyableContainer {
|
|
|
56
93
|
}
|
|
57
94
|
}
|
|
58
95
|
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 });
|
|
96
|
+
ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { delay: "delay", offset: "offset", scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { top: "top", bottom: "bottom", limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
|
|
60
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, decorators: [{
|
|
61
98
|
type: Directive,
|
|
62
99
|
args: [{
|
|
63
100
|
selector: '[vi-scroll-check]'
|
|
64
101
|
}]
|
|
65
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: {
|
|
102
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { top: [{
|
|
103
|
+
type: Output
|
|
104
|
+
}], bottom: [{
|
|
105
|
+
type: Output
|
|
106
|
+
}], limitExceed: [{
|
|
66
107
|
type: Output
|
|
108
|
+
}], delay: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], offset: [{
|
|
111
|
+
type: Input
|
|
67
112
|
}], scrollLimit: [{
|
|
68
113
|
type: Input,
|
|
69
114
|
args: ['vi-scroll-check']
|
|
70
115
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# 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    private isTop: boolean = false;\n    private isBottom: boolean = false;\n    private isExceedLimit: boolean = false;\n\n    @Input()\n    public delay: number = DateUtil.MILLISECONDS_SECOND / 10;\n    @Input()\n    public offset: number = 50;\n\n    //--------------------------------------------------------------------------\n    //\n    //\tConstructor\n    //\n    //--------------------------------------------------------------------------\n\n    constructor(element: ElementRef) {\n        super();\n        this.delay = DateUtil.MILLISECONDS_SECOND / 10;\n        this.element = element.nativeElement;\n\n        fromEvent(this.element, 'scroll').pipe(debounceTime(this.delay), takeUntil(this.destroyed)).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(value);\n        }\n\n        value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;\n        this.bottom.next(value);\n\n        /*\n        if (value !== this.isBottom) {\n            this.isBottom = value;\n            this.bottom.next(value);\n        }\n        */\n\n        value = this.scrollValue < this.offset;\n        this.top.next(value);\n        /*\n        if (value !== this.isTop) {\n            this.isTop = value;\n            this.top.next(value);\n        }\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,64 @@ 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.delay = DateUtil.MILLISECONDS_SECOND / 10;
|
|
2961
|
+
this.offset = 50;
|
|
2962
|
+
//--------------------------------------------------------------------------
|
|
2963
|
+
//
|
|
2964
|
+
// Protected Methods
|
|
2965
|
+
//
|
|
2966
|
+
//--------------------------------------------------------------------------
|
|
2967
|
+
this.check = () => {
|
|
2968
|
+
let value = this.scrollValue >= this.scrollLimit;
|
|
2969
|
+
if (value !== this.isExceedLimit) {
|
|
2970
|
+
this.isExceedLimit = value;
|
|
2971
|
+
this.limitExceed.emit(value);
|
|
2972
|
+
}
|
|
2973
|
+
value = this.scrollValue + this.clientHeight + this.offset > this.scrollHeight;
|
|
2974
|
+
this.bottom.next(value);
|
|
2975
|
+
/*
|
|
2976
|
+
if (value !== this.isBottom) {
|
|
2977
|
+
this.isBottom = value;
|
|
2978
|
+
this.bottom.next(value);
|
|
2979
|
+
}
|
|
2980
|
+
*/
|
|
2981
|
+
value = this.scrollValue < this.offset;
|
|
2982
|
+
this.top.next(value);
|
|
2983
|
+
/*
|
|
2984
|
+
if (value !== this.isTop) {
|
|
2985
|
+
this.isTop = value;
|
|
2986
|
+
this.top.next(value);
|
|
2987
|
+
}
|
|
2988
|
+
*/
|
|
2989
|
+
};
|
|
2990
|
+
this.delay = DateUtil.MILLISECONDS_SECOND / 10;
|
|
2991
|
+
this.element = element.nativeElement;
|
|
2992
|
+
fromEvent(this.element, 'scroll').pipe(debounceTime(this.delay), takeUntil(this.destroyed)).subscribe(this.check);
|
|
2963
2993
|
}
|
|
2964
2994
|
//--------------------------------------------------------------------------
|
|
2965
2995
|
//
|
|
2966
|
-
//
|
|
2996
|
+
// Private Properties
|
|
2967
2997
|
//
|
|
2968
2998
|
//--------------------------------------------------------------------------
|
|
2969
|
-
|
|
2970
|
-
|
|
2971
|
-
|
|
2972
|
-
|
|
2973
|
-
|
|
2974
|
-
|
|
2999
|
+
// --------------------------------------------------------------------------
|
|
3000
|
+
//
|
|
3001
|
+
// Private Properties
|
|
3002
|
+
//
|
|
3003
|
+
// --------------------------------------------------------------------------
|
|
3004
|
+
get scrollValue() {
|
|
3005
|
+
return this.element.scrollTop;
|
|
3006
|
+
}
|
|
3007
|
+
get scrollHeight() {
|
|
3008
|
+
return this.element.scrollHeight;
|
|
3009
|
+
}
|
|
3010
|
+
get clientHeight() {
|
|
3011
|
+
return this.element.clientHeight;
|
|
2975
3012
|
}
|
|
2976
3013
|
//--------------------------------------------------------------------------
|
|
2977
3014
|
//
|
|
@@ -2990,14 +3027,22 @@ class ScrollCheckDirective extends DestroyableContainer {
|
|
|
2990
3027
|
}
|
|
2991
3028
|
}
|
|
2992
3029
|
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 });
|
|
3030
|
+
ScrollCheckDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: ScrollCheckDirective, selector: "[vi-scroll-check]", inputs: { delay: "delay", offset: "offset", scrollLimit: ["vi-scroll-check", "scrollLimit"] }, outputs: { top: "top", bottom: "bottom", limitExceed: "limitExceed" }, usesInheritance: true, ngImport: i0 });
|
|
2994
3031
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ScrollCheckDirective, decorators: [{
|
|
2995
3032
|
type: Directive,
|
|
2996
3033
|
args: [{
|
|
2997
3034
|
selector: '[vi-scroll-check]'
|
|
2998
3035
|
}]
|
|
2999
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: {
|
|
3036
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { top: [{
|
|
3000
3037
|
type: Output
|
|
3038
|
+
}], bottom: [{
|
|
3039
|
+
type: Output
|
|
3040
|
+
}], limitExceed: [{
|
|
3041
|
+
type: Output
|
|
3042
|
+
}], delay: [{
|
|
3043
|
+
type: Input
|
|
3044
|
+
}], offset: [{
|
|
3045
|
+
type: Input
|
|
3001
3046
|
}], scrollLimit: [{
|
|
3002
3047
|
type: Input,
|
|
3003
3048
|
args: ['vi-scroll-check']
|