UNPKG

@scoped-vaadin/select

Version:
81 lines (69 loc) 2.39 kB
/** * @license * Copyright (c) 2017 - 2024 Vaadin Ltd. * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/ */ import { html, PolymerElement } from '@polymer/polymer/polymer-element.js'; import { defineCustomElement } from '@scoped-vaadin/component-base/src/define.js'; import { overlayStyles } from '@scoped-vaadin/overlay/src/vaadin-overlay-styles.js'; import { css, registerStyles, ThemableMixin } from '@scoped-vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js'; import { SelectOverlayMixin } from './vaadin-select-overlay-mixin.js'; const selectOverlayStyles = css` :host { align-items: flex-start; justify-content: flex-start; } :host(:not([phone])) [part='overlay'] { min-width: var(--vaadin-select-overlay-width, var(--vaadin-select-text-field-width)); } @media (forced-colors: active) { [part='overlay'] { outline: 3px solid; } } `; registerStyles('vaadin24-select-overlay', [overlayStyles, selectOverlayStyles], { moduleId: 'vaadin-select-overlay-styles', }); /** * An element used internally by `<vaadin24-select>`. Not intended to be used separately. * * @customElement * @extends HTMLElement * @mixes SelectOverlayMixin * @mixes ThemableMixin * @private */ export class SelectOverlay extends SelectOverlayMixin(ThemableMixin(PolymerElement)) { static get is() { return 'vaadin24-select-overlay'; } static get template() { return html` <div id="backdrop" part="backdrop" hidden$="[[!withBackdrop]]"></div> <div part="overlay" id="overlay" tabindex="0"> <div part="content" id="content"> <slot></slot> </div> </div> `; } /** @protected */ ready() { super.ready(); // When setting `opened` as an attribute, the overlay is already teleported to body // by the time when `ready()` callback of the `vaadin24-select` is executed by Polymer, // so querySelector() would return null. So we use this workaround to set properties. this.owner = this.__dataHost; this.owner._overlayElement = this; } requestContentUpdate() { super.requestContentUpdate(); if (this.owner) { // Ensure menuElement reference is correct. const menuElement = this._getMenuElement(); this.owner._assignMenuElement(menuElement); } } } defineCustomElement(SelectOverlay);