/** * External dependencies */ import { OrderSummary, TotalsCoupon, TotalsDiscount, TotalsFooterItem, TotalsShipping, } from '@woocommerce/base-components/cart-checkout'; import { Subtotal, TotalsFees, TotalsTaxes, ExperimentalOrderMeta, } 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'; const CheckoutSidebar = ( { cartCoupons = [], cartItems = [], cartFees = [], cartTotals = {}, } ) => { 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 ( <> { needsShipping && ( ) } { ! getSetting( 'displayCartPricesIncludingTax', false ) && ( ) } { getSetting( 'couponsEnabled', true ) && ( ) } ); }; export default CheckoutSidebar;