/** * External dependencies */ import { useSelect } from '@wordpress/data'; import { Badge } from '@woocommerce/components'; import { Button, Panel, PanelBody, PanelRow, __experimentalText as Text, } from '@wordpress/components'; import { getSetting } from '@woocommerce/wc-admin-settings'; import { OPTIONS_STORE_NAME } from '@woocommerce/data'; import { recordEvent } from '@woocommerce/tracks'; import { useEffect } from '@wordpress/element'; import { snakeCase } from 'lodash'; /** * Internal dependencies */ import './style.scss'; import { getLowStockCount, getOrderStatuses, getUnreadOrders, } from './orders/utils'; import { getAllPanels } from './panels'; import { getUnapprovedReviews } from './reviews/utils'; import { getUrlParams } from '../../utils'; export const ActivityPanel = () => { const panelsData = useSelect( ( select ) => { const totalOrderCount = getSetting( 'orderCount', 0 ); const orderStatuses = getOrderStatuses( select ); const reviewsEnabled = getSetting( 'reviewsEnabled', 'no' ); const countUnreadOrders = getUnreadOrders( select, orderStatuses ); const manageStock = getSetting( 'manageStock', 'no' ); const countLowStockProducts = getLowStockCount( select ); const countUnapprovedReviews = getUnapprovedReviews( select ); const publishedProductCount = getSetting( 'publishedProductCount', 0 ); const { getOption } = select( OPTIONS_STORE_NAME ); const isTaskListHidden = getOption( 'woocommerce_task_list_hidden' ); return { countLowStockProducts, countUnapprovedReviews, countUnreadOrders, isTaskListHidden, manageStock, publishedProductCount, reviewsEnabled, totalOrderCount, orderStatuses, }; } ); const panels = getAllPanels( panelsData ); useEffect( () => { if ( panelsData.isTaskListHidden !== undefined ) { const visiblePanels = panels.reduce( ( acc, panel ) => { const panelId = snakeCase( panel.id ); acc[ panelId ] = true; return acc; }, { task_list: panelsData.isTaskListHidden !== 'yes' } ); recordEvent( 'activity_panel_visible_panels', visiblePanels ); } }, [ panelsData.isTaskListHidden ] ); if ( panels.length === 0 ) { return null; } const getInitialOpenState = ( panelId ) => { const { opened_panel: openedPanel } = getUrlParams( window.location.search ); return panelId === openedPanel; }; return ( { panels.map( ( panelData ) => { const { className, count, id, initialOpen, panel, title, collapsible, } = panelData; return collapsible ? ( { title } , count !== null && ( ), ] } key={ id } className={ className } initialOpen={ getInitialOpenState( id ) || initialOpen } collapsible={ collapsible } disabled={ ! collapsible } onToggle={ ( isOpen ) => { if ( ! isOpen ) { return; } recordEvent( 'activity_panel_open', { tab: id, } ); } } > { panel } ) : (

); } ) }
); };