/** * External dependencies */ import { __ } from '@wordpress/i18n'; import { useEffect, useRef } from '@wordpress/element'; import { Button, Card, CardBody, CardHeader } from '@wordpress/components'; import { useSelect, useDispatch } from '@wordpress/data'; import { EllipsisMenu, Badge, __experimentalList as List, } from '@woocommerce/components'; import { updateQueryString } from '@woocommerce/navigation'; import { OPTIONS_STORE_NAME, ONBOARDING_STORE_NAME } from '@woocommerce/data'; import { recordEvent } from '@woocommerce/tracks'; import { Text } from '@woocommerce/experimental'; /** * Internal dependencies */ import { TaskItem } from './task-item'; export const TaskList = ( { query, name = 'task_list', isComplete, dismissedTasks, tasks, trackedCompletedTasks: totalTrackedCompletedTasks, title: listTitle, } ) => { const { createNotice } = useDispatch( 'core/notices' ); const { updateOptions } = useDispatch( OPTIONS_STORE_NAME ); const { profileItems } = useSelect( ( select ) => { const { getProfileItems } = select( ONBOARDING_STORE_NAME ); return { profileItems: getProfileItems(), }; } ); const prevQueryRef = useRef( query ); useEffect( () => { recordTaskListView(); }, [] ); useEffect( () => { const { task: prevTask } = prevQueryRef.current; const { task } = query; if ( prevTask !== task ) { window.document.documentElement.scrollTop = 0; prevQueryRef.current = query; } possiblyCompleteTaskList(); possiblyTrackCompletedTasks(); }, [ query ] ); const possiblyCompleteTaskList = () => { const taskListVariableName = `woocommerce_${ name }_complete`; const taskListToComplete = isComplete ? { [ taskListVariableName ]: 'no' } : { [ taskListVariableName ]: 'yes' }; if ( name === 'task_list' ) { taskListToComplete.woocommerce_default_homepage_layout = 'two_columns'; } if ( ( ! getIncompleteTasks().length && ! isComplete ) || ( getIncompleteTasks().length && isComplete ) ) { updateOptions( { ...taskListToComplete, } ); } }; const getCompletedTaskKeys = () => { return getVisibleTasks() .filter( ( task ) => task.completed ) .map( ( task ) => task.key ); }; const getIncompleteTasks = () => { return tasks.filter( ( task ) => task.visible && ! task.completed && ! dismissedTasks.includes( task.key ) ); }; const getTrackedIncompletedTasks = ( partialCompletedTasks, allTrackedTask ) => { return getVisibleTasks() .filter( ( task ) => allTrackedTask.includes( task.key ) && ! partialCompletedTasks.includes( task.key ) ) .map( ( task ) => task.key ); }; const possiblyTrackCompletedTasks = () => { const completedTaskKeys = getCompletedTaskKeys(); const trackedCompletedTasks = getTrackedCompletedTasks( completedTaskKeys, totalTrackedCompletedTasks ); const trackedIncompleteTasks = getTrackedIncompletedTasks( trackedCompletedTasks, totalTrackedCompletedTasks ); if ( shouldUpdateCompletedTasks( trackedCompletedTasks, trackedIncompleteTasks, completedTaskKeys ) ) { updateOptions( { woocommerce_task_list_tracked_completed_tasks: getTasksForUpdate( completedTaskKeys, totalTrackedCompletedTasks, trackedIncompleteTasks ), } ); } }; const dismissTask = ( { key, onDismiss } ) => { createNotice( 'success', __( 'Task dismissed' ), { actions: [ { label: __( 'Undo', 'woocommerce-admin' ), onClick: () => undoDismissTask( key ), }, ], } ); recordEvent( 'tasklist_dismiss_task', { task_name: key } ); updateOptions( { woocommerce_task_list_dismissed_tasks: [ ...dismissedTasks, key ], } ); if ( onDismiss ) { onDismiss(); } }; const undoDismissTask = ( key ) => { const updatedDismissedTasks = dismissedTasks.filter( ( task ) => task !== key ); updateOptions( { woocommerce_task_list_dismissed_tasks: updatedDismissedTasks, } ); }; const getVisibleTasks = () => { return tasks.filter( ( task ) => task.visible && ! dismissedTasks.includes( task.key ) ); }; const recordTaskListView = () => { if ( query.task ) { return; } const isCoreTaskList = name === 'task_list'; const taskListName = isCoreTaskList ? 'tasklist' : 'extended_tasklist'; const visibleTasks = getVisibleTasks(); recordEvent( `${ taskListName }_view`, { number_tasks: visibleTasks.length, store_connected: profileItems.wccom_connected, } ); }; const hideTaskCard = ( action ) => { const isCoreTaskList = name === 'task_list'; const taskListName = isCoreTaskList ? 'tasklist' : 'extended_tasklist'; const updateOptionsParams = { [ `woocommerce_${ name }_hidden` ]: 'yes', }; if ( isCoreTaskList ) { updateOptionsParams.woocommerce_task_list_prompt_shown = true; updateOptionsParams.woocommerce_default_homepage_layout = 'two_columns'; } recordEvent( `${ taskListName }_completed`, { action, completed_task_count: getCompletedTaskKeys().length, incomplete_task_count: getIncompleteTasks().length, } ); updateOptions( { ...updateOptionsParams, } ); }; const renderMenu = () => { return (