UNPKG

@blueprintjs/core

Version:

Core styles & components

26 lines 1.48 kB
"use strict"; /* ! * (c) Copyright 2023 Palantir Technologies Inc. All rights reserved. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.AsyncControllableTextArea = void 0; const tslib_1 = require("tslib"); const React = tslib_1.__importStar(require("react")); const common_1 = require("../../common"); const useAsyncControllableValue_1 = require("../../hooks/useAsyncControllableValue"); /** * A wrapper around the low-level <textarea> component which works around a React bug * the same way <AsyncControllableInput> does. */ exports.AsyncControllableTextArea = React.forwardRef(function AsyncControllableTextArea(props, ref) { const { value: parentValue, onChange: parentOnChange, onCompositionStart: parentOnCompositionStart, onCompositionEnd: parentOnCompositionEnd, ...restProps } = props; const { value, onChange, onCompositionStart, onCompositionEnd } = (0, useAsyncControllableValue_1.useAsyncControllableValue)({ onChange: parentOnChange, onCompositionEnd: parentOnCompositionEnd, onCompositionStart: parentOnCompositionStart, value: parentValue, }); return (React.createElement("textarea", { ...restProps, value: value, onChange: onChange, onCompositionStart: onCompositionStart, onCompositionEnd: onCompositionEnd, ref: ref })); }); exports.AsyncControllableTextArea.displayName = `${common_1.DISPLAYNAME_PREFIX}.AsyncControllableTextArea`; //# sourceMappingURL=asyncControllableTextArea.js.map