@wordpress/block-library
Version:
Block library for the WordPress editor.
97 lines (88 loc) • 1.65 kB
JavaScript
/**
* External dependencies
*/
import classnames from 'classnames';
/**
* WordPress dependencies
*/
import { RichText, useBlockProps } from '@wordpress/block-editor';
/**
* Internal dependencies
*/
import migrateFontFamily from '../utils/migrate-font-family';
const v1 = {
attributes: {
content: {
type: 'string',
source: 'html',
selector: 'pre',
default: '',
},
textAlign: {
type: 'string',
},
},
save( { attributes } ) {
const { textAlign, content } = attributes;
return (
<RichText.Content
tagName="pre"
style={ { textAlign } }
value={ content }
/>
);
},
};
const v2 = {
attributes: {
content: {
type: 'string',
source: 'html',
selector: 'pre',
default: '',
__unstablePreserveWhiteSpace: true,
__experimentalRole: 'content',
},
textAlign: {
type: 'string',
},
},
supports: {
anchor: true,
color: {
gradients: true,
link: true,
},
typography: {
fontSize: true,
__experimentalFontFamily: true,
},
spacing: {
padding: true,
},
},
save( { attributes } ) {
const { textAlign, content } = attributes;
const className = classnames( {
[ `has-text-align-${ textAlign }` ]: textAlign,
} );
return (
<pre { ...useBlockProps.save( { className } ) }>
<RichText.Content value={ content } />
</pre>
);
},
migrate: migrateFontFamily,
isEligible( { style } ) {
return style?.typography?.fontFamily;
},
};
/**
* New deprecations need to be placed first
* for them to have higher priority.
*
* Old deprecations may need to be updated as well.
*
* See block-deprecation.md
*/
export default [ v2, v1 ];