UNPKG

@vaadin/tabsheet

Version:
102 lines (92 loc) 3.35 kB
/** * @license * Copyright (c) 2022 - 2026 Vaadin Ltd. * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/ */ import { ElementMixin } from '@vaadin/component-base/src/element-mixin.js'; import type { Tab } from '@vaadin/tabs/src/vaadin-tab.js'; import { ThemableMixin } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js'; import { TabSheetMixin } from './vaadin-tabsheet-mixin.js'; /** * Fired when the `items` property changes. */ export type TabSheetItemsChangedEvent = CustomEvent<{ value: Tab[] }>; /** * Fired when the `selected` property changes. */ export type TabSheetSelectedChangedEvent = CustomEvent<{ value: number }>; export interface TabSheetCustomEventMap { 'items-changed': TabSheetItemsChangedEvent; 'selected-changed': TabSheetSelectedChangedEvent; } export interface TabSheetEventMap extends HTMLElementEventMap, TabSheetCustomEventMap {} /** * `<vaadin-tabsheet>` is a Web Component for organizing and grouping content * into scrollable panels. The panels can be switched between by using tabs. * * ```html * <vaadin-tabsheet> * <div slot="prefix">Prefix</div> * <div slot="suffix">Suffix</div> * * <vaadin-tabs slot="tabs"> * <vaadin-tab id="tab-1">Tab 1</vaadin-tab> * <vaadin-tab id="tab-2">Tab 2</vaadin-tab> * <vaadin-tab id="tab-3">Tab 3</vaadin-tab> * </vaadin-tabs> * * <div tab="tab-1">Panel 1</div> * <div tab="tab-2">Panel 2</div> * <div tab="tab-3">Panel 3</div> * </vaadin-tabsheet> * ``` * * ### Styling * * The following shadow DOM parts are exposed for styling: * * Part name | Description * --------- | --------------- * `tabs-container` | The container for the slotted prefix, tabs and suffix * `content` | The container for the slotted panels * * The following state attributes are available for styling: * * Attribute | Description * ------------------|------------- * `loading` | Set when a tab without associated content is selected * `overflow` | Set to `top`, `bottom`, `start`, `end`, all of them, or none. * * The following custom CSS properties are available for styling: * * Custom CSS property | * :------------------------------------| * | `--vaadin-tabsheet-border-color` | * | `--vaadin-tabsheet-border-radius` | * | `--vaadin-tabsheet-border-width` | * | `--vaadin-tabsheet-gap` | * | `--vaadin-tabsheet-padding` | * * See [Styling Components](https://vaadin.com/docs/latest/styling/styling-components) documentation. * * @fires {CustomEvent} items-changed - Fired when the `items` property changes. * @fires {CustomEvent} selected-changed - Fired when the `selected` property changes. */ declare class TabSheet extends ThemableMixin(TabSheetMixin<Tab>(ElementMixin(HTMLElement))) { addEventListener<K extends keyof TabSheetEventMap>( type: K, listener: (this: TabSheet, ev: TabSheetEventMap[K]) => void, options?: AddEventListenerOptions | boolean, ): void; removeEventListener<K extends keyof TabSheetEventMap>( type: K, listener: (this: TabSheet, ev: TabSheetEventMap[K]) => void, options?: EventListenerOptions | boolean, ): void; } declare global { interface HTMLElementTagNameMap { 'vaadin-tabsheet': TabSheet; } } export { TabSheet };