UNPKG

@vaadin/combo-box

Version:

Web Component for displaying a list of items with filtering

66 lines (61 loc) 2.11 kB
/** * @license * Copyright (c) 2015 - 2026 Vaadin Ltd. * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/ */ import { html, LitElement } from 'lit'; import { defineCustomElement } from '@vaadin/component-base/src/define.js'; import { DirMixin } from '@vaadin/component-base/src/dir-mixin.js'; import { PolylitMixin } from '@vaadin/component-base/src/polylit-mixin.js'; import { itemStyles } from '@vaadin/item/src/styles/vaadin-item-base-styles.js'; import { LumoInjectionMixin } from '@vaadin/vaadin-themable-mixin/lumo-injection-mixin.js'; import { ThemableMixin } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js'; import { comboBoxItemStyles } from './styles/vaadin-combo-box-item-base-styles.js'; import { ComboBoxItemMixin } from './vaadin-combo-box-item-mixin.js'; /** * An item element used by the `<vaadin-combo-box>` dropdown. * * ### Styling * * The following shadow DOM parts are available for styling: * * Part name | Description * ------------|-------------- * `checkmark` | The graphical checkmark shown for a selected item * `content` | The element that wraps the item content * * The following state attributes are exposed for styling: * * Attribute | Description * -------------|------------- * `selected` | Set when the item is selected * `focused` | Set when the item is focused * * See [Styling Components](https://vaadin.com/docs/latest/styling/styling-components) documentation. * * @customElement vaadin-combo-box-item * @mixes ComboBoxItemMixin * @mixes ThemableMixin * @mixes DirMixin * @private */ export class ComboBoxItem extends ComboBoxItemMixin( ThemableMixin(DirMixin(PolylitMixin(LumoInjectionMixin(LitElement)))), ) { static get is() { return 'vaadin-combo-box-item'; } static get styles() { return [itemStyles, comboBoxItemStyles]; } /** @protected */ render() { return html` <span part="checkmark" aria-hidden="true"></span> <div part="content"> <slot></slot> </div> `; } } defineCustomElement(ComboBoxItem);