UNPKG

@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
/** * @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 };