114 lines
2.6 KiB
JavaScript
Raw Permalink Normal View History

2024-05-20 15:37:46 +03:00
import {
__experimentalUnitControl,
PanelRow,
UnitControl as __stableUnitControl,
} from '@wordpress/components';
import { compose, withInstanceId } from '@wordpress/compose';
import { withDispatch, withSelect } from '@wordpress/data';
import { Component } from '@wordpress/element';
import { addFilter } from '@wordpress/hooks';
import { __ } from '@wordpress/i18n';
const UnitControl = __stableUnitControl || __experimentalUnitControl;
/**
* Component
*/
class VpImageFocalPointComponent extends Component {
render() {
const { getMeta, featuredImageId, updateMeta } = this.props;
if (!featuredImageId) {
return null;
}
let focalPoint = getMeta('_vp_image_focal_point');
if (!focalPoint || !focalPoint.x || !focalPoint.y) {
focalPoint = {
x: 0.5,
y: 0.5,
};
}
return (
<div className="vpf-post-image-focal-point-panel">
<PanelRow>
<p className="description">
{__(
'Focal point will be used in Visual Portfolio layouts only:',
'visual-portfolio'
)}
</p>
</PanelRow>
<PanelRow>
<UnitControl
label={__('Left', 'visual-portfolio')}
value={100 * focalPoint.x + '%'}
onChange={(val) => {
const newFocalPoint = { ...focalPoint };
newFocalPoint.x = parseFloat(val) / 100;
updateMeta('_vp_image_focal_point', newFocalPoint);
}}
min={0}
max={100}
step={1}
units={[{ value: '%', label: '%' }]}
/>
<UnitControl
label={__('Top', 'visual-portfolio')}
value={100 * focalPoint.y + '%'}
onChange={(val) => {
const newFocalPoint = { ...focalPoint };
newFocalPoint.y = parseFloat(val) / 100;
updateMeta('_vp_image_focal_point', newFocalPoint);
}}
min={0}
max={100}
step={1}
units={[{ value: '%', label: '%' }]}
/>
</PanelRow>
</div>
);
}
}
const VpImageFocalPoint = compose([
withSelect((select) => {
const { getEditedPostAttribute } = select('core/editor');
const featuredImageId = getEditedPostAttribute('featured_media');
const meta = getEditedPostAttribute('meta') || {};
return {
featuredImageId,
getMeta(name) {
return meta[name];
},
};
}),
withDispatch((dispatch) => ({
updateMeta(name, val) {
dispatch('core/editor').editPost({ meta: { [name]: val } });
},
})),
withInstanceId,
])(VpImageFocalPointComponent);
addFilter(
'editor.PostFeaturedImage',
'vpf/post-featured-image-focal-point',
(OriginalComponent) =>
function (props) {
return (
<>
<OriginalComponent {...props} />
<VpImageFocalPoint />
</>
);
}
);