-
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
Parsing: Declare all block attributes #714
Conversation
blocks/api/parser.js
Outdated
...parseBlockAttributes( rawContent, blockSettings ), | ||
}; | ||
} | ||
const computedAttributes = reduce( blockSettings.attributes, ( memo, attribute, key ) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we explain a bit more how this works here and the motivation behind it?
15fed13
to
1800bba
Compare
@@ -32,7 +32,8 @@ registerBlock( 'core/button', { | |||
attributes: { | |||
url: attr( 'a', 'href' ), | |||
title: attr( 'a', 'title' ), | |||
text: children( 'a' ) | |||
text: children( 'a' ), | |||
align: metadata() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm personally on the fence, but how do you feel about being even more explicit here with defining the metadata key to be extracted, rather than inferred by the key of the attribute.
For example:
align: metadata( 'align' )
My worry with this would be that there'd likely be very undesirable consequences if the developer were to make a typo or otherwise use an argument different from the key.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That was the first API I had, I made it optional in a second step. I thought it'd be handy to avoid duplication, but I'm ok reverting to a mandatory attribute name.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That was the first API I had, I made it optional in a second step. I thought it'd be handy to avoid duplication, but I'm ok reverting to a mandatory attribute name.
To avoid errors, it's probably better to keep as-is.
There's a side-question here of: is "metadata" the terminology we want to use for describing attributes serialized in the block comment? |
I'm not feeling the chainable API. Do you think if we were able to encode more types like numbers in the serialized comment itself, we'd even need it? |
I can understand. But the answer to the question is yes we need something to describe the arguments. I think the important part of this PR is introducing the attributes "metadata" (or descriptors, or whatever, we should choose a name). The attribute metadata could contain:
Now, how does a block author describe these metadata. I tought the chaining API could be a sugar syntax for this, but It's not a "requirement" for me. Having a more explicit object descriptor like this is ok for me to: attributes: {
align: {
source: metadata(),
type: 'string',
choices: [ 'left', 'right' ],
description: 'Text Align'
showInInspector: true
}
} |
I'd separately commented at #731 (comment) that I'm not sure I see reason that we need force inspector to be merged into attributes. Even if we had form builder logic included, would it be much worse as: attributes: {
align: metadata()
},
inspector: [
{
attribute: 'align',
type: 'string',
choices: [ /* ... */ ],
description: '...'
}
] Note also that this accounts for field ordering. I also don't have a good sense of the sorts of fields we'll expect to be included in an inspector. Should we really expect them to map so cleanly to attributes? To only display fields of supported types (dropdowns, text inputs)? What about custom inputs? All this being said, I think I could be convinced that it's nice to treat |
Me neither but I think we could display all attributes except "content" attributes. It's not very clear in my suggestion above but I'm proposing a
Yeah, I don't see much reasons to split the parsing information of attributes from the other descriptors which are generic information about the attribute and not specifically tied to the inspector. They serve for attributes "reflexion". They could be useful elsewhere. |
How can we move this forward? Should we take a decision now, or maybe I can update the PR to leave the |
I think ultimately the decision we make here should be made by those of you with technical prowess. But I'd like to give my high level thoughts on the purpose of the inspector, what problems it hopes to solve, and perhaps that can help guide a technical decision. Traditionally WordPress on the desktop has a quick toolbar with access to bold, italic, etc. Some actions, like editing a gallery or an audio shortcode, or a video shortcode, these all open modal windows: On mobile, however, these actions are rarely surfaced at all: The modal is also disruptive to the flow, and doesn't show context, as it essentially "covers the screen". The inspector is an attempt at fixing that, across mobile and desktop, by ensuring that all metadata lives in a single place, the Post Settings sidebar. On desktop, the post settings sidebar is shown by default, but can be toggled off. On mobile, the post settings sidebar has to be toggled when you want to access it. We are essentially levelling the playing field: all metadata lives in Post Settings. With no blocks selected you see the document level metadata — tags, categories, etc. When a block is selected, you see the block level metadata. Block level metadata is:
The decision on how to proceed should probably be informed by looking at what plugin authors currently put inside modals. Here are some more modal screenshots: Note: In the name of shipping I don't expect us to replace all those modals in V1 at all — that'll likely take time. But it would be the ultimate dream goal, to not need modals at all. |
Sorry I've let this one linger. Not specifically to the pieces addressed here, but matcher APIs have been on my mind lately related to #608 (still very easy to gain access to DOM properties, lacking some tools for deduplication) and #771 (better representation of |
Fair enough, I was planning to reuse some of these to start experimenting with the inspector, but it's not really blocking, let's close it for now. Fine to revisit later |
Related: #672 |
closes #609
attributes
propertyattributes
property` can not be defined as a function anymoremetadata
descriptor to declare an attribute as a comment attribute.This PR doesn't solve the typing yet, but the chainable API allows easily to add type descriptors (
isString
,isNumber
) etc...The chainable API allows things like that #609 (comment)