@wordpress/block-library
Version:
Block library for the WordPress editor.
112 lines (105 loc) • 2.48 kB
JavaScript
/**
* WordPress dependencies
*/
import { createBlock, getBlockAttributes } from '@wordpress/blocks';
/**
* Internal dependencies
*/
import { getLevelFromHeadingNodeName } from './shared';
import { getTransformedMetadata } from '../utils/get-transformed-metadata';
const transforms = {
from: [
{
type: 'block',
isMultiBlock: true,
blocks: [ 'core/paragraph' ],
transform: ( attributes ) =>
attributes.map(
( { content, anchor, align: textAlign, metadata } ) =>
createBlock( 'core/heading', {
content,
anchor,
textAlign,
metadata: getTransformedMetadata(
metadata,
'core/heading',
( { content: contentBinding } ) => ( {
content: contentBinding,
} )
),
} )
),
},
{
type: 'raw',
selector: 'h1,h2,h3,h4,h5,h6',
schema: ( { phrasingContentSchema, isPaste } ) => {
const schema = {
children: phrasingContentSchema,
attributes: isPaste ? [] : [ 'style', 'id' ],
};
return {
h1: schema,
h2: schema,
h3: schema,
h4: schema,
h5: schema,
h6: schema,
};
},
transform( node ) {
const attributes = getBlockAttributes(
'core/heading',
node.outerHTML
);
const { textAlign } = node.style || {};
attributes.level = getLevelFromHeadingNodeName( node.nodeName );
if (
textAlign === 'left' ||
textAlign === 'center' ||
textAlign === 'right'
) {
attributes.align = textAlign;
}
return createBlock( 'core/heading', attributes );
},
},
...[ 1, 2, 3, 4, 5, 6 ].map( ( level ) => ( {
type: 'prefix',
prefix: Array( level + 1 ).join( '#' ),
transform( content ) {
return createBlock( 'core/heading', {
level,
content,
} );
},
} ) ),
...[ 1, 2, 3, 4, 5, 6 ].map( ( level ) => ( {
type: 'enter',
regExp: new RegExp( `^/(h|H)${ level }$` ),
transform: () => createBlock( 'core/heading', { level } ),
} ) ),
],
to: [
{
type: 'block',
isMultiBlock: true,
blocks: [ 'core/paragraph' ],
transform: ( attributes ) =>
attributes.map( ( { content, textAlign: align, metadata } ) =>
createBlock( 'core/paragraph', {
content,
align,
metadata: getTransformedMetadata(
metadata,
'core/paragraph',
( { content: contentBinding } ) => ( {
content: contentBinding,
} )
),
} )
),
},
],
};
export default transforms;