@fundamental-ngx/platform 0.53.1-rc.21 → 0.53.1-rc.23
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.
|
@@ -242,22 +242,17 @@ export class IconTabBarComponent {
|
|
|
242
242
|
flatIndexRef = flatIndexRef || { value: 0 };
|
|
243
243
|
return config.map((item, index) => {
|
|
244
244
|
const uId = `${indexPrefix}${index}`;
|
|
245
|
-
|
|
246
|
-
item.color = 'default';
|
|
247
|
-
}
|
|
245
|
+
item.color = item.color || 'default';
|
|
248
246
|
const result = {
|
|
249
247
|
...item,
|
|
250
248
|
index,
|
|
251
|
-
cssClasses: [],
|
|
249
|
+
cssClasses: item.color ? [`fd-icon-tab-bar__item--${item.color}`] : [],
|
|
252
250
|
uId,
|
|
253
251
|
hidden: false,
|
|
254
252
|
parentUId,
|
|
255
253
|
flatIndex: flatIndexRef.value++,
|
|
256
254
|
subItems: this._generateTabBarItems(item.subItems || [], `${uId}${UNIQUE_KEY_SEPARATOR}`, flatIndexRef, uId)
|
|
257
255
|
};
|
|
258
|
-
if (item.color) {
|
|
259
|
-
result.cssClasses = [`fd-icon-tab-bar__item--${item.color}`];
|
|
260
|
-
}
|
|
261
256
|
return result;
|
|
262
257
|
});
|
|
263
258
|
}
|
|
@@ -307,4 +302,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
307
302
|
type: HostBinding,
|
|
308
303
|
args: ['class.fd-tabs-custom']
|
|
309
304
|
}] } });
|
|
310
|
-
//# 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            badge: tab.badge(),\n            counter: tab.counter(),\n            renderer: tab.renderer(),\n            id: tab.id(),\n            titleTemplate: tab.titleTemplate(),\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            if (!('color' in item)) {\n                item.color = 'default';\n            }\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"]}
|
|
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            badge: tab.badge(),\n            counter: tab.counter(),\n            renderer: tab.renderer(),\n            id: tab.id(),\n            titleTemplate: tab.titleTemplate(),\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"]}
|
|
@@ -1933,22 +1933,17 @@ class IconTabBarComponent {
|
|
|
1933
1933
|
flatIndexRef = flatIndexRef || { value: 0 };
|
|
1934
1934
|
return config.map((item, index) => {
|
|
1935
1935
|
const uId = `${indexPrefix}${index}`;
|
|
1936
|
-
|
|
1937
|
-
item.color = 'default';
|
|
1938
|
-
}
|
|
1936
|
+
item.color = item.color || 'default';
|
|
1939
1937
|
const result = {
|
|
1940
1938
|
...item,
|
|
1941
1939
|
index,
|
|
1942
|
-
cssClasses: [],
|
|
1940
|
+
cssClasses: item.color ? [`fd-icon-tab-bar__item--${item.color}`] : [],
|
|
1943
1941
|
uId,
|
|
1944
1942
|
hidden: false,
|
|
1945
1943
|
parentUId,
|
|
1946
1944
|
flatIndex: flatIndexRef.value++,
|
|
1947
1945
|
subItems: this._generateTabBarItems(item.subItems || [], `${uId}${UNIQUE_KEY_SEPARATOR}`, flatIndexRef, uId)
|
|
1948
1946
|
};
|
|
1949
|
-
if (item.color) {
|
|
1950
|
-
result.cssClasses = [`fd-icon-tab-bar__item--${item.color}`];
|
|
1951
|
-
}
|
|
1952
1947
|
return result;
|
|
1953
1948
|
});
|
|
1954
1949
|
}
|