UNPKG

@wordpress/editor

Version:
93 lines (86 loc) 2.58 kB
/** * WordPress dependencies */ import { useDispatch, useSelect } from '@wordpress/data'; import { useMemo, useEffect } from '@wordpress/element'; /** * Internal dependencies */ import { store as editorStore } from '../../store'; import { unlock } from '../../lock-unlock'; export function usePostActions( { postType, onActionPerformed, context } ) { const { defaultActions } = useSelect( ( select ) => { const { getEntityActions } = unlock( select( editorStore ) ); return { defaultActions: getEntityActions( 'postType', postType ), }; }, [ postType ] ); const { registerPostTypeActions } = unlock( useDispatch( editorStore ) ); useEffect( () => { registerPostTypeActions( postType ); }, [ registerPostTypeActions, postType ] ); return useMemo( () => { // Filter actions based on provided context. If not provided // all actions are returned. We'll have a single entry for getting the actions // and the consumer should provide the context to filter the actions, if needed. // Actions should also provide the `context` they support, if it's specific, to // compare with the provided context to get all the actions. // Right now the only supported context is `list`. const actions = defaultActions.filter( ( action ) => { if ( ! action.context ) { return true; } return action.context === context; } ); if ( onActionPerformed ) { for ( let i = 0; i < actions.length; ++i ) { if ( actions[ i ].callback ) { const existingCallback = actions[ i ].callback; actions[ i ] = { ...actions[ i ], callback: ( items, argsObject ) => { existingCallback( items, { ...argsObject, onActionPerformed: ( _items ) => { if ( argsObject?.onActionPerformed ) { argsObject.onActionPerformed( _items ); } onActionPerformed( actions[ i ].id, _items ); }, } ); }, }; } if ( actions[ i ].RenderModal ) { const ExistingRenderModal = actions[ i ].RenderModal; actions[ i ] = { ...actions[ i ], RenderModal: ( props ) => { return ( <ExistingRenderModal { ...props } onActionPerformed={ ( _items ) => { if ( props.onActionPerformed ) { props.onActionPerformed( _items ); } onActionPerformed( actions[ i ].id, _items ); } } /> ); }, }; } } } return actions; }, [ defaultActions, onActionPerformed, context ] ); }