@blueprintjs/core
Version:
Core styles & components
61 lines (60 loc) • 2.04 kB
TypeScript
import * as React from "react";
import { IconName } from "@blueprintjs/icons";
import { AbstractPureComponent } from "../../common";
import { HTMLDivProps, MaybeElement, Props } from "../../common/props";
import { TagProps } from "../tag/tag";
export type TabId = string | number;
export interface TabProps extends Props, Omit<HTMLDivProps, "id" | "title" | "onClick"> {
/**
* Content of tab title, rendered in a list above the active panel.
* Can also be set via the `title` prop.
*/
children?: React.ReactNode;
/**
* Whether the tab is disabled.
*
* @default false
*/
disabled?: boolean;
/**
* Unique identifier used to control which tab is selected
* and to generate ARIA attributes for accessibility.
*/
id: TabId;
/**
* Panel content, rendered by the parent `Tabs` when this tab is active.
* If omitted, no panel will be rendered for this tab.
*/
panel?: JSX.Element;
/**
* Space-delimited string of class names applied to tab panel container.
*/
panelClassName?: string;
/**
* Content of tab title element, rendered in a list above the active panel.
* Can also be set via React `children`.
*/
title?: React.ReactNode;
/** Name of a Blueprint UI icon (or an icon element) to render before the children. */
icon?: IconName | MaybeElement;
/**
* Content to render inside a `<Tag>` after the children.
* The tag is `minimal` by default; it can be further modified by using `tagProps`.
*/
tagContent?: TagProps["children"];
/**
* Props to customize the `<Tag>` rendered after the children.
* This has no effect if `tagContent` is `undefined`.
*/
tagProps?: Omit<TagProps, "children">;
}
/**
* Tab component.
*
* @see https://blueprintjs.com/docs/#core/components/tabs.tab
*/
export declare class Tab extends AbstractPureComponent<TabProps> {
static defaultProps: Partial<TabProps>;
static displayName: string;
render(): JSX.Element;
}