@scoped-vaadin/grid
Version:
A free, flexible and high-quality Web Component for showing large amounts of tabular data
58 lines (51 loc) • 1.78 kB
TypeScript
/**
* @license
* Copyright (c) 2016 - 2024 Vaadin Ltd.
* This program is available under Apache License Version 2.0, available at https://vaadin.com/license/
*/
import { ThemableMixin } from '@scoped-vaadin/vaadin-themable-mixin';
import { GridFilterElementMixin, type GridFilterEventMap } from './vaadin-grid-filter-element-mixin.js';
export * from './vaadin-grid-filter-element-mixin.js';
/**
* `<vaadin24-grid-filter>` is a helper element for the `<vaadin24-grid>` that provides out-of-the-box UI controls,
* and handlers for filtering the grid data.
*
* #### Example:
* ```html
* <vaadin24-grid-column id="column"></vaadin24-grid-column>
* ```
* ```js
* const column = document.querySelector('#column');
* column.headerRenderer = (root, column) => {
* let filter = root.firstElementChild;
* if (!filter) {
* filter = document.createElement('vaadin24-grid-filter');
* root.appendChild(filter);
* }
* filter.path = 'name.first';
* };
* column.renderer = (root, column, model) => {
* root.textContent = model.item.name.first;
* };
* ```
*
* @fires {CustomEvent} value-changed - Fired when the `value` property changes.
*/
declare class GridFilter extends GridFilterElementMixin(ThemableMixin(HTMLElement)) {
addEventListener<K extends keyof GridFilterEventMap>(
type: K,
listener: (this: GridFilter, ev: GridFilterEventMap[K]) => void,
options?: AddEventListenerOptions | boolean,
): void;
removeEventListener<K extends keyof GridFilterEventMap>(
type: K,
listener: (this: GridFilter, ev: GridFilterEventMap[K]) => void,
options?: EventListenerOptions | boolean,
): void;
}
declare global {
interface HTMLElementTagNameMap {
'vaadin24-grid-filter': GridFilter;
}
}
export { GridFilter };