Configure link for the proceed to checkout button (https://github.com/woocommerce/woocommerce-blocks/pull/1981)
* Add link for proceed to checkout button * Fixes to indenting/types * Update snaps * Update notice
This commit is contained in:
parent
cdfb457341
commit
bd6c7f657c
|
@ -15,6 +15,10 @@ const blockAttributes = {
|
|||
type: 'boolean',
|
||||
default: IS_SHIPPING_COST_HIDDEN,
|
||||
},
|
||||
checkoutPageId: {
|
||||
type: 'number',
|
||||
default: 0,
|
||||
},
|
||||
};
|
||||
|
||||
export default blockAttributes;
|
||||
|
|
|
@ -2,27 +2,76 @@
|
|||
* External dependencies
|
||||
*/
|
||||
import { __ } from '@wordpress/i18n';
|
||||
|
||||
import FeedbackPrompt from '@woocommerce/block-components/feedback-prompt';
|
||||
import { InspectorControls } from '@wordpress/block-editor';
|
||||
import { Disabled, PanelBody, ToggleControl } from '@wordpress/components';
|
||||
import {
|
||||
Disabled,
|
||||
PanelBody,
|
||||
ToggleControl,
|
||||
SelectControl,
|
||||
Notice,
|
||||
} from '@wordpress/components';
|
||||
import PropTypes from 'prop-types';
|
||||
import { withFeedbackPrompt } from '@woocommerce/block-hocs';
|
||||
import ViewSwitcher from '@woocommerce/block-components/view-switcher';
|
||||
import { SHIPPING_ENABLED } from '@woocommerce/block-settings';
|
||||
import { SHIPPING_ENABLED, CART_PAGE_ID } from '@woocommerce/block-settings';
|
||||
import BlockErrorBoundary from '@woocommerce/base-components/block-error-boundary';
|
||||
import { EditorProvider } from '@woocommerce/base-context';
|
||||
import { EditorProvider, useEditorContext } from '@woocommerce/base-context';
|
||||
import { useSelect } from '@wordpress/data';
|
||||
import { __experimentalCreateInterpolateElement } from 'wordpress-element';
|
||||
import { getAdminLink } from '@woocommerce/settings';
|
||||
|
||||
/**
|
||||
* Internal dependencies
|
||||
*/
|
||||
import FullCart from './full-cart';
|
||||
import EmptyCart from './empty-cart';
|
||||
import './editor.scss';
|
||||
|
||||
const BlockSettings = ( { attributes, setAttributes } ) => {
|
||||
const { isShippingCalculatorEnabled, isShippingCostHidden } = attributes;
|
||||
const {
|
||||
isShippingCalculatorEnabled,
|
||||
isShippingCostHidden,
|
||||
checkoutPageId,
|
||||
} = attributes;
|
||||
const pages =
|
||||
useSelect( ( select ) => {
|
||||
return select( 'core' ).getEntityRecords( 'postType', 'page', {
|
||||
status: 'publish',
|
||||
orderby: 'title',
|
||||
order: 'asc',
|
||||
per_page: 100,
|
||||
} );
|
||||
}, [] ) || null;
|
||||
const { currentPostId } = useEditorContext();
|
||||
|
||||
return (
|
||||
<InspectorControls>
|
||||
{ currentPostId !== CART_PAGE_ID && (
|
||||
<Notice
|
||||
className="wc-block-cart__page-notice"
|
||||
isDismissible={ false }
|
||||
status="warning"
|
||||
>
|
||||
{ __experimentalCreateInterpolateElement(
|
||||
__(
|
||||
'If you would like to use this block as your default cart you must update your <a>page settings in WooCommerce</a>.',
|
||||
'woo-gutenberg-products-block'
|
||||
),
|
||||
{
|
||||
a: (
|
||||
// eslint-disable-next-line jsx-a11y/anchor-has-content
|
||||
<a
|
||||
href={ getAdminLink(
|
||||
'admin.php?page=wc-settings&tab=advanced'
|
||||
) }
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
/>
|
||||
),
|
||||
}
|
||||
) }
|
||||
</Notice>
|
||||
) }
|
||||
<PanelBody
|
||||
title={ __( 'Shipping rates', 'woo-gutenberg-products-block' ) }
|
||||
>
|
||||
|
@ -59,6 +108,50 @@ const BlockSettings = ( { attributes, setAttributes } ) => {
|
|||
}
|
||||
/>
|
||||
</PanelBody>
|
||||
{ ( currentPostId !== CART_PAGE_ID || checkoutPageId ) && pages && (
|
||||
<PanelBody
|
||||
title={ __(
|
||||
'Proceed to Checkout button',
|
||||
'woo-gutenberg-products-block'
|
||||
) }
|
||||
>
|
||||
<SelectControl
|
||||
label={ __(
|
||||
'Link to',
|
||||
'woo-gutenberg-products-block'
|
||||
) }
|
||||
value={ checkoutPageId }
|
||||
options={ [
|
||||
...[
|
||||
{
|
||||
label: __(
|
||||
'WooCommerce Checkout Page',
|
||||
'woo-gutenberg-products-block'
|
||||
),
|
||||
value: 0,
|
||||
},
|
||||
],
|
||||
...Object.values( pages ).map( ( page ) => {
|
||||
return {
|
||||
label: page.title.raw,
|
||||
value: parseInt( page.id, 10 ),
|
||||
};
|
||||
} ),
|
||||
] }
|
||||
onChange={ ( value ) =>
|
||||
setAttributes( {
|
||||
checkoutPageId: parseInt( value, 10 ),
|
||||
} )
|
||||
}
|
||||
/>
|
||||
</PanelBody>
|
||||
) }
|
||||
<FeedbackPrompt
|
||||
text={ __(
|
||||
'We are currently working on improving our cart and checkout blocks, providing merchants with the tools and customization options they need.',
|
||||
'woo-gutenberg-products-block'
|
||||
) }
|
||||
/>
|
||||
</InspectorControls>
|
||||
);
|
||||
};
|
||||
|
@ -67,7 +160,6 @@ const BlockSettings = ( { attributes, setAttributes } ) => {
|
|||
* Component to handle edit mode of "Cart Block".
|
||||
*/
|
||||
const CartEditor = ( { className, attributes, setAttributes } ) => {
|
||||
const { isShippingCalculatorEnabled, isShippingCostHidden } = attributes;
|
||||
return (
|
||||
<div className={ className }>
|
||||
<ViewSwitcher
|
||||
|
@ -114,12 +206,7 @@ const CartEditor = ( { className, attributes, setAttributes } ) => {
|
|||
<Disabled>
|
||||
<EditorProvider>
|
||||
<FullCart
|
||||
isShippingCostHidden={
|
||||
isShippingCostHidden
|
||||
}
|
||||
isShippingCalculatorEnabled={
|
||||
isShippingCalculatorEnabled
|
||||
}
|
||||
attributes={ attributes }
|
||||
/>
|
||||
</EditorProvider>
|
||||
</Disabled>
|
||||
|
@ -154,9 +241,4 @@ CartEditor.propTypes = {
|
|||
className: PropTypes.string,
|
||||
};
|
||||
|
||||
export default withFeedbackPrompt(
|
||||
__(
|
||||
'We are currently working on improving our cart and checkout blocks, providing merchants with the tools and customization options they need.',
|
||||
'woo-gutenberg-products-block'
|
||||
)
|
||||
)( CartEditor );
|
||||
export default CartEditor;
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
.wc-block-cart__page-notice {
|
||||
margin: 0;
|
||||
}
|
|
@ -32,12 +32,7 @@ const Block = ( { emptyCart, attributes } ) => {
|
|||
<RawHTML>{ emptyCart }</RawHTML>
|
||||
) : (
|
||||
<LoadingMask showSpinner={ true } isLoading={ cartIsLoading }>
|
||||
<FullCart
|
||||
isShippingCalculatorEnabled={
|
||||
attributes.isShippingCalculatorEnabled
|
||||
}
|
||||
isShippingCostHidden={ attributes.isShippingCostHidden }
|
||||
/>
|
||||
<FullCart attributes={ attributes } />
|
||||
</LoadingMask>
|
||||
) }
|
||||
</>
|
||||
|
|
|
@ -15,12 +15,12 @@ import { MastercardLogo, VisaLogo } from './payment-logos'; // @todo we want to
|
|||
/**
|
||||
* Checkout button rendered in the full cart page.
|
||||
*/
|
||||
const CheckoutButton = () => {
|
||||
const CheckoutButton = ( { link } ) => {
|
||||
return (
|
||||
<div className="wc-block-cart__submit-container">
|
||||
<Button
|
||||
className="wc-block-cart__submit-button"
|
||||
href={ CHECKOUT_URL }
|
||||
href={ link || CHECKOUT_URL }
|
||||
>
|
||||
{ __( 'Proceed to Checkout', 'woo-gutenberg-products-block' ) }
|
||||
</Button>
|
||||
|
|
|
@ -27,6 +27,7 @@ import {
|
|||
SidebarLayout,
|
||||
Main,
|
||||
} from '@woocommerce/base-components/sidebar-layout';
|
||||
import { getSetting } from '@woocommerce/settings';
|
||||
|
||||
/**
|
||||
* Internal dependencies
|
||||
|
@ -41,8 +42,9 @@ import './editor.scss';
|
|||
/**
|
||||
* Component that renders the Cart block when user has something in cart aka "full".
|
||||
*/
|
||||
const Cart = ( { isShippingCalculatorEnabled, isShippingCostHidden } ) => {
|
||||
const Cart = ( { attributes } ) => {
|
||||
const { cartItems, cartTotals, cartIsLoading } = useStoreCart();
|
||||
const { isShippingCalculatorEnabled, isShippingCostHidden } = attributes;
|
||||
|
||||
const {
|
||||
applyCoupon,
|
||||
|
@ -117,7 +119,12 @@ const Cart = ( { isShippingCalculatorEnabled, isShippingCostHidden } ) => {
|
|||
currency={ totalsCurrency }
|
||||
values={ cartTotals }
|
||||
/>
|
||||
<CheckoutButton />
|
||||
<CheckoutButton
|
||||
link={ getSetting(
|
||||
'page-' + attributes?.checkoutPageId,
|
||||
false
|
||||
) }
|
||||
/>
|
||||
</CardBody>
|
||||
</Card>
|
||||
</Sidebar>
|
||||
|
@ -126,8 +133,7 @@ const Cart = ( { isShippingCalculatorEnabled, isShippingCostHidden } ) => {
|
|||
};
|
||||
|
||||
Cart.propTypes = {
|
||||
isShippingCalculatorEnabled: PropTypes.bool,
|
||||
isShippingCostHidden: PropTypes.bool,
|
||||
attributes: PropTypes.object.isRequired,
|
||||
};
|
||||
|
||||
export default Cart;
|
||||
|
|
|
@ -332,13 +332,10 @@ const Block = ( {
|
|||
<div className="wc-block-checkout__actions">
|
||||
{ attributes.showReturnToCart && (
|
||||
<ReturnToCartButton
|
||||
link={
|
||||
getSetting(
|
||||
'page-' +
|
||||
attributes?.cartPageId,
|
||||
false
|
||||
)
|
||||
}
|
||||
link={ getSetting(
|
||||
'page-' + attributes?.cartPageId,
|
||||
false
|
||||
) }
|
||||
/>
|
||||
) }
|
||||
<PlaceOrderButton />
|
||||
|
|
|
@ -267,7 +267,7 @@ const BlockSettings = ( { attributes, setAttributes } ) => {
|
|||
'WooCommerce Cart Page',
|
||||
'woo-gutenberg-products-block'
|
||||
),
|
||||
value: '',
|
||||
value: 0,
|
||||
},
|
||||
],
|
||||
...Object.values( pages ).map( ( page ) => {
|
||||
|
|
|
@ -49,6 +49,12 @@ class Cart extends AbstractBlock {
|
|||
$data_registry = Package::container()->get(
|
||||
\Automattic\WooCommerce\Blocks\Assets\AssetDataRegistry::class
|
||||
);
|
||||
if ( ! empty( $attributes['checkoutPageId'] ) && ! $data_registry->exists( 'page-' . $attributes['checkoutPageId'] ) ) {
|
||||
$permalink = get_permalink( $attributes['checkoutPageId'] );
|
||||
if ( $permalink ) {
|
||||
$data_registry->add( 'page-' . $attributes['checkoutPageId'], get_permalink( $attributes['checkoutPageId'] ) );
|
||||
}
|
||||
}
|
||||
if ( ! $data_registry->exists( 'shippingCountries' ) ) {
|
||||
$data_registry->add( 'shippingCountries', WC()->countries->get_shipping_countries() );
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
|
||||
exports[`Cart Block can be created 1`] = `
|
||||
"<!-- wp:woocommerce/cart -->
|
||||
<div class=\\"wp-block-woocommerce-cart is-loading\\" data-is-shipping-calculator-enabled=\\"true\\" data-is-shipping-cost-hidden=\\"false\\"><!-- wp:image {\\"align\\":\\"center\\",\\"sizeSlug\\":\\"small\\"} -->
|
||||
<div class=\\"wp-block-woocommerce-cart is-loading\\" data-is-shipping-calculator-enabled=\\"true\\" data-is-shipping-cost-hidden=\\"false\\" data-checkout-page-id=\\"0\\"><!-- wp:image {\\"align\\":\\"center\\",\\"sizeSlug\\":\\"small\\"} -->
|
||||
<div class=\\"wp-block-image\\"><figure class=\\"aligncenter size-small\\"><img src=\\"\\" alt=\\"\\"/></figure></div>
|
||||
<!-- /wp:image -->
|
||||
|
||||
|
|
Loading…
Reference in New Issue