woocommerce/plugins/woocommerce-admin/client/tasks/task.tsx

54 lines
1.4 KiB
TypeScript
Raw Normal View History

/**
* External dependencies
*/
import { WooOnboardingTask } from '@woocommerce/onboarding';
import { getHistory, getNewPath } from '@woocommerce/navigation';
import { ONBOARDING_STORE_NAME, TaskType } from '@woocommerce/data';
import { useCallback } from '@wordpress/element';
import { useDispatch } from '@wordpress/data';
2022-04-20 08:48:53 +00:00
import { History } from 'history';
/**
* Internal dependencies
*/
import { WooHeaderNavigationItem, WooHeaderPageTitle } from '~/header/utils';
import { BackButton } from './back-button';
export type TaskProps = {
2022-04-20 08:48:53 +00:00
query: { task?: string };
task: TaskType;
};
export const Task: React.FC< TaskProps > = ( { query, task } ) => {
const id = query.task;
const {
invalidateResolutionForStoreSelector,
optimisticallyCompleteTask,
} = useDispatch( ONBOARDING_STORE_NAME );
const onComplete = useCallback(
( options ) => {
optimisticallyCompleteTask( id );
2022-04-20 08:48:53 +00:00
( getHistory() as History ).push(
options && options.redirectPath
? options.redirectPath
: getNewPath( {}, '/', {} )
);
invalidateResolutionForStoreSelector( 'getTaskLists' );
},
[ id ]
);
return (
<>
<WooHeaderNavigationItem>
<BackButton title={ task.title } />
</WooHeaderNavigationItem>
<WooHeaderPageTitle>{ task.title }</WooHeaderPageTitle>
<WooOnboardingTask.Slot
id={ id }
fillProps={ { onComplete, query, task } }
/>
</>
);
};