import Component from '../../components/textarea/textarea.component.js'; import { type EventName } from '@lit/react'; import type { MfBlurEvent } from '../../events/events.js'; import type { MfChangeEvent } from '../../events/events.js'; import type { MfFocusEvent } from '../../events/events.js'; import type { MfInputEvent } from '../../events/events.js'; import type { MfInvalidEvent } from '../../events/events.js'; export type { MfBlurEvent } from '../../events/events.js'; export type { MfChangeEvent } from '../../events/events.js'; export type { MfFocusEvent } from '../../events/events.js'; export type { MfInputEvent } from '../../events/events.js'; export type { MfInvalidEvent } from '../../events/events.js'; /** * @summary Textareas collect data from the user and allow multiple lines of text. * @documentation https://shoelace.style/components/textarea * @status stable * @since 2.0 * * @slot label - The textarea's label. Alternatively, you can use the `label` attribute. * @slot help-text - Text that describes how to use the input. Alternatively, you can use the `help-text` attribute. * * @event mf-blur - Emitted when the control loses focus. * @event mf-change - Emitted when an alteration to the control's value is committed by the user. * @event mf-focus - Emitted when the control gains focus. * @event mf-input - Emitted when the control receives input. * @event mf-invalid - Emitted when the form control has been checked for validity and its constraints aren't satisfied. * * @csspart form-control - The form control that wraps the label, input, and help text. * @csspart form-control-label - The label's wrapper. * @csspart form-control-input - The input's wrapper. * @csspart form-control-help-text - The help text's wrapper. * @csspart base - The component's base wrapper. * @csspart textarea - The internal `