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

Allow extending editor preview in more ways #65005

Open
simison opened this issue Sep 3, 2024 · 8 comments
Open

Allow extending editor preview in more ways #65005

simison opened this issue Sep 3, 2024 · 8 comments
Labels
[Feature] Extensibility The ability to extend blocks or the editing experience [Type] Enhancement A suggestion for improvement.

Comments

@simison
Copy link
Member

simison commented Sep 3, 2024

What problem does this address?

In #64644 we allowed extending the "preview dropdown" in a simple, fairly restrictive manner:

359590714-1330a6e3-f879-4a7b-8416-4d5abf436ba6

This is great for gathering feedback from real usage.

Extending the preview menu and canvas allow variety of publishing flows and tools, some examples:

  • Social media share previews
  • Previewing same content in different formats such as website, email, RSS, printed
  • Displaying with different membership or paid access restrictions/without
  • Dark mode for websites that implement it while editor stays light mode by default
  • Additional display sizes for more exotic targets such as televisions, watches
  • eBook previews
  • AMP format previews

An example of more complex preview capabilities from Substack done directly in the canvas:

Screen.Recording.2023-07-26.at.12.03.19.mov

Another simpler example from Jetpack Social, opening a modal for previewing:

Screenshot 2024-09-03 at 16 13 20

What is your proposed solution?

  • Allow extending pre-defined device sizes list
  • Allow extending preview dropdown menu with multi-selection items
  • Allow adding multiple sections to preview dropdown menu
  • Allow extending the editor canvas

Allow extending pre-defined device sizes list

Extending existing devices list is simplest step, as the API could be purely declarative (size, icon, label) and hook into existing functionality:

Screenshot 2024-09-03 at 16 16 37

Examples might be slideshow presentations, TV screens, watches and other more exotic devices. WP is used to build not just websites.

Allow extending preview dropdown menu with multi-selection items

Selections would work in conjunction with existing device-size selectors, and work well with allowing extending editor canvas:

In above scenario you can preview post as a "free" or "paid" subscriber in various device sizes.

Some concerns come from having multiple plugins extend the menu in their own way, and how the menu should then look like. Do we force each plugin onto their own sub-menu or section? Should selections from one plugin clear selections from others? What are the defaults? How do we allow branding show up?

Allow adding multiple sections to preview dropdown menu

Expanding on above example, one could also introduce multiple devices/platforms that are separate from device sizes, such as "email" and "website":

2256164379-57da36ab-9fc7-41a5-9f0f-f5b2f079752d

Allow extending the editor canvas

Screenshot 2024-09-03 at 16 08 19

Extending canvas could be done in multiple ways. We could allow:

  • completely replacing canvas with custom preview like custom built editor,
  • passing alternative styles like dark/light mode, print/TV/website/email
  • passing meta info to existing canvas (like free/paid) user

Allowing replacing the canvas brings up questions like do users expect to always be able edit what they see in the canvas, or can canvas work purely for "previewing" too?

@simison simison added the [Type] Enhancement A suggestion for improvement. label Sep 3, 2024
@gziolo gziolo added the [Feature] Extensibility The ability to extend blocks or the editing experience label Sep 3, 2024
@fabiankaegy
Copy link
Member

Thank you for summarizing the needs here so well :) This would really go a long way!

@mtias
Copy link
Member

mtias commented Sep 5, 2024

Another example from core itself could be the Style Book—rendering on the canvas as a target. The cases where we render a pattern or a template part in isolation also seem relevant since elements like resize handlers could be part of the API.

@gziolo
Copy link
Member

gziolo commented Sep 5, 2024

Another example from core itself could be the Style Book—rendering on the canvas as a target. The cases where we render a pattern or a template part in isolation also seem relevant since elements like resize handlers could be part of the API.

Interesting use cases. It makes me wonder whether we need to replicate the same SlotFill behavior we have for the sidebar. It feels like it would make perfect sense and could become an interesting option for extenders. I'm surprised we don't change the URL or store the visit to the Style Book in the browser history. Going back in the history 7-8 years, that was most likely the primary concern for opening the canvas for extenders.

@skorasaurus
Copy link
Member

skorasaurus commented Sep 6, 2024

@bacoords
Copy link
Contributor

This is great! I'm a huge fan of "Allow extending the editor canvas"- some additional use cases:

  • similar to the "watch" example, we have post types that also feed their block data to mobile apps, where the blocks render a bit differently.
  • swapping out the canvas for a 'fields/data mode' where you can populate custom fields (instead of having to use the sidebar or a modal to show custom fields)
  • advanced developer plugins that might want to let you view a post as it's 'data model', for example, what does this post look like as it's REST API endpoint, what does it look like to my GraphQL plugin - those tools could integrate right into the editor.

@fabiankaegy
Copy link
Member

Something that I am coming back to every time I am using this API is that we need a better way to manage body classes (inside the iframe) for many of the preview options to be possible.

Just look at this example from @ndiego about how to manually add a custom class name to the iframe: https://github.com/ndiego/dark-mode-toggle-block/blob/341188f6c46c39a1c1ce34384cabb61f43998c48/src/index.js#L91-L149

This new extensibility entry point would be so much more powerful if we had an API for managing these classes :)

@abder
Copy link
Contributor

abder commented Dec 10, 2024

Hi,

@simison is there a timeline for adding support to manipulate the canvas size?

On my plugin I wanted to add support for other screen sizes, but the fact that the iframe only appears with Tablet and Mobile ( and not in desktop ) make it challenging ( I don't think is a good practice to intereact with the DOM either )

I think the way the preview menu is extended with the new component is kind of static, there should be a way to update the preview dynamically as well from anywhere, the same way we update to Tablet, Mobile & Desktop devices:

wp?.data?.dispatch("core/edit-post")?.__experimentalSetPreviewDeviceType(device)

@simison
Copy link
Member Author

simison commented Jan 17, 2025

is there a timeline for adding support to manipulate the canvas size?

@abder Not at this time unfortunately and I'm not working on this feature, but there seems to be agreenment that such feature would be helpful so contributions are welcome!

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 [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

No branches or pull requests

7 participants