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

66 lines
1.6 KiB
TypeScript
Raw Normal View History

/**
* External dependencies
*/
import { registerPlugin } from '@wordpress/plugins';
import { WooOnboardingTask } from '@woocommerce/onboarding';
import { useSelect } from '@wordpress/data';
2022-04-21 04:44:19 +00:00
import {
ONBOARDING_STORE_NAME,
TaskType,
WCDataSelector,
} from '@woocommerce/data';
import { useEffect, useState } from '@wordpress/element';
2022-04-21 04:44:19 +00:00
type DeprecatedTask = TaskType & {
container: React.ReactNode;
};
const DeprecatedWooOnboardingTaskFills = () => {
2022-04-21 04:44:19 +00:00
const [ deprecatedTasks, setDeprecatedTasks ] = useState<
DeprecatedTask[]
>( [] );
const { isResolving, taskLists } = useSelect(
( select: WCDataSelector ) => {
return {
isResolving: select( ONBOARDING_STORE_NAME ).isResolving(
'getTaskLists'
),
taskLists: select( ONBOARDING_STORE_NAME ).getTaskLists(),
};
}
);
useEffect( () => {
if ( taskLists && taskLists.length > 0 ) {
const deprecatedTasksWithContainer = [];
for ( const tasklist of taskLists ) {
for ( const task of tasklist.tasks ) {
if ( task.isDeprecated && task.container ) {
deprecatedTasksWithContainer.push( task );
}
}
}
setDeprecatedTasks( deprecatedTasksWithContainer );
}
}, [ taskLists ] );
if ( isResolving ) {
return null;
}
return (
<>
{ deprecatedTasks.map( ( task ) => (
<WooOnboardingTask id={ task.id } key={ task.id }>
2022-04-21 04:44:19 +00:00
{ () => task.container }
</WooOnboardingTask>
) ) }
</>
);
};
registerPlugin( 'wc-admin-deprecated-task-container', {
2022-04-21 04:44:19 +00:00
// @ts-expect-error @types/wordpress__plugins need to be updated
scope: 'woocommerce-tasks',
render: () => <DeprecatedWooOnboardingTaskFills />,
} );