From a030d059eb6ae8838d11bb1cef79f66d8d9354a5 Mon Sep 17 00:00:00 2001
From: Mike Jolley
Date: Wed, 11 Oct 2023 15:09:43 +0100
Subject: [PATCH] Remove Shipping calculator settings and link to the
WooCommerce admin settings (#11184)
* Remove block level options in favour of settings
* Remove calculator toggle test
* Update assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/block.tsx
Co-authored-by: Thomas Roberts <5656702+opr@users.noreply.github.com>
* Remove unused attributes
---------
Co-authored-by: Thomas Roberts <5656702+opr@users.noreply.github.com>
---
.../attributes.tsx | 18 ------
.../cart-order-summary-shipping/block.tsx | 14 ++---
.../cart-order-summary-shipping/edit.tsx | 39 +++++-------
.../cart-order-summary-shipping/frontend.tsx | 8 +--
.../cart-order-summary-shipping/index.tsx | 2 -
assets/js/blocks/cart/test/block.js | 13 +---
.../edit.tsx | 2 +-
.../attributes.tsx | 4 --
.../checkout-shipping-method-block/block.json | 4 --
.../checkout-shipping-method-block/block.tsx | 7 ++-
.../checkout-shipping-method-block/edit.tsx | 35 -----------
.../frontend.tsx | 3 -
.../attributes.tsx | 4 --
.../block.json | 4 --
.../checkout-shipping-methods-block/edit.tsx | 63 ++++++-------------
.../external-link-card/editor.scss | 3 +
.../__fixtures__/checkout.fixture.json | 2 +-
.../cart-block.merchant.block_theme.spec.ts | 20 +-----
18 files changed, 55 insertions(+), 190 deletions(-)
delete mode 100644 assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/attributes.tsx
diff --git a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/attributes.tsx b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/attributes.tsx
deleted file mode 100644
index e5378cb59e8..00000000000
--- a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/attributes.tsx
+++ /dev/null
@@ -1,18 +0,0 @@
-/**
- * External dependencies
- */
-import { getSetting } from '@woocommerce/settings';
-
-export default {
- isShippingCalculatorEnabled: {
- type: 'boolean',
- default: getSetting( 'isShippingCalculatorEnabled', true ),
- },
- lock: {
- type: 'object',
- default: {
- move: false,
- remove: true,
- },
- },
-};
diff --git a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/block.tsx b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/block.tsx
index dacbbc32938..e29d0f86ddd 100644
--- a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/block.tsx
+++ b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/block.tsx
@@ -5,14 +5,9 @@ import { TotalsShipping } from '@woocommerce/base-components/cart-checkout';
import { getCurrencyFromPriceResponse } from '@woocommerce/price-format';
import { useStoreCart } from '@woocommerce/base-context/hooks';
import { TotalsWrapper } from '@woocommerce/blocks-checkout';
+import { getSetting } from '@woocommerce/settings';
-const Block = ( {
- className,
- isShippingCalculatorEnabled,
-}: {
- className: string;
- isShippingCalculatorEnabled: boolean;
-} ): JSX.Element | null => {
+const Block = ( { className }: { className: string } ): JSX.Element | null => {
const { cartTotals, cartNeedsShipping } = useStoreCart();
if ( ! cartNeedsShipping ) {
@@ -24,7 +19,10 @@ const Block = ( {
return (
(
+ 'isShippingCalculatorEnabled',
+ true
+ ) }
showRateSelector={ true }
values={ cartTotals }
currency={ totalsCurrency }
diff --git a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/edit.tsx b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/edit.tsx
index ccaaf05677f..5a44c2ef8a5 100644
--- a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/edit.tsx
+++ b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/edit.tsx
@@ -3,8 +3,8 @@
*/
import { __ } from '@wordpress/i18n';
import { useBlockProps, InspectorControls } from '@wordpress/block-editor';
-import { PanelBody, ToggleControl } from '@wordpress/components';
-import { getSetting } from '@woocommerce/settings';
+import { PanelBody, ExternalLink } from '@wordpress/components';
+import { ADMIN_URL, getSetting } from '@woocommerce/settings';
import Noninteractive from '@woocommerce/base-components/noninteractive';
/**
@@ -14,19 +14,16 @@ import Block from './block';
export const Edit = ( {
attributes,
- setAttributes,
}: {
attributes: {
- isShippingCalculatorEnabled: boolean;
className: string;
lock: {
move: boolean;
remove: boolean;
};
};
- setAttributes: ( attributes: Record< string, unknown > ) => void;
} ): JSX.Element => {
- const { isShippingCalculatorEnabled, className } = attributes;
+ const { className } = attributes;
const shippingEnabled = getSetting( 'shippingEnabled', true );
const blockProps = useBlockProps();
@@ -36,35 +33,29 @@ export const Edit = ( {
{ !! shippingEnabled && (
-
+ { __(
+ 'Options that control shipping can be managed in your store settings.',
'woo-gutenberg-products-block'
) }
- help={ __(
- 'Allow customers to estimate shipping by entering their address.',
+
+
+ { __(
+ 'Manage shipping options',
'woo-gutenberg-products-block'
) }
- checked={ isShippingCalculatorEnabled }
- onChange={ () =>
- setAttributes( {
- isShippingCalculatorEnabled:
- ! isShippingCalculatorEnabled,
- } )
- }
- />
+ { ' ' }
) }
-
+
);
diff --git a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/frontend.tsx b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/frontend.tsx
index b6c773996b2..4fc9ad2897a 100644
--- a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/frontend.tsx
+++ b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/frontend.tsx
@@ -1,12 +1,6 @@
-/**
- * External dependencies
- */
-import { withFilteredAttributes } from '@woocommerce/shared-hocs';
-
/**
* Internal dependencies
*/
import Block from './block';
-import attributes from './attributes';
-export default withFilteredAttributes( attributes )( Block );
+export default Block;
diff --git a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/index.tsx b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/index.tsx
index 9f300d474eb..c6a8fcd99f0 100644
--- a/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/index.tsx
+++ b/assets/js/blocks/cart/inner-blocks/cart-order-summary-shipping/index.tsx
@@ -9,7 +9,6 @@ import { registerBlockType } from '@wordpress/blocks';
* Internal dependencies
*/
import { Edit, Save } from './edit';
-import attributes from './attributes';
registerBlockType( 'woocommerce/cart-order-summary-shipping-block', {
icon: {
@@ -20,7 +19,6 @@ registerBlockType( 'woocommerce/cart-order-summary-shipping-block', {
/>
),
},
- attributes,
edit: Edit,
save: Save,
} );
diff --git a/assets/js/blocks/cart/test/block.js b/assets/js/blocks/cart/test/block.js
index bdacc3a673c..dfca48b4b9b 100644
--- a/assets/js/blocks/cart/test/block.js
+++ b/assets/js/blocks/cart/test/block.js
@@ -40,15 +40,10 @@ jest.mock( '@wordpress/compose', () => ( {
const CartBlock = ( {
attributes = {
showRateAfterTaxName: false,
- isShippingCalculatorEnabled: false,
checkoutPageId: 0,
},
} ) => {
- const {
- showRateAfterTaxName,
- isShippingCalculatorEnabled,
- checkoutPageId,
- } = attributes;
+ const { showRateAfterTaxName, checkoutPageId } = attributes;
return (
@@ -59,11 +54,7 @@ const CartBlock = ( {
-
+
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-contact-information-block/edit.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-contact-information-block/edit.tsx
index 0c414b8c169..e1d503854bc 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-contact-information-block/edit.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-contact-information-block/edit.tsx
@@ -49,7 +49,7 @@ export const Edit = ( {
>
{ __(
- 'Account creation and guest checkout settings can be managed in the WooCommerce settings.',
+ 'Account creation and guest checkout settings can be managed in your store settings.',
'woo-gutenberg-products-block'
) }
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/attributes.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/attributes.tsx
index 9c21e4de517..42dfb4696fa 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/attributes.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/attributes.tsx
@@ -44,8 +44,4 @@ export default {
remove: true,
},
},
- shippingCostRequiresAddress: {
- type: 'boolean',
- default: false,
- },
};
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.json b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.json
index b3255985c2d..b080adafec9 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.json
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.json
@@ -19,10 +19,6 @@
"remove": true,
"move": true
}
- },
- "shippingCostRequiresAddress": {
- "type": "boolean",
- "default": false
}
},
"parent": [ "woocommerce/checkout-fields-block" ],
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.tsx
index 190cb4fa3f2..56130c0adae 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/block.tsx
@@ -13,6 +13,7 @@ import { useEffect } from '@wordpress/element';
import { CART_STORE_KEY, VALIDATION_STORE_KEY } from '@woocommerce/block-data';
import { useDispatch, useSelect } from '@wordpress/data';
import { isPackageRateCollectable } from '@woocommerce/base-utils';
+import { getSetting } from '@woocommerce/settings';
/**
* Internal dependencies
@@ -164,17 +165,19 @@ const Block = ( {
showIcon,
localPickupText,
shippingText,
- shippingCostRequiresAddress = false,
}: {
checked: string;
onChange: ( value: string ) => void;
showPrice: boolean;
showIcon: boolean;
- shippingCostRequiresAddress: boolean;
localPickupText: string;
shippingText: string;
} ): JSX.Element | null => {
const { shippingRates } = useShippingData();
+ const shippingCostRequiresAddress = getSetting< boolean >(
+ 'shippingCostRequiresAddress',
+ false
+ );
return (
) => void;
} ): JSX.Element | null => {
- const toggleAttribute = ( key: keyof Attributes ): void => {
- const newAttributes = {} as Partial< Attributes >;
- newAttributes[ key ] = ! ( attributes[ key ] as boolean );
- setAttributes( newAttributes );
- };
-
const { setPrefersCollection } = useDispatch( CHECKOUT_STORE_KEY );
const { prefersCollection } = useSelect( ( select ) => {
const checkoutStore = select( CHECKOUT_STORE_KEY );
@@ -221,30 +210,6 @@ export const Edit = ( {
) }
>
-
- {
- updateAttributeInSiblingBlock(
- clientId,
- 'shippingCostRequiresAddress',
- selected,
- 'woocommerce/checkout-shipping-methods-block'
- );
-
- toggleAttribute( 'shippingCostRequiresAddress' );
- } }
- />
-
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/frontend.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/frontend.tsx
index 86f5154a87b..74ae2cc83f8 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/frontend.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-method-block/frontend.tsx
@@ -25,12 +25,10 @@ const FrontendBlock = ( {
showIcon,
shippingText,
localPickupText,
- shippingCostRequiresAddress,
}: {
title: string;
description: string;
showStepNumber: boolean;
- shippingCostRequiresAddress: boolean;
children: JSX.Element;
className?: string;
showPrice: boolean;
@@ -92,7 +90,6 @@ const FrontendBlock = ( {
showIcon={ showIcon }
localPickupText={ localPickupText }
shippingText={ shippingText }
- shippingCostRequiresAddress={ shippingCostRequiresAddress }
/>
{ children }
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/attributes.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/attributes.tsx
index 17cb4f6bf2f..b36f320660d 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/attributes.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/attributes.tsx
@@ -24,8 +24,4 @@ export default {
remove: true,
},
},
- shippingCostRequiresAddress: {
- type: 'boolean',
- default: false,
- },
};
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/block.json b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/block.json
index b4c5dc5192f..df53c0117c8 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/block.json
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/block.json
@@ -19,10 +19,6 @@
"remove": true,
"move": true
}
- },
- "shippingCostRequiresAddress": {
- "type": "boolean",
- "default": false
}
},
"parent": [ "woocommerce/checkout-fields-block" ],
diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/edit.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/edit.tsx
index 0edb15d412a..04feb320af8 100644
--- a/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/edit.tsx
+++ b/assets/js/blocks/checkout/inner-blocks/checkout-shipping-methods-block/edit.tsx
@@ -4,14 +4,12 @@
import classnames from 'classnames';
import { __ } from '@wordpress/i18n';
import { InspectorControls, useBlockProps } from '@wordpress/block-editor';
-import { PanelBody, ExternalLink, ToggleControl } from '@wordpress/components';
+import { PanelBody, ExternalLink } from '@wordpress/components';
import { ADMIN_URL, getSetting } from '@woocommerce/settings';
import ExternalLinkCard from '@woocommerce/editor-components/external-link-card';
import { innerBlockAreas } from '@woocommerce/blocks-checkout';
import { useCheckoutAddress } from '@woocommerce/base-context/hooks';
import Noninteractive from '@woocommerce/base-components/noninteractive';
-import { Attributes } from '@woocommerce/blocks/checkout/types';
-import { updateAttributeInSiblingBlock } from '@woocommerce/utils';
/**
* Internal dependencies
@@ -34,15 +32,12 @@ type shippingAdminLink = {
export const Edit = ( {
attributes,
setAttributes,
- clientId,
}: {
- clientId: string;
attributes: {
title: string;
description: string;
showStepNumber: boolean;
className: string;
- shippingCostRequiresAddress: boolean;
};
setAttributes: ( attributes: Record< string, unknown > ) => void;
} ): JSX.Element | null => {
@@ -59,12 +54,6 @@ export const Edit = ( {
return null;
}
- const toggleAttribute = ( key: keyof Attributes ): void => {
- const newAttributes = {} as Partial< Attributes >;
- newAttributes[ key ] = ! ( attributes[ key ] as boolean );
- setAttributes( newAttributes );
- };
-
return (
-
+ { __(
+ 'Options that control shipping can be managed in your store settings.',
'woo-gutenberg-products-block'
) }
- checked={ attributes.shippingCostRequiresAddress }
- onChange={ ( selected ) => {
- updateAttributeInSiblingBlock(
- clientId,
- 'shippingCostRequiresAddress',
- selected,
- 'woocommerce/checkout-shipping-method-block'
- );
- toggleAttribute( 'shippingCostRequiresAddress' );
- } }
- />
+
+
+ { __(
+ 'Manage shipping options',
+ 'woo-gutenberg-products-block'
+ ) }
+ { ' ' }
{ globalShippingMethods.length > 0 && (
{ __(
- 'You currently have the following shipping zones active.',
+ 'Shipping Zones can be made managed in your store settings.',
'woo-gutenberg-products-block'
) }
@@ -151,24 +141,11 @@ export const Edit = ( {
/>
);
} ) }
-
- { __(
- 'Manage shipping zones',
- 'woo-gutenberg-products-block'
- ) }
-
) }
- }
- shippingCostRequiresAddress={
- attributes.shippingCostRequiresAddress
- }
- />
+ } />
diff --git a/assets/js/editor-components/external-link-card/editor.scss b/assets/js/editor-components/external-link-card/editor.scss
index 841bd0e22ba..be06854d15b 100644
--- a/assets/js/editor-components/external-link-card/editor.scss
+++ b/assets/js/editor-components/external-link-card/editor.scss
@@ -9,6 +9,9 @@
+ .wc-block-editor-components-external-link-card {
margin-top: -($gap-large - $gap);
}
+ &:last-child {
+ margin-bottom: 0;
+ }
.wc-block-editor-components-external-link-card__content {
flex: 1 1 0;
padding-right: $gap;
diff --git a/tests/e2e-jest/specs/backend/__fixtures__/checkout.fixture.json b/tests/e2e-jest/specs/backend/__fixtures__/checkout.fixture.json
index 2d9631d676c..b0be2edc810 100644
--- a/tests/e2e-jest/specs/backend/__fixtures__/checkout.fixture.json
+++ b/tests/e2e-jest/specs/backend/__fixtures__/checkout.fixture.json
@@ -1 +1 @@
-{"title":"Checkout Block","pageContent":"\n\n
\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n
\n\n\n\n
\n
\n"}
+{"title":"Checkout Block","pageContent":"\n\n
\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n\n\n\n
\n
\n\n\n\n
\n
\n"}
diff --git a/tests/e2e/tests/cart/cart-block.merchant.block_theme.spec.ts b/tests/e2e/tests/cart/cart-block.merchant.block_theme.spec.ts
index 76fb7a3162e..060ffcffc47 100644
--- a/tests/e2e/tests/cart/cart-block.merchant.block_theme.spec.ts
+++ b/tests/e2e/tests/cart/cart-block.merchant.block_theme.spec.ts
@@ -143,7 +143,7 @@ test.describe( 'Merchant → Cart', () => {
await expect( filledCartAudioButton ).toBeHidden();
} );
- test( 'shows empty cart when changing the view and allows toggling of shipping calculator', async ( {
+ test( 'shows empty cart when changing the view', async ( {
page,
editor,
editorUtils,
@@ -188,24 +188,6 @@ test.describe( 'Merchant → Cart', () => {
' [data-type="woocommerce/empty-cart-block"]'
)
).toBeHidden();
-
- await editor.selectBlocks(
- await editorUtils.getBlockByName(
- 'woocommerce/cart-order-summary-shipping-block'
- )
- );
- await editor.openDocumentSettingsSidebar();
- const shippingLabel = editorUtils.page.getByLabel(
- 'Shipping calculator'
- );
- await shippingLabel.check();
- await expect(
- editor.canvas.getByText( 'Change address' )
- ).toBeVisible();
- await shippingLabel.uncheck();
- await expect(
- editor.canvas.getByText( 'Change address' )
- ).toBeHidden();
} );
} );
} );