carbon-components-angular
Version:
Next generation components
322 lines • 25.9 kB
JavaScript
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"]}