UNPKG

carbon-components-angular

Version:
322 lines 25.9 kB
import { Component, forwardRef, HostBinding, Input, ViewChild } from "@angular/core"; import { TabHeaderBase } from "./tab-header.directive"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "carbon-components-angular/tooltip"; /** * Tab header with template for label, optional icon, secondary label, badge, and dismissable close. * * ```html * <cds-tab-header-group> * <cds-tab-header [paneReference]="c1">Dashboard</cds-tab-header> * <cds-tab-header [paneReference]="c2" [icon]="iconTpl" secondaryLabel="(1/4)"> * Monitoring * </cds-tab-header> * </cds-tab-header-group> * <cds-tab #c1>...</cds-tab> * <cds-tab #c2>...</cds-tab> * ``` */ export class TabHeaderComponent extends TabHeaderBase { constructor() { super(...arguments); /** * Icon-only tab: set `icon` and `iconLabel`. */ this.iconOnly = false; /** * **Preview**: Icon-only tabs — show a notification dot on the icon. */ this.badgeIndicator = false; /** * Icon-only tabs: icon size `default` (16px) or `lg` (20px); usually set on the parent group. */ this.iconSize = "default"; /** * `aria-label` for the dismissable close button. */ this.closeButtonAriaLabel = "Press delete to remove tab"; /** * Icon-only tabs: open the tooltip on first render. */ this.isTooltipOpen = false; this.displayContents = "contents"; } ngAfterViewInit() { // Mirror the deprecated directive's title-fallback behavior, but read // from the inner rendered button rather than the `display: contents` host. setTimeout(() => { if (!this.title && this.tabButton?.nativeElement) { const text = this.tabButton.nativeElement.textContent?.trim(); if (text) { this.title = text; } } }); } /** * Focus the rendered tab button (not the host). */ focus() { this.tabButton?.nativeElement?.focus(); } onTabButtonClick() { this.selectTab(); } /** * `Delete` closes dismissable tabs when focus is on the tab. */ onTabButtonKeyDown(event) { if (this.dismissable && event.key === "Delete") { event.stopPropagation(); this.tabClose.emit(); } } /** * Close button click; stops propagation so the tab does not activate. */ onClose(event) { event.stopPropagation(); if (this.disabled) { return; } this.tabClose.emit(); } get resolvedTitle() { if (this.iconOnly) { return this.iconLabel || null; } return this.title || null; } get closeButtonTitle() { const label = this.tabButton?.nativeElement?.textContent?.trim(); return label ? `Remove ${label} tab` : "Remove tab"; } } TabHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TabHeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); TabHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TabHeaderComponent, selector: "cds-tab-header, ibm-tab-header", inputs: { iconOnly: "iconOnly", iconLabel: "iconLabel", badgeIndicator: "badgeIndicator", iconSize: "iconSize", closeButtonAriaLabel: "closeButtonAriaLabel", enterDelayMs: "enterDelayMs", leaveDelayMs: "leaveDelayMs", isTooltipOpen: "isTooltipOpen" }, host: { properties: { "style.display": "this.displayContents" } }, providers: [ // tslint:disable-next-line:no-forward-ref { provide: TabHeaderBase, useExisting: forwardRef(() => TabHeaderComponent) } ], viewQueries: [{ propertyName: "tabButton", first: true, predicate: ["tabButton"], descendants: true }], usesInheritance: true, ngImport: i0, template: ` <cds-tooltip *ngIf="iconOnly; else plainButton" align="bottom" [autoAlign]="true" class="cds--icon-tooltip" [description]="iconLabel" [enterDelayMs]="enterDelayMs" [leaveDelayMs]="leaveDelayMs" [isOpen]="isTooltipOpen" [disabled]="disabled"> <ng-container *ngTemplateOutlet="tabButtonTemplate"></ng-container> </cds-tooltip> <ng-template #plainButton> <ng-container *ngTemplateOutlet="tabButtonTemplate"></ng-container> </ng-template> <ng-template #tabButtonTemplate> <button #tabButton type="button" role="tab" class="cds--tabs__nav-item cds--tabs__nav-link" [ngClass]="{ 'cds--tabs__nav-item--selected': active, 'cds--tabs__nav-item--disabled': disabled, 'cds--tabs__nav-item--icon-only': iconOnly, 'cds--tabs__nav-item--icon-only__20': iconOnly && iconSize === 'lg' }" [attr.aria-selected]="active" [attr.aria-disabled]="disabled" [attr.aria-controls]="paneReference?.id || null" [attr.aria-label]="iconOnly ? iconLabel : null" [attr.tabindex]="active ? 0 : -1" [attr.title]="resolvedTitle" [disabled]="disabled" (click)="onTabButtonClick()" (keydown)="onTabButtonKeyDown($event)"> <ng-container *ngIf="iconOnly; else labeledTab"> <ng-container [ngTemplateOutlet]="icon"></ng-container> <span *ngIf="!disabled && badgeIndicator" class="cds--badge-indicator" aria-hidden="true"> </span> </ng-container> <ng-template #labeledTab> <div class="cds--tabs__nav-item-label-wrapper"> <div *ngIf="dismissable && icon" class="cds--tabs__nav-item--icon-left"> <ng-container [ngTemplateOutlet]="icon"></ng-container> </div> <span class="cds--tabs__nav-item-label"> <ng-content></ng-content> </span> <div *ngIf="!dismissable && icon" class="cds--tabs__nav-item--icon"> <ng-container [ngTemplateOutlet]="icon"></ng-container> </div> </div> <div *ngIf="secondaryLabel" class="cds--tabs__nav-item-secondary-label" [attr.title]="secondaryLabel"> {{ secondaryLabel }} </div> </ng-template> </button> </ng-template> <div *ngIf="dismissable" class="cds--tabs__nav-item--close"> <button type="button" class="cds--tabs__nav-item--close-icon" [attr.tabindex]="-1" [attr.aria-disabled]="disabled" [attr.aria-hidden]="!(active && !disabled)" [ngClass]="{ 'cds--tabs__nav-item--close-icon--selected': active, 'cds--tabs__nav-item--close-icon--disabled': disabled }" [disabled]="disabled" [attr.title]="closeButtonTitle" (click)="onClose($event)"> <svg focusable="false" preserveAspectRatio="xMidYMid meet" xmlns="http://www.w3.org/2000/svg" fill="currentColor" width="16" height="16" viewBox="0 0 32 32" [attr.aria-label]="closeButtonAriaLabel" [attr.aria-hidden]="!(active && !disabled)"> <path d="M17.4141 16L24 9.4141 22.5859 8 16 14.5859 9.4143 8 8 9.4141 14.5859 16 8 22.5859 9.4143 24 16 17.4141 22.5859 24 24 22.5859 17.4141 16z"></path> </svg> </button> </div> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.Tooltip, selector: "cds-tooltip, ibm-tooltip", inputs: ["id", "enterDelayMs", "leaveDelayMs", "disabled", "description", "templateContext"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TabHeaderComponent, decorators: [{ type: Component, args: [{ selector: "cds-tab-header, ibm-tab-header", providers: [ // tslint:disable-next-line:no-forward-ref { provide: TabHeaderBase, useExisting: forwardRef(() => TabHeaderComponent) } ], template: ` <cds-tooltip *ngIf="iconOnly; else plainButton" align="bottom" [autoAlign]="true" class="cds--icon-tooltip" [description]="iconLabel" [enterDelayMs]="enterDelayMs" [leaveDelayMs]="leaveDelayMs" [isOpen]="isTooltipOpen" [disabled]="disabled"> <ng-container *ngTemplateOutlet="tabButtonTemplate"></ng-container> </cds-tooltip> <ng-template #plainButton> <ng-container *ngTemplateOutlet="tabButtonTemplate"></ng-container> </ng-template> <ng-template #tabButtonTemplate> <button #tabButton type="button" role="tab" class="cds--tabs__nav-item cds--tabs__nav-link" [ngClass]="{ 'cds--tabs__nav-item--selected': active, 'cds--tabs__nav-item--disabled': disabled, 'cds--tabs__nav-item--icon-only': iconOnly, 'cds--tabs__nav-item--icon-only__20': iconOnly && iconSize === 'lg' }" [attr.aria-selected]="active" [attr.aria-disabled]="disabled" [attr.aria-controls]="paneReference?.id || null" [attr.aria-label]="iconOnly ? iconLabel : null" [attr.tabindex]="active ? 0 : -1" [attr.title]="resolvedTitle" [disabled]="disabled" (click)="onTabButtonClick()" (keydown)="onTabButtonKeyDown($event)"> <ng-container *ngIf="iconOnly; else labeledTab"> <ng-container [ngTemplateOutlet]="icon"></ng-container> <span *ngIf="!disabled && badgeIndicator" class="cds--badge-indicator" aria-hidden="true"> </span> </ng-container> <ng-template #labeledTab> <div class="cds--tabs__nav-item-label-wrapper"> <div *ngIf="dismissable && icon" class="cds--tabs__nav-item--icon-left"> <ng-container [ngTemplateOutlet]="icon"></ng-container> </div> <span class="cds--tabs__nav-item-label"> <ng-content></ng-content> </span> <div *ngIf="!dismissable && icon" class="cds--tabs__nav-item--icon"> <ng-container [ngTemplateOutlet]="icon"></ng-container> </div> </div> <div *ngIf="secondaryLabel" class="cds--tabs__nav-item-secondary-label" [attr.title]="secondaryLabel"> {{ secondaryLabel }} </div> </ng-template> </button> </ng-template> <div *ngIf="dismissable" class="cds--tabs__nav-item--close"> <button type="button" class="cds--tabs__nav-item--close-icon" [attr.tabindex]="-1" [attr.aria-disabled]="disabled" [attr.aria-hidden]="!(active && !disabled)" [ngClass]="{ 'cds--tabs__nav-item--close-icon--selected': active, 'cds--tabs__nav-item--close-icon--disabled': disabled }" [disabled]="disabled" [attr.title]="closeButtonTitle" (click)="onClose($event)"> <svg focusable="false" preserveAspectRatio="xMidYMid meet" xmlns="http://www.w3.org/2000/svg" fill="currentColor" width="16" height="16" viewBox="0 0 32 32" [attr.aria-label]="closeButtonAriaLabel" [attr.aria-hidden]="!(active && !disabled)"> <path d="M17.4141 16L24 9.4141 22.5859 8 16 14.5859 9.4143 8 8 9.4141 14.5859 16 8 22.5859 9.4143 24 16 17.4141 22.5859 24 24 22.5859 17.4141 16z"></path> </svg> </button> </div> ` }] }], propDecorators: { iconOnly: [{ type: Input }], iconLabel: [{ type: Input }], badgeIndicator: [{ type: Input }], iconSize: [{ type: Input }], closeButtonAriaLabel: [{ type: Input }], enterDelayMs: [{ type: Input }], leaveDelayMs: [{ type: Input }], isTooltipOpen: [{ type: Input }], displayContents: [{ type: HostBinding, args: ["style.display"] }], tabButton: [{ type: ViewChild, args: ["tabButton"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-header.component.js","sourceRoot":"","sources":["../../../src/tabs/tab-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tAfterViewInit,\r\n\tComponent,\r\n\tElementRef,\r\n\tforwardRef,\r\n\tHostBinding,\r\n\tInput,\r\n\tViewChild\r\n} from \"@angular/core\";\r\n\r\nimport { TabHeaderBase } from \"./tab-header.directive\";\r\n\r\n/**\r\n * Tab header with template for label, optional icon, secondary label, badge, and dismissable close.\r\n *\r\n * ```html\r\n * <cds-tab-header-group>\r\n *   <cds-tab-header [paneReference]=\"c1\">Dashboard</cds-tab-header>\r\n *   <cds-tab-header [paneReference]=\"c2\" [icon]=\"iconTpl\" secondaryLabel=\"(1/4)\">\r\n *     Monitoring\r\n *   </cds-tab-header>\r\n * </cds-tab-header-group>\r\n * <cds-tab #c1>...</cds-tab>\r\n * <cds-tab #c2>...</cds-tab>\r\n * ```\r\n */\r\n@Component({\r\n\tselector: \"cds-tab-header, ibm-tab-header\",\r\n\tproviders: [\r\n\t\t// tslint:disable-next-line:no-forward-ref\r\n\t\t{ provide: TabHeaderBase, useExisting: forwardRef(() => TabHeaderComponent) }\r\n\t],\r\n\ttemplate: `\r\n\t\t<cds-tooltip\r\n\t\t\t*ngIf=\"iconOnly; else plainButton\"\r\n\t\t\talign=\"bottom\"\r\n\t\t\t[autoAlign]=\"true\"\r\n\t\t\tclass=\"cds--icon-tooltip\"\r\n\t\t\t[description]=\"iconLabel\"\r\n\t\t\t[enterDelayMs]=\"enterDelayMs\"\r\n\t\t\t[leaveDelayMs]=\"leaveDelayMs\"\r\n\t\t\t[isOpen]=\"isTooltipOpen\"\r\n\t\t\t[disabled]=\"disabled\">\r\n\t\t\t<ng-container *ngTemplateOutlet=\"tabButtonTemplate\"></ng-container>\r\n\t\t</cds-tooltip>\r\n\t\t<ng-template #plainButton>\r\n\t\t\t<ng-container *ngTemplateOutlet=\"tabButtonTemplate\"></ng-container>\r\n\t\t</ng-template>\r\n\t\t<ng-template #tabButtonTemplate>\r\n\t\t\t<button\r\n\t\t\t\t#tabButton\r\n\t\t\t\ttype=\"button\"\r\n\t\t\t\trole=\"tab\"\r\n\t\t\t\tclass=\"cds--tabs__nav-item cds--tabs__nav-link\"\r\n\t\t\t\t[ngClass]=\"{\r\n\t\t\t\t\t'cds--tabs__nav-item--selected': active,\r\n\t\t\t\t\t'cds--tabs__nav-item--disabled': disabled,\r\n\t\t\t\t\t'cds--tabs__nav-item--icon-only': iconOnly,\r\n\t\t\t\t\t'cds--tabs__nav-item--icon-only__20': iconOnly && iconSize === 'lg'\r\n\t\t\t\t}\"\r\n\t\t\t\t[attr.aria-selected]=\"active\"\r\n\t\t\t\t[attr.aria-disabled]=\"disabled\"\r\n\t\t\t\t[attr.aria-controls]=\"paneReference?.id || null\"\r\n\t\t\t\t[attr.aria-label]=\"iconOnly ? iconLabel : null\"\r\n\t\t\t\t[attr.tabindex]=\"active ? 0 : -1\"\r\n\t\t\t\t[attr.title]=\"resolvedTitle\"\r\n\t\t\t\t[disabled]=\"disabled\"\r\n\t\t\t\t(click)=\"onTabButtonClick()\"\r\n\t\t\t\t(keydown)=\"onTabButtonKeyDown($event)\">\r\n\t\t\t\t<ng-container *ngIf=\"iconOnly; else labeledTab\">\r\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"icon\"></ng-container>\r\n\t\t\t\t\t<span\r\n\t\t\t\t\t\t*ngIf=\"!disabled && badgeIndicator\"\r\n\t\t\t\t\t\tclass=\"cds--badge-indicator\"\r\n\t\t\t\t\t\taria-hidden=\"true\">\r\n\t\t\t\t\t</span>\r\n\t\t\t\t</ng-container>\r\n\t\t\t\t<ng-template #labeledTab>\r\n\t\t\t\t\t<div class=\"cds--tabs__nav-item-label-wrapper\">\r\n\t\t\t\t\t\t<div *ngIf=\"dismissable && icon\" class=\"cds--tabs__nav-item--icon-left\">\r\n\t\t\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"icon\"></ng-container>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<span class=\"cds--tabs__nav-item-label\">\r\n\t\t\t\t\t\t\t<ng-content></ng-content>\r\n\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t<div *ngIf=\"!dismissable && icon\" class=\"cds--tabs__nav-item--icon\">\r\n\t\t\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"icon\"></ng-container>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\t*ngIf=\"secondaryLabel\"\r\n\t\t\t\t\t\tclass=\"cds--tabs__nav-item-secondary-label\"\r\n\t\t\t\t\t\t[attr.title]=\"secondaryLabel\">\r\n\t\t\t\t\t\t{{ secondaryLabel }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</button>\r\n\t\t</ng-template>\r\n\t\t<div *ngIf=\"dismissable\" class=\"cds--tabs__nav-item--close\">\r\n\t\t\t<button\r\n\t\t\t\ttype=\"button\"\r\n\t\t\t\tclass=\"cds--tabs__nav-item--close-icon\"\r\n\t\t\t\t[attr.tabindex]=\"-1\"\r\n\t\t\t\t[attr.aria-disabled]=\"disabled\"\r\n\t\t\t\t[attr.aria-hidden]=\"!(active && !disabled)\"\r\n\t\t\t\t[ngClass]=\"{\r\n\t\t\t\t\t'cds--tabs__nav-item--close-icon--selected': active,\r\n\t\t\t\t\t'cds--tabs__nav-item--close-icon--disabled': disabled\r\n\t\t\t\t}\"\r\n\t\t\t\t[disabled]=\"disabled\"\r\n\t\t\t\t[attr.title]=\"closeButtonTitle\"\r\n\t\t\t\t(click)=\"onClose($event)\">\r\n\t\t\t\t<svg\r\n\t\t\t\t\tfocusable=\"false\"\r\n\t\t\t\t\tpreserveAspectRatio=\"xMidYMid meet\"\r\n\t\t\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\t\t\tfill=\"currentColor\"\r\n\t\t\t\t\twidth=\"16\"\r\n\t\t\t\t\theight=\"16\"\r\n\t\t\t\t\tviewBox=\"0 0 32 32\"\r\n\t\t\t\t\t[attr.aria-label]=\"closeButtonAriaLabel\"\r\n\t\t\t\t\t[attr.aria-hidden]=\"!(active && !disabled)\">\r\n\t\t\t\t\t<path d=\"M17.4141 16L24 9.4141 22.5859 8 16 14.5859 9.4143 8 8 9.4141 14.5859 16 8 22.5859 9.4143 24 16 17.4141 22.5859 24 24 22.5859 17.4141 16z\"></path>\r\n\t\t\t\t</svg>\r\n\t\t\t</button>\r\n\t\t</div>\r\n\t`\r\n})\r\nexport class TabHeaderComponent extends TabHeaderBase implements AfterViewInit {\r\n\t/**\r\n\t * Icon-only tab: set `icon` and `iconLabel`.\r\n\t */\r\n\t@Input() iconOnly = false;\r\n\t/**\r\n\t * Icon-only tabs: accessible name (`aria-label` / `title`).\r\n\t */\r\n\t@Input() iconLabel: string;\r\n\t/**\r\n\t * **Preview**: Icon-only tabs — show a notification dot on the icon.\r\n\t */\r\n\t@Input() badgeIndicator = false;\r\n\t/**\r\n\t * Icon-only tabs: icon size `default` (16px) or `lg` (20px); usually set on the parent group.\r\n\t */\r\n\t@Input() iconSize: \"default\" | \"lg\" = \"default\";\r\n\t/**\r\n\t * `aria-label` for the dismissable close button.\r\n\t */\r\n\t@Input() closeButtonAriaLabel = \"Press delete to remove tab\";\r\n\t/**\r\n\t * Icon-only tabs: tooltip show delay (ms).\r\n\t */\r\n\t@Input() enterDelayMs: number;\r\n\t/**\r\n\t * Icon-only tabs: tooltip hide delay (ms).\r\n\t */\r\n\t@Input() leaveDelayMs: number;\r\n\t/**\r\n\t * Icon-only tabs: open the tooltip on first render.\r\n\t */\r\n\t@Input() isTooltipOpen = false;\r\n\r\n\t@HostBinding(\"style.display\") displayContents = \"contents\";\r\n\r\n\t@ViewChild(\"tabButton\") tabButton: ElementRef<HTMLButtonElement>;\r\n\r\n\tngAfterViewInit() {\r\n\t\t// Mirror the deprecated directive's title-fallback behavior, but read\r\n\t\t// from the inner rendered button rather than the `display: contents` host.\r\n\t\tsetTimeout(() => {\r\n\t\t\tif (!this.title && this.tabButton?.nativeElement) {\r\n\t\t\t\tconst text = this.tabButton.nativeElement.textContent?.trim();\r\n\t\t\t\tif (text) {\r\n\t\t\t\t\tthis.title = text;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Focus the rendered tab button (not the host).\r\n\t */\r\n\tfocus() {\r\n\t\tthis.tabButton?.nativeElement?.focus();\r\n\t}\r\n\r\n\tonTabButtonClick() {\r\n\t\tthis.selectTab();\r\n\t}\r\n\r\n\t/**\r\n\t * `Delete` closes dismissable tabs when focus is on the tab.\r\n\t */\r\n\tonTabButtonKeyDown(event: KeyboardEvent) {\r\n\t\tif (this.dismissable && event.key === \"Delete\") {\r\n\t\t\tevent.stopPropagation();\r\n\t\t\tthis.tabClose.emit();\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Close button click; stops propagation so the tab does not activate.\r\n\t */\r\n\tonClose(event: Event) {\r\n\t\tevent.stopPropagation();\r\n\t\tif (this.disabled) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.tabClose.emit();\r\n\t}\r\n\r\n\tget resolvedTitle(): string | null {\r\n\t\tif (this.iconOnly) {\r\n\t\t\treturn this.iconLabel || null;\r\n\t\t}\r\n\t\treturn this.title || null;\r\n\t}\r\n\r\n\tget closeButtonTitle(): string {\r\n\t\tconst label = this.tabButton?.nativeElement?.textContent?.trim();\r\n\t\treturn label ? `Remove ${label} tab` : \"Remove tab\";\r\n\t}\r\n}\r\n"]}