@testgorilla/tgo-ui 2.33.17 → 2.33.18

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.
@@ -13,6 +13,7 @@ export declare class TabDirective implements OnInit {
13
13
  nextTab: Tab;
14
14
  }) => boolean | Promise<boolean>) | undefined>;
15
15
  linkUrl: import("@angular/core").InputSignal<string | undefined>;
16
+ order: import("@angular/core").InputSignal<number | undefined>;
16
17
  private tabsComponent;
17
18
  private template;
18
19
  private syncProps;
@@ -20,5 +21,5 @@ export declare class TabDirective implements OnInit {
20
21
  ngOnInit(): void;
21
22
  private addTab;
22
23
  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>;
24
+ 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; }; "order": { "alias": "order"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
24
25
  }
@@ -57,9 +57,12 @@ export declare class TabsComponent {
57
57
  protected tabs: Tab[];
58
58
  readonly tabIndex: import("@angular/core").WritableSignal<number>;
59
59
  protected tabIndexMap: Record<string, number>;
60
+ private insertionCounter;
60
61
  constructor(defaultAppTheme: ApplicationTheme, isMobile$: Observable<boolean>);
61
62
  ngAfterViewInit(): void;
62
63
  addTab(tab: Tab): void;
64
+ private sortTabs;
65
+ private updateTabIndexMap;
63
66
  onTabChange(ev: MatTabChangeEvent): void;
64
67
  selectTab(tabName: string): void;
65
68
  indexOf(tabName: string): number;
@@ -12,5 +12,6 @@ export interface Tab {
12
12
  }) => boolean | Promise<boolean>;
13
13
  linkUrl?: string;
14
14
  ariaLabel?: string;
15
+ order?: number;
15
16
  }
16
17
  export type TabsType = 'underlined' | 'filled';
@@ -10,6 +10,7 @@ export class TabDirective {
10
10
  this.disabled = input(false, { transform: booleanAttribute });
11
11
  this.canLeave = input();
12
12
  this.linkUrl = input();
13
+ this.order = input();
13
14
  this.tabsComponent = inject(TabsComponent);
14
15
  this.template = inject(TemplateRef);
15
16
  this.syncProps = effect(() => {
@@ -20,6 +21,7 @@ export class TabDirective {
20
21
  disabled: this.disabled(),
21
22
  canLeave: this.canLeave(),
22
23
  linkUrl: this.linkUrl(),
24
+ order: this.order(),
23
25
  });
24
26
  });
25
27
  this.cleanup = inject(DestroyRef).onDestroy(() => {
@@ -39,10 +41,11 @@ export class TabDirective {
39
41
  contentTemplateRef: this.template,
40
42
  canLeave: this.canLeave(),
41
43
  linkUrl: this.linkUrl(),
44
+ order: this.order(),
42
45
  });
43
46
  }
44
47
  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 }); }
48
+ 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 }, order: { classPropertyName: "order", publicName: "order", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
46
49
  }
47
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, decorators: [{
48
51
  type: Directive,
@@ -51,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
51
54
  selector: 'ng-template[uiTab]',
52
55
  }]
53
56
  }] });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPakQsTUFBTSxPQUFPLFlBQVk7SUFKekI7UUFLRSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ3BDLFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDbkMsYUFBUSxHQUFHLEtBQUssRUFBWSxDQUFDO1FBQzdCLGNBQVMsR0FBRyxLQUFLLEVBQVksQ0FBQztRQUM5QixhQUFRLEdBQUcsS0FBSyxDQUFrQixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQzFFLGFBQVEsR0FBRyxLQUFLLEVBQTJFLENBQUM7UUFDNUYsWUFBTyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBRWxCLGtCQUFhLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3RDLGFBQVEsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFL0IsY0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDOUIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFO2dCQUMzQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDekIsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFO2dCQUMzQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDekIsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO2FBQ3hCLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUssWUFBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2xELElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLENBQUMsQ0FBQyxDQUFDO0tBa0JKO0lBaEJDLFFBQVE7UUFDTixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVPLE1BQU07UUFDWixJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztZQUN4QixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUN2QixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUMzQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixrQkFBa0IsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUNqQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtTQUN4QixDQUFDLENBQUM7SUFDTCxDQUFDOytHQTFDVSxZQUFZO21HQUFaLFlBQVk7OzRGQUFaLFlBQVk7a0JBSnhCLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYm9vbGVhbkF0dHJpYnV0ZSwgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBlZmZlY3QsIGluamVjdCwgaW5wdXQsIE9uSW5pdCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZGVsJztcbmltcG9ydCB7IFRhYnNDb21wb25lbnQgfSBmcm9tICcuL3RhYnMuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYiB9IGZyb20gJy4vdGFicy5tb2RlbCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW3VpVGFiXScsXG59KVxuZXhwb3J0IGNsYXNzIFRhYkRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHRhYkxhYmVsID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuICB0YWJOYW1lID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuICBpY29uTGVmdCA9IGlucHV0PEljb25OYW1lPigpO1xuICBpY29uUmlnaHQgPSBpbnB1dDxJY29uTmFtZT4oKTtcbiAgZGlzYWJsZWQgPSBpbnB1dDxib29sZWFuLCBzdHJpbmc+KGZhbHNlLCB7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KTtcbiAgY2FuTGVhdmUgPSBpbnB1dDwoY3R4PzogeyBjdXJyZW50VGFiOiBUYWI7IG5leHRUYWI6IFRhYiB9KSA9PiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPj4oKTtcbiAgbGlua1VybCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBwcml2YXRlIHRhYnNDb21wb25lbnQgPSBpbmplY3QoVGFic0NvbXBvbmVudCk7XG4gIHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXG4gIHByaXZhdGUgc3luY1Byb3BzID0gZWZmZWN0KCgpID0+IHtcbiAgICB0aGlzLnRhYnNDb21wb25lbnQudXBkYXRlVGFiKHRoaXMudGFiTmFtZSgpLCB7XG4gICAgICB0YWJMYWJlbDogdGhpcy50YWJMYWJlbCgpLFxuICAgICAgaWNvbkxlZnQ6IHRoaXMuaWNvbkxlZnQoKSxcbiAgICAgIGljb25SaWdodDogdGhpcy5pY29uUmlnaHQoKSxcbiAgICAgIGRpc2FibGVkOiB0aGlzLmRpc2FibGVkKCksXG4gICAgICBjYW5MZWF2ZTogdGhpcy5jYW5MZWF2ZSgpLFxuICAgICAgbGlua1VybDogdGhpcy5saW5rVXJsKCksXG4gICAgfSk7XG4gIH0pO1xuXG4gIHByaXZhdGUgY2xlYW51cCA9IGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xuICAgIHRoaXMudGFic0NvbXBvbmVudC5yZW1vdmVUYWIodGhpcy50YWJOYW1lKCkpO1xuICB9KTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmFkZFRhYigpO1xuICB9XG5cbiAgcHJpdmF0ZSBhZGRUYWIoKTogdm9pZCB7XG4gICAgdGhpcy50YWJzQ29tcG9uZW50LmFkZFRhYih7XG4gICAgICB0YWJMYWJlbDogdGhpcy50YWJMYWJlbCgpLFxuICAgICAgdGFiTmFtZTogdGhpcy50YWJOYW1lKCksXG4gICAgICBpY29uTGVmdDogdGhpcy5pY29uTGVmdCgpLFxuICAgICAgaWNvblJpZ2h0OiB0aGlzLmljb25SaWdodCgpLFxuICAgICAgZGlzYWJsZWQ6IHRoaXMuZGlzYWJsZWQoKSxcbiAgICAgIGNvbnRlbnRUZW1wbGF0ZVJlZjogdGhpcy50ZW1wbGF0ZSxcbiAgICAgIGNhbkxlYXZlOiB0aGlzLmNhbkxlYXZlKCksXG4gICAgICBsaW5rVXJsOiB0aGlzLmxpbmtVcmwoKSxcbiAgICB9KTtcbiAgfVxufVxuIl19
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBILE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPakQsTUFBTSxPQUFPLFlBQVk7SUFKekI7UUFLRSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ3BDLFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDbkMsYUFBUSxHQUFHLEtBQUssRUFBWSxDQUFDO1FBQzdCLGNBQVMsR0FBRyxLQUFLLEVBQVksQ0FBQztRQUM5QixhQUFRLEdBQUcsS0FBSyxDQUFrQixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQzFFLGFBQVEsR0FBRyxLQUFLLEVBQTJFLENBQUM7UUFDNUYsWUFBTyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQzFCLFVBQUssR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUVoQixrQkFBYSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN0QyxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRS9CLGNBQVMsR0FBRyxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQzlCLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRTtnQkFDM0MsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN6QixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRTtnQkFDM0IsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN6QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDdkIsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUU7YUFDcEIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSyxZQUFPLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDbEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDL0MsQ0FBQyxDQUFDLENBQUM7S0FtQko7SUFqQkMsUUFBUTtRQUNOLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRU8sTUFBTTtRQUNaLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDO1lBQ3hCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ3pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ3pCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQzNCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ3pCLGtCQUFrQixFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ2pDLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ3pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFO1NBQ3BCLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBN0NVLFlBQVk7bUdBQVosWUFBWTs7NEZBQVosWUFBWTtrQkFKeEIsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLG9CQUFvQjtpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBib29sZWFuQXR0cmlidXRlLCBEZXN0cm95UmVmLCBEaXJlY3RpdmUsIGVmZmVjdCwgaW5qZWN0LCBpbnB1dCwgT25Jbml0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWNvbk5hbWUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kZWwnO1xuaW1wb3J0IHsgVGFic0NvbXBvbmVudCB9IGZyb20gJy4vdGFicy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGFiIH0gZnJvbSAnLi90YWJzLm1vZGVsJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbdWlUYWJdJyxcbn0pXG5leHBvcnQgY2xhc3MgVGFiRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgdGFiTGFiZWwgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gIHRhYk5hbWUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gIGljb25MZWZ0ID0gaW5wdXQ8SWNvbk5hbWU+KCk7XG4gIGljb25SaWdodCA9IGlucHV0PEljb25OYW1lPigpO1xuICBkaXNhYmxlZCA9IGlucHV0PGJvb2xlYW4sIHN0cmluZz4oZmFsc2UsIHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pO1xuICBjYW5MZWF2ZSA9IGlucHV0PChjdHg/OiB7IGN1cnJlbnRUYWI6IFRhYjsgbmV4dFRhYjogVGFiIH0pID0+IGJvb2xlYW4gfCBQcm9taXNlPGJvb2xlYW4+PigpO1xuICBsaW5rVXJsID0gaW5wdXQ8c3RyaW5nPigpO1xuICBvcmRlciA9IGlucHV0PG51bWJlcj4oKTtcblxuICBwcml2YXRlIHRhYnNDb21wb25lbnQgPSBpbmplY3QoVGFic0NvbXBvbmVudCk7XG4gIHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXG4gIHByaXZhdGUgc3luY1Byb3BzID0gZWZmZWN0KCgpID0+IHtcbiAgICB0aGlzLnRhYnNDb21wb25lbnQudXBkYXRlVGFiKHRoaXMudGFiTmFtZSgpLCB7XG4gICAgICB0YWJMYWJlbDogdGhpcy50YWJMYWJlbCgpLFxuICAgICAgaWNvbkxlZnQ6IHRoaXMuaWNvbkxlZnQoKSxcbiAgICAgIGljb25SaWdodDogdGhpcy5pY29uUmlnaHQoKSxcbiAgICAgIGRpc2FibGVkOiB0aGlzLmRpc2FibGVkKCksXG4gICAgICBjYW5MZWF2ZTogdGhpcy5jYW5MZWF2ZSgpLFxuICAgICAgbGlua1VybDogdGhpcy5saW5rVXJsKCksXG4gICAgICBvcmRlcjogdGhpcy5vcmRlcigpLFxuICAgIH0pO1xuICB9KTtcblxuICBwcml2YXRlIGNsZWFudXAgPSBpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHtcbiAgICB0aGlzLnRhYnNDb21wb25lbnQucmVtb3ZlVGFiKHRoaXMudGFiTmFtZSgpKTtcbiAgfSk7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5hZGRUYWIoKTtcbiAgfVxuXG4gIHByaXZhdGUgYWRkVGFiKCk6IHZvaWQge1xuICAgIHRoaXMudGFic0NvbXBvbmVudC5hZGRUYWIoe1xuICAgICAgdGFiTGFiZWw6IHRoaXMudGFiTGFiZWwoKSxcbiAgICAgIHRhYk5hbWU6IHRoaXMudGFiTmFtZSgpLFxuICAgICAgaWNvbkxlZnQ6IHRoaXMuaWNvbkxlZnQoKSxcbiAgICAgIGljb25SaWdodDogdGhpcy5pY29uUmlnaHQoKSxcbiAgICAgIGRpc2FibGVkOiB0aGlzLmRpc2FibGVkKCksXG4gICAgICBjb250ZW50VGVtcGxhdGVSZWY6IHRoaXMudGVtcGxhdGUsXG4gICAgICBjYW5MZWF2ZTogdGhpcy5jYW5MZWF2ZSgpLFxuICAgICAgbGlua1VybDogdGhpcy5saW5rVXJsKCksXG4gICAgICBvcmRlcjogdGhpcy5vcmRlcigpLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -60,6 +60,8 @@ export class TabsComponent {
60
60
  this.tabs = [];
61
61
  this.tabIndex = signal(0);
62
62
  this.tabIndexMap = {};
63
+ // Counter for default ordering when order is not specified
64
+ this.insertionCounter = 0;
63
65
  if (defaultAppTheme) {
64
66
  this.applicationTheme = defaultAppTheme;
65
67
  }
@@ -107,8 +109,29 @@ export class TabsComponent {
107
109
  });
108
110
  }
109
111
  addTab(tab) {
112
+ // If no explicit order is provided, use the insertion counter
113
+ if (tab.order === undefined) {
114
+ tab.order = this.insertionCounter++;
115
+ }
116
+ // Add the tab and sort the tabs array
110
117
  this.tabs.push(tab);
111
- this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
118
+ this.sortTabs();
119
+ // Update the index map
120
+ this.updateTabIndexMap();
121
+ }
122
+ sortTabs() {
123
+ // Sort by the order property (lowest first)
124
+ this.tabs.sort((a, b) => {
125
+ const orderA = a.order ?? Infinity;
126
+ const orderB = b.order ?? Infinity;
127
+ return orderA - orderB;
128
+ });
129
+ }
130
+ updateTabIndexMap() {
131
+ // Update the index map after sorting
132
+ this.tabs.forEach((tab, index) => {
133
+ this.tabIndexMap[tab.tabName] = index;
134
+ });
112
135
  }
113
136
  onTabChange(ev) {
114
137
  const selectedTab = this.tabs[ev.index];
@@ -135,13 +158,18 @@ export class TabsComponent {
135
158
  if (index !== undefined) {
136
159
  this.tabs.splice(index, 1);
137
160
  delete this.tabIndexMap[tabName];
138
- this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
161
+ this.updateTabIndexMap();
139
162
  }
140
163
  }
141
164
  updateTab(tabName, tab) {
142
165
  const index = this.tabIndexMap[tabName];
143
166
  if (index !== undefined) {
144
167
  this.tabs[index] = { ...this.tabs[index], ...tab };
168
+ // Re-sort if the order changed
169
+ if (tab.order !== undefined) {
170
+ this.sortTabs();
171
+ this.updateTabIndexMap();
172
+ }
145
173
  }
146
174
  }
147
175
  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 }); }
@@ -186,4 +214,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
186
214
  type: ViewChild,
187
215
  args: ['tabGroup', { static: true }]
188
216
  }] } });
189
- //# 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  role=\"tablist\"\n>\n  <mat-tab\n    *ngFor=\"let tab of tabs; trackBy: trackByTabName;let i = index\"\n    [disabled]=\"tab.disabled ?? false\"\n    [attr.aria-label]=\"tab?.ariaLabel\"\n  >\n    <ng-template mat-tab-label>\n      <a\n        data-test-role=\"tab-link\"\n        [attr.data-testid]=\"tab.tabName\"\n        class=\"tab-name\"\n        [href]=\"tab?.linkUrl ? tab.linkUrl : '#'\"\n        (click)=\"$event.preventDefault()\"\n        [attr.aria-selected]=\"i === tabIndex()\"\n        [attr.aria-label]=\"tab.tabLabel + (i === tabIndex() ? ', ' + ('TABS.SELECTED' | uiTranslate | async) : '')\"\n        role=\"tab\"\n      >\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\n          [size]=\"'24'\"\n          class=\"right-icon\"\n          [name]=\"tab.iconRight!\"\n          *ngIf=\"tab?.iconRight\"\n        ></ui-icon>\n      </a>\n    </ng-template>\n    <div\n      role=\"tabpanel\"\n      [attr.id]=\"'tabpanel-' + i\"\n      [attr.aria-labelledby]=\"'tab-' + i\"\n    >\n      <ng-container *ngTemplateOutlet=\"tab.contentTemplateRef\"></ng-container>\n    </div>\n  </mat-tab>\n</mat-tab-group>\n"]}
217
+ //# 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  // Counter for default ordering when order is not specified\n  private insertionCounter: number = 0;\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    // If no explicit order is provided, use the insertion counter\n    if (tab.order === undefined) {\n      tab.order = this.insertionCounter++;\n    }\n\n    // Add the tab and sort the tabs array\n    this.tabs.push(tab);\n    this.sortTabs();\n\n    // Update the index map\n    this.updateTabIndexMap();\n  }\n\n  private sortTabs(): void {\n    // Sort by the order property (lowest first)\n    this.tabs.sort((a, b) => {\n      const orderA = a.order ?? Infinity;\n      const orderB = b.order ?? Infinity;\n      return orderA - orderB;\n    });\n  }\n\n  private updateTabIndexMap(): void {\n    // Update the index map after sorting\n    this.tabs.forEach((tab, index) => {\n      this.tabIndexMap[tab.tabName] = index;\n    });\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.updateTabIndexMap();\n    }\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      // Re-sort if the order changed\n      if (tab.order !== undefined) {\n        this.sortTabs();\n        this.updateTabIndexMap();\n      }\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  role=\"tablist\"\n>\n  <mat-tab\n    *ngFor=\"let tab of tabs; trackBy: trackByTabName;let i = index\"\n    [disabled]=\"tab.disabled ?? false\"\n    [attr.aria-label]=\"tab?.ariaLabel\"\n  >\n    <ng-template mat-tab-label>\n      <a\n        data-test-role=\"tab-link\"\n        [attr.data-testid]=\"tab.tabName\"\n        class=\"tab-name\"\n        [href]=\"tab?.linkUrl ? tab.linkUrl : '#'\"\n        (click)=\"$event.preventDefault()\"\n        [attr.aria-selected]=\"i === tabIndex()\"\n        [attr.aria-label]=\"tab.tabLabel + (i === tabIndex() ? ', ' + ('TABS.SELECTED' | uiTranslate | async) : '')\"\n        role=\"tab\"\n      >\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\n          [size]=\"'24'\"\n          class=\"right-icon\"\n          [name]=\"tab.iconRight!\"\n          *ngIf=\"tab?.iconRight\"\n        ></ui-icon>\n      </a>\n    </ng-template>\n    <div\n      role=\"tabpanel\"\n      [attr.id]=\"'tabpanel-' + i\"\n      [attr.aria-labelledby]=\"'tab-' + i\"\n    >\n      <ng-container *ngTemplateOutlet=\"tab.contentTemplateRef\"></ng-container>\n    </div>\n  </mat-tab>\n</mat-tab-group>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYnMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWIge1xuICB0YWJOYW1lOiBzdHJpbmc7XG4gIHRhYkxhYmVsOiBzdHJpbmc7XG4gIGNvbnRlbnRUZW1wbGF0ZVJlZjogYW55O1xuICBpY29uTGVmdD86IEljb25OYW1lO1xuICBpY29uUmlnaHQ/OiBJY29uTmFtZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBjYW5MZWF2ZT86IChjdHg/IDogeyBjdXJyZW50VGFiOlRhYiwgbmV4dFRhYjpUYWIgfSkgPT4gYm9vbGVhbiB8IFByb21pc2U8Ym9vbGVhbj47XG4gIGxpbmtVcmw/OiBzdHJpbmc7XG4gIGFyaWFMYWJlbD86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVGFic1R5cGUgPSAndW5kZXJsaW5lZCcgfCAnZmlsbGVkJztcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy90YWJzL3RhYnMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWIge1xuICB0YWJOYW1lOiBzdHJpbmc7XG4gIHRhYkxhYmVsOiBzdHJpbmc7XG4gIGNvbnRlbnRUZW1wbGF0ZVJlZjogYW55O1xuICBpY29uTGVmdD86IEljb25OYW1lO1xuICBpY29uUmlnaHQ/OiBJY29uTmFtZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBjYW5MZWF2ZT86IChjdHg/OiB7IGN1cnJlbnRUYWI6IFRhYjsgbmV4dFRhYjogVGFiIH0pID0+IGJvb2xlYW4gfCBQcm9taXNlPGJvb2xlYW4+O1xuICBsaW5rVXJsPzogc3RyaW5nO1xuICBhcmlhTGFiZWw/OiBzdHJpbmc7XG4gIG9yZGVyPzogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBUYWJzVHlwZSA9ICd1bmRlcmxpbmVkJyB8ICdmaWxsZWQnO1xuIl19
@@ -14513,6 +14513,8 @@ class TabsComponent {
14513
14513
  this.tabs = [];
14514
14514
  this.tabIndex = signal(0);
14515
14515
  this.tabIndexMap = {};
14516
+ // Counter for default ordering when order is not specified
14517
+ this.insertionCounter = 0;
14516
14518
  if (defaultAppTheme) {
14517
14519
  this.applicationTheme = defaultAppTheme;
14518
14520
  }
@@ -14560,8 +14562,29 @@ class TabsComponent {
14560
14562
  });
14561
14563
  }
14562
14564
  addTab(tab) {
14565
+ // If no explicit order is provided, use the insertion counter
14566
+ if (tab.order === undefined) {
14567
+ tab.order = this.insertionCounter++;
14568
+ }
14569
+ // Add the tab and sort the tabs array
14563
14570
  this.tabs.push(tab);
14564
- this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
14571
+ this.sortTabs();
14572
+ // Update the index map
14573
+ this.updateTabIndexMap();
14574
+ }
14575
+ sortTabs() {
14576
+ // Sort by the order property (lowest first)
14577
+ this.tabs.sort((a, b) => {
14578
+ const orderA = a.order ?? Infinity;
14579
+ const orderB = b.order ?? Infinity;
14580
+ return orderA - orderB;
14581
+ });
14582
+ }
14583
+ updateTabIndexMap() {
14584
+ // Update the index map after sorting
14585
+ this.tabs.forEach((tab, index) => {
14586
+ this.tabIndexMap[tab.tabName] = index;
14587
+ });
14565
14588
  }
14566
14589
  onTabChange(ev) {
14567
14590
  const selectedTab = this.tabs[ev.index];
@@ -14588,13 +14611,18 @@ class TabsComponent {
14588
14611
  if (index !== undefined) {
14589
14612
  this.tabs.splice(index, 1);
14590
14613
  delete this.tabIndexMap[tabName];
14591
- this.tabs.forEach((v, index) => (this.tabIndexMap[v.tabName] = index));
14614
+ this.updateTabIndexMap();
14592
14615
  }
14593
14616
  }
14594
14617
  updateTab(tabName, tab) {
14595
14618
  const index = this.tabIndexMap[tabName];
14596
14619
  if (index !== undefined) {
14597
14620
  this.tabs[index] = { ...this.tabs[index], ...tab };
14621
+ // Re-sort if the order changed
14622
+ if (tab.order !== undefined) {
14623
+ this.sortTabs();
14624
+ this.updateTabIndexMap();
14625
+ }
14598
14626
  }
14599
14627
  }
14600
14628
  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 }); }
@@ -14649,6 +14677,7 @@ class TabDirective {
14649
14677
  this.disabled = input(false, { transform: booleanAttribute });
14650
14678
  this.canLeave = input();
14651
14679
  this.linkUrl = input();
14680
+ this.order = input();
14652
14681
  this.tabsComponent = inject(TabsComponent);
14653
14682
  this.template = inject(TemplateRef);
14654
14683
  this.syncProps = effect(() => {
@@ -14659,6 +14688,7 @@ class TabDirective {
14659
14688
  disabled: this.disabled(),
14660
14689
  canLeave: this.canLeave(),
14661
14690
  linkUrl: this.linkUrl(),
14691
+ order: this.order(),
14662
14692
  });
14663
14693
  });
14664
14694
  this.cleanup = inject(DestroyRef).onDestroy(() => {
@@ -14678,10 +14708,11 @@ class TabDirective {
14678
14708
  contentTemplateRef: this.template,
14679
14709
  canLeave: this.canLeave(),
14680
14710
  linkUrl: this.linkUrl(),
14711
+ order: this.order(),
14681
14712
  });
14682
14713
  }
14683
14714
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
14684
- 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 }); }
14715
+ 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 }, order: { classPropertyName: "order", publicName: "order", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
14685
14716
  }
14686
14717
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabDirective, decorators: [{
14687
14718
  type: Directive,