UNPKG

@wordpress/components

Version:
120 lines (109 loc) 3.21 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import { createElement } from "@wordpress/element"; /** * External dependencies */ /** * WordPress dependencies */ import { useInstanceId } from '@wordpress/compose'; import { forwardRef, useMemo } from '@wordpress/element'; /** * Internal dependencies */ import Backdrop from './backdrop'; import Label from './label'; import { Container, Root, Prefix, Suffix, getSizeConfig } from './styles/input-control-styles'; import { ContextSystemProvider } from '../ui/context'; function useUniqueId(idProp) { const instanceId = useInstanceId(InputBase); const id = `input-base-control-${instanceId}`; return idProp || id; } // Adapter to map props for the new ui/flex component. function getUIFlexProps(labelPosition) { const props = {}; switch (labelPosition) { case 'top': props.direction = 'column'; props.expanded = false; props.gap = 0; break; case 'bottom': props.direction = 'column-reverse'; props.expanded = false; props.gap = 0; break; case 'edge': props.justify = 'space-between'; break; } return props; } export function InputBase(_ref, ref) { let { __next36pxDefaultSize, __unstableInputWidth, children, className, disabled = false, hideLabelFromVision = false, labelPosition, id: idProp, isFocused = false, label, prefix, size = 'default', suffix, ...props } = _ref; const id = useUniqueId(idProp); const hideLabel = hideLabelFromVision || !label; const { paddingLeft, paddingRight } = getSizeConfig({ inputSize: size, __next36pxDefaultSize }); const prefixSuffixContextValue = useMemo(() => { return { InputControlPrefixWrapper: { paddingLeft }, InputControlSuffixWrapper: { paddingRight } }; }, [paddingLeft, paddingRight]); return (// @ts-expect-error The `direction` prop from Flex (FlexDirection) conflicts with legacy SVGAttributes `direction` (string) that come from React intrinsic prop definitions. createElement(Root, _extends({}, props, getUIFlexProps(labelPosition), { className: className, gap: 2, isFocused: isFocused, labelPosition: labelPosition, ref: ref }), createElement(Label, { className: "components-input-control__label", hideLabelFromVision: hideLabelFromVision, labelPosition: labelPosition, htmlFor: id }, label), createElement(Container, { __unstableInputWidth: __unstableInputWidth, className: "components-input-control__container", disabled: disabled, hideLabel: hideLabel, labelPosition: labelPosition }, createElement(ContextSystemProvider, { value: prefixSuffixContextValue }, prefix && createElement(Prefix, { className: "components-input-control__prefix" }, prefix), children, suffix && createElement(Suffix, { className: "components-input-control__suffix" }, suffix)), createElement(Backdrop, { disabled: disabled, isFocused: isFocused }))) ); } export default forwardRef(InputBase); //# sourceMappingURL=input-base.js.map