67 lines
1.7 KiB
JavaScript
67 lines
1.7 KiB
JavaScript
|
/**
|
||
|
* External dependencies
|
||
|
*/
|
||
|
import { __ } from '@wordpress/i18n';
|
||
|
import { Button } from '@wordpress/components';
|
||
|
import { useState, useCallback } from '@wordpress/element';
|
||
|
import { recordEvent } from '@woocommerce/tracks';
|
||
|
|
||
|
/**
|
||
|
* Internal dependencies
|
||
|
*/
|
||
|
import CartModal from '~/dashboard/components/cart-modal';
|
||
|
import TimerImage from './timer.svg';
|
||
|
import { WC_ASSET_URL } from '../../utils/admin-settings';
|
||
|
|
||
|
const PurchaseHeader = ( { task } ) => {
|
||
|
const [ cartModalOpen, setCartModalOpen ] = useState( false );
|
||
|
|
||
|
const toggleCartModal = useCallback( () => {
|
||
|
if ( ! cartModalOpen ) {
|
||
|
recordEvent( 'tasklist_purchase_extensions' );
|
||
|
}
|
||
|
|
||
|
setCartModalOpen( ! cartModalOpen );
|
||
|
}, [ cartModalOpen ] );
|
||
|
|
||
|
return (
|
||
|
<div className="woocommerce-task-header__contents-container">
|
||
|
<img
|
||
|
alt={ __( 'Purchase illustration', 'woocommerce' ) }
|
||
|
src={
|
||
|
WC_ASSET_URL + 'images/task_list/purchase-illustration.png'
|
||
|
}
|
||
|
className="svg-background"
|
||
|
/>
|
||
|
<div className="woocommerce-task-header__contents">
|
||
|
<h1>{ task.title }</h1>
|
||
|
<p>
|
||
|
{ __(
|
||
|
'Good choice! You chose to add amazing new features to your store. Continue to checkout to complete your purchase.',
|
||
|
'woocommerce'
|
||
|
) }
|
||
|
</p>
|
||
|
<Button
|
||
|
isSecondary={ task.isComplete }
|
||
|
isPrimary={ ! task.isComplete }
|
||
|
onClick={ toggleCartModal }
|
||
|
>
|
||
|
{ __( 'Continue', 'woocommerce' ) }
|
||
|
</Button>
|
||
|
<p className="woocommerce-task-header__timer">
|
||
|
<img src={ TimerImage } alt="Timer" />{ ' ' }
|
||
|
<span>{ task.time }</span>
|
||
|
</p>
|
||
|
</div>
|
||
|
{ cartModalOpen && (
|
||
|
<CartModal
|
||
|
onClose={ () => toggleCartModal() }
|
||
|
onClickPurchaseLater={ () => toggleCartModal() }
|
||
|
/>
|
||
|
) }
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default PurchaseHeader;
|