UNPKG

@wordpress/components

Version:
71 lines (64 loc) 1.68 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import { createElement } from "@wordpress/element"; /** * External dependencies */ import { noop } from 'lodash'; /** * Internal dependencies */ import UnitControl from './unit-control'; import { LABELS, getAllValue, isValuesMixed, isValuesDefined } from './utils'; export default function AllInputControl({ onChange = noop, onFocus = noop, onHoverOn = noop, onHoverOff = noop, values, sides, ...props }) { const allValue = getAllValue(values); const hasValues = isValuesDefined(values); const isMixed = hasValues && isValuesMixed(values); const allPlaceholder = isMixed ? LABELS.mixed : null; const handleOnFocus = event => { onFocus(event, { side: 'all' }); }; const handleOnChange = next => { const nextValues = { ...values }; const selectedSides = sides !== null && sides !== void 0 && sides.length ? sides : ['top', 'right', 'bottom', 'left']; selectedSides.forEach(side => nextValues[side] = next); onChange(nextValues); }; const handleOnHoverOn = () => { onHoverOn({ top: true, bottom: true, left: true, right: true }); }; const handleOnHoverOff = () => { onHoverOff({ top: false, bottom: false, left: false, right: false }); }; return createElement(UnitControl, _extends({}, props, { disableUnits: isMixed, isOnly: true, value: allValue, onChange: handleOnChange, onFocus: handleOnFocus, onHoverOn: handleOnHoverOn, onHoverOff: handleOnHoverOff, placeholder: allPlaceholder })); } //# sourceMappingURL=all-input-control.js.map