@wordpress/block-library
Version:
Block library for the WordPress editor.
95 lines (83 loc) • 2.72 kB
JavaScript
import { createElement } from "@wordpress/element";
/**
* WordPress dependencies
*/
import { __ } from '@wordpress/i18n';
/**
* Internal dependencies
*/
import { getColorObjectByColorValue, getColorObjectByAttributeValues, getGradientValueBySlug, getGradientSlugByValue, __experimentalPanelColorGradientSettings as PanelColorGradientSettings } from '@wordpress/block-editor';
import { useMemo } from '@wordpress/element';
import { useMobileGlobalStylesColors } from '@wordpress/components';
function OverlayColorSettings(_ref) {
let {
overlayColor,
customOverlayColor,
gradient,
customGradient,
setAttributes
} = _ref;
const colors = useMobileGlobalStylesColors();
const gradients = useMobileGlobalStylesColors('gradients');
const gradientValue = customGradient || getGradientValueBySlug(gradients, gradient);
const colorValue = getColorObjectByAttributeValues(colors, overlayColor, customOverlayColor).color;
const settings = useMemo(() => {
const setOverlayAttribute = (attributeName, value) => {
setAttributes({
// Clear all related attributes (only one should be set)
overlayColor: undefined,
customOverlayColor: undefined,
gradient: undefined,
customGradient: undefined,
[attributeName]: value
});
};
const onColorChange = value => {
// Do nothing for falsy values.
if (!value) {
return;
}
const colorObject = getColorObjectByColorValue(colors, value);
if (colorObject !== null && colorObject !== void 0 && colorObject.slug) {
setOverlayAttribute('overlayColor', colorObject.slug);
} else {
setOverlayAttribute('customOverlayColor', value);
}
};
const onGradientChange = value => {
// Do nothing for falsy values.
if (!value) {
return;
}
const slug = getGradientSlugByValue(gradients, value);
if (slug) {
setOverlayAttribute('gradient', slug);
} else {
setOverlayAttribute('customGradient', value);
}
};
const onColorCleared = () => {
setAttributes({
overlayColor: undefined,
customOverlayColor: undefined,
gradient: undefined,
customGradient: undefined
});
};
return [{
label: __('Color'),
onColorChange,
colorValue,
gradientValue,
onGradientChange,
onColorCleared
}];
}, [colorValue, gradientValue, colors, gradients]);
return createElement(PanelColorGradientSettings, {
title: __('Overlay'),
initialOpen: false,
settings: settings
});
}
export default OverlayColorSettings;
//# sourceMappingURL=overlay-color-settings.native.js.map