UNPKG

@scoped-vaadin/grid

Version:

A free, flexible and high-quality Web Component for showing large amounts of tabular data

82 lines (76 loc) 2.8 kB
/** * @license * Copyright (c) 2016 - 2024 Vaadin Ltd. * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/ */ import { DirMixin } from '@scoped-vaadin/component-base/src/dir-mixin.js'; import { ThemableMixin } from '@scoped-vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js'; import type { GridTreeToggleEventMap } from './vaadin-grid-tree-toggle-mixin.js'; import { GridTreeToggleMixin } from './vaadin-grid-tree-toggle-mixin.js'; export * from './vaadin-grid-tree-toggle-mixin.js'; /** * `<vaadin24-grid-tree-toggle>` is a helper element for the `<vaadin24-grid>` * that provides toggle and level display functionality for the item tree. * * #### Example: * ```html * <vaadin24-grid-column id="column"></vaadin24-grid-column> * ``` * ```js * const column = document.querySelector('#column'); * column.renderer = (root, column, model) => { * let treeToggle = root.firstElementChild; * if (!treeToggle) { * treeToggle = document.createElement('vaadin24-grid-tree-toggle'); * treeToggle.addEventListener('expanded-changed', () => { ... }); * root.appendChild(treeToggle); * } * treeToggle.leaf = !model.item.hasChildren; * treeToggle.level = level; * treeToggle.expanded = expanded; * treeToggle.textContent = model.item.name; * }; * ``` * * ### Styling * * The following shadow DOM parts are available for styling: * * Part name | Description * ---|--- * `toggle` | The tree toggle icon * * The following state attributes are available for styling: * * Attribute | Description | Part name * ---|---|--- * `expanded` | When present, the toggle is expanded | :host * `leaf` | When present, the toggle is not expandable, i. e., the current item is a leaf | :host * * The following custom CSS properties are available on * the `<vaadin24-grid-tree-toggle>` element: * * Custom CSS property | Description | Default * ---|---|--- * `--vaadin-grid-tree-toggle-level-offset` | Visual offset step for each tree sublevel | `1em` * * @fires {CustomEvent} expanded-changed - Fired when the `expanded` property changes. */ declare class GridTreeToggle extends GridTreeToggleMixin(ThemableMixin(DirMixin(HTMLElement))) { addEventListener<K extends keyof GridTreeToggleEventMap>( type: K, listener: (this: GridTreeToggle, ev: GridTreeToggleEventMap[K]) => void, options?: AddEventListenerOptions | boolean, ): void; removeEventListener<K extends keyof GridTreeToggleEventMap>( type: K, listener: (this: GridTreeToggle, ev: GridTreeToggleEventMap[K]) => void, options?: EventListenerOptions | boolean, ): void; } declare global { interface HTMLElementTagNameMap { 'vaadin24-grid-tree-toggle': GridTreeToggle; } } export { GridTreeToggle };