Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add extensibility to PreviewOptions #36119

Closed

Conversation

arcangelini
Copy link
Contributor

@arcangelini arcangelini commented Nov 1, 2021

Description

This is a continuation of the following PR #31984
The overall goal of this PR is to make the Preview menu extensible using SlotFill similarly to PinnedItems and PluginSidebar.

Markup 2021-11-01 at 16 19 21

The menu is extended using the <PluginPreview> component built into @wordpress/interface package. It allows for defining a custom "Preview" menu item. There are then two ways to manipulate the preview.

  1. Using children will completely replace the VisualEditor component. In my example, I used an iframe and grabbed the preview URL to display a full site preview in iPhone resolution.
  2. Using wrapper component, the VisualEditor iframe is passed in as a prop and allows you to control how the preview is displayed. In my example, I added a basic div, but this could be more robust if desired.

In absence of both of these the view will default back to 'Desktop' allowing for only adding an onClick event with no change to the display. Along with the addition of the SlotFill, this PR also refactors the <PreviewOptions> component to consolidate the device type names.

How has this been tested?

I created a test plugin to allow for easy testing, download here (updated). Once you install the plugin you should see three new items added to your previews dropdown.

Likewise, you can use the following code to create your own plugin and test as you like:

Updated with wrapper prop

/**
 * WordPress dependencies
 */
import { __ } from '@wordpress/i18n';
import { PluginPreview } from '@wordpress/interface';
import { registerPlugin } from '@wordpress/plugins';
import { external } from '@wordpress/icons';
import { store as editorStore } from '@wordpress/editor';
import { useSelect } from '@wordpress/data';

function PluginPreviewTest() {
	const previewLink = useSelect(
		( select ) => select( editorStore ).getEditedPostPreviewLink(),
		[]
	);

	function wrapper( content ) {
		return (
			<>
				<h1
					style={ {
						textAlign: 'center',
						margin: 25,
						textTransform: 'uppercase',
					} }
				>
					My custom wrapper
				</h1>
				<div
					className="Custom"
					style={ {
						padding: 175,
						background: '#03395C',
						width: '100%',
						height: '100%',
					} }
				>
					{ content }
				</div>
			</>
		);
	}

	return (
		<>
			<PluginPreview
				name="preview-custom-1"
				title={ __( 'VisualEditor Wrapper' ) }
				wrapper={ wrapper }
			></PluginPreview>

			<PluginPreview
				name="preview-custom-2"
				title={ __( 'Overwrite VisualEditor' ) }
				onClick={ ( event ) => console.log( event ) }
			>
				<div style={ { background: 'grey', height: '100%' } }>
					<h1
						style={ {
							textAlign: 'center',
							margin: 25,
							textTransform: 'uppercase',
						} }
					>
						Iframe to the page preview URL
					</h1>
					<iframe
						style={ {
							width: 375,
							height: 812,
							margin: 'auto',
							display: 'block',
						} }
						title="Plugin Preview"
						src={ previewLink }
					></iframe>
				</div>
			</PluginPreview>

			<PluginPreview
				name="custom-action"
				title={ __( 'Custom Action' ) }
				icon={ external }
				onClick={ ( event ) => console.log( event ) }
			/>
		</>
	);
}

registerPlugin( 'preview-tester', {
	render() {
		return (
			<>
				<PluginPreviewTest />
			</>
		);
	},
} );

Screenshots

Screen Capture on 2021-11-08 at 18-06-49

Markup 2021-11-01 at 16 26 33

Types of changes

New feature (non-breaking change which adds functionality)

Fixes #25309
Relates to Automattic/wp-calypso#42896
Relates to ampproject/amp-wp#5943

Checklist:

  • My code is tested.
  • My code follows the WordPress code style.
  • My code follows the accessibility standards.
  • I've tested my changes with keyboard and screen readers.
  • My code has proper inline documentation.
  • I've included developer documentation if appropriate.
  • I've updated all React Native files affected by any refactorings/renamings in this PR (please manually search all *.native.js files for terms that need renaming or removal).

@github-actions github-actions bot added the First-time Contributor Pull request opened by a first-time contributor to Gutenberg repository label Nov 1, 2021
@github-actions
Copy link

github-actions bot commented Nov 1, 2021

👋 Thanks for your first Pull Request and for helping build the future of Gutenberg and WordPress, @arcangelini! In case you missed it, we'd love to have you join us in our Slack community, where we hold regularly weekly meetings open to anyone to coordinate with each other.

If you want to learn more about WordPress development in general, check out the Core Handbook full of helpful information.

Comment on lines 51 to 64
{ coreDeviceTypes.map( ( device ) => (
<MenuItem
key={ device }
className="block-editor-post-preview__button-resize"
onClick={ () => setDeviceType( device ) }
icon={ deviceType === device && check }
>
{ device }
</MenuItem>
) ) }
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like how you introduced the coreDeviceTypes array and then streamlined the way the
MenuItem components are being rendered using map().

One thing I think we could consider is to make the output of device labels
translatable.

An idea I have on my mind is to turn the array of strings into the array of objects
and let the label have its own translatable value that isn't used for any logic:

diff --git a/packages/block-editor/src/components/preview-options/index.js b/packages/block-editor/src/components/preview-options/index.js
index 03b3f3cea9..c3e67ab580 100644
--- a/packages/block-editor/src/components/preview-options/index.js
+++ b/packages/block-editor/src/components/preview-options/index.js
@@ -19,7 +19,11 @@ export default function PreviewOptions( {
 	deviceType,
 	setDeviceType,
 } ) {
-	const coreDeviceTypes = [ 'Desktop', 'Tablet', 'Mobile' ];
+	const coreDeviceTypes = [
+		{ type: 'Desktop', label: __( 'Desktop' ) },
+		{ type: 'Tablet', label: __( 'Tablet' ) },
+		{ type: 'Mobile', label: __( 'Mobile' ) },
+	];
 
 	const isMobile = useViewportMatch( 'small', '<' );
 	if ( isMobile ) return null;
@@ -50,12 +54,12 @@ export default function PreviewOptions( {
 					<MenuGroup>
 						{ coreDeviceTypes.map( ( device ) => (
 							<MenuItem
-								key={ device }
+								key={ device.type }
 								className="block-editor-post-preview__button-resize"
-								onClick={ () => setDeviceType( device ) }
-								icon={ deviceType === device && check }
+								onClick={ () => setDeviceType( device.type ) }
+								icon={ deviceType === device.type && check }
 							>
-								{ device }
+								{ device.label }
 							</MenuItem>
 						) ) }
 					</MenuGroup>

@ivan-ottinger
Copy link
Contributor

Thank you for adding the plugin download link to the PR. It made it much easier to test your code. 👍🏼 👍🏼

@gziolo gziolo added the [Feature] Extensibility The ability to extend blocks or the editing experience label Nov 2, 2021
@arcangelini arcangelini marked this pull request as ready for review November 8, 2021 17:49
@arcangelini arcangelini requested a review from ellatrix as a code owner November 8, 2021 17:49
@simison simison requested review from gziolo and youknowriad November 8, 2021 18:52
@arcangelini arcangelini force-pushed the add/preview-slot-fill branch from e21eb3a to d010e05 Compare March 18, 2022 10:12
@arcangelini
Copy link
Contributor Author

I rebased this PR. I realize this is still a rough draft, but would love feedback to potentially get this moving forward if possible 😄

@youknowriad @gziolo

@tomektomczuk
Copy link

I get this error

export 'PluginPreview' (imported as 'PluginPreview') was not found in '@wordpress/interface' (possible exports: ActionItem, ComplementaryArea, ComplementaryAreaMoreMenuItem, FullscreenMode, InterfaceSkeleton, MoreMenuDropdown, MoreMenuFeatureToggle, PinnedItems, PreferencesModal, PreferencesModalSection, PreferencesModalTabs, ___unstablePreferencesModalBaseOption, store)

@UranymusDev
Copy link

Yea me too, did you manage to work this out?

@arcangelini
Copy link
Contributor Author

It has been a little while since I have worked on this. I would be happy to clean it up this week and see what is going on. I will let y'all know when it is ready to test again @UranymusDev and @tomektomczuk

@phil-sola
Copy link

Is there any update on this please? This is a much-needed feature and I know a lot of people are keen to see this happen.

simison added a commit that referenced this pull request May 12, 2023
First pass at continuing work on extending preview menu in editors.

The work is entirely copied from #36119, which includes work from #31984

Tony Arcangelini <tony@arcangelini.com>
Piotr Delawski <piotr.delawski@gmail.com>
@arcangelini
Copy link
Contributor Author

This is no longer relevant it seems. Closing.

@arcangelini arcangelini deleted the add/preview-slot-fill branch June 19, 2024 09:41
@gziolo
Copy link
Member

gziolo commented Sep 3, 2024

Implemented with #64644.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Extensibility The ability to extend blocks or the editing experience First-time Contributor Pull request opened by a first-time contributor to Gutenberg repository
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Allow external preview links in Preview dropdown to be extended
6 participants