/** * External dependencies */ import { Fragment, Suspense, lazy, useState, useRef, useEffect, } from '@wordpress/element'; import { Button } from '@wordpress/components'; import { compose } from '@wordpress/compose'; import classnames from 'classnames'; import { get } from 'lodash'; import PropTypes from 'prop-types'; /** * WooCommerce dependencies */ import { Spinner } from '@woocommerce/components'; /** * Internal dependencies */ import QuickLinks from '../quick-links'; import StatsOverview from './stats-overview'; import './style.scss'; import { isOnboardingEnabled } from 'dashboard/utils'; import withSelect from 'wc-api/with-select'; import TaskListPlaceholder from '../task-list/placeholder'; const TaskList = lazy( () => import( /* webpackChunkName: "task-list" */ '../task-list' ) ); export const Layout = ( props ) => { const [ showInbox, setShowInbox ] = useState( true ); const [ isContentSticky, setIsContentSticky ] = useState( false ); const content = useRef( null ); const maybeStickContent = () => { if ( ! content.current ) { return; } const { bottom } = content.current.getBoundingClientRect(); const shouldBeSticky = showInbox && bottom < window.innerHeight; setIsContentSticky( shouldBeSticky ); }; useEffect( () => { maybeStickContent(); window.addEventListener( 'resize', maybeStickContent ); return () => { window.removeEventListener( 'resize', maybeStickContent ); }; }, [] ); const { query, requestingTaskList, taskListHidden } = props; const isTaskListEnabled = taskListHidden === false; const isDashboardShown = ! isTaskListEnabled || ! query.task; const renderColumns = () => { return ( { showInbox && (
) }
{ isTaskListEnabled && renderTaskList() }
); }; const renderTaskList = () => { if ( requestingTaskList ) { return ; } return ( }> ); }; return (
{ isDashboardShown ? renderColumns() : isTaskListEnabled && renderTaskList() }
); }; Layout.propTypes = { /** * If the task list option is being fetched. */ requestingTaskList: PropTypes.bool.isRequired, /** * If the task list is hidden. */ taskListHidden: PropTypes.bool, /** * Page query, used to determine the current task if any. */ query: PropTypes.object.isRequired, }; export default compose( withSelect( ( select ) => { const { getOptions, isGetOptionsRequesting, } = select( 'wc-api' ); if ( isOnboardingEnabled() ) { const options = getOptions( [ 'woocommerce_task_list_hidden', ] ); return { requestingTaskList: isGetOptionsRequesting( [ 'woocommerce_task_list_hidden', ] ), taskListHidden: get( options, [ 'woocommerce_task_list_hidden' ] ) === 'yes', }; } return { requestingTaskList: false, }; } ) )( Layout );