ngx-tethys 18.2.2 → 18.2.4
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 +18 -0
- package/esm2022/date-picker/lib/popups/date-popup.component.mjs +2 -2
- package/esm2022/nav/nav-item.directive.mjs +17 -7
- package/esm2022/nav/nav.component.mjs +58 -18
- package/esm2022/tabs/tabs.component.mjs +2 -2
- package/esm2022/version.mjs +2 -2
- package/fesm2022/ngx-tethys-date-picker.mjs +1 -1
- package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
- package/fesm2022/ngx-tethys-nav.mjs +72 -22
- package/fesm2022/ngx-tethys-nav.mjs.map +1 -1
- package/fesm2022/ngx-tethys-tabs.mjs +1 -1
- package/fesm2022/ngx-tethys-tabs.mjs.map +1 -1
- package/fesm2022/ngx-tethys.mjs +1 -1
- package/fesm2022/ngx-tethys.mjs.map +1 -1
- package/nav/examples/{type/type.component.scss → card/card.component.scss} +0 -3
- package/nav/nav-item.directive.d.ts +7 -1
- package/nav/nav.component.d.ts +18 -4
- package/nav/styles/mixin.scss +35 -21
- package/nav/styles/nav.scss +75 -13
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/styles/variables.scss +5 -2
- package/theme/examples/basic/basic.component.scss +13 -0
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { ThyPopover } from 'ngx-tethys/popover';
|
|
2
2
|
import { merge, Observable, of } from 'rxjs';
|
|
3
|
-
import {
|
|
3
|
+
import { startWith, take, tap } from 'rxjs/operators';
|
|
4
4
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { useHostRenderer } from '@tethys/cdk/dom';
|
|
6
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, DestroyRef, ElementRef, HostBinding, inject, Input, NgZone, QueryList, TemplateRef, ViewChild } from '@angular/core';
|
|
6
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, DestroyRef, ElementRef, HostBinding, inject, input, Input, NgZone, QueryList, TemplateRef, ViewChild } from '@angular/core';
|
|
7
7
|
import { RouterLinkActive } from '@angular/router';
|
|
8
8
|
import { ThyNavInkBarDirective } from './nav-ink-bar.directive';
|
|
9
9
|
import { ThyNavItemDirective } from './nav-item.directive';
|
|
@@ -19,6 +19,7 @@ const navTypeClassesMap = {
|
|
|
19
19
|
tabs: ['thy-nav-tabs'],
|
|
20
20
|
pills: ['thy-nav-pills'],
|
|
21
21
|
lite: ['thy-nav-lite'],
|
|
22
|
+
card: ['thy-nav-card'],
|
|
22
23
|
//如下类型已经废弃
|
|
23
24
|
primary: ['thy-nav-primary'],
|
|
24
25
|
secondary: ['thy-nav-secondary'],
|
|
@@ -61,11 +62,22 @@ export class ThyNav {
|
|
|
61
62
|
* 是否是填充模式
|
|
62
63
|
*/
|
|
63
64
|
this.thyFill = false;
|
|
65
|
+
/**
|
|
66
|
+
* 支持暂停自适应计算
|
|
67
|
+
*/
|
|
68
|
+
this.thyPauseReCalculate = input(false);
|
|
64
69
|
/**
|
|
65
70
|
* 更多操作的菜单点击内部是否可关闭
|
|
71
|
+
* @deprecated please use thyPopoverOptions
|
|
66
72
|
*/
|
|
67
73
|
this.thyInsideClosable = true;
|
|
74
|
+
/**
|
|
75
|
+
* 更多菜单弹出框的参数,底层使用 Popover 组件
|
|
76
|
+
* @type ThyPopoverConfig
|
|
77
|
+
*/
|
|
78
|
+
this.thyPopoverOptions = input(null);
|
|
68
79
|
this.prevActiveIndex = NaN;
|
|
80
|
+
this.navSubscription = null;
|
|
69
81
|
}
|
|
70
82
|
/**
|
|
71
83
|
* 导航类型
|
|
@@ -136,16 +148,27 @@ export class ThyNav {
|
|
|
136
148
|
});
|
|
137
149
|
}
|
|
138
150
|
this.ngZone.runOutsideAngular(() => {
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
this.resetSizes();
|
|
143
|
-
this.setHiddenItems();
|
|
144
|
-
this.calculateMoreIsActive();
|
|
151
|
+
this.links.changes.pipe(startWith(this.links), takeUntilDestroyed(this.destroyRef)).subscribe(() => {
|
|
152
|
+
if (this.navSubscription) {
|
|
153
|
+
this.navSubscription.unsubscribe();
|
|
145
154
|
}
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
155
|
+
this.navSubscription = merge(this.createResizeObserver(this.elementRef.nativeElement), ...this.links.map(item => this.createResizeObserver(item.elementRef.nativeElement).pipe(tap(() => item.setOffset()))), ...(this.routers || []).map(router => router?.isActiveChange))
|
|
156
|
+
.pipe(takeUntilDestroyed(this.destroyRef), tap(() => {
|
|
157
|
+
if (this.thyPauseReCalculate()) {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
if (this.thyResponsive) {
|
|
161
|
+
this.resetSizes();
|
|
162
|
+
this.setHiddenItems();
|
|
163
|
+
this.calculateMoreIsActive();
|
|
164
|
+
}
|
|
165
|
+
if (this.type === 'card') {
|
|
166
|
+
this.setNavItemDivider();
|
|
167
|
+
}
|
|
168
|
+
}))
|
|
169
|
+
.subscribe(() => {
|
|
170
|
+
this.alignInkBarToSelectedTab();
|
|
171
|
+
});
|
|
149
172
|
});
|
|
150
173
|
});
|
|
151
174
|
}
|
|
@@ -172,6 +195,18 @@ export class ThyNav {
|
|
|
172
195
|
width: this.defaultMoreOperation?.nativeElement?.offsetWidth
|
|
173
196
|
};
|
|
174
197
|
}
|
|
198
|
+
setNavItemDivider() {
|
|
199
|
+
const tabs = this.links.toArray();
|
|
200
|
+
const activeIndex = tabs.findIndex(item => item.linkIsActive());
|
|
201
|
+
for (let i = 0; i < tabs.length; i++) {
|
|
202
|
+
if ((i !== activeIndex && i !== activeIndex - 1 && i !== tabs.length - 1) || (i === activeIndex - 1 && this.moreActive)) {
|
|
203
|
+
tabs[i].addClass('has-right-divider');
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
tabs[i].removeClass('has-right-divider');
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
175
210
|
createResizeObserver(element) {
|
|
176
211
|
return typeof ResizeObserver === 'undefined'
|
|
177
212
|
? of(null)
|
|
@@ -265,16 +300,16 @@ export class ThyNav {
|
|
|
265
300
|
top: this.elementRef.nativeElement.offsetTop || 0
|
|
266
301
|
};
|
|
267
302
|
}
|
|
268
|
-
|
|
269
|
-
this.popover.open(template, {
|
|
303
|
+
openMoreMenu(event, template) {
|
|
304
|
+
this.popover.open(template, Object.assign({
|
|
270
305
|
origin: event.currentTarget,
|
|
271
306
|
hasBackdrop: true,
|
|
272
307
|
backdropClosable: true,
|
|
273
|
-
insideClosable:
|
|
308
|
+
insideClosable: true,
|
|
274
309
|
placement: 'bottom',
|
|
275
310
|
panelClass: 'thy-nav-list-popover',
|
|
276
311
|
originActiveClass: 'thy-nav-origin-active'
|
|
277
|
-
});
|
|
312
|
+
}, this.thyPopoverOptions() ? this.thyPopoverOptions() : {}));
|
|
278
313
|
}
|
|
279
314
|
navItemClick(item) {
|
|
280
315
|
item.elementRef.nativeElement.click();
|
|
@@ -301,8 +336,13 @@ export class ThyNav {
|
|
|
301
336
|
this.alignInkBarToSelectedTab();
|
|
302
337
|
}
|
|
303
338
|
}
|
|
339
|
+
ngOnDestroy() {
|
|
340
|
+
if (this.navSubscription) {
|
|
341
|
+
this.navSubscription.unsubscribe();
|
|
342
|
+
}
|
|
343
|
+
}
|
|
304
344
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyNav, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
305
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ThyNav, isStandalone: true, selector: "thy-nav", inputs: { thyType: "thyType", thySize: "thySize", thyHorizontal: "thyHorizontal", thyVertical:
|
|
345
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ThyNav, isStandalone: true, selector: "thy-nav", inputs: { thyType: { classPropertyName: "thyType", publicName: "thyType", isSignal: false, isRequired: false, transformFunction: null }, thySize: { classPropertyName: "thySize", publicName: "thySize", isSignal: false, isRequired: false, transformFunction: null }, thyHorizontal: { classPropertyName: "thyHorizontal", publicName: "thyHorizontal", isSignal: false, isRequired: false, transformFunction: null }, thyVertical: { classPropertyName: "thyVertical", publicName: "thyVertical", isSignal: false, isRequired: false, transformFunction: coerceBooleanProperty }, thyFill: { classPropertyName: "thyFill", publicName: "thyFill", isSignal: false, isRequired: false, transformFunction: coerceBooleanProperty }, thyResponsive: { classPropertyName: "thyResponsive", publicName: "thyResponsive", isSignal: false, isRequired: false, transformFunction: coerceBooleanProperty }, thyPauseReCalculate: { classPropertyName: "thyPauseReCalculate", publicName: "thyPauseReCalculate", isSignal: true, isRequired: false, transformFunction: null }, thyInsideClosable: { classPropertyName: "thyInsideClosable", publicName: "thyInsideClosable", isSignal: false, isRequired: false, transformFunction: coerceBooleanProperty }, thyPopoverOptions: { classPropertyName: "thyPopoverOptions", publicName: "thyPopoverOptions", isSignal: true, isRequired: false, transformFunction: null }, thyExtra: { classPropertyName: "thyExtra", publicName: "thyExtra", isSignal: false, isRequired: false, transformFunction: null } }, host: { properties: { "class.thy-nav--vertical": "this.thyVertical", "class.thy-nav--fill": "this.thyFill" }, classAttribute: "thy-nav" }, queries: [{ propertyName: "moreOperation", first: true, predicate: ["more"], descendants: true }, { propertyName: "morePopover", first: true, predicate: ["morePopover"], descendants: true }, { propertyName: "extra", first: true, predicate: ["extra"], descendants: true }, { propertyName: "links", predicate: ThyNavItemDirective, descendants: true }, { propertyName: "routers", predicate: RouterLinkActive, descendants: true }], viewQueries: [{ propertyName: "defaultMoreOperation", first: true, predicate: ["moreOperationContainer"], descendants: true }, { propertyName: "inkBar", first: true, predicate: ThyNavInkBarDirective, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"thy-nav-list\" [ngClass]=\"horizontal ? 'justify-content-' + horizontal : ''\" #navList>\n <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n @if (thyResponsive) {\n <a\n href=\"javascript:;\"\n class=\"thy-nav-more-container\"\n [class.d-none]=\"!showMore\"\n [class.invisible]=\"!initialized\"\n #moreOperationContainer\n thyNavLink\n [thyNavItemActive]=\"moreActive\"\n (click)=\"openMoreMenu($event, navListPopover)\">\n @if (moreOperation) {\n <ng-container [ngTemplateOutlet]=\"moreOperation\"></ng-container>\n } @else {\n {{ locale().more }}\n <thy-icon thyIconName=\"angle-down\" class=\"thy-nav-more-icon\"></thy-icon>\n }\n </a>\n }\n @if (thyExtra || extra) {\n <div class=\"thy-nav-extra\">\n <ng-container [ngTemplateOutlet]=\"thyExtra || extra\"></ng-container>\n </div>\n }\n <thy-nav-ink-bar [showInkBar]=\"showInkBar\" [isVertical]=\"thyVertical\"></thy-nav-ink-bar>\n</div>\n\n<ng-template #navListPopover>\n @if (morePopover) {\n <ng-container [ngTemplateOutlet]=\"morePopover\" [ngTemplateOutletContext]=\"{ $implicit: hiddenItems }\"></ng-container>\n } @else {\n <thy-dropdown-menu thyImmediateRender>\n @for (item of hiddenItems; track $index) {\n <span\n class=\"thy-nav-item-more\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"item.isActive\"\n (click)=\"navItemClick(item)\"\n [innerHTML]=\"item.elementRef.nativeElement.innerHTML | bypassSecurityTrustHtml\"></span>\n }\n </thy-dropdown-menu>\n }\n</ng-template>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: ["id", "thyNavItemActive", "thyNavLinkActive", "thyNavItemDisabled"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: ThyNavInkBarDirective, selector: "thy-nav-ink-bar, [thyNavInkBar]", inputs: ["isVertical", "showInkBar"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "directive", type: ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: ThyDropdownMenuItemActiveDirective, selector: "[thyDropdownMenuItemActive]", inputs: ["thyDropdownMenuItemActive"] }, { kind: "pipe", type: BypassSecurityTrustHtmlPipe, name: "bypassSecurityTrustHtml" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
306
346
|
}
|
|
307
347
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyNav, decorators: [{
|
|
308
348
|
type: Component,
|
|
@@ -318,7 +358,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
318
358
|
ThyDropdownMenuItemDirective,
|
|
319
359
|
ThyDropdownMenuItemActiveDirective,
|
|
320
360
|
BypassSecurityTrustHtmlPipe
|
|
321
|
-
], template: "<div class=\"thy-nav-list\" [ngClass]=\"horizontal ? 'justify-content-' + horizontal : ''\" #navList>\n <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n @if (thyResponsive) {\n <a\n href=\"javascript:;\"\n class=\"thy-nav-more-container\"\n [class.d-none]=\"!showMore\"\n [class.invisible]=\"!initialized\"\n #moreOperationContainer\n thyNavLink\n [
|
|
361
|
+
], template: "<div class=\"thy-nav-list\" [ngClass]=\"horizontal ? 'justify-content-' + horizontal : ''\" #navList>\n <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n @if (thyResponsive) {\n <a\n href=\"javascript:;\"\n class=\"thy-nav-more-container\"\n [class.d-none]=\"!showMore\"\n [class.invisible]=\"!initialized\"\n #moreOperationContainer\n thyNavLink\n [thyNavItemActive]=\"moreActive\"\n (click)=\"openMoreMenu($event, navListPopover)\">\n @if (moreOperation) {\n <ng-container [ngTemplateOutlet]=\"moreOperation\"></ng-container>\n } @else {\n {{ locale().more }}\n <thy-icon thyIconName=\"angle-down\" class=\"thy-nav-more-icon\"></thy-icon>\n }\n </a>\n }\n @if (thyExtra || extra) {\n <div class=\"thy-nav-extra\">\n <ng-container [ngTemplateOutlet]=\"thyExtra || extra\"></ng-container>\n </div>\n }\n <thy-nav-ink-bar [showInkBar]=\"showInkBar\" [isVertical]=\"thyVertical\"></thy-nav-ink-bar>\n</div>\n\n<ng-template #navListPopover>\n @if (morePopover) {\n <ng-container [ngTemplateOutlet]=\"morePopover\" [ngTemplateOutletContext]=\"{ $implicit: hiddenItems }\"></ng-container>\n } @else {\n <thy-dropdown-menu thyImmediateRender>\n @for (item of hiddenItems; track $index) {\n <span\n class=\"thy-nav-item-more\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"item.isActive\"\n (click)=\"navItemClick(item)\"\n [innerHTML]=\"item.elementRef.nativeElement.innerHTML | bypassSecurityTrustHtml\"></span>\n }\n </thy-dropdown-menu>\n }\n</ng-template>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n" }]
|
|
322
362
|
}], propDecorators: { thyType: [{
|
|
323
363
|
type: Input
|
|
324
364
|
}], thySize: [{
|
|
@@ -367,4 +407,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
367
407
|
type: ViewChild,
|
|
368
408
|
args: [ThyNavInkBarDirective, { static: true }]
|
|
369
409
|
}] } });
|
|
370
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav.component.js","sourceRoot":"","sources":["../../../../src/nav/nav.component.ts","../../../../src/nav/nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThyPopover } from 'ngx-tethys/popover';\nimport { merge, Observable, of } from 'rxjs';\nimport { debounceTime, take, tap } from 'rxjs/operators';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport {\n    AfterContentChecked,\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    DestroyRef,\n    ElementRef,\n    HostBinding,\n    inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    QueryList,\n    Signal,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { RouterLinkActive } from '@angular/router';\nimport { ThyNavInkBarDirective } from './nav-ink-bar.directive';\nimport { ThyNavItemDirective } from './nav-item.directive';\nimport { BypassSecurityTrustHtmlPipe } from './nav.pipe';\nimport { ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemActiveDirective } from 'ngx-tethys/dropdown';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\nimport { injectLocale, ThyNavLocale } from 'ngx-tethys/i18n';\n\nexport type ThyNavType = 'pulled' | 'tabs' | 'pills' | 'lite' | 'primary' | 'secondary' | 'thirdly' | 'secondary-divider';\nexport type ThyNavSize = 'lg' | 'md' | 'sm';\nexport type ThyNavHorizontal = '' | 'start' | 'center' | 'end';\n\nconst navTypeClassesMap = {\n    pulled: ['thy-nav-pulled'],\n    tabs: ['thy-nav-tabs'],\n    pills: ['thy-nav-pills'],\n    lite: ['thy-nav-lite'],\n    //如下类型已经废弃\n    primary: ['thy-nav-primary'],\n    secondary: ['thy-nav-secondary'],\n    thirdly: ['thy-nav-thirdly'],\n    'secondary-divider': ['thy-nav-secondary-divider']\n};\n\nconst navSizeClassesMap = {\n    lg: 'thy-nav-lg',\n    md: 'thy-nav-md',\n    sm: 'thy-nav-sm'\n};\n\nconst tabItemRight = 20;\n\n/**\n * 导航组件\n * @name thy-nav\n * @order 10\n */\n@Component({\n    selector: 'thy-nav',\n    templateUrl: './nav.component.html',\n    host: {\n        class: 'thy-nav'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [\n        NgClass,\n        NgTemplateOutlet,\n        ThyNavItemDirective,\n        ThyIcon,\n        ThyNavInkBarDirective,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuItemDirective,\n        ThyDropdownMenuItemActiveDirective,\n        BypassSecurityTrustHtmlPipe\n    ]\n})\nexport class ThyNav implements OnInit, AfterViewInit, AfterContentInit, AfterContentChecked, OnChanges {\n    private elementRef = inject(ElementRef);\n    private ngZone = inject(NgZone);\n    private changeDetectorRef = inject(ChangeDetectorRef);\n    private popover = inject(ThyPopover);\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    private type: ThyNavType = 'pulled';\n    private size: ThyNavSize = 'md';\n    public initialized = false;\n\n    public horizontal: ThyNavHorizontal;\n    public wrapperOffset: { height: number; width: number; left: number; top: number } = {\n        height: 0,\n        width: 0,\n        left: 0,\n        top: 0\n    };\n\n    public hiddenItems: ThyNavItemDirective[] = [];\n\n    public moreActive: boolean;\n\n    public showMore = true;\n\n    private moreBtnOffset: { height: number; width: number } = { height: 0, width: 0 };\n\n    private hostRenderer = useHostRenderer();\n\n    private innerLinks: QueryList<ThyNavItemDirective>;\n\n    locale: Signal<ThyNavLocale> = injectLocale('nav');\n\n    /**\n     * 导航类型\n     * @type pulled | tabs | pills | lite | primary | secondary | thirdly | secondary-divider\n     * @default pulled\n     */\n    @Input()\n    set thyType(type: ThyNavType) {\n        this.type = type || 'pulled';\n        if (this.initialized) {\n            this.updateClasses();\n        }\n    }\n\n    /**\n     * 导航大小\n     * @type lg | md | sm\n     * @default md\n     */\n    @Input()\n    set thySize(size: ThyNavSize) {\n        this.size = size;\n        if (this.initialized) {\n            this.updateClasses();\n        }\n    }\n\n    /**\n     * 水平排列\n     * @type '' | 'start' | 'center' | 'end'\n     * @default false\n     */\n    @Input()\n    set thyHorizontal(horizontal: ThyNavHorizontal) {\n        this.horizontal = (horizontal as string) === 'right' ? 'end' : horizontal;\n    }\n\n    /**\n     * 是否垂直排列\n     * @default false\n     */\n    @HostBinding('class.thy-nav--vertical')\n    @Input({ transform: coerceBooleanProperty })\n    thyVertical: boolean;\n\n    /**\n     * 是否是填充模式\n     */\n    @HostBinding('class.thy-nav--fill')\n    @Input({ transform: coerceBooleanProperty })\n    thyFill: boolean = false;\n\n    /**\n     * 是否响应式，自动计算宽度存放 thyNavItem，并添加更多弹框\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty })\n    thyResponsive: boolean;\n\n    /**\n     * 更多操作的菜单点击内部是否可关闭\n     */\n    @Input({ transform: coerceBooleanProperty })\n    thyInsideClosable = true;\n\n    /**\n     * 右侧额外区域模板\n     * @type TemplateRef\n     */\n    @Input() thyExtra: TemplateRef<unknown>;\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyNavItemDirective, { descendants: true })\n    set links(value) {\n        this.innerLinks = value;\n        this.prevActiveIndex = NaN;\n    }\n    get links(): QueryList<ThyNavItemDirective> {\n        return this.innerLinks;\n    }\n\n    /**\n     * @private\n     */\n    @ContentChildren(RouterLinkActive, { descendants: true }) routers: QueryList<RouterLinkActive>;\n\n    /**\n     * 响应式模式下更多操作模板\n     * @type TemplateRef\n     */\n    @ContentChild('more') moreOperation: TemplateRef<unknown>;\n\n    /**\n     * 响应式模式下更多弹框模板\n     * @type TemplateRef\n     */\n    @ContentChild('morePopover') morePopover: TemplateRef<unknown>;\n\n    /**\n     * 右侧额外区域模板，支持 thyExtra 传参和 <ng-template #extra></ng-template> 模板\n     * @name extra\n     * @type TemplateRef\n     */\n    @ContentChild('extra') extra: TemplateRef<unknown>;\n\n    @ViewChild('moreOperationContainer') defaultMoreOperation: ElementRef<HTMLAnchorElement>;\n\n    @ViewChild(ThyNavInkBarDirective, { static: true }) inkBar!: ThyNavInkBarDirective;\n\n    get showInkBar(): boolean {\n        const showTypes: ThyNavType[] = ['pulled', 'tabs'];\n        return showTypes.includes(this.type);\n    }\n\n    private updateClasses() {\n        let classNames: string[] = [];\n        if (navTypeClassesMap[this.type]) {\n            classNames = [...navTypeClassesMap[this.type]];\n        }\n        if (navSizeClassesMap[this.size]) {\n            classNames.push(navSizeClassesMap[this.size]);\n        }\n        this.hostRenderer.updateClass(classNames);\n    }\n\n    private curActiveIndex: number;\n\n    private prevActiveIndex: number = NaN;\n\n    ngOnInit() {\n        if (!this.thyResponsive) {\n            this.initialized = true;\n        }\n\n        this.updateClasses();\n    }\n\n    ngAfterViewInit() {\n        if (this.thyResponsive) {\n            this.setMoreBtnOffset();\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.links.toArray().forEach(link => link.setOffset());\n                this.setHiddenItems();\n            });\n        }\n        this.ngZone.runOutsideAngular(() => {\n            merge(\n                this.links.changes,\n                this.createResizeObserver(this.elementRef.nativeElement).pipe(debounceTime(100)),\n                ...this.links.map(item => this.createResizeObserver(item.elementRef.nativeElement).pipe(debounceTime(100))),\n                ...(this.routers || []).map(router => router?.isActiveChange)\n            )\n                .pipe(\n                    takeUntilDestroyed(this.destroyRef),\n                    tap(() => {\n                        if (this.thyResponsive) {\n                            this.resetSizes();\n                            this.setHiddenItems();\n                            this.calculateMoreIsActive();\n                        }\n                    })\n                )\n                .subscribe(() => {\n                    this.alignInkBarToSelectedTab();\n                });\n        });\n    }\n\n    ngAfterContentInit(): void {\n        if (this.thyResponsive) {\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.resetSizes();\n            });\n        }\n    }\n\n    ngAfterContentChecked() {\n        this.calculateMoreIsActive();\n\n        this.curActiveIndex = this.links && this.links.length ? this.links.toArray().findIndex(item => item.linkIsActive()) : -1;\n        if (this.curActiveIndex < 0) {\n            this.inkBar.hide();\n        } else if (this.curActiveIndex !== this.prevActiveIndex) {\n            this.alignInkBarToSelectedTab();\n        }\n    }\n\n    private setMoreBtnOffset() {\n        this.moreBtnOffset = {\n            height: this.defaultMoreOperation?.nativeElement?.offsetHeight,\n            width: this.defaultMoreOperation?.nativeElement?.offsetWidth\n        };\n    }\n\n    createResizeObserver(element: HTMLElement) {\n        return typeof ResizeObserver === 'undefined'\n            ? of(null)\n            : new Observable(observer => {\n                  const resize = new ResizeObserver(entries => {\n                      observer.next(entries);\n                  });\n                  resize.observe(element);\n                  return () => {\n                      resize.disconnect();\n                  };\n              });\n    }\n\n    private calculateMoreIsActive() {\n        this.moreActive = this.hiddenItems.some(item => {\n            return item.linkIsActive();\n        });\n        this.changeDetectorRef.detectChanges();\n    }\n\n    private setHiddenItems() {\n        this.moreActive = false;\n        const tabs = this.links.toArray();\n        if (!tabs.length) {\n            this.hiddenItems = [];\n            this.showMore = this.hiddenItems.length > 0;\n            return;\n        }\n\n        const endIndex = this.thyVertical ? this.getShowItemsEndIndexWhenVertical(tabs) : this.getShowItemsEndIndexWhenHorizontal(tabs);\n\n        const showItems = tabs.slice(0, endIndex + 1);\n        (showItems || []).forEach(item => {\n            item.setNavLinkHidden(false);\n        });\n\n        this.hiddenItems = endIndex === tabs.length - 1 ? [] : tabs.slice(endIndex + 1);\n        (this.hiddenItems || []).forEach(item => {\n            item.setNavLinkHidden(true);\n        });\n\n        this.showMore = this.hiddenItems.length > 0;\n        this.initialized = true;\n    }\n\n    private getShowItemsEndIndexWhenHorizontal(tabs: ThyNavItemDirective[]) {\n        const tabsLength = tabs.length;\n        let endIndex = tabsLength;\n        let totalWidth = 0;\n\n        for (let i = 0; i < tabsLength; i += 1) {\n            const _totalWidth = i === tabsLength - 1 ? totalWidth + tabs[i].offset.width : totalWidth + tabs[i].offset.width + tabItemRight;\n            if (_totalWidth > this.wrapperOffset.width) {\n                let moreOperationWidth = this.moreBtnOffset.width;\n                if (totalWidth + moreOperationWidth <= this.wrapperOffset.width) {\n                    endIndex = i - 1;\n                } else {\n                    endIndex = i - 2;\n                }\n                break;\n            } else {\n                totalWidth = _totalWidth;\n                endIndex = i;\n            }\n        }\n        return endIndex;\n    }\n\n    private getShowItemsEndIndexWhenVertical(tabs: ThyNavItemDirective[]) {\n        const tabsLength = tabs.length;\n        let endIndex = tabsLength;\n        let totalHeight = 0;\n        for (let i = 0; i < tabsLength; i += 1) {\n            const _totalHeight = totalHeight + tabs[i].offset.height;\n            if (_totalHeight > this.wrapperOffset.height) {\n                let moreOperationHeight = this.moreBtnOffset.height;\n                if (totalHeight + moreOperationHeight <= this.wrapperOffset.height) {\n                    endIndex = i - 1;\n                } else {\n                    endIndex = i - 2;\n                }\n                break;\n            } else {\n                totalHeight = _totalHeight;\n                endIndex = i;\n            }\n        }\n        return endIndex;\n    }\n\n    private resetSizes() {\n        this.wrapperOffset = {\n            height: this.elementRef.nativeElement.offsetHeight || 0,\n            width: this.elementRef.nativeElement.offsetWidth || 0,\n            left: this.elementRef.nativeElement.offsetLeft || 0,\n            top: this.elementRef.nativeElement.offsetTop || 0\n        };\n    }\n\n    openMore(event: Event, template: TemplateRef<any>) {\n        this.popover.open(template, {\n            origin: event.currentTarget as HTMLElement,\n            hasBackdrop: true,\n            backdropClosable: true,\n            insideClosable: this.thyInsideClosable,\n            placement: 'bottom',\n            panelClass: 'thy-nav-list-popover',\n            originActiveClass: 'thy-nav-origin-active'\n        });\n    }\n\n    navItemClick(item: ThyNavItemDirective) {\n        item.elementRef.nativeElement.click();\n    }\n\n    private alignInkBarToSelectedTab(): void {\n        if (!this.showInkBar) {\n            this.inkBar.hide();\n            return;\n        }\n        const tabs = this.links?.toArray() ?? [];\n        const selectedItem = tabs.find(item => item.linkIsActive());\n        let selectedItemElement: HTMLElement = selectedItem && selectedItem.elementRef.nativeElement;\n\n        if (selectedItem && this.moreActive) {\n            selectedItemElement = this.defaultMoreOperation.nativeElement;\n        }\n        if (selectedItemElement) {\n            this.prevActiveIndex = this.curActiveIndex;\n            this.inkBar.alignToElement(selectedItemElement);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyVertical, thyType } = changes;\n\n        if (thyType?.currentValue !== thyType?.previousValue || thyVertical?.currentValue !== thyVertical?.previousValue) {\n            this.alignInkBarToSelectedTab();\n        }\n    }\n}\n","<div class=\"thy-nav-list\" [ngClass]=\"horizontal ? 'justify-content-' + horizontal : ''\" #navList>\n  <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n  @if (thyResponsive) {\n    <a\n      href=\"javascript:;\"\n      class=\"thy-nav-more-container\"\n      [class.d-none]=\"!showMore\"\n      [class.invisible]=\"!initialized\"\n      #moreOperationContainer\n      thyNavLink\n      [thyNavLinkActive]=\"moreActive\"\n      (click)=\"openMore($event, navListPopover)\">\n      @if (moreOperation) {\n        <ng-container [ngTemplateOutlet]=\"moreOperation\"></ng-container>\n      } @else {\n        {{ locale().more }}\n        <thy-icon thyIconName=\"angle-down\" class=\"thy-nav-more-icon\"></thy-icon>\n      }\n    </a>\n  }\n  <thy-nav-ink-bar [showInkBar]=\"showInkBar\" [isVertical]=\"thyVertical\"></thy-nav-ink-bar>\n</div>\n\n<ng-template #navListPopover>\n  @if (morePopover) {\n    <ng-container [ngTemplateOutlet]=\"morePopover\" [ngTemplateOutletContext]=\"{ $implicit: hiddenItems }\"></ng-container>\n  } @else {\n    <thy-dropdown-menu thyImmediateRender>\n      @for (item of hiddenItems; track $index) {\n        <span\n          class=\"thy-nav-item-more\"\n          thyDropdownMenuItem\n          [thyDropdownMenuItemActive]=\"item.isActive\"\n          (click)=\"navItemClick(item)\"\n          [innerHTML]=\"item.elementRef.nativeElement.innerHTML | bypassSecurityTrustHtml\"></span>\n      }\n    </thy-dropdown-menu>\n  }\n</ng-template>\n\n<ng-template #content>\n  <ng-content></ng-content>\n</ng-template>\n\n@if (thyExtra || extra) {\n  <div class=\"thy-nav-extra\">\n    <ng-container [ngTemplateOutlet]=\"thyExtra || extra\"></ng-container>\n  </div>\n}\n"]}
|
|
410
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav.component.js","sourceRoot":"","sources":["../../../../src/nav/nav.component.ts","../../../../src/nav/nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThyPopover, ThyPopoverConfig } from 'ngx-tethys/popover';\nimport { merge, Observable, of } from 'rxjs';\nimport { startWith, take, tap } from 'rxjs/operators';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport {\n    AfterContentChecked,\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    DestroyRef,\n    ElementRef,\n    HostBinding,\n    inject,\n    input,\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    QueryList,\n    Signal,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { RouterLinkActive } from '@angular/router';\nimport { ThyNavInkBarDirective } from './nav-ink-bar.directive';\nimport { ThyNavItemDirective } from './nav-item.directive';\nimport { BypassSecurityTrustHtmlPipe } from './nav.pipe';\nimport { ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemActiveDirective } from 'ngx-tethys/dropdown';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\nimport { injectLocale, ThyNavLocale } from 'ngx-tethys/i18n';\nimport { ThyPlacement } from 'ngx-tethys/core';\n\nexport type ThyNavType = 'pulled' | 'tabs' | 'pills' | 'lite' | 'card' | 'primary' | 'secondary' | 'thirdly' | 'secondary-divider';\nexport type ThyNavSize = 'lg' | 'md' | 'sm';\nexport type ThyNavHorizontal = '' | 'start' | 'center' | 'end';\n\nconst navTypeClassesMap = {\n    pulled: ['thy-nav-pulled'],\n    tabs: ['thy-nav-tabs'],\n    pills: ['thy-nav-pills'],\n    lite: ['thy-nav-lite'],\n    card: ['thy-nav-card'],\n    //如下类型已经废弃\n    primary: ['thy-nav-primary'],\n    secondary: ['thy-nav-secondary'],\n    thirdly: ['thy-nav-thirdly'],\n    'secondary-divider': ['thy-nav-secondary-divider']\n};\n\nconst navSizeClassesMap = {\n    lg: 'thy-nav-lg',\n    md: 'thy-nav-md',\n    sm: 'thy-nav-sm'\n};\n\nconst tabItemRight = 20;\n\n/**\n * 导航组件\n * @name thy-nav\n * @order 10\n */\n@Component({\n    selector: 'thy-nav',\n    templateUrl: './nav.component.html',\n    host: {\n        class: 'thy-nav'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [\n        NgClass,\n        NgTemplateOutlet,\n        ThyNavItemDirective,\n        ThyIcon,\n        ThyNavInkBarDirective,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuItemDirective,\n        ThyDropdownMenuItemActiveDirective,\n        BypassSecurityTrustHtmlPipe\n    ]\n})\nexport class ThyNav implements OnInit, AfterViewInit, AfterContentInit, AfterContentChecked, OnChanges {\n    private elementRef = inject(ElementRef);\n    private ngZone = inject(NgZone);\n    private changeDetectorRef = inject(ChangeDetectorRef);\n    private popover = inject(ThyPopover);\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    public type: ThyNavType = 'pulled';\n    private size: ThyNavSize = 'md';\n    public initialized = false;\n\n    public horizontal: ThyNavHorizontal;\n    public wrapperOffset: { height: number; width: number; left: number; top: number } = {\n        height: 0,\n        width: 0,\n        left: 0,\n        top: 0\n    };\n\n    public hiddenItems: ThyNavItemDirective[] = [];\n\n    public moreActive: boolean;\n\n    public showMore = true;\n\n    private moreBtnOffset: { height: number; width: number } = { height: 0, width: 0 };\n\n    private hostRenderer = useHostRenderer();\n\n    private innerLinks: QueryList<ThyNavItemDirective>;\n\n    locale: Signal<ThyNavLocale> = injectLocale('nav');\n\n    /**\n     * 导航类型\n     * @type pulled | tabs | pills | lite | primary | secondary | thirdly | secondary-divider\n     * @default pulled\n     */\n    @Input()\n    set thyType(type: ThyNavType) {\n        this.type = type || 'pulled';\n        if (this.initialized) {\n            this.updateClasses();\n        }\n    }\n\n    /**\n     * 导航大小\n     * @type lg | md | sm\n     * @default md\n     */\n    @Input()\n    set thySize(size: ThyNavSize) {\n        this.size = size;\n        if (this.initialized) {\n            this.updateClasses();\n        }\n    }\n\n    /**\n     * 水平排列\n     * @type '' | 'start' | 'center' | 'end'\n     * @default false\n     */\n    @Input()\n    set thyHorizontal(horizontal: ThyNavHorizontal) {\n        this.horizontal = (horizontal as string) === 'right' ? 'end' : horizontal;\n    }\n\n    /**\n     * 是否垂直排列\n     * @default false\n     */\n    @HostBinding('class.thy-nav--vertical')\n    @Input({ transform: coerceBooleanProperty })\n    thyVertical: boolean;\n\n    /**\n     * 是否是填充模式\n     */\n    @HostBinding('class.thy-nav--fill')\n    @Input({ transform: coerceBooleanProperty })\n    thyFill: boolean = false;\n\n    /**\n     * 是否响应式，自动计算宽度存放 thyNavItem，并添加更多弹框\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty })\n    thyResponsive: boolean;\n\n    /**\n     * 支持暂停自适应计算\n     */\n    thyPauseReCalculate = input<boolean>(false);\n\n    /**\n     * 更多操作的菜单点击内部是否可关闭\n     * @deprecated please use thyPopoverOptions\n     */\n    @Input({ transform: coerceBooleanProperty })\n    thyInsideClosable = true;\n\n    /**\n     * 更多菜单弹出框的参数，底层使用 Popover 组件\n     * @type ThyPopoverConfig\n     */\n    thyPopoverOptions = input<ThyPopoverConfig<unknown>>(null);\n\n    /**\n     * 右侧额外区域模板\n     * @type TemplateRef\n     */\n    @Input() thyExtra: TemplateRef<unknown>;\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyNavItemDirective, { descendants: true })\n    set links(value) {\n        this.innerLinks = value;\n        this.prevActiveIndex = NaN;\n    }\n    get links(): QueryList<ThyNavItemDirective> {\n        return this.innerLinks;\n    }\n\n    /**\n     * @private\n     */\n    @ContentChildren(RouterLinkActive, { descendants: true }) routers: QueryList<RouterLinkActive>;\n\n    /**\n     * 响应式模式下更多操作模板\n     * @type TemplateRef\n     */\n    @ContentChild('more') moreOperation: TemplateRef<unknown>;\n\n    /**\n     * 响应式模式下更多弹框模板\n     * @type TemplateRef\n     */\n    @ContentChild('morePopover') morePopover: TemplateRef<unknown>;\n\n    /**\n     * 右侧额外区域模板，支持 thyExtra 传参和 <ng-template #extra></ng-template> 模板\n     * @name extra\n     * @type TemplateRef\n     */\n    @ContentChild('extra') extra: TemplateRef<unknown>;\n\n    @ViewChild('moreOperationContainer') defaultMoreOperation: ElementRef<HTMLAnchorElement>;\n\n    @ViewChild(ThyNavInkBarDirective, { static: true }) inkBar!: ThyNavInkBarDirective;\n\n    get showInkBar(): boolean {\n        const showTypes: ThyNavType[] = ['pulled', 'tabs'];\n        return showTypes.includes(this.type);\n    }\n\n    private updateClasses() {\n        let classNames: string[] = [];\n        if (navTypeClassesMap[this.type]) {\n            classNames = [...navTypeClassesMap[this.type]];\n        }\n        if (navSizeClassesMap[this.size]) {\n            classNames.push(navSizeClassesMap[this.size]);\n        }\n        this.hostRenderer.updateClass(classNames);\n    }\n\n    private curActiveIndex: number;\n\n    private prevActiveIndex: number = NaN;\n\n    private navSubscription: { unsubscribe: () => void } | null = null;\n\n    ngOnInit() {\n        if (!this.thyResponsive) {\n            this.initialized = true;\n        }\n\n        this.updateClasses();\n    }\n\n    ngAfterViewInit() {\n        if (this.thyResponsive) {\n            this.setMoreBtnOffset();\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.links.toArray().forEach(link => link.setOffset());\n                this.setHiddenItems();\n            });\n        }\n\n        this.ngZone.runOutsideAngular(() => {\n            this.links.changes.pipe(startWith(this.links), takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n                if (this.navSubscription) {\n                    this.navSubscription.unsubscribe();\n                }\n\n                this.navSubscription = merge(\n                    this.createResizeObserver(this.elementRef.nativeElement),\n                    ...this.links.map(item => this.createResizeObserver(item.elementRef.nativeElement).pipe(tap(() => item.setOffset()))),\n                    ...(this.routers || []).map(router => router?.isActiveChange)\n                )\n                    .pipe(\n                        takeUntilDestroyed(this.destroyRef),\n                        tap(() => {\n                            if (this.thyPauseReCalculate()) {\n                                return;\n                            }\n\n                            if (this.thyResponsive) {\n                                this.resetSizes();\n                                this.setHiddenItems();\n                                this.calculateMoreIsActive();\n                            }\n\n                            if (this.type === 'card') {\n                                this.setNavItemDivider();\n                            }\n                        })\n                    )\n                    .subscribe(() => {\n                        this.alignInkBarToSelectedTab();\n                    });\n            });\n        });\n    }\n\n    ngAfterContentInit(): void {\n        if (this.thyResponsive) {\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.resetSizes();\n            });\n        }\n    }\n\n    ngAfterContentChecked() {\n        this.calculateMoreIsActive();\n\n        this.curActiveIndex = this.links && this.links.length ? this.links.toArray().findIndex(item => item.linkIsActive()) : -1;\n        if (this.curActiveIndex < 0) {\n            this.inkBar.hide();\n        } else if (this.curActiveIndex !== this.prevActiveIndex) {\n            this.alignInkBarToSelectedTab();\n        }\n    }\n\n    private setMoreBtnOffset() {\n        this.moreBtnOffset = {\n            height: this.defaultMoreOperation?.nativeElement?.offsetHeight,\n            width: this.defaultMoreOperation?.nativeElement?.offsetWidth\n        };\n    }\n\n    private setNavItemDivider() {\n        const tabs = this.links.toArray();\n        const activeIndex = tabs.findIndex(item => item.linkIsActive());\n\n        for (let i = 0; i < tabs.length; i++) {\n            if ((i !== activeIndex && i !== activeIndex - 1 && i !== tabs.length - 1) || (i === activeIndex - 1 && this.moreActive)) {\n                tabs[i].addClass('has-right-divider');\n            } else {\n                tabs[i].removeClass('has-right-divider');\n            }\n        }\n    }\n\n    createResizeObserver(element: HTMLElement) {\n        return typeof ResizeObserver === 'undefined'\n            ? of(null)\n            : new Observable(observer => {\n                  const resize = new ResizeObserver(entries => {\n                      observer.next(entries);\n                  });\n                  resize.observe(element);\n                  return () => {\n                      resize.disconnect();\n                  };\n              });\n    }\n\n    private calculateMoreIsActive() {\n        this.moreActive = this.hiddenItems.some(item => {\n            return item.linkIsActive();\n        });\n        this.changeDetectorRef.detectChanges();\n    }\n\n    private setHiddenItems() {\n        this.moreActive = false;\n        const tabs = this.links.toArray();\n        if (!tabs.length) {\n            this.hiddenItems = [];\n            this.showMore = this.hiddenItems.length > 0;\n            return;\n        }\n\n        const endIndex = this.thyVertical ? this.getShowItemsEndIndexWhenVertical(tabs) : this.getShowItemsEndIndexWhenHorizontal(tabs);\n\n        const showItems = tabs.slice(0, endIndex + 1);\n        (showItems || []).forEach(item => {\n            item.setNavLinkHidden(false);\n        });\n\n        this.hiddenItems = endIndex === tabs.length - 1 ? [] : tabs.slice(endIndex + 1);\n        (this.hiddenItems || []).forEach(item => {\n            item.setNavLinkHidden(true);\n        });\n\n        this.showMore = this.hiddenItems.length > 0;\n        this.initialized = true;\n    }\n\n    private getShowItemsEndIndexWhenHorizontal(tabs: ThyNavItemDirective[]) {\n        const tabsLength = tabs.length;\n        let endIndex = tabsLength;\n        let totalWidth = 0;\n\n        for (let i = 0; i < tabsLength; i += 1) {\n            const _totalWidth = i === tabsLength - 1 ? totalWidth + tabs[i].offset.width : totalWidth + tabs[i].offset.width + tabItemRight;\n            if (_totalWidth > this.wrapperOffset.width) {\n                let moreOperationWidth = this.moreBtnOffset.width;\n                if (totalWidth + moreOperationWidth <= this.wrapperOffset.width) {\n                    endIndex = i - 1;\n                } else {\n                    endIndex = i - 2;\n                }\n                break;\n            } else {\n                totalWidth = _totalWidth;\n                endIndex = i;\n            }\n        }\n        return endIndex;\n    }\n\n    private getShowItemsEndIndexWhenVertical(tabs: ThyNavItemDirective[]) {\n        const tabsLength = tabs.length;\n        let endIndex = tabsLength;\n        let totalHeight = 0;\n        for (let i = 0; i < tabsLength; i += 1) {\n            const _totalHeight = totalHeight + tabs[i].offset.height;\n            if (_totalHeight > this.wrapperOffset.height) {\n                let moreOperationHeight = this.moreBtnOffset.height;\n                if (totalHeight + moreOperationHeight <= this.wrapperOffset.height) {\n                    endIndex = i - 1;\n                } else {\n                    endIndex = i - 2;\n                }\n                break;\n            } else {\n                totalHeight = _totalHeight;\n                endIndex = i;\n            }\n        }\n        return endIndex;\n    }\n\n    private resetSizes() {\n        this.wrapperOffset = {\n            height: this.elementRef.nativeElement.offsetHeight || 0,\n            width: this.elementRef.nativeElement.offsetWidth || 0,\n            left: this.elementRef.nativeElement.offsetLeft || 0,\n            top: this.elementRef.nativeElement.offsetTop || 0\n        };\n    }\n\n    openMoreMenu(event: Event, template: TemplateRef<any>) {\n        this.popover.open(\n            template,\n            Object.assign(\n                {\n                    origin: event.currentTarget as HTMLElement,\n                    hasBackdrop: true,\n                    backdropClosable: true,\n                    insideClosable: true,\n                    placement: 'bottom' as ThyPlacement,\n                    panelClass: 'thy-nav-list-popover',\n                    originActiveClass: 'thy-nav-origin-active'\n                },\n                this.thyPopoverOptions() ? this.thyPopoverOptions() : {}\n            )\n        );\n    }\n\n    navItemClick(item: ThyNavItemDirective) {\n        item.elementRef.nativeElement.click();\n    }\n\n    private alignInkBarToSelectedTab(): void {\n        if (!this.showInkBar) {\n            this.inkBar.hide();\n            return;\n        }\n        const tabs = this.links?.toArray() ?? [];\n        const selectedItem = tabs.find(item => item.linkIsActive());\n        let selectedItemElement: HTMLElement = selectedItem && selectedItem.elementRef.nativeElement;\n\n        if (selectedItem && this.moreActive) {\n            selectedItemElement = this.defaultMoreOperation.nativeElement;\n        }\n        if (selectedItemElement) {\n            this.prevActiveIndex = this.curActiveIndex;\n            this.inkBar.alignToElement(selectedItemElement);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyVertical, thyType } = changes;\n\n        if (thyType?.currentValue !== thyType?.previousValue || thyVertical?.currentValue !== thyVertical?.previousValue) {\n            this.alignInkBarToSelectedTab();\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.navSubscription) {\n            this.navSubscription.unsubscribe();\n        }\n    }\n}\n","<div class=\"thy-nav-list\" [ngClass]=\"horizontal ? 'justify-content-' + horizontal : ''\" #navList>\n  <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n  @if (thyResponsive) {\n    <a\n      href=\"javascript:;\"\n      class=\"thy-nav-more-container\"\n      [class.d-none]=\"!showMore\"\n      [class.invisible]=\"!initialized\"\n      #moreOperationContainer\n      thyNavLink\n      [thyNavItemActive]=\"moreActive\"\n      (click)=\"openMoreMenu($event, navListPopover)\">\n      @if (moreOperation) {\n        <ng-container [ngTemplateOutlet]=\"moreOperation\"></ng-container>\n      } @else {\n        {{ locale().more }}\n        <thy-icon thyIconName=\"angle-down\" class=\"thy-nav-more-icon\"></thy-icon>\n      }\n    </a>\n  }\n  @if (thyExtra || extra) {\n    <div class=\"thy-nav-extra\">\n      <ng-container [ngTemplateOutlet]=\"thyExtra || extra\"></ng-container>\n    </div>\n  }\n  <thy-nav-ink-bar [showInkBar]=\"showInkBar\" [isVertical]=\"thyVertical\"></thy-nav-ink-bar>\n</div>\n\n<ng-template #navListPopover>\n  @if (morePopover) {\n    <ng-container [ngTemplateOutlet]=\"morePopover\" [ngTemplateOutletContext]=\"{ $implicit: hiddenItems }\"></ng-container>\n  } @else {\n    <thy-dropdown-menu thyImmediateRender>\n      @for (item of hiddenItems; track $index) {\n        <span\n          class=\"thy-nav-item-more\"\n          thyDropdownMenuItem\n          [thyDropdownMenuItemActive]=\"item.isActive\"\n          (click)=\"navItemClick(item)\"\n          [innerHTML]=\"item.elementRef.nativeElement.innerHTML | bypassSecurityTrustHtml\"></span>\n      }\n    </thy-dropdown-menu>\n  }\n</ng-template>\n\n<ng-template #content>\n  <ng-content></ng-content>\n</ng-template>\n"]}
|
|
@@ -104,7 +104,7 @@ export class ThyTabs {
|
|
|
104
104
|
this.thyActiveTabChange.emit(activeTab);
|
|
105
105
|
}
|
|
106
106
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyTabs, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ThyTabs, isStandalone: true, selector: "thy-tabs", inputs: { thyType: "thyType", thySize: "thySize", thyActiveTab: "thyActiveTab", thyExtra: "thyExtra", thyPosition: "thyPosition", thyAnimated: ["thyAnimated", "thyAnimated", coerceBooleanProperty], thyResponsive: ["thyResponsive", "thyResponsive", coerceBooleanProperty] }, outputs: { thyActiveTabChange: "thyActiveTabChange" }, host: { properties: { "class.thy-tabs-top": "thyPosition === 'top'", "class.thy-tabs-left": "thyPosition === 'left'", "style.overflow": "transitionStarted ? \"hidden\" : null" }, classAttribute: "thy-tabs" }, queries: [{ propertyName: "tabs", predicate: ThyTab, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- tabs nav -->\n<thy-nav\n class=\"thy-tabs-nav\"\n [thyType]=\"thyType\"\n [thySize]=\"thySize\"\n [thyExtra]=\"thyExtra\"\n [thyVertical]=\"thyPosition === 'left'\"\n [thyResponsive]=\"thyResponsive\">\n @for (tab of tabs; track $index; let i = $index) {\n <a\n href=\"javascript:;\"\n thyNavItem\n [id]=\"tab.id\"\n [thyNavItemDisabled]=\"tab.thyDisabled\"\n [thyNavItemActive]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n (click)=\"activeTab(tab, i)\">\n @if (tab.titleTemplateRef) {\n <ng-template [ngTemplateOutlet]=\"tab.titleTemplateRef\"></ng-template>\n } @else {\n {{ tab.thyTitle }}\n }\n </a>\n }\n</thy-nav>\n<!-- tabs content -->\n<div class=\"thy-tabs-content\" [class.thy-tabs-content-animated]=\"tabPaneAnimated\" [style.margin-left]=\"getTabContentMarginLeft()\">\n @for (tab of tabs; track $index; let i = $index) {\n <div\n thyTabContent\n [active]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n [content]=\"tab.content\"\n [tabPaneAnimated]=\"tabPaneAnimated\"></div>\n }\n</div>\n", dependencies: [{ kind: "component", type: ThyNav, selector: "thy-nav", inputs: ["thyType", "thySize", "thyHorizontal", "thyVertical", "thyFill", "thyResponsive", "thyInsideClosable", "thyExtra"] }, { kind: "directive", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: ["thyNavItemActive", "thyNavLinkActive", "thyNavItemDisabled"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ThyTabContent, selector: "thy-tab-content, [thyTabContent]", inputs: ["content", "active", "tabPaneAnimated"], exportAs: ["thyTabContent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
107
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ThyTabs, isStandalone: true, selector: "thy-tabs", inputs: { thyType: "thyType", thySize: "thySize", thyActiveTab: "thyActiveTab", thyExtra: "thyExtra", thyPosition: "thyPosition", thyAnimated: ["thyAnimated", "thyAnimated", coerceBooleanProperty], thyResponsive: ["thyResponsive", "thyResponsive", coerceBooleanProperty] }, outputs: { thyActiveTabChange: "thyActiveTabChange" }, host: { properties: { "class.thy-tabs-top": "thyPosition === 'top'", "class.thy-tabs-left": "thyPosition === 'left'", "style.overflow": "transitionStarted ? \"hidden\" : null" }, classAttribute: "thy-tabs" }, queries: [{ propertyName: "tabs", predicate: ThyTab, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- tabs nav -->\n<thy-nav\n class=\"thy-tabs-nav\"\n [thyType]=\"thyType\"\n [thySize]=\"thySize\"\n [thyExtra]=\"thyExtra\"\n [thyVertical]=\"thyPosition === 'left'\"\n [thyResponsive]=\"thyResponsive\">\n @for (tab of tabs; track $index; let i = $index) {\n <a\n href=\"javascript:;\"\n thyNavItem\n [id]=\"tab.id\"\n [thyNavItemDisabled]=\"tab.thyDisabled\"\n [thyNavItemActive]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n (click)=\"activeTab(tab, i)\">\n @if (tab.titleTemplateRef) {\n <ng-template [ngTemplateOutlet]=\"tab.titleTemplateRef\"></ng-template>\n } @else {\n {{ tab.thyTitle }}\n }\n </a>\n }\n</thy-nav>\n<!-- tabs content -->\n<div class=\"thy-tabs-content\" [class.thy-tabs-content-animated]=\"tabPaneAnimated\" [style.margin-left]=\"getTabContentMarginLeft()\">\n @for (tab of tabs; track $index; let i = $index) {\n <div\n thyTabContent\n [active]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n [content]=\"tab.content\"\n [tabPaneAnimated]=\"tabPaneAnimated\"></div>\n }\n</div>\n", dependencies: [{ kind: "component", type: ThyNav, selector: "thy-nav", inputs: ["thyType", "thySize", "thyHorizontal", "thyVertical", "thyFill", "thyResponsive", "thyPauseReCalculate", "thyInsideClosable", "thyPopoverOptions", "thyExtra"] }, { kind: "directive", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: ["id", "thyNavItemActive", "thyNavLinkActive", "thyNavItemDisabled"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ThyTabContent, selector: "thy-tab-content, [thyTabContent]", inputs: ["content", "active", "tabPaneAnimated"], exportAs: ["thyTabContent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
108
108
|
}
|
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyTabs, decorators: [{
|
|
110
110
|
type: Component,
|
|
@@ -136,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
136
136
|
}], thyActiveTabChange: [{
|
|
137
137
|
type: Output
|
|
138
138
|
}] } });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../src/tabs/tabs.component.ts","../../../../src/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n    inject\n} from '@angular/core';\nimport { coerceBooleanProperty, isString } from 'ngx-tethys/util';\nimport { fromEvent } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyTab } from './tab.component';\nimport { ThyActiveTabInfo, ThyTabActiveEvent } from './types';\nimport { ThyTabContent } from './tab-content.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ThyNav, ThyNavItemDirective } from 'ngx-tethys/nav';\n\nexport type ThyTabsSize = 'lg' | 'md' | 'sm';\n\nexport type ThyTabsType = 'pulled' | 'tabs' | 'pills' | 'lite';\n\nexport type ThyTabsPosition = 'top' | 'left';\n\n/**\n * 选项卡切换组件\n * @name thy-tabs\n */\n@Component({\n    selector: 'thy-tabs',\n    templateUrl: './tabs.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-tabs',\n        '[class.thy-tabs-top]': `thyPosition === 'top'`,\n        '[class.thy-tabs-left]': `thyPosition === 'left'`,\n        '[style.overflow]': `transitionStarted ? \"hidden\" : null`\n    },\n    standalone: true,\n    imports: [ThyNav, ThyNavItemDirective, NgTemplateOutlet, ThyTabContent]\n})\nexport class ThyTabs implements OnInit, OnChanges, AfterContentInit {\n    private cd = inject(ChangeDetectorRef);\n    private el = inject(ElementRef);\n\n    @ContentChildren(ThyTab, { descendants: true }) tabs = new QueryList<ThyTab>();\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    /**\n     * 标签类型\n     * @type 'pulled' | 'tabs' | 'pills' | 'lite'\n     */\n    @Input() thyType: ThyTabsType = 'tabs';\n\n    /**\n     * 选项卡的大小\n     * @type 'lg' | 'md' | 'sm'\n     */\n    @Input() thySize: ThyTabsSize = 'md';\n\n    /**\n     * 激活的项\n     */\n    @Input()\n    set thyActiveTab(value: ThyActiveTabInfo) {\n        if (isString(value)) {\n            this.activeTabId = value;\n            this.activeTabIndex = undefined;\n        } else {\n            this.activeTabIndex = value;\n            this.activeTabId = undefined;\n        }\n    }\n\n    /**\n     * 附加操作\n     */\n    @Input() thyExtra: TemplateRef<unknown>;\n\n    /**\n     * 选项卡的位置\n     * @type 'top' | 'left'\n     */\n    @Input() thyPosition: ThyTabsPosition = 'top';\n\n    /**\n     * 是否使用动画切换 Tabs\n     */\n    @Input({ transform: coerceBooleanProperty }) thyAnimated: boolean = false;\n\n    /**\n     * 响应式，自动计算宽度存放 thyNavItem，并添加更多弹框\n     */\n    @Input({ transform: coerceBooleanProperty }) thyResponsive: boolean = false;\n\n    /**\n     * 激活的项发生改变时的回调\n     */\n    @Output() thyActiveTabChange: EventEmitter<ThyTabActiveEvent> = new EventEmitter<ThyTabActiveEvent>();\n\n    activeTabIndex: number = 0;\n\n    activeTabId: string;\n\n    transitionStarted: boolean = false;\n\n    ngOnInit(): void {\n        const tabsContent = this.el.nativeElement.querySelector('.thy-tabs-content');\n        fromEvent(tabsContent, 'transitionend')\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                this.transitionStarted = false;\n                this.cd.markForCheck();\n            });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyActiveTab } = changes;\n        if (thyActiveTab && !thyActiveTab.firstChange && this.thyAnimated) {\n            const index = thyActiveTab?.currentValue?.index || Array.from(this.tabs).findIndex(k => k.id === thyActiveTab?.currentValue.id);\n            this.transitionStarted = this.activeTabIndex !== index;\n            this.activeTabIndex = index;\n        }\n    }\n\n    ngAfterContentInit() {\n        this.tabs.changes.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(data => {\n            this.thyAnimated && (this.transitionStarted = true);\n            this.activeTabIndex = data.length - 1;\n            this.cd.markForCheck();\n        });\n    }\n\n    get tabPaneAnimated(): boolean {\n        return this.thyPosition === 'top' && this.thyAnimated;\n    }\n\n    getTabContentMarginLeft(): string {\n        if (this.tabPaneAnimated) {\n            return `${-(this.activeTabIndex || 0) * 100}%`;\n        }\n        return '';\n    }\n\n    activeTab(tab: ThyTab, index: number) {\n        if (tab.thyDisabled) {\n            return;\n        }\n        this.activeTabId = tab.id || null;\n        this.thyAnimated && (this.transitionStarted = this.activeTabIndex !== index);\n        this.activeTabIndex = index;\n        const activeTab = tab.id ? tab.id : index;\n        this.thyActiveTabChange.emit(activeTab);\n    }\n}\n","<!-- tabs nav -->\n<thy-nav\n  class=\"thy-tabs-nav\"\n  [thyType]=\"thyType\"\n  [thySize]=\"thySize\"\n  [thyExtra]=\"thyExtra\"\n  [thyVertical]=\"thyPosition === 'left'\"\n  [thyResponsive]=\"thyResponsive\">\n  @for (tab of tabs; track $index; let i = $index) {\n    <a\n      href=\"javascript:;\"\n      thyNavItem\n      [id]=\"tab.id\"\n      [thyNavItemDisabled]=\"tab.thyDisabled\"\n      [thyNavItemActive]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n      (click)=\"activeTab(tab, i)\">\n      @if (tab.titleTemplateRef) {\n        <ng-template [ngTemplateOutlet]=\"tab.titleTemplateRef\"></ng-template>\n      } @else {\n        {{ tab.thyTitle }}\n      }\n    </a>\n  }\n</thy-nav>\n<!-- tabs content -->\n<div class=\"thy-tabs-content\" [class.thy-tabs-content-animated]=\"tabPaneAnimated\" [style.margin-left]=\"getTabContentMarginLeft()\">\n  @for (tab of tabs; track $index; let i = $index) {\n    <div\n      thyTabContent\n      [active]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n      [content]=\"tab.content\"\n      [tabPaneAnimated]=\"tabPaneAnimated\"></div>\n  }\n</div>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../src/tabs/tabs.component.ts","../../../../src/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n    inject\n} from '@angular/core';\nimport { coerceBooleanProperty, isString } from 'ngx-tethys/util';\nimport { fromEvent } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyTab } from './tab.component';\nimport { ThyActiveTabInfo, ThyTabActiveEvent } from './types';\nimport { ThyTabContent } from './tab-content.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ThyNav, ThyNavItemDirective } from 'ngx-tethys/nav';\n\nexport type ThyTabsSize = 'lg' | 'md' | 'sm';\n\nexport type ThyTabsType = 'pulled' | 'tabs' | 'pills' | 'lite';\n\nexport type ThyTabsPosition = 'top' | 'left';\n\n/**\n * 选项卡切换组件\n * @name thy-tabs\n */\n@Component({\n    selector: 'thy-tabs',\n    templateUrl: './tabs.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-tabs',\n        '[class.thy-tabs-top]': `thyPosition === 'top'`,\n        '[class.thy-tabs-left]': `thyPosition === 'left'`,\n        '[style.overflow]': `transitionStarted ? \"hidden\" : null`\n    },\n    standalone: true,\n    imports: [ThyNav, ThyNavItemDirective, NgTemplateOutlet, ThyTabContent]\n})\nexport class ThyTabs implements OnInit, OnChanges, AfterContentInit {\n    private cd = inject(ChangeDetectorRef);\n    private el = inject(ElementRef);\n\n    @ContentChildren(ThyTab, { descendants: true }) tabs = new QueryList<ThyTab>();\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    /**\n     * 标签类型\n     * @type 'pulled' | 'tabs' | 'pills' | 'lite'\n     */\n    @Input() thyType: ThyTabsType = 'tabs';\n\n    /**\n     * 选项卡的大小\n     * @type 'lg' | 'md' | 'sm'\n     */\n    @Input() thySize: ThyTabsSize = 'md';\n\n    /**\n     * 激活的项\n     */\n    @Input()\n    set thyActiveTab(value: ThyActiveTabInfo) {\n        if (isString(value)) {\n            this.activeTabId = value;\n            this.activeTabIndex = undefined;\n        } else {\n            this.activeTabIndex = value;\n            this.activeTabId = undefined;\n        }\n    }\n\n    /**\n     * 附加操作\n     */\n    @Input() thyExtra: TemplateRef<unknown>;\n\n    /**\n     * 选项卡的位置\n     * @type 'top' | 'left'\n     */\n    @Input() thyPosition: ThyTabsPosition = 'top';\n\n    /**\n     * 是否使用动画切换 Tabs\n     */\n    @Input({ transform: coerceBooleanProperty }) thyAnimated: boolean = false;\n\n    /**\n     * 响应式，自动计算宽度存放 thyNavItem，并添加更多弹框\n     */\n    @Input({ transform: coerceBooleanProperty }) thyResponsive: boolean = false;\n\n    /**\n     * 激活的项发生改变时的回调\n     */\n    @Output() thyActiveTabChange: EventEmitter<ThyTabActiveEvent> = new EventEmitter<ThyTabActiveEvent>();\n\n    activeTabIndex: number = 0;\n\n    activeTabId: string;\n\n    transitionStarted: boolean = false;\n\n    ngOnInit(): void {\n        const tabsContent = this.el.nativeElement.querySelector('.thy-tabs-content');\n        fromEvent(tabsContent, 'transitionend')\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                this.transitionStarted = false;\n                this.cd.markForCheck();\n            });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { thyActiveTab } = changes;\n        if (thyActiveTab && !thyActiveTab.firstChange && this.thyAnimated) {\n            const index = thyActiveTab?.currentValue?.index || Array.from(this.tabs).findIndex(k => k.id === thyActiveTab?.currentValue.id);\n            this.transitionStarted = this.activeTabIndex !== index;\n            this.activeTabIndex = index;\n        }\n    }\n\n    ngAfterContentInit() {\n        this.tabs.changes.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(data => {\n            this.thyAnimated && (this.transitionStarted = true);\n            this.activeTabIndex = data.length - 1;\n            this.cd.markForCheck();\n        });\n    }\n\n    get tabPaneAnimated(): boolean {\n        return this.thyPosition === 'top' && this.thyAnimated;\n    }\n\n    getTabContentMarginLeft(): string {\n        if (this.tabPaneAnimated) {\n            return `${-(this.activeTabIndex || 0) * 100}%`;\n        }\n        return '';\n    }\n\n    activeTab(tab: ThyTab, index: number) {\n        if (tab.thyDisabled) {\n            return;\n        }\n        this.activeTabId = tab.id || null;\n        this.thyAnimated && (this.transitionStarted = this.activeTabIndex !== index);\n        this.activeTabIndex = index;\n        const activeTab = tab.id ? tab.id : index;\n        this.thyActiveTabChange.emit(activeTab);\n    }\n}\n","<!-- tabs nav -->\n<thy-nav\n  class=\"thy-tabs-nav\"\n  [thyType]=\"thyType\"\n  [thySize]=\"thySize\"\n  [thyExtra]=\"thyExtra\"\n  [thyVertical]=\"thyPosition === 'left'\"\n  [thyResponsive]=\"thyResponsive\">\n  @for (tab of tabs; track $index; let i = $index) {\n    <a\n      href=\"javascript:;\"\n      thyNavItem\n      [id]=\"tab.id\"\n      [thyNavItemDisabled]=\"tab.thyDisabled\"\n      [thyNavItemActive]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n      (click)=\"activeTab(tab, i)\">\n      @if (tab.titleTemplateRef) {\n        <ng-template [ngTemplateOutlet]=\"tab.titleTemplateRef\"></ng-template>\n      } @else {\n        {{ tab.thyTitle }}\n      }\n    </a>\n  }\n</thy-nav>\n<!-- tabs content -->\n<div class=\"thy-tabs-content\" [class.thy-tabs-content-animated]=\"tabPaneAnimated\" [style.margin-left]=\"getTabContentMarginLeft()\">\n  @for (tab of tabs; track $index; let i = $index) {\n    <div\n      thyTabContent\n      [active]=\"(tab.id && activeTabId && tab.id === activeTabId) ?? i === activeTabIndex\"\n      [content]=\"tab.content\"\n      [tabPaneAnimated]=\"tabPaneAnimated\"></div>\n  }\n</div>\n"]}
|
package/esm2022/version.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { Version } from '@angular/core';
|
|
2
|
-
export const VERSION = new Version('18.2.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const VERSION = new Version('18.2.4');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVyc2lvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxOC4yLjQnKTtcbiJdfQ==
|
|
@@ -2467,7 +2467,7 @@ class DatePopup {
|
|
|
2467
2467
|
}
|
|
2468
2468
|
}
|
|
2469
2469
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: DatePopup, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2470
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: DatePopup, isStandalone: true, selector: "date-popup", inputs: { isRange: "isRange", showWeek: "showWeek", format: "format", disabledDate: "disabledDate", minDate: "minDate", maxDate: "maxDate", showToday: "showToday", showTime: "showTime", mustShowTime: "mustShowTime", dateRender: "dateRender", className: "className", panelMode: "panelMode", value: "value", defaultPickerValue: "defaultPickerValue", showShortcut: "showShortcut", shortcutPresets: "shortcutPresets", shortcutPosition: "shortcutPosition", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity", timestampPrecision: "timestampPrecision" }, outputs: { panelModeChange: "panelModeChange", calendarChange: "calendarChange", valueChange: "valueChange", resultOk: "resultOk", showTimePickerChange: "showTimePickerChange", dateValueChange: "dateValueChange" }, exportAs: ["datePopup"], usesOnChanges: true, ngImport: i0, template: "<div class=\"{{ prefixCls }}-picker-container {{ className }}\">\n <div\n class=\"{{ prefixCls }} {{ showWeek ? prefixCls + '-week-number' : '' }}\n {{ isRange ? prefixCls + '-range' : '' }} {{ prefixCls }}-picker-shortcut-{{ shortcutPosition === 'left' ? 'left' : 'bottom' }}\">\n @if (showShortcut) {\n <div class=\"{{ prefixCls }}-picker-shortcut\">\n @for (item of innerShortcutPresets; track $index) {\n <div class=\"{{ prefixCls }}-picker-shortcut-item\" [class.disabled]=\"item.disabled\" (click)=\"shortcutSetValue(item)\">\n {{ item.title }}\n </div>\n }\n </div>\n }\n <div class=\"{{ prefixCls }}-panel\">\n <div class=\"{{ prefixCls }}-date-panel\">\n @if (flexible) {\n <div class=\"{{ prefixCls }}-date-panel-flexible\">\n <div class=\"{{ prefixCls }}-date-panel-flexible-tab\">\n <thy-nav thyType=\"pulled\" thySize=\"sm\">\n <a href=\"javascript:;\" thyNavLink [thyNavLinkActive]=\"flexibleActiveTab === 'advanced'\" (click)=\"selectTab('advanced')\">{{\n locale().advance\n }}</a>\n <a href=\"javascript:;\" thyNavLink [thyNavLinkActive]=\"flexibleActiveTab === 'custom'\" (click)=\"selectTab('custom')\">{{\n locale().custom\n }}</a>\n </thy-nav>\n <button thyButtonIcon=\"sweep\" thySize=\"sm\" class=\"clear-date-button\" (click)=\"clearFlexibleValue()\"></button>\n </div>\n <ng-container>\n <div class=\"{{ prefixCls }}-date-panel-advanced\" [hidden]=\"flexibleActiveTab !== 'advanced'\">\n <date-carousel\n name=\"dateCarousel\"\n (ngModelChange)=\"changeValueFromAdvancedSelect($event)\"\n [(ngModel)]=\"advancedSelectedValue\"\n [activeDate]=\"selectedValue[0]\"></date-carousel>\n </div>\n </ng-container>\n <div [hidden]=\"flexibleActiveTab !== 'custom'\">\n <ng-container *ngTemplateOutlet=\"tplInnerPopup\"></ng-container>\n </div>\n </div>\n } @else {\n @if (isRange) {\n <ng-container *ngTemplateOutlet=\"tplRangePart; context: { partType: 'left' }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"tplRangePart; context: { partType: 'right' }\"></ng-container>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"tplInnerPopup\"></ng-container>\n </div>\n }\n @if (!isRange) {\n <ng-container *ngTemplateOutlet=\"tplFooter\"></ng-container>\n }\n }\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #tplInnerPopup let-partType=\"partType\">\n <inner-popup\n [showWeek]=\"showWeek\"\n [isRange]=\"isRange\"\n [panelMode]=\"getPanelMode(panelMode, partType)\"\n [endPanelMode]=\"getPanelMode(endPanelMode, partType)\"\n [partType]=\"partType\"\n [showDateRangeInput]=\"flexible && flexibleActiveTab === 'custom'\"\n (panelModeChange)=\"onPanelModeChange($event, partType)\"\n [value]=\"getValueBySelector(partType)\"\n [selectedValue]=\"selectedValue\"\n [activeDate]=\"getActiveDate(partType)\"\n [rangeActiveDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n [dateRender]=\"dateRender\"\n [hoverValue]=\"hoverValue\"\n [enablePrev]=\"enablePrevNext('prev', partType)\"\n [enableNext]=\"enablePrevNext('next', partType)\"\n (dayHover)=\"onDayHover($event)\"\n (selectDate)=\"changeValueFromSelect($event, partType)\"\n (headerChange)=\"onHeaderChange($event, partType)\"></inner-popup>\n</ng-template>\n\n<ng-template #tplFooter>\n <calendar-footer\n [showTime]=\"showTime\"\n [mustShowTime]=\"mustShowTime\"\n [value]=\"value\"\n [disableTimeConfirm]=\"disableTimeConfirm\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n (selectTime)=\"onSelectTime($event)\"\n (clickOk)=\"onClickOk()\"\n (clickRemove)=\"onClickRemove()\"></calendar-footer>\n</ng-template>\n\n<!-- Single ONLY -->\n\n<!-- Range ONLY -->\n<ng-template #tplRangePart let-partType=\"partType\">\n <div class=\"{{ prefixCls }}-range-part {{ prefixCls }}-range-{{ partType }}\">\n <div style=\"outline: none\">\n <ng-container *ngTemplateOutlet=\"tplInnerPopup; context: { partType: partType }\"></ng-container>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: ThyNav, selector: "thy-nav", inputs: ["thyType", "thySize", "thyHorizontal", "thyVertical", "thyFill", "thyResponsive", "thyInsideClosable", "thyExtra"] }, { kind: "directive", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: ["thyNavItemActive", "thyNavLinkActive", "thyNavItemDisabled"] }, { kind: "component", type: ThyButtonIcon, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: ["thySize", "thyIcon", "thyButtonIcon", "thyShape", "thyLight", "thyActive", "thyTheme", "thyColor"] }, { kind: "component", type: DateCarousel, selector: "date-carousel", inputs: ["activeDate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: InnerPopup, selector: "inner-popup", inputs: ["showWeek", "isRange", "activeDate", "rangeActiveDate", "enablePrev", "enableNext", "disabledDate", "dateRender", "selectedValue", "hoverValue", "panelMode", "showDateRangeInput", "partType", "endPanelMode", "value"], outputs: ["panelModeChange", "headerChange", "selectDate", "dayHover"], exportAs: ["innerPopup"] }, { kind: "component", type: CalendarFooter, selector: "calendar-footer", inputs: ["showTime", "mustShowTime", "value", "disableTimeConfirm"], outputs: ["selectTime", "clickOk", "clickRemove", "showTimePickerChange"], exportAs: ["calendarFooter"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2470
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: DatePopup, isStandalone: true, selector: "date-popup", inputs: { isRange: "isRange", showWeek: "showWeek", format: "format", disabledDate: "disabledDate", minDate: "minDate", maxDate: "maxDate", showToday: "showToday", showTime: "showTime", mustShowTime: "mustShowTime", dateRender: "dateRender", className: "className", panelMode: "panelMode", value: "value", defaultPickerValue: "defaultPickerValue", showShortcut: "showShortcut", shortcutPresets: "shortcutPresets", shortcutPosition: "shortcutPosition", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity", timestampPrecision: "timestampPrecision" }, outputs: { panelModeChange: "panelModeChange", calendarChange: "calendarChange", valueChange: "valueChange", resultOk: "resultOk", showTimePickerChange: "showTimePickerChange", dateValueChange: "dateValueChange" }, exportAs: ["datePopup"], usesOnChanges: true, ngImport: i0, template: "<div class=\"{{ prefixCls }}-picker-container {{ className }}\">\n <div\n class=\"{{ prefixCls }} {{ showWeek ? prefixCls + '-week-number' : '' }}\n {{ isRange ? prefixCls + '-range' : '' }} {{ prefixCls }}-picker-shortcut-{{ shortcutPosition === 'left' ? 'left' : 'bottom' }}\">\n @if (showShortcut) {\n <div class=\"{{ prefixCls }}-picker-shortcut\">\n @for (item of innerShortcutPresets; track $index) {\n <div class=\"{{ prefixCls }}-picker-shortcut-item\" [class.disabled]=\"item.disabled\" (click)=\"shortcutSetValue(item)\">\n {{ item.title }}\n </div>\n }\n </div>\n }\n <div class=\"{{ prefixCls }}-panel\">\n <div class=\"{{ prefixCls }}-date-panel\">\n @if (flexible) {\n <div class=\"{{ prefixCls }}-date-panel-flexible\">\n <div class=\"{{ prefixCls }}-date-panel-flexible-tab\">\n <thy-nav thyType=\"pulled\" thySize=\"sm\">\n <a href=\"javascript:;\" thyNavLink [thyNavLinkActive]=\"flexibleActiveTab === 'advanced'\" (click)=\"selectTab('advanced')\">{{\n locale().advance\n }}</a>\n <a href=\"javascript:;\" thyNavLink [thyNavLinkActive]=\"flexibleActiveTab === 'custom'\" (click)=\"selectTab('custom')\">{{\n locale().custom\n }}</a>\n </thy-nav>\n <button thyButtonIcon=\"sweep\" thySize=\"sm\" class=\"clear-date-button\" (click)=\"clearFlexibleValue()\"></button>\n </div>\n <ng-container>\n <div class=\"{{ prefixCls }}-date-panel-advanced\" [hidden]=\"flexibleActiveTab !== 'advanced'\">\n <date-carousel\n name=\"dateCarousel\"\n (ngModelChange)=\"changeValueFromAdvancedSelect($event)\"\n [(ngModel)]=\"advancedSelectedValue\"\n [activeDate]=\"selectedValue[0]\"></date-carousel>\n </div>\n </ng-container>\n <div [hidden]=\"flexibleActiveTab !== 'custom'\">\n <ng-container *ngTemplateOutlet=\"tplInnerPopup\"></ng-container>\n </div>\n </div>\n } @else {\n @if (isRange) {\n <ng-container *ngTemplateOutlet=\"tplRangePart; context: { partType: 'left' }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"tplRangePart; context: { partType: 'right' }\"></ng-container>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"tplInnerPopup\"></ng-container>\n </div>\n }\n @if (!isRange) {\n <ng-container *ngTemplateOutlet=\"tplFooter\"></ng-container>\n }\n }\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #tplInnerPopup let-partType=\"partType\">\n <inner-popup\n [showWeek]=\"showWeek\"\n [isRange]=\"isRange\"\n [panelMode]=\"getPanelMode(panelMode, partType)\"\n [endPanelMode]=\"getPanelMode(endPanelMode, partType)\"\n [partType]=\"partType\"\n [showDateRangeInput]=\"flexible && flexibleActiveTab === 'custom'\"\n (panelModeChange)=\"onPanelModeChange($event, partType)\"\n [value]=\"getValueBySelector(partType)\"\n [selectedValue]=\"selectedValue\"\n [activeDate]=\"getActiveDate(partType)\"\n [rangeActiveDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n [dateRender]=\"dateRender\"\n [hoverValue]=\"hoverValue\"\n [enablePrev]=\"enablePrevNext('prev', partType)\"\n [enableNext]=\"enablePrevNext('next', partType)\"\n (dayHover)=\"onDayHover($event)\"\n (selectDate)=\"changeValueFromSelect($event, partType)\"\n (headerChange)=\"onHeaderChange($event, partType)\"></inner-popup>\n</ng-template>\n\n<ng-template #tplFooter>\n <calendar-footer\n [showTime]=\"showTime\"\n [mustShowTime]=\"mustShowTime\"\n [value]=\"value\"\n [disableTimeConfirm]=\"disableTimeConfirm\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n (selectTime)=\"onSelectTime($event)\"\n (clickOk)=\"onClickOk()\"\n (clickRemove)=\"onClickRemove()\"></calendar-footer>\n</ng-template>\n\n<!-- Single ONLY -->\n\n<!-- Range ONLY -->\n<ng-template #tplRangePart let-partType=\"partType\">\n <div class=\"{{ prefixCls }}-range-part {{ prefixCls }}-range-{{ partType }}\">\n <div style=\"outline: none\">\n <ng-container *ngTemplateOutlet=\"tplInnerPopup; context: { partType: partType }\"></ng-container>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: ThyNav, selector: "thy-nav", inputs: ["thyType", "thySize", "thyHorizontal", "thyVertical", "thyFill", "thyResponsive", "thyPauseReCalculate", "thyInsideClosable", "thyPopoverOptions", "thyExtra"] }, { kind: "directive", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: ["id", "thyNavItemActive", "thyNavLinkActive", "thyNavItemDisabled"] }, { kind: "component", type: ThyButtonIcon, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: ["thySize", "thyIcon", "thyButtonIcon", "thyShape", "thyLight", "thyActive", "thyTheme", "thyColor"] }, { kind: "component", type: DateCarousel, selector: "date-carousel", inputs: ["activeDate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: InnerPopup, selector: "inner-popup", inputs: ["showWeek", "isRange", "activeDate", "rangeActiveDate", "enablePrev", "enableNext", "disabledDate", "dateRender", "selectedValue", "hoverValue", "panelMode", "showDateRangeInput", "partType", "endPanelMode", "value"], outputs: ["panelModeChange", "headerChange", "selectDate", "dayHover"], exportAs: ["innerPopup"] }, { kind: "component", type: CalendarFooter, selector: "calendar-footer", inputs: ["showTime", "mustShowTime", "value", "disableTimeConfirm"], outputs: ["selectTime", "clickOk", "clickRemove", "showTimePickerChange"], exportAs: ["calendarFooter"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2471
2471
|
}
|
|
2472
2472
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: DatePopup, decorators: [{
|
|
2473
2473
|
type: Component,
|