@wordpress/components
Version:
UI components for WordPress.
71 lines (64 loc) • 1.65 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import { createElement } from "@wordpress/element";
/**
* External dependencies
*/
import { noop } from 'lodash';
/**
* WordPress dependencies
*/
import { __ } from '@wordpress/i18n';
/**
* Internal dependencies
*/
import { UnitControl as BaseUnitControl, ControlWrapper } from './styles/focal-point-picker-style';
import { fractionToPercentage } from './utils';
const TEXTCONTROL_MIN = 0;
const TEXTCONTROL_MAX = 100;
export default function FocalPointPickerControls({
onChange = noop,
percentages = {
x: 0.5,
y: 0.5
}
}) {
const valueX = fractionToPercentage(percentages.x);
const valueY = fractionToPercentage(percentages.y);
const handleOnXChange = next => {
onChange({ ...percentages,
x: parseInt(next) / 100
});
};
const handleOnYChange = next => {
onChange({ ...percentages,
y: parseInt(next) / 100
});
};
return createElement(ControlWrapper, {
className: "focal-point-picker__controls"
}, createElement(UnitControl, {
label: __('Left'),
value: valueX,
onChange: handleOnXChange,
dragDirection: "e"
}), createElement(UnitControl, {
label: __('Top'),
value: valueY,
onChange: handleOnYChange,
dragDirection: "s"
}));
}
function UnitControl(props) {
return createElement(BaseUnitControl, _extends({
className: "focal-point-picker__controls-position-unit-control",
labelPosition: "side",
max: TEXTCONTROL_MAX,
min: TEXTCONTROL_MIN,
unit: "%",
units: [{
value: '%',
label: '%'
}]
}, props));
}
//# sourceMappingURL=controls.js.map