UNPKG

@vaadin/select

Version:
66 lines (59 loc) 1.91 kB
/** * @license * Copyright (c) 2017 - 2025 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 { ItemMixin } from '@vaadin/item/src/vaadin-item-mixin.js'; import { LumoInjectionMixin } from '@vaadin/vaadin-themable-mixin/lumo-injection-mixin.js'; import { ThemableMixin } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js'; /** * An element used internally by `<vaadin-select>`. Not intended to be used separately. * * @customElement * @extends HTMLElement * @mixes DirMixin * @mixes ItemMixin * @mixes ThemableMixin * @protected */ class SelectItem extends ItemMixin(ThemableMixin(DirMixin(PolylitMixin(LumoInjectionMixin(LitElement))))) { static get is() { return 'vaadin-select-item'; } static get styles() { return itemStyles; } static get properties() { return { /** * Use property instead of setting an attribute in `ready()` * for cloning the selected item attached to the value button: * in this case, `role` attribute is removed synchronously, and * using `ready()` would incorrectly restore the attribute. * * @protected */ role: { type: String, value: 'option', reflectToAttribute: true, }, }; } /** @protected */ render() { return html` <span part="checkmark" aria-hidden="true"></span> <div part="content"> <slot></slot> </div> `; } } defineCustomElement(SelectItem); export { SelectItem };