Skip to content

Reusable Blocks: Reimplement reusable block as embedded editor #7119

Closed
@youknowriad

Description

At the moment, fetching reusable blocks also parses their content and insert them to the editor's block list state. This approach have some drawbacks:

  • We need to maintain a cycle dependency between blocks and shared blocks
  • Fetching shared blocks from the server retriggers the parsing which means if it's currently rendered, the block will unmount/remount.

I tried simplifying the state in #7080 but it fails at dealing with the nested blocks.

The idea of the PR is to avoid having to parse the reusable blocks (content property) when loading them, and when we insert a reusable block into the editor, don’t parse it and add the parsed blocks into the editor’s state because these parsed blocks are not part of the post content but just a property of the reusable block and is already present in the state in its serialized form.

So when we insert the reusable block, its edit method is responsible of parsing the content and updating it when the user saves the reusable block’s form.

But the problem happens when we have inner blocks because the way we render the InnerBlocks we assume these are present in state, we don’t pass the list of blocks to show explicitly to the BlockList as opposed to the BlockEdit (root) where we can just pass the attributes of the block to show.

The path forward is not clear:

  • My “perfectionism” tells me we should refactor our component to avoid relying too much on state getBlock( uid ) and accepts blocks as props.
  • But this is a lot of work and we lose a lot of flexibility in using selectors etc...
  • We can also try to load another Gutenberg instance :man-shrugging: when clicking the “edit” button of a reusable block, but this obviously requires a lot of work to make Gutenberg reusable this way (which should benefit things like multiple Gutenberg instances in a page) and this also means we’d need to figure out where to show the inspector of this inner instance, should it be shown above the outer instance’s inspector.
  • Or we should keep our current hack: (load the shared blocks inner blocks into state, but try to improve it in a way that we don’t remount the shared blocks when we update them/trigger another fetch)

related #5010 #5228

Activity

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Assignees

No one assigned

    Labels

    [Feature] Synced PatternsRelated to synced patterns (formerly reusable blocks)[Type] BugAn existing feature does not function as intended

    Type

    No type

    Projects

    No projects

    Milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions