@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.
@@ -1,26 +1,24 @@
1
- import { OnChanges, OnDestroy, TemplateRef } from '@angular/core';
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 OnChanges, OnDestroy {
7
- private tabsComponent;
8
- private template;
9
- tabLabel: string;
10
- tabName: string;
11
- iconLeft: IconName;
12
- iconRight: IconName;
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?: string;
19
- constructor(tabsComponent: TabsComponent, template: TemplateRef<any>);
20
- ngOnChanges(): void;
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
- ngOnDestroy(): void;
23
- static ɵfac: i0.ɵɵFactoryDeclaration<TabDirective, [{ host: true; }, null]>;
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 "./tabs.model";
3
- import { ApplicationTheme } from "../../models/application-theme.model";
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], [typeof i3.CommonModule, typeof i4.MatTabsModule, typeof i5.IconComponentModule], [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, Host, Input } from '@angular/core';
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(tabsComponent, template) {
6
- this.tabsComponent = tabsComponent;
7
- this.template = template;
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
- ngOnChanges() {
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
- ngOnDestroy() {
25
- this.tabsComponent.removeTab(this.tabName);
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
- selector: '[uiTab]'
50
+ standalone: true,
51
+ selector: 'ng-template[uiTab]',
34
52
  }]
35
- }], ctorParameters: () => [{ type: i1.TabsComponent, decorators: [{
36
- type: Host
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":"AAAA,OAAO,EACL,gBAAgB,EAChB,SAAS,EACT,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EACN,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAG5D,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;;;;;;AAOrE,MAAM,OAAO,aAAa;IA+DxB,YAC6E,eAAiC,EAChE,SAA8B;QADC,oBAAe,GAAf,eAAe,CAAkB;QAChE,cAAS,GAAT,SAAS,CAAqB;QAhE5E;;;;;;WAMG;QAGH,iBAAY,GAAkB,SAAS,CAAC;QACxC;;;;;;WAMG;QACM,SAAI,GAAa,YAAY,CAAC;QAEvC;;;;;WAKG;QACM,sBAAiB,GAAG,GAAG,CAAC;QAEjC;;;;;WAKG;QAGH,yBAAoB,GAAG,MAAM,CAAC;QAE9B;;;;WAIG;QACqC,kBAAa,GAAG,IAAI,CAAC;QAE7D;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAE5C,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC9C,gBAAW,GAAG,IAAI,YAAY,EAAO,CAAC;QAItC,SAAI,GAAU,EAAE,CAAC;QAClB,aAAQ,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,gBAAW,GAA2B,EAAE,CAAC;QAMjD,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,SAAS,GAAI,IAAI,CAAC,QAAgB,CAAC,UAAU,CAAC;YACpD,SAAS,CAAC,cAAc,GAAG,KAAK,EAAE,KAAoB,EAAE,EAAE;gBACxD,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC1B,OAAO;gBACT,CAAC;gBACD,QAAQ,KAAK,CAAC,OAAO,EAAE,CAAC;oBACtB,KAAK,KAAK,CAAC;oBACX,KAAK,KAAK;wBACR,MAAM,QAAQ,GAAI,KAAK,CAAC,MAAsB,CAAC,SAAS,CAAC;wBACzD,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;wBAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;wBAEjE,IAAI,CAAC,OAAO,EAAE,CAAC;4BACb,OAAO;wBACT,CAAC;wBAED,MAAM,QAAQ,GAAG,CAAC,MAAM,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC;wBAChF,IAAI,UAAU,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,IAAI,QAAQ,EAAE,CAAC;4BACvD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;4BACvD,SAAS,CAAC,UAAU,GAAG,YAAY,CAAC;4BACpC,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,YAAY,CAAC;wBAC7C,CAAC;wBACD,MAAM;oBACR;wBACE,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC,CAAC;YAED,IAAI,CAAC,QAAgB,CAAC,YAAY,GAAG,KAAK,EAAE,GAAW,EAAE,SAAc,EAAE,KAAa,EAAE,EAAE;gBACzF,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;gBACjD,IAAI,GAAG,CAAC,QAAQ,IAAI,YAAY,KAAK,SAAS,IAAI,KAAK,KAAK,YAAY,EAAE,CAAC;oBACzE,OAAO;gBACT,CAAC;gBACD,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;gBAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACjC,MAAM,QAAQ,GAAG,CAAC,MAAM,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC;gBAChF,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,IAAI,KAAK,IAAI,QAAQ,EAAE,CAAC;oBACrD,SAAS,CAAC,UAAU,GAAG,KAAK,CAAC;oBAC7B,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,KAAK,CAAC;gBACtC,CAAC;YACH,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IACzE,CAAC;IAED,WAAW,CAAC,EAAqB;QAC/B,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACrC,CAAC;IAED,SAAS,CAAC,OAAe;QACvB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACzB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,OAAO,CAAC,OAAe;QACrB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,KAAa,EAAE,GAAQ;QACpC,OAAO,GAAG,CAAC,OAAO,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,OAAe;QACvB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC3B,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACjC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IACD,SAAS,CAAC,OAAe,EAAE,GAAkC;QAC3D,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC;QACrD,CAAC;IACH,CAAC;+GAhKU,aAAa,kBAgEF,oCAAoC,6BAChD,eAAe;mGAjEd,aAAa,4LAmCJ,CAAC,KAAa,EAAU,EAAE,CAAC,KAAK,GAAG,IAAI,qDAQvC,gBAAgB,qYCnEtC,ukCAsBA;;4FDEa,aAAa;kBALzB,SAAS;+BACE,SAAS;;0BAoEhB,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BACvD,MAAM;2BAAC,eAAe;yCAvDzB,YAAY;sBAFX,WAAW;uBAAC,eAAe;;sBAC3B,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAUN,oBAAoB;sBAFnB,WAAW;uBAAC,gCAAgC;;sBAC5C,KAAK;uBAAC,EAAE,SAAS,EAAE,CAAC,KAAa,EAAU,EAAE,CAAC,KAAK,GAAG,IAAI,EAAE;gBAQrB,aAAa;sBAApD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAS7B,gBAAgB;sBAAxB,KAAK;gBAEI,gBAAgB;sBAAzB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBAEkC,QAAQ;sBAAhD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","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 "@angular/material/tabs";
5
- import { IconComponentModule } from "../icon/icon.component.module";
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
- TabDirective], imports: [CommonModule,
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
- TabsComponent,
23
- TabDirective
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5jb21wb25lbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL3RhYnMvdGFicy5jb21wb25lbnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQWdCL0MsTUFBTSxPQUFPLG1CQUFtQjsrR0FBbkIsbUJBQW1CO2dIQUFuQixtQkFBbUIsaUJBVjVCLGFBQWE7WUFDYixZQUFZLGFBR1osWUFBWTtZQUNaLGFBQWE7WUFDYixtQkFBbUIsYUFFWCxhQUFhLEVBQUUsWUFBWTtnSEFFMUIsbUJBQW1CLFlBTjVCLFlBQVk7WUFDWixhQUFhO1lBQ2IsbUJBQW1COzs0RkFJVixtQkFBbUI7a0JBWi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGFBQWE7d0JBQ2IsWUFBWTtxQkFDYjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsYUFBYSxFQUFFLFlBQVksQ0FBQztpQkFDdkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFRhYnNDb21wb25lbnQgfSBmcm9tICcuL3RhYnMuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdFRhYnNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvdGFic1wiO1xuaW1wb3J0IHsgSWNvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gXCIuLi9pY29uL2ljb24uY29tcG9uZW50Lm1vZHVsZVwiO1xuaW1wb3J0IHsgVGFiRGlyZWN0aXZlIH0gZnJvbSAnLi90YWIuZGlyZWN0aXZlJztcblxuXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFRhYnNDb21wb25lbnQsXG4gICAgVGFiRGlyZWN0aXZlXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0VGFic01vZHVsZSxcbiAgICBJY29uQ29tcG9uZW50TW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtUYWJzQ29tcG9uZW50LCBUYWJEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIFRhYnNDb21wb25lbnRNb2R1bGUgeyB9XG4iXX0=
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, Host, ElementRef } 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, 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(tabsComponent, template) {
10938
- this.tabsComponent = tabsComponent;
10939
- this.template = template;
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
- ngOnChanges() {
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
- ngOnDestroy() {
10957
- this.tabsComponent.removeTab(this.tabName);
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
- selector: '[uiTab]'
10988
+ standalone: true,
10989
+ selector: 'ng-template[uiTab]',
10966
10990
  }]
10967
- }], ctorParameters: () => [{ type: TabsComponent, decorators: [{
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
- TabDirective], imports: [CommonModule,
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
- TabsComponent,
11003
- TabDirective
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