From 8d8c1857068fac521909ed4d33a10d9560e557d6 Mon Sep 17 00:00:00 2001 From: Vipul Gupta Date: Thu, 19 Dec 2024 18:31:53 +0530 Subject: [PATCH 1/2] feat: Adds story for block preview. --- .../block-preview/stories/index.story.js | 101 ++++++++++++++++++ 1 file changed, 101 insertions(+) create mode 100644 packages/block-editor/src/components/block-preview/stories/index.story.js diff --git a/packages/block-editor/src/components/block-preview/stories/index.story.js b/packages/block-editor/src/components/block-preview/stories/index.story.js new file mode 100644 index 00000000000000..ca38211eaecd2c --- /dev/null +++ b/packages/block-editor/src/components/block-preview/stories/index.story.js @@ -0,0 +1,101 @@ +/** + * WordPress dependencies + */ +import { createBlock } from '@wordpress/blocks'; +import { registerCoreBlocks } from '@wordpress/block-library'; + +/** + * Internal dependencies + */ +import BlockPreview from '../index'; + +// Register core blocks to be used in the preview. +registerCoreBlocks(); + +// Sample blocks for the story. +const sampleBlocks = [ + createBlock( 'core/heading', { + content: 'This is a heading block.', + level: 2, + } ), + createBlock( 'core/paragraph', { content: 'This is a paragraph block.' } ), +]; + +const meta = { + title: 'BlockEditor/BlockPreview', + component: BlockPreview, + parameters: { + docs: { + description: { + component: + 'The `BlockPreview` component renders a preview of blocks in an isolated editor environment.', + }, + }, + }, + argTypes: { + blocks: { + description: 'Block instance(s) to render in the preview.', + control: 'object', + table: { + type: { + summary: 'Array|Object', + }, + }, + }, + viewportWidth: { + description: 'Width of the preview container in pixels.', + control: 'number', + table: { + type: { + summary: 'number', + }, + }, + defaultValue: 1200, + }, + minHeight: { + description: 'Minimum height of the preview iframe in pixels.', + control: 'number', + table: { + type: { + summary: 'number', + }, + }, + }, + additionalStyles: { + description: + 'Additional styles to apply to the preview iframe as an array of CSS rules.', + control: 'object', + table: { + type: { + summary: 'Array', + }, + }, + defaultValue: [], + }, + }, +}; +export default meta; + +export const Default = { + render: function Template( args ) { + return ; + }, + args: { + blocks: sampleBlocks, + viewportWidth: 1200, + minHeight: 100, + additionalStyles: [], + }, +}; + +export const CustomStyles = { + render: function Template( args ) { + return ; + }, + args: { + blocks: sampleBlocks, + viewportWidth: 1200, + minHeight: 100, + additionalStyles: [ { css: `body { color: #ff0000; }` } ], + }, +}; From 510885ea2fd588268225d11c9ac135a2431a8c3b Mon Sep 17 00:00:00 2001 From: Vipul Gupta Date: Fri, 20 Dec 2024 10:57:50 +0530 Subject: [PATCH 2/2] fix: Additional styles story. --- .../block-preview/stories/index.story.js | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/packages/block-editor/src/components/block-preview/stories/index.story.js b/packages/block-editor/src/components/block-preview/stories/index.story.js index ca38211eaecd2c..1b7cfad781f4ff 100644 --- a/packages/block-editor/src/components/block-preview/stories/index.story.js +++ b/packages/block-editor/src/components/block-preview/stories/index.story.js @@ -7,7 +7,8 @@ import { registerCoreBlocks } from '@wordpress/block-library'; /** * Internal dependencies */ -import BlockPreview from '../index'; +import BlockPreview from '..'; +import { BlockEditorProvider } from '../../provider'; // Register core blocks to be used in the preview. registerCoreBlocks(); @@ -63,7 +64,7 @@ const meta = { }, additionalStyles: { description: - 'Additional styles to apply to the preview iframe as an array of CSS rules.', + 'Additional styles to apply to the preview iframe as an array of CSS rules. Each object should contain a `css` attribute.', control: 'object', table: { type: { @@ -78,7 +79,11 @@ export default meta; export const Default = { render: function Template( args ) { - return ; + return ( + + + + ); }, args: { blocks: sampleBlocks, @@ -90,12 +95,16 @@ export const Default = { export const CustomStyles = { render: function Template( args ) { - return ; + return ( + + + + ); }, args: { blocks: sampleBlocks, viewportWidth: 1200, minHeight: 100, - additionalStyles: [ { css: `body { color: #ff0000; }` } ], + additionalStyles: [ { css: `p { color: #ff0000; }` } ], }, };