@fundamental-ngx/platform 0.50.3 → 0.50.5

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.
@@ -240,19 +240,17 @@ export class IconTabBarComponent {
240
240
  flatIndexRef = flatIndexRef || { value: 0 };
241
241
  return config.map((item, index) => {
242
242
  const uId = `${indexPrefix}${index}`;
243
+ item.color = item.color || 'default';
243
244
  const result = {
244
245
  ...item,
245
246
  index,
246
- cssClasses: [],
247
+ cssClasses: item.color ? [`fd-icon-tab-bar__item--${item.color}`] : [],
247
248
  uId,
248
249
  hidden: false,
249
250
  parentUId,
250
251
  flatIndex: flatIndexRef.value++,
251
252
  subItems: this._generateTabBarItems(item.subItems || [], `${uId}${UNIQUE_KEY_SEPARATOR}`, flatIndexRef, uId)
252
253
  };
253
- if (item.color) {
254
- result.cssClasses = [`fd-icon-tab-bar__item--${item.color}`];
255
- }
256
254
  return result;
257
255
  });
258
256
  }
@@ -302,4 +300,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
302
300
  type: HostBinding,
303
301
  args: ['class.fd-tabs-custom']
304
302
  }] } });
305
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-tab-bar.component.js","sourceRoot":"","sources":["../../../../../libs/platform/icon-tab-bar/icon-tab-bar.component.ts","../../../../../libs/platform/icon-tab-bar/icon-tab-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    computed,\n    contentChildren,\n    DestroyRef,\n    ElementRef,\n    HostBinding,\n    inject,\n    Input,\n    input,\n    model,\n    OnInit,\n    Optional,\n    output,\n    signal,\n    viewChild,\n    viewChildren,\n    ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ContentDensityService, Nullable, RtlService, scrollTop } from '@fundamental-ngx/cdk/utils';\nimport { FD_DYNAMIC_PAGE } from '@fundamental-ngx/core/dynamic-page';\nimport { IconFont } from '@fundamental-ngx/core/icon';\nimport { ScrollSpyDirective } from '@fundamental-ngx/core/scroll-spy';\nimport { ScrollbarDirective } from '@fundamental-ngx/core/scrollbar';\nimport { FD_TABLIST, TabList } from '@fundamental-ngx/core/shared';\nimport { fromEvent } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, first } from 'rxjs/operators';\nimport { IconTabBarBase } from './components';\nimport { IconTabBarFilterTypeComponent } from './components/icon-tab-bar-filter-type/icon-tab-bar-filter-type.component';\nimport { IconTabBarIconTypeComponent } from './components/icon-tab-bar-icon-type/icon-tab-bar-icon-type.component';\nimport { IconTabBarProcessTypeComponent } from './components/icon-tab-bar-process-type/icon-tab-bar-process-type.component';\nimport {\n    IconTabBarTabComponent,\n    IconTabBarTabContentDirective\n} from './components/icon-tab-bar-tab/icon-tab-bar-tab.component';\nimport { IconTabBarTextTypeComponent } from './components/icon-tab-bar-text-type/icon-tab-bar-text-type.component';\nimport { UNIQUE_KEY_SEPARATOR } from './constants';\nimport { IconTabBarItem } from './interfaces/icon-tab-bar-item.interface';\nimport { TabColorAssociations } from './interfaces/tab-color-associations.interface';\nimport { TabConfig } from './interfaces/tab-config.interface';\nimport { IconTabBarBackground, IconTabBarSize, TabDestinyMode, TabType } from './types';\n\n@Component({\n    selector: 'fdp-icon-tab-bar',\n    templateUrl: './icon-tab-bar.component.html',\n    styleUrl: './icon-tab-bar.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    providers: [\n        {\n            provide: FD_TABLIST,\n            useExisting: IconTabBarComponent\n        }\n    ],\n    imports: [\n        NgTemplateOutlet,\n        IconTabBarProcessTypeComponent,\n        IconTabBarFilterTypeComponent,\n        IconTabBarIconTypeComponent,\n        IconTabBarTextTypeComponent,\n        ScrollbarDirective,\n        ScrollSpyDirective,\n        IconTabBarTabContentDirective\n    ]\n})\nexport class IconTabBarComponent implements OnInit, TabList {\n    /**\n     * Whether to open tab content one under another without collapsing.\n     * Works only for content-projected tab content.\n     */\n    @Input({ transform: booleanAttribute })\n    stackContent = false;\n\n    /** @description Type of tab bar view. */\n    iconTabType = input<TabType>('text');\n\n    /**\n     * @description A tab bar configuration that stores the state of each tab. Based on this configuration, a tab bar is representing.\n     */\n    tabsConfig = model<TabConfig[]>();\n\n    /** @description Destiny mode. */\n    densityMode = model<TabDestinyMode>('inherit');\n\n    /** @description Icon font */\n    iconTabFont = input<IconFont>('SAP-icons');\n\n    /** @description Disable or enable reordering(drag and drop) feature. (supported by text type only) */\n    enableTabReordering = input(false);\n\n    /** @description Boolean flag indicating to show total tab.(supported by filter type only) */\n    showTotalTab = input(true);\n\n    /** Whether to render icon tab item as multi-click variant. */\n    multiClick = input(false);\n\n    /** @description Layout type for tab (supported by text type only) */\n    layoutMode = input<'row' | 'column'>('row');\n\n    /** @description Icon tab bar background type. */\n    iconTabBackground = input<IconTabBarBackground>('solid');\n\n    /** @description Icon tab bar size. */\n    iconTabSize = input<IconTabBarSize>();\n\n    /**\n     * @description Associations for colors of the tabs.\n     * If any of the color associations provided, they'll be read by screenreader instead of the actual color\n     */\n    colorAssociations = input<TabColorAssociations>();\n\n    /**\n     * Maximum height of the content.\n     * Works only for content-projected tab content.\n     */\n    maxContentHeight = input('100%');\n\n    /** @description Emits when some tab is selected. */\n    iconTabSelected = output<IconTabBarItem>();\n\n    /** @description Emits when user drop tab. */\n    iconTabReordered = output<IconTabBarItem[]>();\n\n    /** Event emitted when user clicks on x icon in tab. */\n    closeTab = output<IconTabBarItem>();\n\n    /** @hidden */\n    children = contentChildren(IconTabBarTabComponent, { descendants: false });\n\n    /** @hidden */\n    _scrollbar = viewChild(ScrollbarDirective);\n\n    /** @hidden */\n    tabDirectives = viewChildren(IconTabBarTabContentDirective);\n\n    @HostBinding('class.fd-tabs-custom')\n    private get _customTabs(): boolean {\n        return this._inDynamicPage;\n    }\n\n    /** @hidden */\n    get headerContainer(): Nullable<ElementRef> {\n        return this._iconTabBarCmp()?.headerElement;\n    }\n\n    /** @hidden */\n    _cssClassForContainer: string[];\n\n    /** @hidden */\n    _disableScrollSpy = false;\n\n    /** @hidden */\n    _init = true;\n\n    /** Scrollable element reference. */\n    get scrollableElement(): Nullable<ElementRef> {\n        return this._scrollbar()?.elementRef;\n    }\n\n    /** @hidden */\n    readonly _selectedUid = signal<string | undefined>(undefined);\n\n    /** @hidden */\n    readonly _tabs$ = computed(() => this._generateTabBarItems(this._tabsConfig$()));\n\n    /** @hidden */\n    readonly _flatTabs$ = computed(() => this._generateFlatTabs(this._tabs$()));\n\n    /** @hidden */\n    readonly _tabRenderer$ = signal<IconTabBarItem | null>(null);\n\n    /** @hidden */\n    readonly _rtl$ = computed(() => !!this._rtlService?.rtlSignal());\n\n    /** @hidden */\n    readonly _tabsConfig$ = computed(() => {\n        const tabConfig = this.tabsConfig();\n        if (tabConfig) {\n            return this.tabsConfig() as TabConfig[];\n        }\n\n        const children = this.children();\n        if (!children) {\n            return [];\n        }\n        return children.map((t) => this._generateTabConfig(t));\n    });\n\n    /** @hidden */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    private readonly _inDynamicPage = !!inject(FD_DYNAMIC_PAGE, { optional: true });\n\n    private readonly _iconTabBarCmp = viewChild<Nullable<IconTabBarBase>>(IconTabBarBase);\n\n    /** @hidden */\n    constructor(\n        private _cd: ChangeDetectorRef,\n        @Optional() private _contentDensityService: ContentDensityService,\n        @Optional() private _rtlService: RtlService\n    ) {}\n\n    /** @hidden */\n    ngOnInit(): void {\n        this._cssClassForContainer = this._generateContainerStyles();\n\n        if (this.densityMode() === 'inherit') {\n            this._contentDensityService?._contentDensityListener\n                .pipe(distinctUntilChanged(), takeUntilDestroyed(this._destroyRef))\n                .subscribe((density) => {\n                    this.densityMode.set(density);\n                    if (density !== 'compact') {\n                        this._cssClassForContainer = this._cssClassForContainer.filter(\n                            (cssClass) => cssClass !== 'fd-icon-tab-bar--compact'\n                        );\n                    } else {\n                        this._cssClassForContainer.push('fd-icon-tab-bar--compact');\n                    }\n                    this._cd.detectChanges();\n                });\n        }\n    }\n\n    /**\n     * @hidden\n     * @param event reordered array of IconTabBarItem\n     */\n    _onReorder(event: IconTabBarItem[]): void {\n        this.iconTabReordered.emit(event);\n    }\n\n    /**\n     * @hidden\n     * @param selectedItem\n     */\n    _selectItem(selectedItem: IconTabBarItem): void {\n        this._tabRenderer$.set(selectedItem);\n        this.iconTabSelected.emit(selectedItem);\n\n        if (this.stackContent) {\n            this._scrollToPanel(this.tabDirectives().find((tab) => tab.uId() === selectedItem.uId)!);\n        }\n    }\n\n    /** @hidden */\n    _closeTab(item: IconTabBarItem): void {\n        this.closeTab.emit(item);\n    }\n\n    /** Programmatically select tab. */\n    selectTab(id: Nullable<string>): void {\n        const selectedItem = this._flatTabs$().find((t) => t.id === id);\n        if (!selectedItem) {\n            return;\n        }\n        this._selectedUid.set(selectedItem.uId);\n        this._selectItem(selectedItem);\n    }\n\n    /** @hidden */\n    highlightActiveTab(id: Nullable<string>, scroll = false): void {\n        if (this._disableScrollSpy) {\n            return;\n        }\n        const activeTab = this.tabDirectives().find((tab) => tab.id() === id);\n        this._selectedUid.set(activeTab?.uId() || undefined);\n        if (scroll && activeTab) {\n            this._scrollToPanel(activeTab);\n        }\n    }\n\n    /**\n     * @hidden\n     * @returns array of css classes for icon-tab-bar container\n     */\n    private _generateContainerStyles(): string[] {\n        const styles = [`fd-icon-tab-bar--${this.iconTabType()}`];\n        const tabsConfig = this.tabsConfig();\n        if (tabsConfig && this.iconTabType() === 'process' && tabsConfig[0].icon) {\n            styles.push('fd-icon-tab-bar--icon');\n        }\n        if (this.iconTabBackground() !== 'solid') {\n            styles.push(`fd-icon-tab-bar--${this.iconTabBackground()}`);\n        }\n        if (this.iconTabSize()) {\n            styles.push(`fd-icon-tab-bar--${this.iconTabSize()!}`);\n        }\n        if (this.densityMode() === 'compact') {\n            styles.push('fd-icon-tab-bar--compact');\n        }\n        if (this.layoutMode() === 'column') {\n            styles.push('fd-icon-tab-bar--counters');\n        }\n        return styles;\n    }\n\n    private _generateTabConfig(tab: IconTabBarTabComponent): TabConfig {\n        const tabConfig: TabConfig = {\n            label: tab.label(),\n            color: tab.color(),\n            active: tab.active(),\n            counter: tab.counter(),\n            renderer: tab.renderer(),\n            id: tab.id(),\n            subItems: tab.children().map((c) => this._generateTabConfig(c))\n        };\n\n        return tabConfig;\n    }\n\n    /** @hidden */\n    private _scrollToPanel(tabPanel: Nullable<IconTabBarTabContentDirective>): void {\n        if (!tabPanel) {\n            return;\n        }\n        const scrollbar = this._scrollbar();\n        if (!scrollbar) {\n            return;\n        }\n        const panelElement = tabPanel.elementRef.nativeElement;\n        const containerElement = scrollbar.elementRef.nativeElement;\n        const distanceToScroll = panelElement.offsetTop - containerElement.offsetTop;\n        const maximumScrollTop = containerElement.scrollHeight - containerElement.clientHeight;\n        const currentScrollPosition = Math.ceil(containerElement.scrollTop);\n\n        if (!(currentScrollPosition === maximumScrollTop && distanceToScroll > maximumScrollTop)) {\n            this._disableScrollSpy = true;\n            fromEvent(containerElement, 'scroll')\n                .pipe(debounceTime(100), first(), takeUntilDestroyed(this._destroyRef))\n                .subscribe(() => (this._disableScrollSpy = false));\n            scrollTop(containerElement, distanceToScroll);\n        }\n    }\n\n    /**\n     * @hidden\n     * @description generate IconTabItems from TabConfig array\n     */\n    private _generateTabBarItems(\n        config: TabConfig[],\n        indexPrefix = '',\n        flatIndexRef?: FlatIndex,\n        parentUId?: string\n    ): IconTabBarItem[] {\n        flatIndexRef = flatIndexRef || { value: 0 };\n        return config.map((item, index) => {\n            const uId = `${indexPrefix}${index}`;\n            const result: IconTabBarItem = {\n                ...item,\n                index,\n                cssClasses: [],\n                uId,\n                hidden: false,\n                parentUId,\n                flatIndex: flatIndexRef!.value++,\n                subItems: this._generateTabBarItems(\n                    item.subItems || [],\n                    `${uId}${UNIQUE_KEY_SEPARATOR}`,\n                    flatIndexRef,\n                    uId\n                )\n            };\n            if (item.color) {\n                result.cssClasses = [`fd-icon-tab-bar__item--${item.color}`];\n            }\n            return result;\n        });\n    }\n\n    private _generateFlatTabs(tabs: IconTabBarItem[]): IconTabBarItem[] {\n        const flatTabs = tabs.reduce((acc: IconTabBarItem[], tab) => {\n            acc.push(tab);\n            if (tab.subItems) {\n                acc.push(...this._generateFlatTabs(tab.subItems));\n            }\n            return acc;\n        }, []);\n\n        return flatTabs;\n    }\n}\n\n/** @hidden helper object that is used in tab generation functions to calculate their indexes not depending on level of nesting */\ninterface FlatIndex {\n    value: number;\n}\n","<div class=\"fd-icon-tab-bar\" [class]=\"_cssClassForContainer\">\n    @if (iconTabType() === 'text') {\n        <ng-template [ngTemplateOutlet]=\"textType\"></ng-template>\n    }\n    @if (iconTabType() === 'icon' || iconTabType() === 'icon-only') {\n        <ng-template [ngTemplateOutlet]=\"iconType\"></ng-template>\n    }\n    @if (iconTabType() === 'filter') {\n        <ng-template [ngTemplateOutlet]=\"filterType\"></ng-template>\n    }\n    @if (iconTabType() === 'process') {\n        <ng-template [ngTemplateOutlet]=\"processType\"></ng-template>\n    }\n    <div\n        class=\"fd-icon-tab-bar__content\"\n        fd-scrollbar\n        (spyChange)=\"highlightActiveTab($event.id)\"\n        [scrollSpyDisabled]=\"!stackContent || _disableScrollSpy\"\n        fdScrollSpy\n        [trackedTags]=\"['fdp-icon-tab-bar-tab-content']\"\n        [style.max-height]=\"maxContentHeight()\"\n    >\n        @if (stackContent) {\n            @for (tab of _flatTabs$(); track tab) {\n                <fdp-icon-tab-bar-tab-content [id]=\"tab.id\" [uId]=\"tab.uId\" class=\"fd-icon-tab-bar__tab-content\">\n                    <ng-template [ngTemplateOutlet]=\"tab.renderer || null\"></ng-template>\n                </fdp-icon-tab-bar-tab-content>\n            }\n        } @else {\n            @if (_tabRenderer$(); as tabRenderer) {\n                <fdp-icon-tab-bar-tab-content\n                    [id]=\"tabRenderer.id\"\n                    [uId]=\"tabRenderer.uId\"\n                    class=\"fd-icon-tab-bar__tab-content\"\n                >\n                    <ng-template [ngTemplateOutlet]=\"tabRenderer.renderer || null\"></ng-template>\n                </fdp-icon-tab-bar-tab-content>\n            }\n        }\n        <ng-content select=\"[fdpIconTabBarFreeContent]\"></ng-content>\n    </div>\n</div>\n<ng-template #processType>\n    <fdp-icon-tab-bar-process-type\n        [tabs]=\"_tabs$()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n    ></fdp-icon-tab-bar-process-type>\n</ng-template>\n<ng-template #filterType>\n    <fdp-icon-tab-bar-filter-type\n        [tabs]=\"_tabs$()\"\n        [showTotalTab]=\"showTotalTab()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n    ></fdp-icon-tab-bar-filter-type>\n</ng-template>\n<ng-template #iconType>\n    <fdp-icon-tab-bar-icon-type\n        [showLabel]=\"iconTabType() === 'icon'\"\n        [tabs]=\"_tabs$()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n        (closeTab)=\"_closeTab($event)\"\n    ></fdp-icon-tab-bar-icon-type>\n</ng-template>\n<ng-template #textType>\n    <fdp-icon-tab-bar-text-type\n        [tabs]=\"_tabs$()\"\n        [multiClick]=\"multiClick()\"\n        [layoutMode]=\"layoutMode()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [enableTabReordering]=\"enableTabReordering()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (reordered)=\"_onReorder($event)\"\n        (selected)=\"_selectItem($event)\"\n        (closeTab)=\"_closeTab($event)\"\n    ></fdp-icon-tab-bar-text-type>\n</ng-template>\n"]}
303
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-tab-bar.component.js","sourceRoot":"","sources":["../../../../../libs/platform/icon-tab-bar/icon-tab-bar.component.ts","../../../../../libs/platform/icon-tab-bar/icon-tab-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    computed,\n    contentChildren,\n    DestroyRef,\n    ElementRef,\n    HostBinding,\n    inject,\n    Input,\n    input,\n    model,\n    OnInit,\n    Optional,\n    output,\n    signal,\n    viewChild,\n    viewChildren,\n    ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ContentDensityService, Nullable, RtlService, scrollTop } from '@fundamental-ngx/cdk/utils';\nimport { FD_DYNAMIC_PAGE } from '@fundamental-ngx/core/dynamic-page';\nimport { IconFont } from '@fundamental-ngx/core/icon';\nimport { ScrollSpyDirective } from '@fundamental-ngx/core/scroll-spy';\nimport { ScrollbarDirective } from '@fundamental-ngx/core/scrollbar';\nimport { FD_TABLIST, TabList } from '@fundamental-ngx/core/shared';\nimport { fromEvent } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, first } from 'rxjs/operators';\nimport { IconTabBarBase } from './components';\nimport { IconTabBarFilterTypeComponent } from './components/icon-tab-bar-filter-type/icon-tab-bar-filter-type.component';\nimport { IconTabBarIconTypeComponent } from './components/icon-tab-bar-icon-type/icon-tab-bar-icon-type.component';\nimport { IconTabBarProcessTypeComponent } from './components/icon-tab-bar-process-type/icon-tab-bar-process-type.component';\nimport {\n    IconTabBarTabComponent,\n    IconTabBarTabContentDirective\n} from './components/icon-tab-bar-tab/icon-tab-bar-tab.component';\nimport { IconTabBarTextTypeComponent } from './components/icon-tab-bar-text-type/icon-tab-bar-text-type.component';\nimport { UNIQUE_KEY_SEPARATOR } from './constants';\nimport { IconTabBarItem } from './interfaces/icon-tab-bar-item.interface';\nimport { TabColorAssociations } from './interfaces/tab-color-associations.interface';\nimport { TabConfig } from './interfaces/tab-config.interface';\nimport { IconTabBarBackground, IconTabBarSize, TabDestinyMode, TabType } from './types';\n\n@Component({\n    selector: 'fdp-icon-tab-bar',\n    templateUrl: './icon-tab-bar.component.html',\n    styleUrl: './icon-tab-bar.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    providers: [\n        {\n            provide: FD_TABLIST,\n            useExisting: IconTabBarComponent\n        }\n    ],\n    imports: [\n        NgTemplateOutlet,\n        IconTabBarProcessTypeComponent,\n        IconTabBarFilterTypeComponent,\n        IconTabBarIconTypeComponent,\n        IconTabBarTextTypeComponent,\n        ScrollbarDirective,\n        ScrollSpyDirective,\n        IconTabBarTabContentDirective\n    ]\n})\nexport class IconTabBarComponent implements OnInit, TabList {\n    /**\n     * Whether to open tab content one under another without collapsing.\n     * Works only for content-projected tab content.\n     */\n    @Input({ transform: booleanAttribute })\n    stackContent = false;\n\n    /** @description Type of tab bar view. */\n    iconTabType = input<TabType>('text');\n\n    /**\n     * @description A tab bar configuration that stores the state of each tab. Based on this configuration, a tab bar is representing.\n     */\n    tabsConfig = model<TabConfig[]>();\n\n    /** @description Destiny mode. */\n    densityMode = model<TabDestinyMode>('inherit');\n\n    /** @description Icon font */\n    iconTabFont = input<IconFont>('SAP-icons');\n\n    /** @description Disable or enable reordering(drag and drop) feature. (supported by text type only) */\n    enableTabReordering = input(false);\n\n    /** @description Boolean flag indicating to show total tab.(supported by filter type only) */\n    showTotalTab = input(true);\n\n    /** Whether to render icon tab item as multi-click variant. */\n    multiClick = input(false);\n\n    /** @description Layout type for tab (supported by text type only) */\n    layoutMode = input<'row' | 'column'>('row');\n\n    /** @description Icon tab bar background type. */\n    iconTabBackground = input<IconTabBarBackground>('solid');\n\n    /** @description Icon tab bar size. */\n    iconTabSize = input<IconTabBarSize>();\n\n    /**\n     * @description Associations for colors of the tabs.\n     * If any of the color associations provided, they'll be read by screenreader instead of the actual color\n     */\n    colorAssociations = input<TabColorAssociations>();\n\n    /**\n     * Maximum height of the content.\n     * Works only for content-projected tab content.\n     */\n    maxContentHeight = input('100%');\n\n    /** @description Emits when some tab is selected. */\n    iconTabSelected = output<IconTabBarItem>();\n\n    /** @description Emits when user drop tab. */\n    iconTabReordered = output<IconTabBarItem[]>();\n\n    /** Event emitted when user clicks on x icon in tab. */\n    closeTab = output<IconTabBarItem>();\n\n    /** @hidden */\n    children = contentChildren(IconTabBarTabComponent, { descendants: false });\n\n    /** @hidden */\n    _scrollbar = viewChild(ScrollbarDirective);\n\n    /** @hidden */\n    tabDirectives = viewChildren(IconTabBarTabContentDirective);\n\n    @HostBinding('class.fd-tabs-custom')\n    private get _customTabs(): boolean {\n        return this._inDynamicPage;\n    }\n\n    /** @hidden */\n    get headerContainer(): Nullable<ElementRef> {\n        return this._iconTabBarCmp()?.headerElement;\n    }\n\n    /** @hidden */\n    _cssClassForContainer: string[];\n\n    /** @hidden */\n    _disableScrollSpy = false;\n\n    /** @hidden */\n    _init = true;\n\n    /** Scrollable element reference. */\n    get scrollableElement(): Nullable<ElementRef> {\n        return this._scrollbar()?.elementRef;\n    }\n\n    /** @hidden */\n    readonly _selectedUid = signal<string | undefined>(undefined);\n\n    /** @hidden */\n    readonly _tabs$ = computed(() => this._generateTabBarItems(this._tabsConfig$()));\n\n    /** @hidden */\n    readonly _flatTabs$ = computed(() => this._generateFlatTabs(this._tabs$()));\n\n    /** @hidden */\n    readonly _tabRenderer$ = signal<IconTabBarItem | null>(null);\n\n    /** @hidden */\n    readonly _rtl$ = computed(() => !!this._rtlService?.rtlSignal());\n\n    /** @hidden */\n    readonly _tabsConfig$ = computed(() => {\n        const tabConfig = this.tabsConfig();\n        if (tabConfig) {\n            return this.tabsConfig() as TabConfig[];\n        }\n\n        const children = this.children();\n        if (!children) {\n            return [];\n        }\n        return children.map((t) => this._generateTabConfig(t));\n    });\n\n    /** @hidden */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    private readonly _inDynamicPage = !!inject(FD_DYNAMIC_PAGE, { optional: true });\n\n    private readonly _iconTabBarCmp = viewChild<Nullable<IconTabBarBase>>(IconTabBarBase);\n\n    /** @hidden */\n    constructor(\n        private _cd: ChangeDetectorRef,\n        @Optional() private _contentDensityService: ContentDensityService,\n        @Optional() private _rtlService: RtlService\n    ) {}\n\n    /** @hidden */\n    ngOnInit(): void {\n        this._cssClassForContainer = this._generateContainerStyles();\n\n        if (this.densityMode() === 'inherit') {\n            this._contentDensityService?._contentDensityListener\n                .pipe(distinctUntilChanged(), takeUntilDestroyed(this._destroyRef))\n                .subscribe((density) => {\n                    this.densityMode.set(density);\n                    if (density !== 'compact') {\n                        this._cssClassForContainer = this._cssClassForContainer.filter(\n                            (cssClass) => cssClass !== 'fd-icon-tab-bar--compact'\n                        );\n                    } else {\n                        this._cssClassForContainer.push('fd-icon-tab-bar--compact');\n                    }\n                    this._cd.detectChanges();\n                });\n        }\n    }\n\n    /**\n     * @hidden\n     * @param event reordered array of IconTabBarItem\n     */\n    _onReorder(event: IconTabBarItem[]): void {\n        this.iconTabReordered.emit(event);\n    }\n\n    /**\n     * @hidden\n     * @param selectedItem\n     */\n    _selectItem(selectedItem: IconTabBarItem): void {\n        this._tabRenderer$.set(selectedItem);\n        this.iconTabSelected.emit(selectedItem);\n\n        if (this.stackContent) {\n            this._scrollToPanel(this.tabDirectives().find((tab) => tab.uId() === selectedItem.uId)!);\n        }\n    }\n\n    /** @hidden */\n    _closeTab(item: IconTabBarItem): void {\n        this.closeTab.emit(item);\n    }\n\n    /** Programmatically select tab. */\n    selectTab(id: Nullable<string>): void {\n        const selectedItem = this._flatTabs$().find((t) => t.id === id);\n        if (!selectedItem) {\n            return;\n        }\n        this._selectedUid.set(selectedItem.uId);\n        this._selectItem(selectedItem);\n    }\n\n    /** @hidden */\n    highlightActiveTab(id: Nullable<string>, scroll = false): void {\n        if (this._disableScrollSpy) {\n            return;\n        }\n        const activeTab = this.tabDirectives().find((tab) => tab.id() === id);\n        this._selectedUid.set(activeTab?.uId() || undefined);\n        if (scroll && activeTab) {\n            this._scrollToPanel(activeTab);\n        }\n    }\n\n    /**\n     * @hidden\n     * @returns array of css classes for icon-tab-bar container\n     */\n    private _generateContainerStyles(): string[] {\n        const styles = [`fd-icon-tab-bar--${this.iconTabType()}`];\n        const tabsConfig = this.tabsConfig();\n        if (tabsConfig && this.iconTabType() === 'process' && tabsConfig[0].icon) {\n            styles.push('fd-icon-tab-bar--icon');\n        }\n        if (this.iconTabBackground() !== 'solid') {\n            styles.push(`fd-icon-tab-bar--${this.iconTabBackground()}`);\n        }\n        if (this.iconTabSize()) {\n            styles.push(`fd-icon-tab-bar--${this.iconTabSize()!}`);\n        }\n        if (this.densityMode() === 'compact') {\n            styles.push('fd-icon-tab-bar--compact');\n        }\n        if (this.layoutMode() === 'column') {\n            styles.push('fd-icon-tab-bar--counters');\n        }\n        return styles;\n    }\n\n    private _generateTabConfig(tab: IconTabBarTabComponent): TabConfig {\n        const tabConfig: TabConfig = {\n            label: tab.label(),\n            color: tab.color(),\n            active: tab.active(),\n            counter: tab.counter(),\n            renderer: tab.renderer(),\n            id: tab.id(),\n            subItems: tab.children().map((c) => this._generateTabConfig(c))\n        };\n\n        return tabConfig;\n    }\n\n    /** @hidden */\n    private _scrollToPanel(tabPanel: Nullable<IconTabBarTabContentDirective>): void {\n        if (!tabPanel) {\n            return;\n        }\n        const scrollbar = this._scrollbar();\n        if (!scrollbar) {\n            return;\n        }\n        const panelElement = tabPanel.elementRef.nativeElement;\n        const containerElement = scrollbar.elementRef.nativeElement;\n        const distanceToScroll = panelElement.offsetTop - containerElement.offsetTop;\n        const maximumScrollTop = containerElement.scrollHeight - containerElement.clientHeight;\n        const currentScrollPosition = Math.ceil(containerElement.scrollTop);\n\n        if (!(currentScrollPosition === maximumScrollTop && distanceToScroll > maximumScrollTop)) {\n            this._disableScrollSpy = true;\n            fromEvent(containerElement, 'scroll')\n                .pipe(debounceTime(100), first(), takeUntilDestroyed(this._destroyRef))\n                .subscribe(() => (this._disableScrollSpy = false));\n            scrollTop(containerElement, distanceToScroll);\n        }\n    }\n\n    /**\n     * @hidden\n     * @description generate IconTabItems from TabConfig array\n     */\n    private _generateTabBarItems(\n        config: TabConfig[],\n        indexPrefix = '',\n        flatIndexRef?: FlatIndex,\n        parentUId?: string\n    ): IconTabBarItem[] {\n        flatIndexRef = flatIndexRef || { value: 0 };\n        return config.map((item, index) => {\n            const uId = `${indexPrefix}${index}`;\n            item.color = item.color || 'default';\n            const result: IconTabBarItem = {\n                ...item,\n                index,\n                cssClasses: item.color ? [`fd-icon-tab-bar__item--${item.color}`] : [],\n                uId,\n                hidden: false,\n                parentUId,\n                flatIndex: flatIndexRef!.value++,\n                subItems: this._generateTabBarItems(\n                    item.subItems || [],\n                    `${uId}${UNIQUE_KEY_SEPARATOR}`,\n                    flatIndexRef,\n                    uId\n                )\n            };\n            return result;\n        });\n    }\n\n    private _generateFlatTabs(tabs: IconTabBarItem[]): IconTabBarItem[] {\n        const flatTabs = tabs.reduce((acc: IconTabBarItem[], tab) => {\n            acc.push(tab);\n            if (tab.subItems) {\n                acc.push(...this._generateFlatTabs(tab.subItems));\n            }\n            return acc;\n        }, []);\n\n        return flatTabs;\n    }\n}\n\n/** @hidden helper object that is used in tab generation functions to calculate their indexes not depending on level of nesting */\ninterface FlatIndex {\n    value: number;\n}\n","<div class=\"fd-icon-tab-bar\" [class]=\"_cssClassForContainer\">\n    @if (iconTabType() === 'text') {\n        <ng-template [ngTemplateOutlet]=\"textType\"></ng-template>\n    }\n    @if (iconTabType() === 'icon' || iconTabType() === 'icon-only') {\n        <ng-template [ngTemplateOutlet]=\"iconType\"></ng-template>\n    }\n    @if (iconTabType() === 'filter') {\n        <ng-template [ngTemplateOutlet]=\"filterType\"></ng-template>\n    }\n    @if (iconTabType() === 'process') {\n        <ng-template [ngTemplateOutlet]=\"processType\"></ng-template>\n    }\n    <div\n        class=\"fd-icon-tab-bar__content\"\n        fd-scrollbar\n        (spyChange)=\"highlightActiveTab($event.id)\"\n        [scrollSpyDisabled]=\"!stackContent || _disableScrollSpy\"\n        fdScrollSpy\n        [trackedTags]=\"['fdp-icon-tab-bar-tab-content']\"\n        [style.max-height]=\"maxContentHeight()\"\n    >\n        @if (stackContent) {\n            @for (tab of _flatTabs$(); track tab) {\n                <fdp-icon-tab-bar-tab-content [id]=\"tab.id\" [uId]=\"tab.uId\" class=\"fd-icon-tab-bar__tab-content\">\n                    <ng-template [ngTemplateOutlet]=\"tab.renderer || null\"></ng-template>\n                </fdp-icon-tab-bar-tab-content>\n            }\n        } @else {\n            @if (_tabRenderer$(); as tabRenderer) {\n                <fdp-icon-tab-bar-tab-content\n                    [id]=\"tabRenderer.id\"\n                    [uId]=\"tabRenderer.uId\"\n                    class=\"fd-icon-tab-bar__tab-content\"\n                >\n                    <ng-template [ngTemplateOutlet]=\"tabRenderer.renderer || null\"></ng-template>\n                </fdp-icon-tab-bar-tab-content>\n            }\n        }\n        <ng-content select=\"[fdpIconTabBarFreeContent]\"></ng-content>\n    </div>\n</div>\n<ng-template #processType>\n    <fdp-icon-tab-bar-process-type\n        [tabs]=\"_tabs$()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n    ></fdp-icon-tab-bar-process-type>\n</ng-template>\n<ng-template #filterType>\n    <fdp-icon-tab-bar-filter-type\n        [tabs]=\"_tabs$()\"\n        [showTotalTab]=\"showTotalTab()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n    ></fdp-icon-tab-bar-filter-type>\n</ng-template>\n<ng-template #iconType>\n    <fdp-icon-tab-bar-icon-type\n        [showLabel]=\"iconTabType() === 'icon'\"\n        [tabs]=\"_tabs$()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (selected)=\"_selectItem($event)\"\n        (closeTab)=\"_closeTab($event)\"\n    ></fdp-icon-tab-bar-icon-type>\n</ng-template>\n<ng-template #textType>\n    <fdp-icon-tab-bar-text-type\n        [tabs]=\"_tabs$()\"\n        [multiClick]=\"multiClick()\"\n        [layoutMode]=\"layoutMode()\"\n        [isRtl]=\"_rtl$()\"\n        [selectedUid]=\"_selectedUid()\"\n        (selectedUidChange)=\"_selectedUid.set($event)\"\n        [densityMode]=\"densityMode()\"\n        [enableTabReordering]=\"enableTabReordering()\"\n        [colorAssociations]=\"colorAssociations()\"\n        (reordered)=\"_onReorder($event)\"\n        (selected)=\"_selectItem($event)\"\n        (closeTab)=\"_closeTab($event)\"\n    ></fdp-icon-tab-bar-text-type>\n</ng-template>\n"]}
@@ -1913,19 +1913,17 @@ class IconTabBarComponent {
1913
1913
  flatIndexRef = flatIndexRef || { value: 0 };
1914
1914
  return config.map((item, index) => {
1915
1915
  const uId = `${indexPrefix}${index}`;
1916
+ item.color = item.color || 'default';
1916
1917
  const result = {
1917
1918
  ...item,
1918
1919
  index,
1919
- cssClasses: [],
1920
+ cssClasses: item.color ? [`fd-icon-tab-bar__item--${item.color}`] : [],
1920
1921
  uId,
1921
1922
  hidden: false,
1922
1923
  parentUId,
1923
1924
  flatIndex: flatIndexRef.value++,
1924
1925
  subItems: this._generateTabBarItems(item.subItems || [], `${uId}${UNIQUE_KEY_SEPARATOR}`, flatIndexRef, uId)
1925
1926
  };
1926
- if (item.color) {
1927
- result.cssClasses = [`fd-icon-tab-bar__item--${item.color}`];
1928
- }
1929
1927
  return result;
1930
1928
  });
1931
1929
  }