/** * External dependencies */ import { __ } from '@wordpress/i18n'; import { useCallback } from '@wordpress/element'; import { useDispatch } from '@wordpress/data'; import { InnerBlockLayoutContextProvider, ProductDataContextProvider, } from '@woocommerce/shared-context'; import { createBlocksFromTemplate } from '@woocommerce/atomic-utils'; import { PanelBody, Button } from '@wordpress/components'; import { backup } from '@wordpress/icons'; import { ProductResponseItem } from '@woocommerce/types'; import { InnerBlocks, InspectorControls, // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore BlockContextProvider, } from '@wordpress/block-editor'; /** * Internal dependencies */ import { DEFAULT_INNER_BLOCKS, ALLOWED_INNER_BLOCKS } from '../constants'; import metadata from '../block.json'; interface LayoutEditorProps { isLoading: boolean; product: ProductResponseItem; clientId: string; } const LayoutEditor = ( { isLoading, product, clientId, }: LayoutEditorProps ) => { const baseClassName = '.wc-block-editor-single-product .wc-block-editor-layout'; const { replaceInnerBlocks } = useDispatch( 'core/block-editor' ); const resetInnerBlocks = useCallback( () => { replaceInnerBlocks( clientId, createBlocksFromTemplate( DEFAULT_INNER_BLOCKS ), false ); }, [ clientId, replaceInnerBlocks ] ); return (
); }; export default LayoutEditor;