File "pattern-details.js"

Full path: /home/webcknlt/admissiontell.com/wp-content/plugins/generateblocks/src/pattern-library/components/pattern-details.js
File size: 2.8 B (2.8 KB bytes)
MIME-type: text/x-java
Charset: utf-8

Download   Open   Edit   Advanced Editor &nnbsp; Back

import { Button } from '@wordpress/components';
import { seen } from '@wordpress/icons';
import { __ } from '@wordpress/i18n';
import { useDispatch, useSelect } from '@wordpress/data';
import { store as blockEditorStore } from '@wordpress/block-editor';
import { parse } from '@wordpress/blocks';
import { decodeEntities } from '@wordpress/html-entities';
import { useLibrary } from './library-provider';
import { InsertPattern } from './insert-pattern';
import { isEmptyContentBlock, updateUniqueIds } from '../utils';

export function PatternDetails( {
	pattern,
	patternRef = null,
	children,
	showPreview = true,
	bulkInsertEnabled,
	showTitle = true,
	globalStyleData,
	closeModal,
	readOnly,
} ) {
	const {
		setActivePatternId,
		setScrollPosition,
	} = useLibrary();
	const { insertBlocks, replaceBlock } = useDispatch( blockEditorStore );
	const { getBlockInsertionPoint, getSelectedBlock } = useSelect( ( select ) => select( blockEditorStore ), [] );
	const { updateBlockAttributes } = useDispatch( blockEditorStore );

	return (
		<div className="gb-pattern-details">
			{ !! showTitle && (
				<h3>{ decodeEntities( pattern.label ) }</h3>
			) }

			<div className="gb-pattern-details__actions">
				{ ! bulkInsertEnabled && ! readOnly && (
					<InsertPattern
						label={ __( 'Insert', 'generateblocks' ) }
						onClick={ async( e ) => {
							e.stopPropagation();

							const blockInsertionPoint = getBlockInsertionPoint();
							const selectedBlock = getSelectedBlock();
							const renderedPattern = parse( pattern.pattern );
							const updatedBlocks = updateUniqueIds( renderedPattern );

							updatedBlocks.forEach( ( block ) => {
								if ( block.attributes && block.clientId ) {
									updateBlockAttributes( block.clientId, block.attributes );
								}
							} );

							const isEmptyContent = isEmptyContentBlock( selectedBlock );

							if ( isEmptyContent ) {
								await replaceBlock(
									selectedBlock.clientId,
									updatedBlocks
								);
							} else {
								await insertBlocks(
									updatedBlocks,
									blockInsertionPoint?.index ?? 0,
									blockInsertionPoint.rootClientId ?? ''
								);
							}

							closeModal();
						} }
						patterns={ [ pattern ] }
						globalStyleData={ globalStyleData }
					/>
				) }

				{ ( showPreview && ! bulkInsertEnabled ) && (
					<Button
						variant="tertiary"
						icon={ seen }
						label={ __( 'Preview', 'generateblocks' ) }
						showTooltip
						onClick={ ( e ) => {
							e.stopPropagation();
							setActivePatternId( pattern.id );

							if ( patternRef ) {
								const patternContent = patternRef.current.closest( '.gb-pattern-library__content' );

								if ( patternContent ) {
									setScrollPosition( patternContent.scrollTop );
								}
							}
						} }
					/>
				) }
				{ children }
			</div>
		</div>
	);
}