-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Data storage mechanisms for blocks #390
Comments
You seem to be mixing apples and oranges here. First, the gallery shortcode is not a block. It's a shortcode with a specific purpose. If the gallery block that is being created is meant to replace the shortcode, it would need a different implementation. From what I can see, the gallery block is not a replacement of the shortcode, but a block that contains all the images and captions within it. It is self-contained and does not get information from outside to render it. That sounds to me like a static block, not a dynamic one. |
@nylen I understand where you're coming from, but there are some big advantages also to being able to reference data stored externally to the post content. For one, it keeps it DRY. Imagine uploading an image to the gallery and you give it a caption but there is a typo. If you create multiple galleries with that image, it would be sad to have to update each gallery with the fixed caption. Ideally you would be able to update it once, and that is what we have today. |
Yes, this is the (unstated) assumption I was making in the original issue - that in general, the Gutenberg editor will be able to transparently "upgrade" post content from shortcodes to
Maybe a gallery isn't the best example to use here, and we'll end up sticking with more of the way WP currently works for this particular case. In particular I'd like to avoid storing information in post meta, rather providing a standard way for blocks to serialize and deserialize the data they need to/from markup inside |
@westonruter on the other hand, that prevents you from having different captions for the same image in different galleries, which is different from how single images work. |
@mtias that's right. So it should be a both/and instead of an either/or, it seems. |
Yes, I'm thinking reusable dynamic blocks needs to be handled differently and probably with an explicit flow. |
Sounds like widgets. |
Widgets are not really reusable, they are instances. |
How do you mean? |
If I have, say, a text widget in a sidebar I can't reuse it in another place without creating a new instance by hand. |
Given the current widget sidebars UI, that's true. But widgets can be used independently of sidebars. For example, there is also |
Besides which, the original example of using different captions on the same image is exactly what the widget does by each instance storing its own version of how to display its data. Again, if you want reuseable "same data", you would use a shortcode with the same parameters. If you want reuseable "customized", you would use a widget. And if you just want the data in the post with nothing dynamic, then it's just plain old content inserted like usual. |
While I've decided to shelve this idea for now, I'll recap an exploration I'd considered yesterday involving using linked data (specifically JSON-LD) as the source of truth data storage mechanism of a block. Instead of parsing the HTML of a block, we'd understand it by its JSON data: <!-- wp:core/image -->
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "ImageObject",
"caption": "Beautiful landscape",
"contentUrl": "https://cldup.com/vuGcj2VB8M.jpg"
}
</script>
<figure>
<img src="https://cldup.com/vuGcj2VB8M.jpg" />
<figcaption>Beautiful landscape</figcaption>
</figure>
<!-- /wp:core/image --> And, as we have already with the block's There are a few benefits of this approach:
And of course some downsides:
A few more interesting references I found along the way:
|
To me the major downside of using something like JSON-LD is that we would be duplicating information between the markup and the annotations. This would unavoidably lead to unexpected results and the two sources of information getting out of sync. |
See also #886 and its discussion of defining a schema with the server-side block registration. |
Closing; this discussion has served its purpose and further tasks should be split out into separate, smaller issues. |
I've been thinking about the best way(s) to handle parsing and data storage, which I think will end up being pretty closely related. This is important for us to get right so that we build a solid foundation for other plugins.
I'll start with one of the things that annoys me about WordPress: settings for shortcodes like
[gallery]
. We see the list of IDs inpost_content
, but what about the other settings? A lot of them are missing, stored along with the attachment post, and I think there are a lot of cases where settings are stored in post meta as well. For a concrete example, if you want to use the same image on multiple galleries, with different captions, AFAIK this is impossible because the caption is stored as a property of the image only.I don't know all the permutations of how this works currently, but it's a mess and I shouldn't have to care. I should be able to take whatever appears in
post_content
for a gallery block, paste it to another post or another location in the same post, and everything should "just work".I'd really like to avoid repeating this set of mistakes from "classic" WordPress. If we're storing data in
post_content
, let's store all the data inpost_content
. If we can also ensure that we serialize block information to semantically-meaningful markup, this will have a lot of other benefits:The text was updated successfully, but these errors were encountered: