UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

82 lines (80 loc) 2.8 kB
/// <reference types="../../index.d.ts" /> import { PropertyValues } from 'lit'; import { PublicLitElement as LitElement, JsxNode, TargetedEvent } from '@arcgis/lumina'; import { FormComponent, MutableValidityState } from '../../utils/form'; import { InteractiveComponent } from '../../utils/interactive'; import { LabelableComponent } from '../../utils/label'; import { Scale, Status, Width } from '../interfaces'; import { IconNameOrString } from '../calcite-icon/interfaces'; import { Option } from '../calcite-option/customElement.js'; import { Label } from '../calcite-label/customElement.js'; /** @slot - A slot for adding `calcite-option`s. */ export declare class Select extends LitElement { /** * When `true`, interaction is prevented and the component is displayed with lower opacity. * * @default false */ disabled: boolean; /** * The `id` of the form that will be associated with the component. * * When not set, the component will be associated with its ancestor form element, if any. */ form: string; /** * Accessible name for the component. * * @required */ label: string; /** * Specifies the name of the component. * * Required to pass the component's `value` on form submission. */ name: string; /** * When `true` and the component resides in a form, * the component must have a value in order for the form to submit. * * @default false */ required: boolean; /** * Specifies the size of the component. * * @default "m" */ scale: Scale; /** The component's selected option `HTMLElement`. */ readonly selectedOption: HTMLCalciteOptionElement; /** * Specifies the status of the input field, which determines message and icons. * * @default "idle" */ status: Status; /** Specifies the validation icon to display under the component. */ validationIcon: IconNameOrString | boolean; /** Specifies the validation message to display under the component. */ validationMessage: string; /** * The current validation state of the component. * * @mdn [ValidityState](https://developer.mozilla.org/en-US/docs/Web/API/ValidityState) */ readonly validity: MutableValidityState; /** The component's `selectedOption` value. */ value: string; /** * Specifies the width of the component. [Deprecated] The `"half"` value is deprecated, use `"full"` instead. * * @default "auto" */ width: Extract<Width, "auto" | "half" | "full">; /** Sets focus on the component. */ setFocus(): Promise<void>; /** Fires when the `selectedOption` changes. */ readonly calciteSelectChange: TargetedEvent<this, void>; }