-
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
Post Type Actions: Unify the list of available actions #61520
Conversation
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 realize this moves away from the "cherry-picking" aspect that we've landed on before, but I think it's for the better.
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
@@ -373,7 +350,7 @@ export default function PagePages() { | |||
}, | |||
[ history ] | |||
); | |||
const actions = usePostActions( onActionPerformed, PAGE_ACTIONS ); | |||
const actions = usePostActions( onActionPerformed ); |
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.
This hook should be receiving the postType, otherwise it will give inconsistent results.
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.
Also, I think this hook is misplaced it should be in "core-data" and not in "editor".
! isTemplateOrTemplatePart && renamePostAction, | ||
isTemplateOrTemplatePart && renameTemplateAction, | ||
! isTemplateOrTemplatePart && trashPostAction, | ||
].filter( Boolean ); |
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.
This is where the filtering of the actions based on post type happens. Ideally we should be checking post type slugs but supports (like we do for postType.viewable).
Also ideally some actions should merge like (rename template and rename post...) but I'm leaving that for later.
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.
The checking for postType.viewable, and even things like rules e.g.: can delete can create another post, etc should be done on isEligible I think.
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.
Not entirely sure about postType.viewable #61520 (comment)
Size Change: +1.77 kB (+0.1%) Total Size: 1.74 MB
ℹ️ View Unchanged
|
@@ -48,7 +48,6 @@ import { | |||
} from '../../utils/constants'; | |||
import { | |||
exportJSONaction, | |||
renameAction, | |||
resetAction, | |||
deleteAction, | |||
duplicatePatternAction, |
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.
All of these actions need to be moved to the editor/post-actions hook rather than being specific to dataviews. I'm not doing that in this PR though.
f034822
to
4b6b24f
Compare
) | ||
: defaultActions; | ||
const actions = [ | ||
isTemplateOrTemplatePart && resetTemplateAction, |
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 wonder if it would not be better to do the checks for post type on the isEligible function of the action it self.
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 thought about it, I do think it would be better but I'm not sure that the current API allows us to do that. The isEligible can't call selectors with resolvers at the moment and be certain that the value is there.
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 also not sure 100% that it's better. This is the mental model I have for now:
- isEligible is for actions that can apply to one item of the current dataviews/list but may not apply for a reason that is specific to the current item.
- The actions you pass to DataViews (or the Actions component) are all "valid" for the current post type.
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.
On the item itself, the rest API provides some checks in wp:action... that allows some possibilities but yes it is very limited.
I imagine a plugin may want to build a view that shows all posts from all types in the database in that case we would want all actions there, and depending on the item some would be available, and some would not.
But given that we are keeping actions as hooks we can keep the current approach the current mental modal long term maybe isEligible should be an async function.
@@ -982,95 +973,96 @@ const renameTemplateAction = { | |||
}, | |||
}; | |||
|
|||
export function usePostActions( onActionPerformed, actionIds = null ) { | |||
export function usePostActions( postType, onActionPerformed ) { |
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 liked the previous flexibility of allowing the consumer to select the actions. I think we will end up needing to retrieve only some actions in some cases. But I'm fine with using postType for now until we see if that need materializes.
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 think flexibility comes with inconsistency. I'd like to avoid it until we find our selves in a situation where we want to pick what we want. Users can still pick what they want, it's just a simple filter on top of the returned value.
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.
Things tested well for me I did not notice any regression, and the code looks good 👍
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 quick! Nice work.
[ 'edit-post', 'view-post-revisions' ] | ||
); | ||
const templatePartActions = usePostActions( TEMPLATE_PART_POST_TYPE ); | ||
const patternActions = usePostActions( PATTERN_TYPES.user ); |
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 ever more convinced we should drop these constants across patterns, dataviews, etc. It's easy to waste 30 seconds, which become 1.5 minutes with the ensuing distractions, especially when the LSP can't trace the identifier to its type/definition due to the opaque unlock
membrane... just to confirm that PATTERN_TYPES.user
is 'wp_block'
. These aren't obscure values, they are standard post types and other such values.
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.
Maybe open a PR and see what folks say about it :)
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 quick! Nice work.
I echo that 😄
Thanks Riad! I think we should keep track of the remaining follow ups that are needed, like moving some actions to different packages, reusing some actions like the renamePostAction, etc.. I like that some things are clearer now like we don't have to pass around specific action ids and filter all the available actions.
I'm wondering if we'll come across use cases where we want different actions in Data Views and Post Card panel actions for the same post type and how we'll accommodate this with this API, but I guess future will tell 😄
item: getCurrentPost(), | ||
postType: getCurrentPostType(), |
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 know this existed here, but I've commented about it elsewhere too. I think it's probably better to use the edited entity, because many actions might be better to use the current info, even if not saved. Examples would be the rename Post action, or the duplicate post action.
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.
Definitely :) Good catch.
So here are the follow-ups that I can think of:
|
What?
While working on the unification of the editor sidebar between the post and site editors, I noticed that we have two separate components to render the "Actions" of a given post type: PostActions and TemplateActions in the site editor. I think we should only have a single component that is responsible of rendering the actions for a given post type. We shouldn't have to be making decisions randomly, instead the post type should give us enough information to know what action is available or not.
This will also help with extensibility since we'll be able to filter the available actions in a single place per post type.
Note This is affects both the actions panel in the editor and the actions in the dataviews for these post types. Some actions don't make sense in both context (like edit) and will need to be moved out of the generic place. So this is not ready entirely.
Testing Instructions
1- Test the Actions menu for all post types (pages, posts, template, template part, pattern)
2- Test in both dataviews and editor.