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 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
  }
@@ -1,4 +1,4 @@
1
- @use "../../styles/variables";
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-left: -4px;
11
- padding-left: 4px;
10
+ margin-block-start: -4px;
11
+ padding-block-start: 4px;
12
12
  overflow: auto;
13
13
  background-color: variables.$white;
14
- }
15
14
 
16
- &-ink {
17
- position: absolute;
18
- top: 0;
19
- left: 0;
20
- height: 100%;
21
- &::before {
22
- position: relative;
23
- display: block;
24
- width: $anchor-border-width;
25
- height: 100%;
26
- margin: 0 auto;
27
- background-color: variables.$nav-border-color;
28
- content: ' ';
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
- &-full {
31
- position: absolute;
32
- border-left: $anchor-border-width solid variables.$primary;
33
- transition: top 0.2s ease-in-out;
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 { fromEvent, Subject } from 'rxjs';
4
+ import { Subject, fromEvent } from 'rxjs';
5
5
  import { takeUntil, throttleTime } from 'rxjs/operators';
6
- import { getOffset } from 'ngx-tethys/util';
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.ink.nativeElement.style.top = `${linkNode.offsetTop}px`;
128
- this.ink.nativeElement.style.height = `${linkNode.clientHeight}px`;
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 class="thy-anchor-wrapper" [ngStyle]="wrapperStyle">
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 class="thy-anchor-wrapper" [ngStyle]="wrapperStyle">
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"]}