ngx-tethys 16.1.13 → 16.1.14
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/CHANGELOG.md +15 -0
- package/anchor/anchor.component.d.ts +11 -4
- package/anchor/style/anchor.scss +65 -21
- package/date-picker/picker.component.d.ts +0 -2
- package/esm2022/anchor/anchor.component.mjs +41 -15
- package/esm2022/date-picker/picker.component.mjs +4 -15
- package/esm2022/date-picker/picker.util.mjs +2 -2
- package/esm2022/version.mjs +2 -2
- package/fesm2022/ngx-tethys-anchor.mjs +39 -13
- package/fesm2022/ngx-tethys-anchor.mjs.map +1 -1
- package/fesm2022/ngx-tethys-date-picker.mjs +5 -15
- package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
- package/fesm2022/ngx-tethys.mjs +1 -1
- package/fesm2022/ngx-tethys.mjs.map +1 -1
- package/input/styles/input-group.scss +27 -5
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,21 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [16.1.14](https://github.com/atinc/ngx-tethys/compare/16.1.13...16.1.14) (2023-11-20)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **date-picker:** adjust updateReadableDate function INFR-10167 ([#2900](https://github.com/atinc/ngx-tethys/issues/2900)) ([4c2f14a](https://github.com/atinc/ngx-tethys/commit/4c2f14a59e86264e39343497dbae8aee4fba7440))
|
|
11
|
+
* **input:** adjust left margin of prefix element and right margin of suffix element #INFR-10515 ([8ad60ce](https://github.com/atinc/ngx-tethys/commit/8ad60ce0272e6fbc1313f37ce763455f6d13f1ec)), closes [#INFR-10515](https://github.com/atinc/ngx-tethys/issues/INFR-10515)
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
### Features
|
|
15
|
+
|
|
16
|
+
* **anchor:** support horizontal display #INFR-10451 ([#2901](https://github.com/atinc/ngx-tethys/issues/2901)) ([bb5d10a](https://github.com/atinc/ngx-tethys/commit/bb5d10a5dde4832a496c24137750e635fead2ec5)), closes [#INFR-10451](https://github.com/atinc/ngx-tethys/issues/INFR-10451)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
5
20
|
## [16.1.13](https://github.com/atinc/ngx-tethys/compare/16.1.12...16.1.13) (2023-11-16)
|
|
6
21
|
|
|
7
22
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Platform } from '@angular/cdk/platform';
|
|
2
|
-
import { AfterViewInit, ChangeDetectorRef, EventEmitter, NgZone, OnChanges, OnDestroy, Renderer2, SimpleChanges } from '@angular/core';
|
|
3
|
-
import { ThyAnchorLinkComponent } from './anchor-link.component';
|
|
2
|
+
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, Renderer2, SimpleChanges } from '@angular/core';
|
|
4
3
|
import { ThyScrollService } from 'ngx-tethys/core';
|
|
4
|
+
import { ThyAnchorLinkComponent } from './anchor-link.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
/**
|
|
7
7
|
* 锚点组件
|
|
@@ -14,6 +14,7 @@ export declare class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnC
|
|
|
14
14
|
private zone;
|
|
15
15
|
private renderer;
|
|
16
16
|
private scrollService;
|
|
17
|
+
private elementRef;
|
|
17
18
|
private ink;
|
|
18
19
|
/**
|
|
19
20
|
* 固定模式
|
|
@@ -32,6 +33,11 @@ export declare class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnC
|
|
|
32
33
|
* @type string | HTMLElement
|
|
33
34
|
*/
|
|
34
35
|
thyContainer?: string | HTMLElement;
|
|
36
|
+
/**
|
|
37
|
+
* 设置导航方向
|
|
38
|
+
* @type 'vertical' | 'horizontal'
|
|
39
|
+
*/
|
|
40
|
+
thyDirection: 'vertical' | 'horizontal';
|
|
35
41
|
/**
|
|
36
42
|
* 点击项触发
|
|
37
43
|
*/
|
|
@@ -49,12 +55,13 @@ export declare class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnC
|
|
|
49
55
|
private animating;
|
|
50
56
|
private destroy$;
|
|
51
57
|
private handleScrollTimeoutID;
|
|
52
|
-
constructor(document: any, cdr: ChangeDetectorRef, platform: Platform, zone: NgZone, renderer: Renderer2, scrollService: ThyScrollService);
|
|
58
|
+
constructor(document: any, cdr: ChangeDetectorRef, platform: Platform, zone: NgZone, renderer: Renderer2, scrollService: ThyScrollService, elementRef: ElementRef);
|
|
53
59
|
registerLink(link: ThyAnchorLinkComponent): void;
|
|
54
60
|
unregisterLink(link: ThyAnchorLinkComponent): void;
|
|
55
61
|
private getContainer;
|
|
56
62
|
ngAfterViewInit(): void;
|
|
57
63
|
ngOnDestroy(): void;
|
|
64
|
+
private warningPrompt;
|
|
58
65
|
private registerScrollEvent;
|
|
59
66
|
handleScroll(): void;
|
|
60
67
|
private clearActive;
|
|
@@ -63,5 +70,5 @@ export declare class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnC
|
|
|
63
70
|
handleScrollTo(linkComponent: ThyAnchorLinkComponent): void;
|
|
64
71
|
ngOnChanges(changes: SimpleChanges): void;
|
|
65
72
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyAnchorComponent, never>;
|
|
66
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<ThyAnchorComponent, "thy-anchor", ["thyAnchor"], { "thyAffix": { "alias": "thyAffix"; "required": false; }; "thyBounds": { "alias": "thyBounds"; "required": false; }; "thyOffsetTop": { "alias": "thyOffsetTop"; "required": false; }; "thyContainer": { "alias": "thyContainer"; "required": false; }; }, { "thyClick": "thyClick"; "thyScroll": "thyScroll"; }, never, ["*"], true, never>;
|
|
73
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ThyAnchorComponent, "thy-anchor", ["thyAnchor"], { "thyAffix": { "alias": "thyAffix"; "required": false; }; "thyBounds": { "alias": "thyBounds"; "required": false; }; "thyOffsetTop": { "alias": "thyOffsetTop"; "required": false; }; "thyContainer": { "alias": "thyContainer"; "required": false; }; "thyDirection": { "alias": "thyDirection"; "required": false; }; }, { "thyClick": "thyClick"; "thyScroll": "thyScroll"; }, never, ["*"], true, never>;
|
|
67
74
|
}
|
package/anchor/style/anchor.scss
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
@use
|
|
1
|
+
@use '../../styles/variables';
|
|
2
2
|
|
|
3
3
|
$anchor-border-width: 2px;
|
|
4
4
|
|
|
@@ -7,30 +7,74 @@ $anchor-border-width: 2px;
|
|
|
7
7
|
padding-left: $anchor-border-width;
|
|
8
8
|
|
|
9
9
|
&-wrapper {
|
|
10
|
-
margin-
|
|
11
|
-
padding-
|
|
10
|
+
margin-block-start: -4px;
|
|
11
|
+
padding-block-start: 4px;
|
|
12
12
|
overflow: auto;
|
|
13
13
|
background-color: variables.$white;
|
|
14
|
-
}
|
|
15
14
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
15
|
+
&:not(&-horizontal) {
|
|
16
|
+
.thy-anchor {
|
|
17
|
+
&-ink {
|
|
18
|
+
position: absolute;
|
|
19
|
+
top: 0;
|
|
20
|
+
left: 0;
|
|
21
|
+
height: 100%;
|
|
22
|
+
|
|
23
|
+
&::before {
|
|
24
|
+
position: relative;
|
|
25
|
+
display: block;
|
|
26
|
+
width: $anchor-border-width;
|
|
27
|
+
height: 100%;
|
|
28
|
+
margin: 0 auto;
|
|
29
|
+
background-color: variables.$nav-border-color;
|
|
30
|
+
content: ' ';
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
&-full {
|
|
34
|
+
position: absolute;
|
|
35
|
+
border-left: $anchor-border-width solid variables.$primary;
|
|
36
|
+
transition: top 0.2s ease-in-out;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
29
40
|
}
|
|
30
|
-
&-
|
|
31
|
-
position:
|
|
32
|
-
|
|
33
|
-
|
|
41
|
+
&-horizontal {
|
|
42
|
+
position: relative;
|
|
43
|
+
|
|
44
|
+
.thy-anchor {
|
|
45
|
+
display: flex;
|
|
46
|
+
overflow-x: scroll;
|
|
47
|
+
scrollbar-width: none;
|
|
48
|
+
|
|
49
|
+
&-ink {
|
|
50
|
+
position: absolute;
|
|
51
|
+
bottom: 0;
|
|
52
|
+
left: 0;
|
|
53
|
+
width: 100%;
|
|
54
|
+
height: 2px;
|
|
55
|
+
|
|
56
|
+
&::before {
|
|
57
|
+
position: relative;
|
|
58
|
+
display: block;
|
|
59
|
+
width: 100%;
|
|
60
|
+
height: $anchor-border-width;
|
|
61
|
+
margin: 0 auto;
|
|
62
|
+
background-color: variables.$nav-border-color;
|
|
63
|
+
content: ' ';
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
&-full {
|
|
67
|
+
position: absolute;
|
|
68
|
+
bottom: 0;
|
|
69
|
+
border-top: $anchor-border-width solid variables.$primary;
|
|
70
|
+
transition: left 0.2s ease-in-out, width 0.2s ease-in-out;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
&-link-title {
|
|
74
|
+
padding-left: 8px;
|
|
75
|
+
padding-right: 8px;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
34
78
|
}
|
|
35
79
|
}
|
|
36
80
|
|
|
@@ -5,7 +5,6 @@ import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter } from '@ang
|
|
|
5
5
|
import { DateHelperService } from './date-helper.service';
|
|
6
6
|
import { CompatibleValue, RangePartType } from './inner-types';
|
|
7
7
|
import { ThyDateGranularity } from './standard-types';
|
|
8
|
-
import { BehaviorSubject } from 'rxjs';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
/**
|
|
11
10
|
* @private
|
|
@@ -43,7 +42,6 @@ export declare class ThyPickerComponent implements AfterViewInit {
|
|
|
43
42
|
private innerFormat;
|
|
44
43
|
private innerValue;
|
|
45
44
|
entering: boolean;
|
|
46
|
-
readableValue$: BehaviorSubject<string>;
|
|
47
45
|
prefixCls: string;
|
|
48
46
|
animationOpenState: boolean;
|
|
49
47
|
overlayOpen: boolean;
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
2
|
import { Platform } from '@angular/cdk/platform';
|
|
3
3
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Input, NgZone, Output, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
4
|
-
import {
|
|
4
|
+
import { Subject, fromEvent } from 'rxjs';
|
|
5
5
|
import { takeUntil, throttleTime } from 'rxjs/operators';
|
|
6
|
-
import {
|
|
7
|
-
import { InputBoolean, InputNumber, ThyScrollService } from 'ngx-tethys/core';
|
|
8
|
-
import { DOCUMENT, NgIf, NgTemplateOutlet, NgStyle } from '@angular/common';
|
|
6
|
+
import { DOCUMENT, NgClass, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';
|
|
9
7
|
import { ThyAffixComponent } from 'ngx-tethys/affix';
|
|
8
|
+
import { InputBoolean, InputNumber, ThyScrollService } from 'ngx-tethys/core';
|
|
9
|
+
import { getOffset } from 'ngx-tethys/util';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@angular/cdk/platform";
|
|
12
12
|
import * as i2 from "ngx-tethys/core";
|
|
@@ -16,13 +16,14 @@ const sharpMatcherRegx = /#([^#]+)$/;
|
|
|
16
16
|
* @name thy-anchor
|
|
17
17
|
*/
|
|
18
18
|
export class ThyAnchorComponent {
|
|
19
|
-
constructor(document, cdr, platform, zone, renderer, scrollService) {
|
|
19
|
+
constructor(document, cdr, platform, zone, renderer, scrollService, elementRef) {
|
|
20
20
|
this.document = document;
|
|
21
21
|
this.cdr = cdr;
|
|
22
22
|
this.platform = platform;
|
|
23
23
|
this.zone = zone;
|
|
24
24
|
this.renderer = renderer;
|
|
25
25
|
this.scrollService = scrollService;
|
|
26
|
+
this.elementRef = elementRef;
|
|
26
27
|
/**
|
|
27
28
|
* 固定模式
|
|
28
29
|
*/
|
|
@@ -35,6 +36,11 @@ export class ThyAnchorComponent {
|
|
|
35
36
|
* 缓冲的偏移量阈值
|
|
36
37
|
*/
|
|
37
38
|
this.thyOffsetTop = undefined;
|
|
39
|
+
/**
|
|
40
|
+
* 设置导航方向
|
|
41
|
+
* @type 'vertical' | 'horizontal'
|
|
42
|
+
*/
|
|
43
|
+
this.thyDirection = 'vertical';
|
|
38
44
|
/**
|
|
39
45
|
* 点击项触发
|
|
40
46
|
*/
|
|
@@ -60,6 +66,7 @@ export class ThyAnchorComponent {
|
|
|
60
66
|
return this.container || window;
|
|
61
67
|
}
|
|
62
68
|
ngAfterViewInit() {
|
|
69
|
+
this.warningPrompt();
|
|
63
70
|
this.registerScrollEvent();
|
|
64
71
|
}
|
|
65
72
|
ngOnDestroy() {
|
|
@@ -67,6 +74,14 @@ export class ThyAnchorComponent {
|
|
|
67
74
|
this.destroy$.next();
|
|
68
75
|
this.destroy$.complete();
|
|
69
76
|
}
|
|
77
|
+
warningPrompt() {
|
|
78
|
+
if (this.thyDirection === 'horizontal') {
|
|
79
|
+
const hasChildren = this.links.some(link => Array.from(link?.elementRef?.nativeElement?.childNodes)?.some((item) => item?.className.includes('thy-anchor-link')));
|
|
80
|
+
if (hasChildren) {
|
|
81
|
+
console.warn("Anchor link nesting is not supported when 'Anchor' direction is horizontal.");
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
70
85
|
registerScrollEvent() {
|
|
71
86
|
if (!this.platform.isBrowser) {
|
|
72
87
|
return;
|
|
@@ -124,8 +139,11 @@ export class ThyAnchorComponent {
|
|
|
124
139
|
this.clearActive();
|
|
125
140
|
linkComponent.setActive();
|
|
126
141
|
const linkNode = linkComponent.getLinkTitleElement();
|
|
127
|
-
this.
|
|
128
|
-
this.ink.nativeElement.style.
|
|
142
|
+
const horizontalAnchor = this.thyDirection === 'horizontal';
|
|
143
|
+
this.ink.nativeElement.style.top = horizontalAnchor ? '' : `${linkNode.offsetTop}px`;
|
|
144
|
+
this.ink.nativeElement.style.height = horizontalAnchor ? '' : `${linkNode.clientHeight}px`;
|
|
145
|
+
this.ink.nativeElement.style.left = horizontalAnchor ? `${linkNode.offsetLeft}px` : '';
|
|
146
|
+
this.ink.nativeElement.style.width = horizontalAnchor ? `${linkNode.clientWidth}px` : '';
|
|
129
147
|
this.visible = true;
|
|
130
148
|
this.setVisible();
|
|
131
149
|
this.thyScroll.emit(linkComponent);
|
|
@@ -171,13 +189,16 @@ export class ThyAnchorComponent {
|
|
|
171
189
|
this.registerScrollEvent();
|
|
172
190
|
}
|
|
173
191
|
}
|
|
174
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: ThyAnchorComponent, deps: [{ token: DOCUMENT }, { token: i0.ChangeDetectorRef }, { token: i1.Platform }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i2.ThyScrollService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
175
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: ThyAnchorComponent, isStandalone: true, selector: "thy-anchor", inputs: { thyAffix: "thyAffix", thyBounds: "thyBounds", thyOffsetTop: "thyOffsetTop", thyContainer: "thyContainer" }, outputs: { thyClick: "thyClick", thyScroll: "thyScroll" }, viewQueries: [{ propertyName: "ink", first: true, predicate: ["ink"], descendants: true }], exportAs: ["thyAnchor"], usesOnChanges: true, ngImport: i0, template: `
|
|
192
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: ThyAnchorComponent, deps: [{ token: DOCUMENT }, { token: i0.ChangeDetectorRef }, { token: i1.Platform }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i2.ThyScrollService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
193
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: ThyAnchorComponent, isStandalone: true, selector: "thy-anchor", inputs: { thyAffix: "thyAffix", thyBounds: "thyBounds", thyOffsetTop: "thyOffsetTop", thyContainer: "thyContainer", thyDirection: "thyDirection" }, outputs: { thyClick: "thyClick", thyScroll: "thyScroll" }, viewQueries: [{ propertyName: "ink", first: true, predicate: ["ink"], descendants: true }], exportAs: ["thyAnchor"], usesOnChanges: true, ngImport: i0, template: `
|
|
176
194
|
<thy-affix *ngIf="thyAffix; else content" [thyOffsetTop]="thyOffsetTop" [thyContainer]="container">
|
|
177
195
|
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
178
196
|
</thy-affix>
|
|
179
197
|
<ng-template #content>
|
|
180
|
-
<div
|
|
198
|
+
<div
|
|
199
|
+
class="thy-anchor-wrapper"
|
|
200
|
+
[ngClass]="{ 'thy-anchor-wrapper-horizontal': thyDirection === 'horizontal' }"
|
|
201
|
+
[ngStyle]="wrapperStyle">
|
|
181
202
|
<div class="thy-anchor">
|
|
182
203
|
<div class="thy-anchor-ink">
|
|
183
204
|
<div class="thy-anchor-ink-full" #ink></div>
|
|
@@ -186,7 +207,7 @@ export class ThyAnchorComponent {
|
|
|
186
207
|
</div>
|
|
187
208
|
</div>
|
|
188
209
|
</ng-template>
|
|
189
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyAffixComponent, selector: "thy-affix", inputs: ["thyContainer", "thyOffsetTop", "thyOffsetBottom"], outputs: ["thyChange"], exportAs: ["thyAffix"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
210
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThyAffixComponent, selector: "thy-affix", inputs: ["thyContainer", "thyOffsetTop", "thyOffsetBottom"], outputs: ["thyChange"], exportAs: ["thyAffix"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
190
211
|
}
|
|
191
212
|
__decorate([
|
|
192
213
|
InputBoolean(),
|
|
@@ -211,7 +232,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
211
232
|
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
212
233
|
</thy-affix>
|
|
213
234
|
<ng-template #content>
|
|
214
|
-
<div
|
|
235
|
+
<div
|
|
236
|
+
class="thy-anchor-wrapper"
|
|
237
|
+
[ngClass]="{ 'thy-anchor-wrapper-horizontal': thyDirection === 'horizontal' }"
|
|
238
|
+
[ngStyle]="wrapperStyle">
|
|
215
239
|
<div class="thy-anchor">
|
|
216
240
|
<div class="thy-anchor-ink">
|
|
217
241
|
<div class="thy-anchor-ink-full" #ink></div>
|
|
@@ -224,12 +248,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
224
248
|
encapsulation: ViewEncapsulation.None,
|
|
225
249
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
226
250
|
standalone: true,
|
|
227
|
-
imports: [NgIf, ThyAffixComponent, NgTemplateOutlet, NgStyle]
|
|
251
|
+
imports: [NgIf, ThyAffixComponent, NgTemplateOutlet, NgStyle, NgClass]
|
|
228
252
|
}]
|
|
229
253
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
230
254
|
type: Inject,
|
|
231
255
|
args: [DOCUMENT]
|
|
232
|
-
}] }, { type: i0.ChangeDetectorRef }, { type: i1.Platform }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i2.ThyScrollService }]; }, propDecorators: { ink: [{
|
|
256
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i1.Platform }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i2.ThyScrollService }, { type: i0.ElementRef }]; }, propDecorators: { ink: [{
|
|
233
257
|
type: ViewChild,
|
|
234
258
|
args: ['ink']
|
|
235
259
|
}], thyAffix: [{
|
|
@@ -240,9 +264,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
240
264
|
type: Input
|
|
241
265
|
}], thyContainer: [{
|
|
242
266
|
type: Input
|
|
267
|
+
}], thyDirection: [{
|
|
268
|
+
type: Input
|
|
243
269
|
}], thyClick: [{
|
|
244
270
|
type: Output
|
|
245
271
|
}], thyScroll: [{
|
|
246
272
|
type: Output
|
|
247
273
|
}] } });
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../../src/anchor/anchor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil, throttleTime } from 'rxjs/operators';\n\nimport { ThyAnchorLinkComponent } from './anchor-link.component';\nimport { getOffset } from 'ngx-tethys/util';\nimport { InputBoolean, InputNumber, ThyScrollService } from 'ngx-tethys/core';\nimport { DOCUMENT, NgIf, NgTemplateOutlet, NgStyle } from '@angular/common';\nimport { ThyAffixComponent } from 'ngx-tethys/affix';\n\ninterface Section {\n    linkComponent: ThyAnchorLinkComponent;\n    top: number;\n}\n\nconst sharpMatcherRegx = /#([^#]+)$/;\n\n/**\n * 锚点组件\n * @name thy-anchor\n */\n@Component({\n    selector: 'thy-anchor',\n    exportAs: 'thyAnchor',\n    preserveWhitespaces: false,\n    template: `\n        <thy-affix *ngIf=\"thyAffix; else content\" [thyOffsetTop]=\"thyOffsetTop\" [thyContainer]=\"container\">\n            <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n        </thy-affix>\n        <ng-template #content>\n            <div class=\"thy-anchor-wrapper\" [ngStyle]=\"wrapperStyle\">\n                <div class=\"thy-anchor\">\n                    <div class=\"thy-anchor-ink\">\n                        <div class=\"thy-anchor-ink-full\" #ink></div>\n                    </div>\n                    <ng-content></ng-content>\n                </div>\n            </div>\n        </ng-template>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, ThyAffixComponent, NgTemplateOutlet, NgStyle]\n})\nexport class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnChanges {\n    @ViewChild('ink') private ink!: ElementRef;\n\n    /**\n     * 固定模式\n     */\n    @Input() @InputBoolean() thyAffix = true;\n\n    /**\n     * 锚点区域边界，单位：px\n     */\n    @Input()\n    @InputNumber()\n    thyBounds = 5;\n\n    /**\n     * 缓冲的偏移量阈值\n     */\n    @Input()\n    @InputNumber()\n    thyOffsetTop?: number = undefined;\n\n    /**\n     * 指定滚动的容器\n     * @type string | HTMLElement\n     */\n    @Input() thyContainer?: string | HTMLElement;\n\n    /**\n     * 点击项触发\n     */\n    @Output() readonly thyClick = new EventEmitter<ThyAnchorLinkComponent>();\n\n    /**\n     * 滚动到某锚点时触发\n     */\n    @Output() readonly thyScroll = new EventEmitter<ThyAnchorLinkComponent>();\n\n    visible = false;\n\n    wrapperStyle = { 'max-height': '100vh' };\n\n    container?: HTMLElement | Window;\n\n    private links: ThyAnchorLinkComponent[] = [];\n\n    private animating = false;\n\n    private destroy$ = new Subject<void>();\n\n    private handleScrollTimeoutID = -1;\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        private cdr: ChangeDetectorRef,\n        private platform: Platform,\n        private zone: NgZone,\n        private renderer: Renderer2,\n        private scrollService: ThyScrollService\n    ) {}\n\n    registerLink(link: ThyAnchorLinkComponent): void {\n        this.links.push(link);\n    }\n\n    unregisterLink(link: ThyAnchorLinkComponent): void {\n        this.links.splice(this.links.indexOf(link), 1);\n    }\n\n    private getContainer(): HTMLElement | Window {\n        return this.container || window;\n    }\n\n    ngAfterViewInit(): void {\n        this.registerScrollEvent();\n    }\n\n    ngOnDestroy(): void {\n        clearTimeout(this.handleScrollTimeoutID);\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private registerScrollEvent(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.destroy$.next();\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.getContainer(), 'scroll', { passive: true })\n                .pipe(throttleTime(50), takeUntil(this.destroy$))\n                .subscribe(() => this.handleScroll());\n        });\n        // Browser would maintain the scrolling position when refreshing.\n        // So we have to delay calculation in avoid of getting a incorrect result.\n        this.handleScrollTimeoutID = setTimeout(() => this.handleScroll());\n    }\n\n    handleScroll(): void {\n        if (typeof document === 'undefined' || this.animating) {\n            return;\n        }\n        const container: HTMLElement = this.container instanceof HTMLElement ? this.container : this.document;\n\n        const sections: Section[] = [];\n        const scope = (this.thyOffsetTop || 0) + this.thyBounds;\n        this.links.forEach(linkComponent => {\n            const sharpLinkMatch = sharpMatcherRegx.exec(linkComponent.thyHref.toString());\n            if (!sharpLinkMatch) {\n                return;\n            }\n            const target = container.querySelector(`#${sharpLinkMatch[1]}`) as HTMLElement;\n            if (target) {\n                const top = getOffset(target, this.getContainer()).top;\n                if (top < scope) {\n                    sections.push({\n                        top,\n                        linkComponent\n                    });\n                }\n            }\n        });\n\n        this.visible = !!sections.length;\n        if (!this.visible) {\n            this.clearActive();\n            this.cdr.detectChanges();\n        } else {\n            const maxSection = sections.reduce((prev, curr) => (curr.top > prev.top ? curr : prev));\n            this.handleActive(maxSection.linkComponent);\n        }\n        this.setVisible();\n    }\n\n    private clearActive(): void {\n        this.links.forEach(i => {\n            i.unsetActive();\n        });\n    }\n\n    private handleActive(linkComponent: ThyAnchorLinkComponent): void {\n        this.clearActive();\n        linkComponent.setActive();\n        const linkNode = linkComponent.getLinkTitleElement();\n\n        this.ink.nativeElement.style.top = `${linkNode.offsetTop}px`;\n        this.ink.nativeElement.style.height = `${linkNode.clientHeight}px`;\n        this.visible = true;\n        this.setVisible();\n        this.thyScroll.emit(linkComponent);\n    }\n\n    private setVisible(): void {\n        const visible = this.visible;\n        const visibleClassname = 'visible';\n        if (this.ink) {\n            if (visible) {\n                this.renderer.addClass(this.ink.nativeElement, visibleClassname);\n            } else {\n                this.renderer.removeClass(this.ink.nativeElement, visibleClassname);\n            }\n        }\n    }\n\n    handleScrollTo(linkComponent: ThyAnchorLinkComponent): void {\n        const container: HTMLElement = this.container instanceof HTMLElement ? this.container : this.document;\n        const linkElement: HTMLElement = container.querySelector(linkComponent.thyHref);\n        if (!linkElement) {\n            return;\n        }\n\n        this.animating = true;\n        const containerScrollTop = this.scrollService.getScroll(this.getContainer());\n        const elementOffsetTop = getOffset(linkElement, this.getContainer()).top;\n        const targetScrollTop = containerScrollTop + elementOffsetTop - (this.thyOffsetTop || 0);\n        this.scrollService.scrollTo(this.getContainer(), targetScrollTop, undefined, () => {\n            this.animating = false;\n        });\n        this.handleActive(linkComponent);\n        this.thyClick.emit(linkComponent);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyOffsetTop, thyContainer } = changes;\n        if (thyOffsetTop) {\n            this.wrapperStyle = {\n                'max-height': `calc(100vh - ${this.thyOffsetTop}px)`\n            };\n        }\n        if (thyContainer && this.thyContainer) {\n            const container = this.thyContainer;\n            this.container = typeof container === 'string' ? this.document.querySelector(container) : container;\n            this.registerScrollEvent();\n        }\n    }\n}\n"]}
|
|
274
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../../src/anchor/anchor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil, throttleTime } from 'rxjs/operators';\n\nimport { DOCUMENT, NgClass, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';\nimport { ThyAffixComponent } from 'ngx-tethys/affix';\nimport { InputBoolean, InputNumber, ThyScrollService } from 'ngx-tethys/core';\nimport { getOffset } from 'ngx-tethys/util';\nimport { ThyAnchorLinkComponent } from './anchor-link.component';\n\ninterface Section {\n    linkComponent: ThyAnchorLinkComponent;\n    top: number;\n}\n\nconst sharpMatcherRegx = /#([^#]+)$/;\n\n/**\n * 锚点组件\n * @name thy-anchor\n */\n@Component({\n    selector: 'thy-anchor',\n    exportAs: 'thyAnchor',\n    preserveWhitespaces: false,\n    template: `\n        <thy-affix *ngIf=\"thyAffix; else content\" [thyOffsetTop]=\"thyOffsetTop\" [thyContainer]=\"container\">\n            <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n        </thy-affix>\n        <ng-template #content>\n            <div\n                class=\"thy-anchor-wrapper\"\n                [ngClass]=\"{ 'thy-anchor-wrapper-horizontal': thyDirection === 'horizontal' }\"\n                [ngStyle]=\"wrapperStyle\">\n                <div class=\"thy-anchor\">\n                    <div class=\"thy-anchor-ink\">\n                        <div class=\"thy-anchor-ink-full\" #ink></div>\n                    </div>\n                    <ng-content></ng-content>\n                </div>\n            </div>\n        </ng-template>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, ThyAffixComponent, NgTemplateOutlet, NgStyle, NgClass]\n})\nexport class ThyAnchorComponent implements OnDestroy, AfterViewInit, OnChanges {\n    @ViewChild('ink') private ink!: ElementRef;\n\n    /**\n     * 固定模式\n     */\n    @Input() @InputBoolean() thyAffix = true;\n\n    /**\n     * 锚点区域边界，单位：px\n     */\n    @Input()\n    @InputNumber()\n    thyBounds = 5;\n\n    /**\n     * 缓冲的偏移量阈值\n     */\n    @Input()\n    @InputNumber()\n    thyOffsetTop?: number = undefined;\n\n    /**\n     * 指定滚动的容器\n     * @type string | HTMLElement\n     */\n    @Input() thyContainer?: string | HTMLElement;\n\n    /**\n     * 设置导航方向\n     * @type 'vertical' | 'horizontal'\n     */\n    @Input() thyDirection: 'vertical' | 'horizontal' = 'vertical';\n\n    /**\n     * 点击项触发\n     */\n    @Output() readonly thyClick = new EventEmitter<ThyAnchorLinkComponent>();\n\n    /**\n     * 滚动到某锚点时触发\n     */\n    @Output() readonly thyScroll = new EventEmitter<ThyAnchorLinkComponent>();\n\n    visible = false;\n\n    wrapperStyle = { 'max-height': '100vh' };\n\n    container?: HTMLElement | Window;\n\n    private links: ThyAnchorLinkComponent[] = [];\n\n    private animating = false;\n\n    private destroy$ = new Subject<void>();\n\n    private handleScrollTimeoutID = -1;\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        private cdr: ChangeDetectorRef,\n        private platform: Platform,\n        private zone: NgZone,\n        private renderer: Renderer2,\n        private scrollService: ThyScrollService,\n        private elementRef: ElementRef\n    ) {}\n\n    registerLink(link: ThyAnchorLinkComponent): void {\n        this.links.push(link);\n    }\n\n    unregisterLink(link: ThyAnchorLinkComponent): void {\n        this.links.splice(this.links.indexOf(link), 1);\n    }\n\n    private getContainer(): HTMLElement | Window {\n        return this.container || window;\n    }\n\n    ngAfterViewInit(): void {\n        this.warningPrompt();\n        this.registerScrollEvent();\n    }\n\n    ngOnDestroy(): void {\n        clearTimeout(this.handleScrollTimeoutID);\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private warningPrompt() {\n        if (this.thyDirection === 'horizontal') {\n            const hasChildren = this.links.some(link =>\n                Array.from(link?.elementRef?.nativeElement?.childNodes)?.some((item: HTMLElement) =>\n                    item?.className.includes('thy-anchor-link')\n                )\n            );\n            if (hasChildren) {\n                console.warn(\"Anchor link nesting is not supported when 'Anchor' direction is horizontal.\");\n            }\n        }\n    }\n\n    private registerScrollEvent(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.destroy$.next();\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.getContainer(), 'scroll', { passive: true })\n                .pipe(throttleTime(50), takeUntil(this.destroy$))\n                .subscribe(() => this.handleScroll());\n        });\n        // Browser would maintain the scrolling position when refreshing.\n        // So we have to delay calculation in avoid of getting a incorrect result.\n        this.handleScrollTimeoutID = setTimeout(() => this.handleScroll());\n    }\n\n    handleScroll(): void {\n        if (typeof document === 'undefined' || this.animating) {\n            return;\n        }\n        const container: HTMLElement = this.container instanceof HTMLElement ? this.container : this.document;\n\n        const sections: Section[] = [];\n        const scope = (this.thyOffsetTop || 0) + this.thyBounds;\n        this.links.forEach(linkComponent => {\n            const sharpLinkMatch = sharpMatcherRegx.exec(linkComponent.thyHref.toString());\n            if (!sharpLinkMatch) {\n                return;\n            }\n            const target = container.querySelector(`#${sharpLinkMatch[1]}`) as HTMLElement;\n            if (target) {\n                const top = getOffset(target, this.getContainer()).top;\n                if (top < scope) {\n                    sections.push({\n                        top,\n                        linkComponent\n                    });\n                }\n            }\n        });\n\n        this.visible = !!sections.length;\n        if (!this.visible) {\n            this.clearActive();\n            this.cdr.detectChanges();\n        } else {\n            const maxSection = sections.reduce((prev, curr) => (curr.top > prev.top ? curr : prev));\n            this.handleActive(maxSection.linkComponent);\n        }\n        this.setVisible();\n    }\n\n    private clearActive(): void {\n        this.links.forEach(i => {\n            i.unsetActive();\n        });\n    }\n\n    private handleActive(linkComponent: ThyAnchorLinkComponent): void {\n        this.clearActive();\n        linkComponent.setActive();\n        const linkNode = linkComponent.getLinkTitleElement();\n        const horizontalAnchor = this.thyDirection === 'horizontal';\n\n        this.ink.nativeElement.style.top = horizontalAnchor ? '' : `${linkNode.offsetTop}px`;\n        this.ink.nativeElement.style.height = horizontalAnchor ? '' : `${linkNode.clientHeight}px`;\n        this.ink.nativeElement.style.left = horizontalAnchor ? `${linkNode.offsetLeft}px` : '';\n        this.ink.nativeElement.style.width = horizontalAnchor ? `${linkNode.clientWidth}px` : '';\n        this.visible = true;\n        this.setVisible();\n        this.thyScroll.emit(linkComponent);\n    }\n\n    private setVisible(): void {\n        const visible = this.visible;\n        const visibleClassname = 'visible';\n        if (this.ink) {\n            if (visible) {\n                this.renderer.addClass(this.ink.nativeElement, visibleClassname);\n            } else {\n                this.renderer.removeClass(this.ink.nativeElement, visibleClassname);\n            }\n        }\n    }\n\n    handleScrollTo(linkComponent: ThyAnchorLinkComponent): void {\n        const container: HTMLElement = this.container instanceof HTMLElement ? this.container : this.document;\n        const linkElement: HTMLElement = container.querySelector(linkComponent.thyHref);\n        if (!linkElement) {\n            return;\n        }\n\n        this.animating = true;\n        const containerScrollTop = this.scrollService.getScroll(this.getContainer());\n        const elementOffsetTop = getOffset(linkElement, this.getContainer()).top;\n        const targetScrollTop = containerScrollTop + elementOffsetTop - (this.thyOffsetTop || 0);\n        this.scrollService.scrollTo(this.getContainer(), targetScrollTop, undefined, () => {\n            this.animating = false;\n        });\n        this.handleActive(linkComponent);\n        this.thyClick.emit(linkComponent);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyOffsetTop, thyContainer } = changes;\n        if (thyOffsetTop) {\n            this.wrapperStyle = {\n                'max-height': `calc(100vh - ${this.thyOffsetTop}px)`\n            };\n        }\n        if (thyContainer && this.thyContainer) {\n            const container = this.thyContainer;\n            this.container = typeof container === 'string' ? this.document.querySelector(container) : container;\n            this.registerScrollEvent();\n        }\n    }\n}\n"]}
|