/** * External dependencies */ import { OrderSummary, TotalsCoupon, TotalsDiscount, TotalsFooterItem, TotalsShipping, } from '@woocommerce/base-components/cart-checkout'; import { Subtotal, TotalsFees, TotalsTaxes, ExperimentalOrderMeta, TotalsWrapper, ExperimentalDiscountsMeta, } from '@woocommerce/blocks-checkout'; import { getCurrencyFromPriceResponse } from '@woocommerce/price-format'; import { useShippingDataContext } from '@woocommerce/base-context'; import { useStoreCartCoupons, useStoreCart, } from '@woocommerce/base-context/hooks'; import { getSetting } from '@woocommerce/settings'; /** * Internal dependencies */ const Block = ( { showRateAfterTaxName = false, className, }: { showRateAfterTaxName: boolean; className?: string; } ): JSX.Element => { const { cartItems, cartTotals, cartCoupons, cartFees } = useStoreCart(); const { applyCoupon, removeCoupon, isApplyingCoupon, isRemovingCoupon, } = useStoreCartCoupons(); const { needsShipping } = useShippingDataContext(); const totalsCurrency = getCurrencyFromPriceResponse( cartTotals ); // Prepare props to pass to the ExperimentalOrderMeta slot fill. // We need to pluck out receiveCart. // eslint-disable-next-line no-unused-vars const { extensions, receiveCart, ...cart } = useStoreCart(); const slotFillProps = { extensions, cart, }; return (
{ getSetting( 'couponsEnabled', true ) && ( ) } { needsShipping && ( ) } { ! getSetting( 'displayCartPricesIncludingTax', false ) && parseInt( cartTotals.total_tax, 10 ) > 0 && ( ) }
); }; export default Block;