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

Blocks: Optional support that optimizes handling blocks for usage as structured data #49437

Open
gziolo opened this issue Mar 29, 2023 · 2 comments
Labels
[Feature] Block API API that allows to express the block paradigm. [Feature] Blocks Overall functionality of blocks [Feature] HTML API An API for updating HTML attributes in markup [Type] Feature New feature to highlight in changelogs.

Comments

@gziolo
Copy link
Member

gziolo commented Mar 29, 2023

What problem does this address?

Related issues and PRs: #2649, #6494, #2649.
Related Trac tickets: 53603, 53602.

There are many ways how people use WordPress. One of them is to consume the content saved by the block editor as JSON. Let's explore whether we can add an optional built-in support that optimizes handling blocks for usage as structured data.

The default configuration optimizes the block editor to store the values assigned to block attributes in two ways:

  • Inside the code, comment as a serialized object - that part we can always read on the server as we have access to that object.
  • Inside the HTML snippet saved with save function – that part we can only read on the client in WordPress core today because we need to know how to query those attributes and have a tool that would do it in PHP.

There is an ongoing exploration (#46345) to build a tool that reads attributes sourced from HTML on the server with PHP, but it might only work in some specific cases. There are several limitations on how far we can go with that approach coming from the architectural decisions made in the past:

  • Blocks need to be registered on the server so we can define the attributes to use when querying HTML content.
  • The way how blocks get saved to HTML might change over time. The only way to migrate them to the latest version is to run the migration logic (usually when opening in the editor) that is written only in PHP. In effect, we can't run the same code on the server to migrate blocks, so even when we have the definition of attributes, that might not be what fully matches the outdated HTML stored in the database.
  • The last but less concerning issue here, but still a valid one, is the attribute's default value. We can't access that value if the block isn't registered on the server. In many cases, it isn't a problem when working with structured data.

What is your proposed solution?

What if we offer an optional editor setting that enables a few optimizations that resolve the listed issues when consuming WordPress blocks as structured data?

Here are some initial ideas:

  1. First idea comes from @dmsnell and is explained at length in his blog post - disable the mechanism that prevents attributes sourced from HTML in the block comment delimiter. It will create duplication, increasing the size of the content stored in the database. That might complicate updating the block by hand, as the HTML of the block would no longer be a source of truth for those attributes. However, in that case, only the block comment delimiter matters because the block's HTML becomes merely a historical snapshot from when it got saved by the editor.
  2. Expose block data directly through REST API endpoints (Trac ticket). When retrieving a post via the REST API you could get the block data as part of the content object instead of the HTML.
  3. Expand get_post's $filter parameter to allow block data as a return shape (Trac ticket).
@gziolo gziolo added [Feature] Block API API that allows to express the block paradigm. [Feature] Blocks Overall functionality of blocks labels Mar 29, 2023
@gziolo gziolo mentioned this issue Mar 29, 2023
69 tasks
@gziolo gziolo changed the title Blocks: Optional support that optimized blocks for usage as structured data Blocks: Optional support that optimizes handling blocks for usage as structured data Mar 29, 2023
@gziolo gziolo added the [Type] Feature New feature to highlight in changelogs. label Mar 29, 2023
@gziolo
Copy link
Member Author

gziolo commented May 12, 2023

We are exploring a new concept of a partially synced pattern, as explained in #48458. There is an ongoing discussion (see my comment #50456 (reply in thread)) on how to dynamically mark content in the saved HTML to replace it on the server with PHP during the rendering phase. While it isn't related to this issue directly, it can offer some new ideas on how to mark and read the content stored inside HTML to use it as structured data. I can see the future where we find a way to post-process the saved HTML in JavaScript and modify the markup to precisely annotate it with data attributes that would hint that tag attributes or inner HTML contains value related to block attributes. This way we could resolve all the issues listed in the description.

@gziolo
Copy link
Member Author

gziolo commented Dec 10, 2024

There is an ongoing exploration (#46345) to build a tool that reads attributes sourced from HTML on the server with PHP, but it might only work in some specific cases.

@sirreal continued exploring how to add CSS selector support to HTML API. The prototype is ready:

This line of work is tracked in WordPress Trac at https://core.trac.wordpress.org/ticket/62653.

In practical terms, it means that eventually we will be able to source block attributes from HTML saved for blocks. This would be a huge win for all the use cases where developers want to consume blocks as structured data. There would still be some limitations as outlined in the description, but this should work pretty well in most cases. The hope is that when all the development concludes, then when rendering the block on the server, the developer will have access to the value of every attribute inside render_callback through the $attributes param. Additionally, two bullet points covered in this issue would be simple to implement:

  1. Expose block data directly through REST API endpoints (Trac ticket). When retrieving a post via the REST API you could get the block data as part of the content object instead of the HTML.
  2. Expand get_post's $filter parameter to allow block data as a return shape (Trac ticket).

@gziolo gziolo added the [Feature] HTML API An API for updating HTML attributes in markup label Dec 10, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Block API API that allows to express the block paradigm. [Feature] Blocks Overall functionality of blocks [Feature] HTML API An API for updating HTML attributes in markup [Type] Feature New feature to highlight in changelogs.
Projects
None yet
Development

No branches or pull requests

1 participant