@testgorilla/tgo-ui 2.21.9 → 2.21.10
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/components/tabs/tab.directive.d.ts +17 -19
- package/components/tabs/tabs.component.d.ts +3 -2
- package/components/tabs/tabs.component.module.d.ts +1 -1
- package/esm2022/components/tabs/tab.directive.mjs +39 -40
- package/esm2022/components/tabs/tabs.component.mjs +9 -3
- package/esm2022/components/tabs/tabs.component.module.mjs +8 -20
- package/fesm2022/testgorilla-tgo-ui.mjs +50 -57
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,26 +1,24 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { TabsComponent } from "./tabs.component";
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
3
2
|
import { IconName } from '../icon/icon.model';
|
|
4
3
|
import { Tab } from './tabs.model';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class TabDirective implements
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
disabled: boolean;
|
|
14
|
-
canLeave?: (ctx?: {
|
|
5
|
+
export declare class TabDirective implements OnInit {
|
|
6
|
+
tabLabel: import("@angular/core").InputSignal<string>;
|
|
7
|
+
tabName: import("@angular/core").InputSignal<string>;
|
|
8
|
+
iconLeft: import("@angular/core").InputSignal<IconName | undefined>;
|
|
9
|
+
iconRight: import("@angular/core").InputSignal<IconName | undefined>;
|
|
10
|
+
disabled: import("@angular/core").InputSignalWithTransform<boolean, string>;
|
|
11
|
+
canLeave: import("@angular/core").InputSignal<((ctx?: {
|
|
15
12
|
currentTab: Tab;
|
|
16
13
|
nextTab: Tab;
|
|
17
|
-
}) => boolean | Promise<boolean>;
|
|
18
|
-
linkUrl
|
|
19
|
-
|
|
20
|
-
|
|
14
|
+
}) => boolean | Promise<boolean>) | undefined>;
|
|
15
|
+
linkUrl: import("@angular/core").InputSignal<string | undefined>;
|
|
16
|
+
private tabsComponent;
|
|
17
|
+
private template;
|
|
18
|
+
private syncProps;
|
|
19
|
+
private cleanup;
|
|
20
|
+
ngOnInit(): void;
|
|
21
21
|
private addTab;
|
|
22
|
-
|
|
23
|
-
static
|
|
24
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TabDirective, "[uiTab]", never, { "tabLabel": { "alias": "tabLabel"; "required": true; }; "tabName": { "alias": "tabName"; "required": true; }; "iconLeft": { "alias": "iconLeft"; "required": false; }; "iconRight": { "alias": "iconRight"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "canLeave": { "alias": "canLeave"; "required": false; }; "linkUrl": { "alias": "linkUrl"; "required": false; }; }, {}, never, never, false, never>;
|
|
25
|
-
static ngAcceptInputType_disabled: unknown;
|
|
22
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TabDirective, never>;
|
|
23
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TabDirective, "ng-template[uiTab]", never, { "tabLabel": { "alias": "tabLabel"; "required": true; "isSignal": true; }; "tabName": { "alias": "tabName"; "required": true; "isSignal": true; }; "iconLeft": { "alias": "iconLeft"; "required": false; "isSignal": true; }; "iconRight": { "alias": "iconRight"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "canLeave": { "alias": "canLeave"; "required": false; "isSignal": true; }; "linkUrl": { "alias": "linkUrl"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
26
24
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EventEmitter } from '@angular/core';
|
|
2
|
-
import { Tab, TabsType } from
|
|
3
|
-
import { ApplicationTheme } from
|
|
2
|
+
import { Tab, TabsType } from './tabs.model';
|
|
3
|
+
import { ApplicationTheme } from '../../models/application-theme.model';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
import { MatTabChangeEvent, MatTabGroup } from '@angular/material/tabs';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -65,6 +65,7 @@ export declare class TabsComponent {
|
|
|
65
65
|
indexOf(tabName: string): number;
|
|
66
66
|
trackByTabName(index: number, tab: Tab): string;
|
|
67
67
|
removeTab(tabName: string): void;
|
|
68
|
+
updateTab(tabName: string, tab: Partial<Omit<Tab, 'tabName'>>): void;
|
|
68
69
|
static ɵfac: i0.ɵɵFactoryDeclaration<TabsComponent, [{ optional: true; }, null]>;
|
|
69
70
|
static ɵcmp: i0.ɵɵComponentDeclaration<TabsComponent, "ui-tabs", never, { "companyColor": { "alias": "companyColor"; "required": false; }; "type": { "alias": "type"; "required": false; }; "animationDuration": { "alias": "animationDuration"; "required": false; }; "headerContentPadding": { "alias": "headerContentPadding"; "required": false; }; "dynamicHeight": { "alias": "dynamicHeight"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; }, { "selectedTabIndex": "selectedTabIndex"; "selectedTab": "selectedTab"; }, never, never, false, never>;
|
|
70
71
|
static ngAcceptInputType_headerContentPadding: number;
|
|
@@ -6,6 +6,6 @@ import * as i4 from "@angular/material/tabs";
|
|
|
6
6
|
import * as i5 from "../icon/icon.component.module";
|
|
7
7
|
export declare class TabsComponentModule {
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<TabsComponentModule, never>;
|
|
9
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TabsComponentModule, [typeof i1.TabsComponent, typeof i2.TabDirective
|
|
9
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TabsComponentModule, [typeof i1.TabsComponent], [typeof i2.TabDirective, typeof i3.CommonModule, typeof i4.MatTabsModule, typeof i5.IconComponentModule], [typeof i1.TabsComponent, typeof i2.TabDirective]>;
|
|
10
10
|
static ɵinj: i0.ɵɵInjectorDeclaration<TabsComponentModule>;
|
|
11
11
|
}
|
|
@@ -1,55 +1,54 @@
|
|
|
1
|
-
import { booleanAttribute, Directive,
|
|
1
|
+
import { booleanAttribute, DestroyRef, Directive, effect, inject, input, TemplateRef } from '@angular/core';
|
|
2
|
+
import { TabsComponent } from './tabs.component';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "./tabs.component";
|
|
4
4
|
export class TabDirective {
|
|
5
|
-
constructor(
|
|
6
|
-
this.
|
|
7
|
-
this.
|
|
5
|
+
constructor() {
|
|
6
|
+
this.tabLabel = input.required();
|
|
7
|
+
this.tabName = input.required();
|
|
8
|
+
this.iconLeft = input();
|
|
9
|
+
this.iconRight = input();
|
|
10
|
+
this.disabled = input(false, { transform: booleanAttribute });
|
|
11
|
+
this.canLeave = input();
|
|
12
|
+
this.linkUrl = input();
|
|
13
|
+
this.tabsComponent = inject(TabsComponent);
|
|
14
|
+
this.template = inject(TemplateRef);
|
|
15
|
+
this.syncProps = effect(() => {
|
|
16
|
+
this.tabsComponent.updateTab(this.tabName(), {
|
|
17
|
+
tabLabel: this.tabLabel(),
|
|
18
|
+
iconLeft: this.iconLeft(),
|
|
19
|
+
iconRight: this.iconRight(),
|
|
20
|
+
disabled: this.disabled(),
|
|
21
|
+
canLeave: this.canLeave(),
|
|
22
|
+
linkUrl: this.linkUrl(),
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
this.cleanup = inject(DestroyRef).onDestroy(() => {
|
|
26
|
+
this.tabsComponent.removeTab(this.tabName());
|
|
27
|
+
});
|
|
8
28
|
}
|
|
9
|
-
|
|
29
|
+
ngOnInit() {
|
|
10
30
|
this.addTab();
|
|
11
31
|
}
|
|
12
32
|
addTab() {
|
|
13
33
|
this.tabsComponent.addTab({
|
|
14
|
-
tabLabel: this.tabLabel,
|
|
15
|
-
tabName: this.tabName,
|
|
16
|
-
iconLeft: this.iconLeft,
|
|
17
|
-
iconRight: this.iconRight,
|
|
18
|
-
disabled: this.disabled,
|
|
34
|
+
tabLabel: this.tabLabel(),
|
|
35
|
+
tabName: this.tabName(),
|
|
36
|
+
iconLeft: this.iconLeft(),
|
|
37
|
+
iconRight: this.iconRight(),
|
|
38
|
+
disabled: this.disabled(),
|
|
19
39
|
contentTemplateRef: this.template,
|
|
20
|
-
canLeave: this.canLeave,
|
|
21
|
-
linkUrl: this.linkUrl,
|
|
40
|
+
canLeave: this.canLeave(),
|
|
41
|
+
linkUrl: this.linkUrl(),
|
|
22
42
|
});
|
|
23
43
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, deps: [{ token: i1.TabsComponent, host: true }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
28
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.12", type: TabDirective, selector: "[uiTab]", inputs: { tabLabel: "tabLabel", tabName: "tabName", iconLeft: "iconLeft", iconRight: "iconRight", disabled: ["disabled", "disabled", booleanAttribute], canLeave: "canLeave", linkUrl: "linkUrl" }, usesOnChanges: true, ngImport: i0 }); }
|
|
44
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
45
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: TabDirective, isStandalone: true, selector: "ng-template[uiTab]", inputs: { tabLabel: { classPropertyName: "tabLabel", publicName: "tabLabel", isSignal: true, isRequired: true, transformFunction: null }, tabName: { classPropertyName: "tabName", publicName: "tabName", isSignal: true, isRequired: true, transformFunction: null }, iconLeft: { classPropertyName: "iconLeft", publicName: "iconLeft", isSignal: true, isRequired: false, transformFunction: null }, iconRight: { classPropertyName: "iconRight", publicName: "iconRight", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, canLeave: { classPropertyName: "canLeave", publicName: "canLeave", isSignal: true, isRequired: false, transformFunction: null }, linkUrl: { classPropertyName: "linkUrl", publicName: "linkUrl", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
|
|
29
46
|
}
|
|
30
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, decorators: [{
|
|
31
48
|
type: Directive,
|
|
32
49
|
args: [{
|
|
33
|
-
|
|
50
|
+
standalone: true,
|
|
51
|
+
selector: 'ng-template[uiTab]',
|
|
34
52
|
}]
|
|
35
|
-
}]
|
|
36
|
-
|
|
37
|
-
}] }, { type: i0.TemplateRef }], propDecorators: { tabLabel: [{
|
|
38
|
-
type: Input,
|
|
39
|
-
args: [{ required: true }]
|
|
40
|
-
}], tabName: [{
|
|
41
|
-
type: Input,
|
|
42
|
-
args: [{ required: true }]
|
|
43
|
-
}], iconLeft: [{
|
|
44
|
-
type: Input
|
|
45
|
-
}], iconRight: [{
|
|
46
|
-
type: Input
|
|
47
|
-
}], disabled: [{
|
|
48
|
-
type: Input,
|
|
49
|
-
args: [{ transform: booleanAttribute }]
|
|
50
|
-
}], canLeave: [{
|
|
51
|
-
type: Input
|
|
52
|
-
}], linkUrl: [{
|
|
53
|
-
type: Input
|
|
54
|
-
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFxQyxNQUFNLGVBQWUsQ0FBQzs7O0FBUTVHLE1BQU0sT0FBTyxZQUFZO0lBU3ZCLFlBQ2tCLGFBQTRCLEVBQ3BDLFFBQTBCO1FBRGxCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQ3BDLGFBQVEsR0FBUixRQUFRLENBQWtCO0lBRXBDLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxNQUFNO1FBQ1osSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7WUFDeEIsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDdkIsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3pCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN2QixrQkFBa0IsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUNqQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDdkIsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1NBQ3RCLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzdDLENBQUM7K0dBbENVLFlBQVk7bUdBQVosWUFBWSw0SkFLSCxnQkFBZ0I7OzRGQUx6QixZQUFZO2tCQUh4QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxTQUFTO2lCQUNwQjs7MEJBV0ksSUFBSTttRUFUb0IsUUFBUTtzQkFBbEMsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBQ0UsT0FBTztzQkFBakMsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBQ2hCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDa0MsUUFBUTtzQkFBL0MsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFDN0IsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBib29sZWFuQXR0cmlidXRlLCBEaXJlY3RpdmUsIEhvc3QsIElucHV0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRhYnNDb21wb25lbnQgfSBmcm9tIFwiLi90YWJzLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgSWNvbk5hbWUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kZWwnO1xuaW1wb3J0IHsgVGFiIH0gZnJvbSAnLi90YWJzLm1vZGVsJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3VpVGFiXSdcbn0pXG5leHBvcnQgY2xhc3MgVGFiRGlyZWN0aXZlIGltcGxlbWVudHMgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSB0YWJMYWJlbDogc3RyaW5nO1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSB0YWJOYW1lOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGljb25MZWZ0OiBJY29uTmFtZTtcbiAgQElucHV0KCkgaWNvblJpZ2h0OiBJY29uTmFtZTtcbiAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pIGRpc2FibGVkOiBib29sZWFuO1xuICBASW5wdXQoKSBjYW5MZWF2ZT86IChjdHg/OiB7Y3VycmVudFRhYjogVGFiLCBuZXh0VGFiOiBUYWJ9KSA9PiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPjtcbiAgQElucHV0KCkgbGlua1VybD86IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASG9zdCgpIHByaXZhdGUgdGFic0NvbXBvbmVudDogVGFic0NvbXBvbmVudCxcbiAgICBwcml2YXRlIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+LFxuICApIHtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIHRoaXMuYWRkVGFiKCk7XG4gIH1cblxuICBwcml2YXRlIGFkZFRhYigpOiB2b2lkIHtcbiAgICB0aGlzLnRhYnNDb21wb25lbnQuYWRkVGFiKHtcbiAgICAgIHRhYkxhYmVsOiB0aGlzLnRhYkxhYmVsLFxuICAgICAgdGFiTmFtZTogdGhpcy50YWJOYW1lLFxuICAgICAgaWNvbkxlZnQ6IHRoaXMuaWNvbkxlZnQsXG4gICAgICBpY29uUmlnaHQ6IHRoaXMuaWNvblJpZ2h0LFxuICAgICAgZGlzYWJsZWQ6IHRoaXMuZGlzYWJsZWQsXG4gICAgICBjb250ZW50VGVtcGxhdGVSZWY6IHRoaXMudGVtcGxhdGUsXG4gICAgICBjYW5MZWF2ZTogdGhpcy5jYW5MZWF2ZSxcbiAgICAgIGxpbmtVcmw6IHRoaXMubGlua1VybCxcbiAgICB9KVxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy50YWJzQ29tcG9uZW50LnJlbW92ZVRhYih0aGlzLnRhYk5hbWUpO1xuICB9XG59XG4iXX0=
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPakQsTUFBTSxPQUFPLFlBQVk7SUFKekI7UUFLRSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ3BDLFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDbkMsYUFBUSxHQUFHLEtBQUssRUFBWSxDQUFDO1FBQzdCLGNBQVMsR0FBRyxLQUFLLEVBQVksQ0FBQztRQUM5QixhQUFRLEdBQUcsS0FBSyxDQUFrQixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQzFFLGFBQVEsR0FBRyxLQUFLLEVBQTJFLENBQUM7UUFDNUYsWUFBTyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBRWxCLGtCQUFhLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3RDLGFBQVEsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFL0IsY0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDOUIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFO2dCQUMzQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDekIsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFO2dCQUMzQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDekIsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO2FBQ3hCLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUssWUFBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2xELElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLENBQUMsQ0FBQyxDQUFDO0tBa0JKO0lBaEJDLFFBQVE7UUFDTixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVPLE1BQU07UUFDWixJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztZQUN4QixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUN2QixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUMzQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixrQkFBa0IsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUNqQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtTQUN4QixDQUFDLENBQUM7SUFDTCxDQUFDOytHQTFDVSxZQUFZO21HQUFaLFlBQVk7OzRGQUFaLFlBQVk7a0JBSnhCLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYm9vbGVhbkF0dHJpYnV0ZSwgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBlZmZlY3QsIGluamVjdCwgaW5wdXQsIE9uSW5pdCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZGVsJztcbmltcG9ydCB7IFRhYnNDb21wb25lbnQgfSBmcm9tICcuL3RhYnMuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYiB9IGZyb20gJy4vdGFicy5tb2RlbCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW3VpVGFiXScsXG59KVxuZXhwb3J0IGNsYXNzIFRhYkRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHRhYkxhYmVsID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuICB0YWJOYW1lID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuICBpY29uTGVmdCA9IGlucHV0PEljb25OYW1lPigpO1xuICBpY29uUmlnaHQgPSBpbnB1dDxJY29uTmFtZT4oKTtcbiAgZGlzYWJsZWQgPSBpbnB1dDxib29sZWFuLCBzdHJpbmc+KGZhbHNlLCB7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KTtcbiAgY2FuTGVhdmUgPSBpbnB1dDwoY3R4PzogeyBjdXJyZW50VGFiOiBUYWI7IG5leHRUYWI6IFRhYiB9KSA9PiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPj4oKTtcbiAgbGlua1VybCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBwcml2YXRlIHRhYnNDb21wb25lbnQgPSBpbmplY3QoVGFic0NvbXBvbmVudCk7XG4gIHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXG4gIHByaXZhdGUgc3luY1Byb3BzID0gZWZmZWN0KCgpID0+IHtcbiAgICB0aGlzLnRhYnNDb21wb25lbnQudXBkYXRlVGFiKHRoaXMudGFiTmFtZSgpLCB7XG4gICAgICB0YWJMYWJlbDogdGhpcy50YWJMYWJlbCgpLFxuICAgICAgaWNvbkxlZnQ6IHRoaXMuaWNvbkxlZnQoKSxcbiAgICAgIGljb25SaWdodDogdGhpcy5pY29uUmlnaHQoKSxcbiAgICAgIGRpc2FibGVkOiB0aGlzLmRpc2FibGVkKCksXG4gICAgICBjYW5MZWF2ZTogdGhpcy5jYW5MZWF2ZSgpLFxuICAgICAgbGlua1VybDogdGhpcy5saW5rVXJsKCksXG4gICAgfSk7XG4gIH0pO1xuXG4gIHByaXZhdGUgY2xlYW51cCA9IGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xuICAgIHRoaXMudGFic0NvbXBvbmVudC5yZW1vdmVUYWIodGhpcy50YWJOYW1lKCkpO1xuICB9KTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmFkZFRhYigpO1xuICB9XG5cbiAgcHJpdmF0ZSBhZGRUYWIoKTogdm9pZCB7XG4gICAgdGhpcy50YWJzQ29tcG9uZW50LmFkZFRhYih7XG4gICAgICB0YWJMYWJlbDogdGhpcy50YWJMYWJlbCgpLFxuICAgICAgdGFiTmFtZTogdGhpcy50YWJOYW1lKCksXG4gICAgICBpY29uTGVmdDogdGhpcy5pY29uTGVmdCgpLFxuICAgICAgaWNvblJpZ2h0OiB0aGlzLmljb25SaWdodCgpLFxuICAgICAgZGlzYWJsZWQ6IHRoaXMuZGlzYWJsZWQoKSxcbiAgICAgIGNvbnRlbnRUZW1wbGF0ZVJlZjogdGhpcy50ZW1wbGF0ZSxcbiAgICAgIGNhbkxlYXZlOiB0aGlzLmNhbkxlYXZlKCksXG4gICAgICBsaW5rVXJsOiB0aGlzLmxpbmtVcmwoKSxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -107,7 +107,7 @@ export class TabsComponent {
|
|
|
107
107
|
}
|
|
108
108
|
addTab(tab) {
|
|
109
109
|
this.tabs.push(tab);
|
|
110
|
-
this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);
|
|
110
|
+
this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
|
|
111
111
|
}
|
|
112
112
|
onTabChange(ev) {
|
|
113
113
|
const selectedTab = this.tabs[ev.index];
|
|
@@ -134,7 +134,13 @@ export class TabsComponent {
|
|
|
134
134
|
if (index !== undefined) {
|
|
135
135
|
this.tabs.splice(index, 1);
|
|
136
136
|
delete this.tabIndexMap[tabName];
|
|
137
|
-
this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);
|
|
137
|
+
this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
updateTab(tabName, tab) {
|
|
141
|
+
const index = this.tabIndexMap[tabName];
|
|
142
|
+
if (index !== undefined) {
|
|
143
|
+
this.tabs[index] = { ...this.tabs[index], ...tab };
|
|
138
144
|
}
|
|
139
145
|
}
|
|
140
146
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: IS_MOBILE_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -179,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
179
185
|
type: ViewChild,
|
|
180
186
|
args: ['tabGroup', { static: true }]
|
|
181
187
|
}] } });
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/tabs/tabs.component.ts","../../../../../projects/tgo-canopy-ui/components/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  signal,\n  ViewChild,\n} from '@angular/core';\nimport { Tab, TabsType } from \"./tabs.model\";\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\nimport { IS_MOBILE_TOKEN } from '../../providers/is-mobile';\nimport { Observable } from 'rxjs';\nimport { MatTab, MatTabChangeEvent, MatTabGroup } from '@angular/material/tabs';\nimport { ENTER, hasModifierKey, SPACE } from '@angular/cdk/keycodes';\n\n@Component({\n  selector: 'ui-tabs',\n  templateUrl: './tabs.component.html',\n  styleUrls: ['./tabs.component.scss']\n})\nexport class TabsComponent {\n  /**\n   * Color of the Tabs.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof TabsComponent\n   */\n  @HostBinding('style.--color')\n  @Input() companyColor: string | null = '#46A997';\n  /**\n   * Type the Tabs.\n   * Defaults underlined.\n   *\n   * @type {TabsType}\n   * @memberof TabsComponent\n   */\n  @Input() type: TabsType = 'underlined';\n\n  /**\n   * Animation duration when switching tabs\n   *\n   * @type {number}\n   * @memberof TabsComponent\n   */\n  @Input() animationDuration = 300;\n\n  /**\n   * Sets the padding for content and header\n   *\n   * @type {number}\n   * @memberof TabsComponent\n   */\n  @HostBinding('style.--header-content-padding')\n  @Input({ transform: (value: number): string => value + 'px' })\n  headerContentPadding = '32px';\n\n  /**\n   * Sets the dynamic height of the tab\n   * @type {boolean}\n   * @memberof TabsComponent\n   */\n  @Input({transform: booleanAttribute}) dynamicHeight = true;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof TabsComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @Output() selectedTabIndex = new EventEmitter<number>();\n  @Output() selectedTab = new EventEmitter<Tab>();\n\n  @ViewChild('tabGroup', { static: true }) tabGroup: MatTabGroup;\n\n  protected tabs: Tab[] = [];\n  readonly tabIndex = signal(0);\n  protected tabIndexMap: Record<string, number> = {};\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      const tabHeader = (this.tabGroup as any)._tabHeader;\n      tabHeader._handleKeydown = async (event: KeyboardEvent) => {\n        if (hasModifierKey(event)) {\n          return;\n        }\n        switch (event.keyCode) {\n          case ENTER:\n          case SPACE:\n            const tabLabel = (event.target as HTMLElement).innerText;\n            const currentTab = this.tabs[this.tabIndex()];\n            const nextTab = this.tabs.find(tab => tab.tabLabel === tabLabel);\n\n            if (!nextTab) {\n              return;\n            }\n\n            const canLeave = (await currentTab.canLeave?.({currentTab, nextTab})) ?? true;\n            if (currentTab.tabName !== nextTab.tabName && canLeave) {\n              const nextTabIndex = this.tabIndexMap[nextTab.tabName];\n              tabHeader.focusIndex = nextTabIndex;\n              this.tabGroup.selectedIndex = nextTabIndex;\n            }\n            break;\n          default:\n            tabHeader._keyManager.onKeydown(event);\n        }\n      };\n\n      (this.tabGroup as any)._handleClick = async (\n        tab: MatTab,\n        tabHeader: any,\n        index: number\n      ) => {\n        const currentIndex = this.tabGroup.selectedIndex;\n        if (tab.disabled || currentIndex === undefined || index === currentIndex) {\n          return;\n        }\n        const currentTab = this.tabs[this.tabIndex()];\n        const nextTab = this.tabs[index];\n        const canLeave = (await currentTab.canLeave?.({currentTab, nextTab})) ?? true;\n        if (this.tabGroup.selectedIndex != index && canLeave) {\n          tabHeader.focusIndex = index;\n          this.tabGroup.selectedIndex = index;\n        }\n      };\n    });\n  }\n\n  addTab(tab: Tab): void {\n    this.tabs.push(tab);\n    this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);\n  }\n\n  onTabChange(ev: MatTabChangeEvent): void {\n    const selectedTab = this.tabs[ev.index];\n    this.tabIndex.set(this.tabIndexMap[selectedTab.tabName]);\n    this.selectedTabIndex.emit(ev.index);\n    this.selectedTab.emit(selectedTab);\n  }\n\n  selectTab(tabName: string): void {\n    const index = this.tabIndexMap[tabName];\n    if (index !== undefined) {\n      this.tabIndex.set(index);\n      this.selectedTabIndex.emit(index);\n      this.selectedTab.emit(this.tabs[index]);\n    }\n  }\n\n  indexOf(tabName: string): number {\n    return this.tabIndexMap[tabName] ?? -1;\n  }\n\n  trackByTabName(index: number, tab: Tab): string {\n    return tab.tabName;\n  }\n\n  removeTab(tabName: string): void {\n    const index = this.tabIndexMap[tabName];\n    if (index !== undefined) {\n      this.tabs.splice(index, 1);\n      delete this.tabIndexMap[tabName];\n      this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);\n    }\n  }\n}\n","<mat-tab-group\n  #tabGroup\n  headerPosition=\"above\"\n  class=\"tabs-container\"\n  [ngClass]=\"'tabs-type-' + ((isMobile$ | async) ? 'underlined' : type)\"\n  [attr.theme]=\"applicationTheme\"\n  [dynamicHeight]=\"dynamicHeight\"\n  [selectedIndex]=\"tabIndex()\"\n  [animationDuration]=\"animationDuration\"\n  (selectedTabChange)=\"onTabChange($event)\"\n>\n  <mat-tab *ngFor=\"let tab of tabs; trackBy: trackByTabName\" [disabled]=\"tab.disabled ?? false\">\n    <ng-template mat-tab-label>\n      <a class=\"tab-name\" [tabindex]=\"0\" [href]=\"tab?.linkUrl ? tab.linkUrl : '#' \" (click)=\"$event.preventDefault()\">\n        <ui-icon [size]=\"'24'\" [tabindex]=\"1\" class=\"left-icon\" [name]=\"tab.iconLeft!\" *ngIf=\"tab?.iconLeft\"></ui-icon>\n        <span class=\"label\">{{ tab.tabLabel }}</span>\n        <ui-icon [size]=\"'24'\" [tabindex]=\"2\" class=\"right-icon\" [name]=\"tab.iconRight!\" *ngIf=\"tab?.iconRight\"></ui-icon>\n      </a>\n    </ng-template>\n    <ng-container *ngTemplateOutlet=\"tab.contentTemplateRef\"></ng-container>\n  </mat-tab>\n</mat-tab-group>\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/tabs/tabs.component.ts","../../../../../projects/tgo-canopy-ui/components/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  signal,\n  ViewChild,\n} from '@angular/core';\nimport { Tab, TabsType } from './tabs.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IS_MOBILE_TOKEN } from '../../providers/is-mobile';\nimport { Observable } from 'rxjs';\nimport { MatTab, MatTabChangeEvent, MatTabGroup } from '@angular/material/tabs';\nimport { ENTER, hasModifierKey, SPACE } from '@angular/cdk/keycodes';\n\n@Component({\n  selector: 'ui-tabs',\n  templateUrl: './tabs.component.html',\n  styleUrls: ['./tabs.component.scss'],\n})\nexport class TabsComponent {\n  /**\n   * Color of the Tabs.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof TabsComponent\n   */\n  @HostBinding('style.--color')\n  @Input()\n  companyColor: string | null = '#46A997';\n  /**\n   * Type the Tabs.\n   * Defaults underlined.\n   *\n   * @type {TabsType}\n   * @memberof TabsComponent\n   */\n  @Input() type: TabsType = 'underlined';\n\n  /**\n   * Animation duration when switching tabs\n   *\n   * @type {number}\n   * @memberof TabsComponent\n   */\n  @Input() animationDuration = 300;\n\n  /**\n   * Sets the padding for content and header\n   *\n   * @type {number}\n   * @memberof TabsComponent\n   */\n  @HostBinding('style.--header-content-padding')\n  @Input({ transform: (value: number): string => value + 'px' })\n  headerContentPadding = '32px';\n\n  /**\n   * Sets the dynamic height of the tab\n   * @type {boolean}\n   * @memberof TabsComponent\n   */\n  @Input({ transform: booleanAttribute }) dynamicHeight = true;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof TabsComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @Output() selectedTabIndex = new EventEmitter<number>();\n  @Output() selectedTab = new EventEmitter<Tab>();\n\n  @ViewChild('tabGroup', { static: true }) tabGroup: MatTabGroup;\n\n  protected tabs: Tab[] = [];\n  readonly tabIndex = signal(0);\n  protected tabIndexMap: Record<string, number> = {};\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      const tabHeader = (this.tabGroup as any)._tabHeader;\n      tabHeader._handleKeydown = async (event: KeyboardEvent) => {\n        if (hasModifierKey(event)) {\n          return;\n        }\n        switch (event.keyCode) {\n          case ENTER:\n          case SPACE:\n            const tabLabel = (event.target as HTMLElement).innerText;\n            const currentTab = this.tabs[this.tabIndex()];\n            const nextTab = this.tabs.find(tab => tab.tabLabel === tabLabel);\n\n            if (!nextTab) {\n              return;\n            }\n\n            const canLeave = (await currentTab.canLeave?.({ currentTab, nextTab })) ?? true;\n            if (currentTab.tabName !== nextTab.tabName && canLeave) {\n              const nextTabIndex = this.tabIndexMap[nextTab.tabName];\n              tabHeader.focusIndex = nextTabIndex;\n              this.tabGroup.selectedIndex = nextTabIndex;\n            }\n            break;\n          default:\n            tabHeader._keyManager.onKeydown(event);\n        }\n      };\n\n      (this.tabGroup as any)._handleClick = async (tab: MatTab, tabHeader: any, index: number) => {\n        const currentIndex = this.tabGroup.selectedIndex;\n        if (tab.disabled || currentIndex === undefined || index === currentIndex) {\n          return;\n        }\n        const currentTab = this.tabs[this.tabIndex()];\n        const nextTab = this.tabs[index];\n        const canLeave = (await currentTab.canLeave?.({ currentTab, nextTab })) ?? true;\n        if (this.tabGroup.selectedIndex != index && canLeave) {\n          tabHeader.focusIndex = index;\n          this.tabGroup.selectedIndex = index;\n        }\n      };\n    });\n  }\n\n  addTab(tab: Tab): void {\n    this.tabs.push(tab);\n    this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));\n  }\n\n  onTabChange(ev: MatTabChangeEvent): void {\n    const selectedTab = this.tabs[ev.index];\n    this.tabIndex.set(this.tabIndexMap[selectedTab.tabName]);\n    this.selectedTabIndex.emit(ev.index);\n    this.selectedTab.emit(selectedTab);\n  }\n\n  selectTab(tabName: string): void {\n    const index = this.tabIndexMap[tabName];\n    if (index !== undefined) {\n      this.tabIndex.set(index);\n      this.selectedTabIndex.emit(index);\n      this.selectedTab.emit(this.tabs[index]);\n    }\n  }\n\n  indexOf(tabName: string): number {\n    return this.tabIndexMap[tabName] ?? -1;\n  }\n\n  trackByTabName(index: number, tab: Tab): string {\n    return tab.tabName;\n  }\n\n  removeTab(tabName: string): void {\n    const index = this.tabIndexMap[tabName];\n    if (index !== undefined) {\n      this.tabs.splice(index, 1);\n      delete this.tabIndexMap[tabName];\n      this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));\n    }\n  }\n  updateTab(tabName: string, tab: Partial<Omit<Tab, 'tabName'>>): void {\n    const index = this.tabIndexMap[tabName];\n    if (index !== undefined) {\n      this.tabs[index] = { ...this.tabs[index], ...tab };\n    }\n  }\n}\n","<mat-tab-group\n  #tabGroup\n  headerPosition=\"above\"\n  class=\"tabs-container\"\n  [ngClass]=\"'tabs-type-' + ((isMobile$ | async) ? 'underlined' : type)\"\n  [attr.theme]=\"applicationTheme\"\n  [dynamicHeight]=\"dynamicHeight\"\n  [selectedIndex]=\"tabIndex()\"\n  [animationDuration]=\"animationDuration\"\n  (selectedTabChange)=\"onTabChange($event)\"\n>\n  <mat-tab *ngFor=\"let tab of tabs; trackBy: trackByTabName\" [disabled]=\"tab.disabled ?? false\">\n    <ng-template mat-tab-label>\n      <a class=\"tab-name\" [tabindex]=\"0\" [href]=\"tab?.linkUrl ? tab.linkUrl : '#' \" (click)=\"$event.preventDefault()\">\n        <ui-icon [size]=\"'24'\" [tabindex]=\"1\" class=\"left-icon\" [name]=\"tab.iconLeft!\" *ngIf=\"tab?.iconLeft\"></ui-icon>\n        <span class=\"label\">{{ tab.tabLabel }}</span>\n        <ui-icon [size]=\"'24'\" [tabindex]=\"2\" class=\"right-icon\" [name]=\"tab.iconRight!\" *ngIf=\"tab?.iconRight\"></ui-icon>\n      </a>\n    </ng-template>\n    <ng-container *ngTemplateOutlet=\"tab.contentTemplateRef\"></ng-container>\n  </mat-tab>\n</mat-tab-group>\n"]}
|
|
@@ -1,33 +1,21 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { TabsComponent } from './tabs.component';
|
|
4
|
-
import { MatTabsModule } from
|
|
5
|
-
import { IconComponentModule } from
|
|
4
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
5
|
+
import { IconComponentModule } from '../icon/icon.component.module';
|
|
6
6
|
import { TabDirective } from './tab.directive';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class TabsComponentModule {
|
|
9
9
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, declarations: [TabsComponent,
|
|
11
|
-
|
|
12
|
-
MatTabsModule,
|
|
13
|
-
IconComponentModule], exports: [TabsComponent, TabDirective] }); }
|
|
14
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, imports: [CommonModule,
|
|
15
|
-
MatTabsModule,
|
|
16
|
-
IconComponentModule] }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, declarations: [TabsComponent], imports: [TabDirective, CommonModule, MatTabsModule, IconComponentModule], exports: [TabsComponent, TabDirective] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, imports: [CommonModule, MatTabsModule, IconComponentModule] }); }
|
|
17
12
|
}
|
|
18
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, decorators: [{
|
|
19
14
|
type: NgModule,
|
|
20
15
|
args: [{
|
|
21
|
-
declarations: [
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
],
|
|
25
|
-
imports: [
|
|
26
|
-
CommonModule,
|
|
27
|
-
MatTabsModule,
|
|
28
|
-
IconComponentModule
|
|
29
|
-
],
|
|
30
|
-
exports: [TabsComponent, TabDirective]
|
|
16
|
+
declarations: [TabsComponent],
|
|
17
|
+
imports: [TabDirective, CommonModule, MatTabsModule, IconComponentModule],
|
|
18
|
+
exports: [TabsComponent, TabDirective],
|
|
31
19
|
}]
|
|
32
20
|
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5jb21wb25lbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL3RhYnMvdGFicy5jb21wb25lbnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQU8vQyxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKZixhQUFhLGFBQ2xCLFlBQVksRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLG1CQUFtQixhQUM5RCxhQUFhLEVBQUUsWUFBWTtnSEFFMUIsbUJBQW1CLFlBSE4sWUFBWSxFQUFFLGFBQWEsRUFBRSxtQkFBbUI7OzRGQUc3RCxtQkFBbUI7a0JBTC9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsYUFBYSxDQUFDO29CQUM3QixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLGFBQWEsRUFBRSxtQkFBbUIsQ0FBQztvQkFDekUsT0FBTyxFQUFFLENBQUMsYUFBYSxFQUFFLFlBQVksQ0FBQztpQkFDdkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFRhYnNDb21wb25lbnQgfSBmcm9tICcuL3RhYnMuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdFRhYnNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJzJztcbmltcG9ydCB7IEljb25Db21wb25lbnRNb2R1bGUgfSBmcm9tICcuLi9pY29uL2ljb24uY29tcG9uZW50Lm1vZHVsZSc7XG5pbXBvcnQgeyBUYWJEaXJlY3RpdmUgfSBmcm9tICcuL3RhYi5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtUYWJzQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1RhYkRpcmVjdGl2ZSwgQ29tbW9uTW9kdWxlLCBNYXRUYWJzTW9kdWxlLCBJY29uQ29tcG9uZW50TW9kdWxlXSxcbiAgZXhwb3J0czogW1RhYnNDb21wb25lbnQsIFRhYkRpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIFRhYnNDb21wb25lbnRNb2R1bGUge31cbiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { trigger, transition, animate, style, state } from '@angular/animations';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { Injectable, Component, ViewEncapsulation, Optional, Inject, HostBinding, Input, EventEmitter, ViewChild, Output, Pipe, ChangeDetectionStrategy, NgModule, Self, Directive, HostListener, forwardRef, booleanAttribute, ViewContainerRef, InjectionToken, inject, PLATFORM_ID, signal,
|
|
3
|
+
import { Injectable, Component, ViewEncapsulation, Optional, Inject, HostBinding, Input, EventEmitter, ViewChild, Output, Pipe, ChangeDetectionStrategy, NgModule, Self, Directive, HostListener, forwardRef, booleanAttribute, ViewContainerRef, InjectionToken, inject, PLATFORM_ID, signal, input, TemplateRef, effect, DestroyRef, ElementRef } from '@angular/core';
|
|
4
4
|
import * as i1$1 from '@angular/platform-browser';
|
|
5
5
|
import * as i1$2 from '@angular/common';
|
|
6
6
|
import { CommonModule, NgIf, NgForOf, NgClass, NgTemplateOutlet, formatDate, isPlatformBrowser, NgOptimizedImage } from '@angular/common';
|
|
@@ -10860,7 +10860,7 @@ class TabsComponent {
|
|
|
10860
10860
|
}
|
|
10861
10861
|
addTab(tab) {
|
|
10862
10862
|
this.tabs.push(tab);
|
|
10863
|
-
this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);
|
|
10863
|
+
this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
|
|
10864
10864
|
}
|
|
10865
10865
|
onTabChange(ev) {
|
|
10866
10866
|
const selectedTab = this.tabs[ev.index];
|
|
@@ -10887,7 +10887,13 @@ class TabsComponent {
|
|
|
10887
10887
|
if (index !== undefined) {
|
|
10888
10888
|
this.tabs.splice(index, 1);
|
|
10889
10889
|
delete this.tabIndexMap[tabName];
|
|
10890
|
-
this.tabs.forEach((v, index) => this.tabIndexMap[v.tabName] = index);
|
|
10890
|
+
this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
|
|
10891
|
+
}
|
|
10892
|
+
}
|
|
10893
|
+
updateTab(tabName, tab) {
|
|
10894
|
+
const index = this.tabIndexMap[tabName];
|
|
10895
|
+
if (index !== undefined) {
|
|
10896
|
+
this.tabs[index] = { ...this.tabs[index], ...tab };
|
|
10891
10897
|
}
|
|
10892
10898
|
}
|
|
10893
10899
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: IS_MOBILE_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -10934,80 +10940,67 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
10934
10940
|
}] } });
|
|
10935
10941
|
|
|
10936
10942
|
class TabDirective {
|
|
10937
|
-
constructor(
|
|
10938
|
-
this.
|
|
10939
|
-
this.
|
|
10943
|
+
constructor() {
|
|
10944
|
+
this.tabLabel = input.required();
|
|
10945
|
+
this.tabName = input.required();
|
|
10946
|
+
this.iconLeft = input();
|
|
10947
|
+
this.iconRight = input();
|
|
10948
|
+
this.disabled = input(false, { transform: booleanAttribute });
|
|
10949
|
+
this.canLeave = input();
|
|
10950
|
+
this.linkUrl = input();
|
|
10951
|
+
this.tabsComponent = inject(TabsComponent);
|
|
10952
|
+
this.template = inject(TemplateRef);
|
|
10953
|
+
this.syncProps = effect(() => {
|
|
10954
|
+
this.tabsComponent.updateTab(this.tabName(), {
|
|
10955
|
+
tabLabel: this.tabLabel(),
|
|
10956
|
+
iconLeft: this.iconLeft(),
|
|
10957
|
+
iconRight: this.iconRight(),
|
|
10958
|
+
disabled: this.disabled(),
|
|
10959
|
+
canLeave: this.canLeave(),
|
|
10960
|
+
linkUrl: this.linkUrl(),
|
|
10961
|
+
});
|
|
10962
|
+
});
|
|
10963
|
+
this.cleanup = inject(DestroyRef).onDestroy(() => {
|
|
10964
|
+
this.tabsComponent.removeTab(this.tabName());
|
|
10965
|
+
});
|
|
10940
10966
|
}
|
|
10941
|
-
|
|
10967
|
+
ngOnInit() {
|
|
10942
10968
|
this.addTab();
|
|
10943
10969
|
}
|
|
10944
10970
|
addTab() {
|
|
10945
10971
|
this.tabsComponent.addTab({
|
|
10946
|
-
tabLabel: this.tabLabel,
|
|
10947
|
-
tabName: this.tabName,
|
|
10948
|
-
iconLeft: this.iconLeft,
|
|
10949
|
-
iconRight: this.iconRight,
|
|
10950
|
-
disabled: this.disabled,
|
|
10972
|
+
tabLabel: this.tabLabel(),
|
|
10973
|
+
tabName: this.tabName(),
|
|
10974
|
+
iconLeft: this.iconLeft(),
|
|
10975
|
+
iconRight: this.iconRight(),
|
|
10976
|
+
disabled: this.disabled(),
|
|
10951
10977
|
contentTemplateRef: this.template,
|
|
10952
|
-
canLeave: this.canLeave,
|
|
10953
|
-
linkUrl: this.linkUrl,
|
|
10978
|
+
canLeave: this.canLeave(),
|
|
10979
|
+
linkUrl: this.linkUrl(),
|
|
10954
10980
|
});
|
|
10955
10981
|
}
|
|
10956
|
-
|
|
10957
|
-
|
|
10958
|
-
}
|
|
10959
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, deps: [{ token: TabsComponent, host: true }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
10960
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.12", type: TabDirective, selector: "[uiTab]", inputs: { tabLabel: "tabLabel", tabName: "tabName", iconLeft: "iconLeft", iconRight: "iconRight", disabled: ["disabled", "disabled", booleanAttribute], canLeave: "canLeave", linkUrl: "linkUrl" }, usesOnChanges: true, ngImport: i0 }); }
|
|
10982
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
10983
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: TabDirective, isStandalone: true, selector: "ng-template[uiTab]", inputs: { tabLabel: { classPropertyName: "tabLabel", publicName: "tabLabel", isSignal: true, isRequired: true, transformFunction: null }, tabName: { classPropertyName: "tabName", publicName: "tabName", isSignal: true, isRequired: true, transformFunction: null }, iconLeft: { classPropertyName: "iconLeft", publicName: "iconLeft", isSignal: true, isRequired: false, transformFunction: null }, iconRight: { classPropertyName: "iconRight", publicName: "iconRight", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, canLeave: { classPropertyName: "canLeave", publicName: "canLeave", isSignal: true, isRequired: false, transformFunction: null }, linkUrl: { classPropertyName: "linkUrl", publicName: "linkUrl", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
|
|
10961
10984
|
}
|
|
10962
10985
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, decorators: [{
|
|
10963
10986
|
type: Directive,
|
|
10964
10987
|
args: [{
|
|
10965
|
-
|
|
10988
|
+
standalone: true,
|
|
10989
|
+
selector: 'ng-template[uiTab]',
|
|
10966
10990
|
}]
|
|
10967
|
-
}]
|
|
10968
|
-
type: Host
|
|
10969
|
-
}] }, { type: i0.TemplateRef }], propDecorators: { tabLabel: [{
|
|
10970
|
-
type: Input,
|
|
10971
|
-
args: [{ required: true }]
|
|
10972
|
-
}], tabName: [{
|
|
10973
|
-
type: Input,
|
|
10974
|
-
args: [{ required: true }]
|
|
10975
|
-
}], iconLeft: [{
|
|
10976
|
-
type: Input
|
|
10977
|
-
}], iconRight: [{
|
|
10978
|
-
type: Input
|
|
10979
|
-
}], disabled: [{
|
|
10980
|
-
type: Input,
|
|
10981
|
-
args: [{ transform: booleanAttribute }]
|
|
10982
|
-
}], canLeave: [{
|
|
10983
|
-
type: Input
|
|
10984
|
-
}], linkUrl: [{
|
|
10985
|
-
type: Input
|
|
10986
|
-
}] } });
|
|
10991
|
+
}] });
|
|
10987
10992
|
|
|
10988
10993
|
class TabsComponentModule {
|
|
10989
10994
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10990
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, declarations: [TabsComponent,
|
|
10991
|
-
|
|
10992
|
-
MatTabsModule,
|
|
10993
|
-
IconComponentModule], exports: [TabsComponent, TabDirective] }); }
|
|
10994
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, imports: [CommonModule,
|
|
10995
|
-
MatTabsModule,
|
|
10996
|
-
IconComponentModule] }); }
|
|
10995
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, declarations: [TabsComponent], imports: [TabDirective, CommonModule, MatTabsModule, IconComponentModule], exports: [TabsComponent, TabDirective] }); }
|
|
10996
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, imports: [CommonModule, MatTabsModule, IconComponentModule] }); }
|
|
10997
10997
|
}
|
|
10998
10998
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabsComponentModule, decorators: [{
|
|
10999
10999
|
type: NgModule,
|
|
11000
11000
|
args: [{
|
|
11001
|
-
declarations: [
|
|
11002
|
-
|
|
11003
|
-
|
|
11004
|
-
],
|
|
11005
|
-
imports: [
|
|
11006
|
-
CommonModule,
|
|
11007
|
-
MatTabsModule,
|
|
11008
|
-
IconComponentModule
|
|
11009
|
-
],
|
|
11010
|
-
exports: [TabsComponent, TabDirective]
|
|
11001
|
+
declarations: [TabsComponent],
|
|
11002
|
+
imports: [TabDirective, CommonModule, MatTabsModule, IconComponentModule],
|
|
11003
|
+
exports: [TabsComponent, TabDirective],
|
|
11011
11004
|
}]
|
|
11012
11005
|
}] });
|
|
11013
11006
|
|