Skip to content

Commit

Permalink
DataViews Extensibility: Allow unregistering the duplicate template p…
Browse files Browse the repository at this point in the history
…art action (#64388)

Co-authored-by: youknowriad <[email protected]>
Co-authored-by: ntsekouras <[email protected]>
  • Loading branch information
3 people authored and getdave committed Aug 14, 2024
1 parent 2472a2c commit a8cc243
Show file tree
Hide file tree
Showing 4 changed files with 83 additions and 71 deletions.
72 changes: 2 additions & 70 deletions packages/editor/src/components/post-actions/actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import { store as coreStore } from '@wordpress/core-data';
import { __, sprintf, _x } from '@wordpress/i18n';
import { store as noticesStore } from '@wordpress/notices';
import { useMemo, useState, useEffect } from '@wordpress/element';
import { parse } from '@wordpress/blocks';
import { DataForm } from '@wordpress/dataviews';
import {
Button,
Expand All @@ -27,7 +26,6 @@ import {
} from '../../store/constants';
import { store as editorStore } from '../../store';
import { unlock } from '../../lock-unlock';
import { CreateTemplatePartModalContents } from '../create-template-part-modal';
import { getItemTitle } from '../../dataviews/actions/utils';

// TODO: this should be shared with other components (see post-fields in edit-site).
Expand Down Expand Up @@ -268,75 +266,14 @@ const useDuplicatePostAction = ( postType ) => {
);
};

export const duplicateTemplatePartAction = {
id: 'duplicate-template-part',
label: _x( 'Duplicate', 'action label' ),
isEligible: ( item ) => item.type === TEMPLATE_PART_POST_TYPE,
modalHeader: _x( 'Duplicate template part', 'action label' ),
RenderModal: ( { items, closeModal } ) => {
const [ item ] = items;
const blocks = useMemo( () => {
return (
item.blocks ??
parse(
typeof item.content === 'string'
? item.content
: item.content.raw,
{
__unstableSkipMigrationLogs: true,
}
)
);
}, [ item.content, item.blocks ] );
const { createSuccessNotice } = useDispatch( noticesStore );
function onTemplatePartSuccess() {
createSuccessNotice(
sprintf(
// translators: %s: The new template part's title e.g. 'Call to action (copy)'.
__( '"%s" duplicated.' ),
getItemTitle( item )
),
{ type: 'snackbar', id: 'edit-site-patterns-success' }
);
closeModal();
}
return (
<CreateTemplatePartModalContents
blocks={ blocks }
defaultArea={ item.area }
defaultTitle={ sprintf(
/* translators: %s: Existing template part title */
__( '%s (Copy)' ),
getItemTitle( item )
) }
onCreate={ onTemplatePartSuccess }
onError={ closeModal }
confirmLabel={ _x( 'Duplicate', 'action label' ) }
closeModal={ closeModal }
/>
);
},
};

export function usePostActions( { postType, onActionPerformed, context } ) {
const {
defaultActions,
postTypeObject,
userCanCreatePostType,
isBlockBasedTheme,
} = useSelect(
const { defaultActions, postTypeObject } = useSelect(
( select ) => {
const { getPostType, canUser, getCurrentTheme } =
select( coreStore );
const { getPostType } = select( coreStore );
const { getEntityActions } = unlock( select( editorStore ) );
return {
postTypeObject: getPostType( postType ),
defaultActions: getEntityActions( 'postType', postType ),
userCanCreatePostType: canUser( 'create', {
kind: 'postType',
name: postType,
} ),
isBlockBasedTheme: getCurrentTheme()?.is_block_theme,
};
},
[ postType ]
Expand Down Expand Up @@ -368,10 +305,6 @@ export function usePostActions( { postType, onActionPerformed, context } ) {
! isPattern &&
duplicatePostAction
: false,
isTemplateOrTemplatePart &&
userCanCreatePostType &&
isBlockBasedTheme &&
duplicateTemplatePartAction,
...defaultActions,
].filter( Boolean );
// Filter actions based on provided context. If not provided
Expand Down Expand Up @@ -437,7 +370,6 @@ export function usePostActions( { postType, onActionPerformed, context } ) {
return actions;
}, [
defaultActions,
userCanCreatePostType,
isTemplateOrTemplatePart,
isPattern,
postTypeObject?.viewable,
Expand Down
70 changes: 70 additions & 0 deletions packages/editor/src/dataviews/actions/duplicate-template-part.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
/**
* WordPress dependencies
*/
import { useDispatch } from '@wordpress/data';
import { __, sprintf, _x } from '@wordpress/i18n';
import { store as noticesStore } from '@wordpress/notices';
import { useMemo } from '@wordpress/element';
// @ts-ignore
import { parse } from '@wordpress/blocks';
import type { Action } from '@wordpress/dataviews';

/**
* Internal dependencies
*/
import { TEMPLATE_PART_POST_TYPE } from '../../store/constants';
import { CreateTemplatePartModalContents } from '../../components/create-template-part-modal';
import { getItemTitle } from './utils';
import type { TemplatePart } from '../types';

const duplicateTemplatePart: Action< TemplatePart > = {
id: 'duplicate-template-part',
label: _x( 'Duplicate', 'action label' ),
isEligible: ( item ) => item.type === TEMPLATE_PART_POST_TYPE,
modalHeader: _x( 'Duplicate template part', 'action label' ),
RenderModal: ( { items, closeModal } ) => {
const [ item ] = items;
const blocks = useMemo( () => {
return (
item.blocks ??
parse(
typeof item.content === 'string'
? item.content
: item.content.raw,
{
__unstableSkipMigrationLogs: true,
}
)
);
}, [ item.content, item.blocks ] );
const { createSuccessNotice } = useDispatch( noticesStore );
function onTemplatePartSuccess() {
createSuccessNotice(
sprintf(
// translators: %s: The new template part's title e.g. 'Call to action (copy)'.
__( '"%s" duplicated.' ),
getItemTitle( item )
),
{ type: 'snackbar', id: 'edit-site-patterns-success' }
);
closeModal?.();
}
return (
<CreateTemplatePartModalContents
blocks={ blocks }
defaultArea={ item.area }
defaultTitle={ sprintf(
/* translators: %s: Existing template part title */
__( '%s (Copy)' ),
getItemTitle( item )
) }
onCreate={ onTemplatePartSuccess }
onError={ closeModal }
confirmLabel={ _x( 'Duplicate', 'action label' ) }
closeModal={ closeModal }
/>
);
},
};

export default duplicateTemplatePart;
8 changes: 8 additions & 0 deletions packages/editor/src/dataviews/store/private-actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { doAction } from '@wordpress/hooks';
*/
import deletePost from '../actions/delete-post';
import duplicatePattern from '../actions/duplicate-pattern';
import duplicateTemplatePart from '../actions/duplicate-template-part';
import exportPattern from '../actions/export-pattern';
import resetPost from '../actions/reset-post';
import trashPost from '../actions/trash-post';
Expand Down Expand Up @@ -81,8 +82,15 @@ export const registerPostTypeActions =
kind: 'postType',
name: postType,
} );
const currentTheme = await registry
.resolveSelect( coreStore )
.getCurrentTheme();

const actions = [
postTypeConfig.slug === 'wp_template_part' &&
canCreate &&
currentTheme?.is_block_theme &&
duplicateTemplatePart,
canCreate && postTypeConfig.slug === 'wp_block'
? duplicatePattern
: undefined,
Expand Down
4 changes: 3 additions & 1 deletion packages/editor/src/dataviews/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,10 @@ type PostStatus =
export interface BasePost {
status?: PostStatus;
title: string | { rendered: string } | { raw: string };
content: string | { raw: string; rendered: string };
type: string;
id: string | number;
blocks?: Object[];
}

export interface Template extends BasePost {
Expand All @@ -27,12 +29,12 @@ export interface TemplatePart extends BasePost {
source: string;
has_theme_file: boolean;
id: string;
area: string;
}

export interface Pattern extends BasePost {
slug: string;
title: { raw: string };
content: { raw: string } | string;
wp_pattern_sync_status: string;
}

Expand Down

0 comments on commit a8cc243

Please sign in to comment.