85 lines
2.1 KiB
TypeScript
85 lines
2.1 KiB
TypeScript
/**
|
|
* External dependencies
|
|
*/
|
|
import { __ } from '@wordpress/i18n';
|
|
import { InspectorControls } from '@wordpress/block-editor';
|
|
import { PanelBody, ToggleControl } from '@wordpress/components';
|
|
import { Icon, postComments } from '@wordpress/icons';
|
|
|
|
/**
|
|
* Internal dependencies
|
|
*/
|
|
import EditorContainerBlock from '../editor-container-block.js';
|
|
import NoReviewsPlaceholder from './no-reviews-placeholder';
|
|
import {
|
|
getSharedReviewContentControls,
|
|
getSharedReviewListControls,
|
|
} from '../edit-utils.js';
|
|
import type { AllReviewsEditorProps } from './types';
|
|
|
|
/**
|
|
* Component to handle edit mode of "All Reviews".
|
|
*
|
|
* @param {Object} props Incoming props for the component.
|
|
* @param {Object} props.attributes Incoming block attributes.
|
|
* @param {function(any):any} props.setAttributes Setter for block attributes.
|
|
*/
|
|
const AllReviewsEditor = ( {
|
|
attributes,
|
|
setAttributes,
|
|
}: AllReviewsEditorProps ) => {
|
|
const getInspectorControls = () => {
|
|
return (
|
|
<InspectorControls key="inspector">
|
|
<PanelBody
|
|
title={ __( 'Content', 'woo-gutenberg-products-block' ) }
|
|
>
|
|
<ToggleControl
|
|
label={ __(
|
|
'Product name',
|
|
'woo-gutenberg-products-block'
|
|
) }
|
|
checked={ attributes.showProductName }
|
|
onChange={ () =>
|
|
setAttributes( {
|
|
showProductName: ! attributes.showProductName,
|
|
} )
|
|
}
|
|
/>
|
|
{ getSharedReviewContentControls(
|
|
attributes,
|
|
setAttributes
|
|
) }
|
|
</PanelBody>
|
|
<PanelBody
|
|
title={ __(
|
|
'List Settings',
|
|
'woo-gutenberg-products-block'
|
|
) }
|
|
>
|
|
{ getSharedReviewListControls( attributes, setAttributes ) }
|
|
</PanelBody>
|
|
</InspectorControls>
|
|
);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
{ getInspectorControls() }
|
|
<EditorContainerBlock
|
|
attributes={ attributes }
|
|
icon={
|
|
<Icon
|
|
icon={ postComments }
|
|
className="block-editor-block-icon"
|
|
/>
|
|
}
|
|
name={ __( 'All Reviews', 'woo-gutenberg-products-block' ) }
|
|
noReviewsPlaceholder={ NoReviewsPlaceholder() }
|
|
/>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default AllReviewsEditor;
|