File "transforms.js"

Full Path: /home/rattkxnv/byattorney.com/wp-content/plugins/generateblocks/src/blocks/container/transforms.js
File size: 2.09 KB
MIME-type: text/x-java
Charset: utf-8

import { convertLegacyHtmlAttributes } from '@utils/convertLegacyHtmlAttributes';
import { convertLocalToStyles } from '@utils/legacyStyleUtils';
import { createBlock, getBlockType } from '@wordpress/blocks';

export const transforms = {
	to: [
		{
			type: 'block',
			blocks: [ 'generateblocks/element' ],
			isMatch: ( {
				useInnerContainer,
				variantRole,
				shapeDividers,
				googleFont,
				isGrid,
				isQueryLoopItem,
				useGlobalStyle = false,
				isGlobalStyle = false,
			} ) => {
				if (
					useInnerContainer ||
					variantRole ||
					shapeDividers.length > 0 ||
					googleFont ||
					isGrid ||
					isQueryLoopItem ||
					useGlobalStyle ||
					isGlobalStyle
				) {
					return false;
				}

				return true;
			},
			transform: ( attributes, blocks ) => {
				const {
					tagName,
					htmlAttributes,
					blockLabel,
					globalClasses,
					anchor,
					className,
					url,
				} = attributes;
				const attributeData = getBlockType( 'generateblocks/container' )?.attributes;
				const styles = convertLocalToStyles( attributeData, attributes, '&:is(:hover, :focus)' );
				const newHtmlAttributes = convertLegacyHtmlAttributes( htmlAttributes );

				if ( anchor ) {
					newHtmlAttributes.id = anchor;
				}

				if ( url ) {
					newHtmlAttributes.href = url;
				}

				const metaData = {};

				if ( blockLabel ) {
					metaData.name = blockLabel;
				}

				// Clone the Blocks to be Grouped
				// Failing to create new block references causes the original blocks
				// to be replaced in the switchToBlockType call thereby meaning they
				// are removed both from their original location and within the
				// new group block.
				const groupInnerBlocks = blocks.map( ( block ) => {
					return createBlock(
						block.name,
						block.attributes,
						block.innerBlocks
					);
				} );

				const newTagName = url ? 'a' : tagName;

				return createBlock(
					'generateblocks/element',
					{
						tagName: newTagName,
						styles,
						htmlAttributes: newHtmlAttributes,
						metadata: metaData,
						globalClasses,
						className,
					},
					groupInnerBlocks
				);
			},
		},
	],
};