diff --git a/assets/js/base/components/cart-checkout/local-pickup-select/index.tsx b/assets/js/base/components/cart-checkout/local-pickup-select/index.tsx index 3a4d42ba6cc..696db0fefae 100644 --- a/assets/js/base/components/cart-checkout/local-pickup-select/index.tsx +++ b/assets/js/base/components/cart-checkout/local-pickup-select/index.tsx @@ -1,12 +1,11 @@ /** * External dependencies */ -import { RadioControlOption } from '@woocommerce/base-components/radio-control/types'; +import { + RadioControl, + RadioControlOptionType, +} from '@woocommerce/blocks-components'; import { CartShippingPackageShippingRate } from '@woocommerce/types'; -/** - * Internal dependencies - */ -import RadioControl from '../../radio-control'; interface LocalPickupSelectProps { title?: string | undefined; @@ -17,7 +16,7 @@ interface LocalPickupSelectProps { renderPickupLocation: ( location: CartShippingPackageShippingRate, pickupLocationsCount: number - ) => RadioControlOption; + ) => RadioControlOptionType; packageCount: number; } /** diff --git a/assets/js/base/components/cart-checkout/shipping-rates-control-package/package-rates.tsx b/assets/js/base/components/cart-checkout/shipping-rates-control-package/package-rates.tsx index 8ea650b608b..31778fba701 100644 --- a/assets/js/base/components/cart-checkout/shipping-rates-control-package/package-rates.tsx +++ b/assets/js/base/components/cart-checkout/shipping-rates-control-package/package-rates.tsx @@ -2,9 +2,10 @@ * External dependencies */ import { useState, useEffect } from '@wordpress/element'; -import RadioControl, { +import { + RadioControl, RadioControlOptionLayout, -} from '@woocommerce/base-components/radio-control'; +} from '@woocommerce/blocks-components'; import type { CartShippingPackageShippingRate } from '@woocommerce/types'; import { usePrevious } from '@woocommerce/base-hooks'; diff --git a/assets/js/base/components/index.ts b/assets/js/base/components/index.ts index f0a57cd8795..fca0dbf0250 100644 --- a/assets/js/base/components/index.ts +++ b/assets/js/base/components/index.ts @@ -10,7 +10,6 @@ export * from './filter-reset-button'; export * from './filter-submit-button'; export * from './form'; export * from './form-token-field'; -export * from './formatted-monetary-amount'; export * from './label'; export * from './load-more-button'; export * from './loading-mask'; @@ -23,8 +22,6 @@ export * from './product-name'; export * from './product-price'; export * from './product-rating'; export * from './quantity-selector'; -export * from './radio-control'; -export * from './radio-control-accordion'; export * from './read-more'; export * from './reviews'; export * from './sidebar-layout'; diff --git a/assets/js/blocks/cart-checkout-shared/payment-methods/payment-method-options.js b/assets/js/blocks/cart-checkout-shared/payment-methods/payment-method-options.js index ec80578572b..fb151538dc4 100644 --- a/assets/js/blocks/cart-checkout-shared/payment-methods/payment-method-options.js +++ b/assets/js/blocks/cart-checkout-shared/payment-methods/payment-method-options.js @@ -8,7 +8,7 @@ import { import { cloneElement, useCallback } from '@wordpress/element'; import { useEditorContext } from '@woocommerce/base-context'; import classNames from 'classnames'; -import RadioControlAccordion from '@woocommerce/base-components/radio-control-accordion'; +import { RadioControlAccordion } from '@woocommerce/blocks-components'; import { useDispatch, useSelect } from '@wordpress/data'; import { getPaymentMethods } from '@woocommerce/blocks-registry'; diff --git a/assets/js/blocks/cart-checkout-shared/payment-methods/saved-payment-method-options.tsx b/assets/js/blocks/cart-checkout-shared/payment-methods/saved-payment-method-options.tsx index c90ab0406db..c6a11c25aec 100644 --- a/assets/js/blocks/cart-checkout-shared/payment-methods/saved-payment-method-options.tsx +++ b/assets/js/blocks/cart-checkout-shared/payment-methods/saved-payment-method-options.tsx @@ -4,7 +4,10 @@ import { useMemo, cloneElement } from '@wordpress/element'; import { __, sprintf } from '@wordpress/i18n'; import { noticeContexts } from '@woocommerce/base-context'; -import RadioControl from '@woocommerce/base-components/radio-control'; +import { + RadioControl, + RadioControlOptionType, +} from '@woocommerce/blocks-components'; import { usePaymentMethodInterface, useStoreEvents, @@ -13,7 +16,6 @@ import { PAYMENT_STORE_KEY } from '@woocommerce/block-data'; import { useDispatch, useSelect } from '@wordpress/data'; import { getPaymentMethods } from '@woocommerce/blocks-registry'; import { isNull } from '@woocommerce/types'; -import { RadioControlOption } from '@woocommerce/base-components/radio-control/types'; /** * Internal dependencies @@ -87,7 +89,7 @@ const SavedPaymentMethodOptions = () => { const { removeNotice } = useDispatch( 'core/notices' ); const { dispatchCheckoutEvent } = useStoreEvents(); - const options = useMemo< RadioControlOption[] >( () => { + const options = useMemo< RadioControlOptionType[] >( () => { const types = Object.keys( savedPaymentMethods ); // Get individual payment methods from saved payment methods and put them into a unique array. @@ -145,7 +147,7 @@ const SavedPaymentMethodOptions = () => { } ); return mappedOptions.filter( ( option ) => typeof option !== 'undefined' - ) as RadioControlOption[]; + ) as RadioControlOptionType[]; }, [ savedPaymentMethods, paymentMethods, diff --git a/assets/js/blocks/cart-checkout-shared/payment-methods/test/payment-methods.js b/assets/js/blocks/cart-checkout-shared/payment-methods/test/payment-methods.js index e426f7f20cc..aac922b2e25 100644 --- a/assets/js/blocks/cart-checkout-shared/payment-methods/test/payment-methods.js +++ b/assets/js/blocks/cart-checkout-shared/payment-methods/test/payment-methods.js @@ -27,19 +27,24 @@ jest.mock( '../saved-payment-method-options', () => ( { onChange } ) => { ); } ); -jest.mock( - '@woocommerce/base-components/radio-control-accordion', - () => - ( { onChange } ) => - ( - <> - Payment method options - - - ) -); +jest.mock( '@woocommerce/blocks-components', () => { + const originalModule = jest.requireActual( + '@woocommerce/blocks-components' + ); + + return { + __esModule: true, + ...originalModule, + RadioControlAccordion: ( { onChange } ) => ( + <> + Payment method options + + + ), + }; +} ); const originalSelect = jest.requireActual( '@wordpress/data' ).select; const selectMock = jest diff --git a/assets/js/blocks/checkout/inner-blocks/checkout-pickup-options-block/block.tsx b/assets/js/blocks/checkout/inner-blocks/checkout-pickup-options-block/block.tsx index bcaf239ee8b..68b3f8a0105 100644 --- a/assets/js/blocks/checkout/inner-blocks/checkout-pickup-options-block/block.tsx +++ b/assets/js/blocks/checkout/inner-blocks/checkout-pickup-options-block/block.tsx @@ -10,11 +10,13 @@ import { } from '@wordpress/element'; import { useShippingData, useStoreCart } from '@woocommerce/base-context/hooks'; import { getCurrencyFromPriceResponse } from '@woocommerce/price-format'; -import { FormattedMonetaryAmount } from '@woocommerce/blocks-components'; +import { + FormattedMonetaryAmount, + RadioControlOptionType, +} from '@woocommerce/blocks-components'; import { decodeEntities } from '@wordpress/html-entities'; import { getSetting } from '@woocommerce/settings'; import { Icon, mapMarker } from '@wordpress/icons'; -import type { RadioControlOption } from '@woocommerce/base-components/radio-control/types'; import { CartShippingPackageShippingRate } from '@woocommerce/types'; import { isPackageRateCollectable, @@ -67,7 +69,7 @@ const getPickupDetails = ( const renderPickupLocation = ( option: CartShippingPackageShippingRate, packageCount: number -): RadioControlOption => { +): RadioControlOptionType => { const priceWithTaxes = getSetting( 'displayCartPricesIncludingTax', false ) ? parseInt( option.price, 10 ) + parseInt( option.taxes, 10 ) : option.price; diff --git a/bin/webpack-entries.js b/bin/webpack-entries.js index 91542d7c89f..d28f2d651b2 100644 --- a/bin/webpack-entries.js +++ b/bin/webpack-entries.js @@ -166,7 +166,7 @@ const getBlockEntries = ( relativePath ) => { const entries = { styling: { // Packages styles - 'packages-style': glob.sync( './packages/**/index.js' ), + 'packages-style': glob.sync( './packages/**/index.{t,j}s' ), // Shared blocks code 'wc-blocks': './assets/js/index.js', @@ -195,7 +195,7 @@ const entries = { wcBlocksSharedHocs: './assets/js/shared/hocs/index.js', priceFormat: './packages/prices/index.js', blocksCheckout: './packages/checkout/index.js', - blocksComponents: './packages/components/index.js', + blocksComponents: './packages/components/index.ts', }, main: { // Shared blocks code diff --git a/packages/checkout/components/order-local-pickup-packages/index.tsx b/packages/checkout/components/order-local-pickup-packages/index.tsx index ef07b6d5fb0..9f7b3eba123 100644 --- a/packages/checkout/components/order-local-pickup-packages/index.tsx +++ b/packages/checkout/components/order-local-pickup-packages/index.tsx @@ -7,12 +7,12 @@ import { CartShippingPackageShippingRate, } from '@woocommerce/type-defs/cart'; import { Component } from '@wordpress/element'; -import { RadioControlOption } from '@woocommerce/base-components/radio-control/types'; /** * Internal dependencies */ import { createSlotFill } from '../../slot'; +import type { RadioControlOption } from '../../../../packages/components/radio-control/types'; const slotName = '__experimentalOrderLocalPickupPackages'; const { diff --git a/packages/components/index.js b/packages/components/index.ts similarity index 50% rename from packages/components/index.js rename to packages/components/index.ts index 43f4a9ecf1f..9ab2bba2dde 100644 --- a/packages/components/index.js +++ b/packages/components/index.ts @@ -1,5 +1,12 @@ export { default as CheckboxList } from './checkbox-list'; +export { Chip, RemovableChip } from './chip'; export { default as Label } from './label'; export { default as FormattedMonetaryAmount } from './formatted-monetary-amount'; -export { Chip, RemovableChip } from './chip'; +export { + default as RadioControl, + RadioControlOption, + RadioControlOptionLayout, +} from './radio-control'; +export type { RadioControlOption as RadioControlOptionType } from './radio-control/types'; +export { default as RadioControlAccordion } from './radio-control-accordion'; export { default as Spinner } from './spinner'; diff --git a/assets/js/base/components/radio-control-accordion/index.tsx b/packages/components/radio-control-accordion/index.tsx similarity index 97% rename from assets/js/base/components/radio-control-accordion/index.tsx rename to packages/components/radio-control-accordion/index.tsx index d55cf315bd3..723a6ff74f9 100644 --- a/assets/js/base/components/radio-control-accordion/index.tsx +++ b/packages/components/radio-control-accordion/index.tsx @@ -7,7 +7,7 @@ import { withInstanceId } from '@wordpress/compose'; /** * Internal dependencies */ -import RadioControlOption from '../radio-control/option'; +import { RadioControlOption } from '../radio-control'; interface RadioControlAccordionProps { className?: string; diff --git a/assets/js/base/components/radio-control/index.tsx b/packages/components/radio-control/index.tsx similarity index 100% rename from assets/js/base/components/radio-control/index.tsx rename to packages/components/radio-control/index.tsx diff --git a/assets/js/base/components/radio-control/option-layout.tsx b/packages/components/radio-control/option-layout.tsx similarity index 100% rename from assets/js/base/components/radio-control/option-layout.tsx rename to packages/components/radio-control/option-layout.tsx diff --git a/assets/js/base/components/radio-control/option.tsx b/packages/components/radio-control/option.tsx similarity index 100% rename from assets/js/base/components/radio-control/option.tsx rename to packages/components/radio-control/option.tsx diff --git a/assets/js/base/components/radio-control/style.scss b/packages/components/radio-control/style.scss similarity index 100% rename from assets/js/base/components/radio-control/style.scss rename to packages/components/radio-control/style.scss diff --git a/assets/js/base/components/radio-control/types.ts b/packages/components/radio-control/types.ts similarity index 100% rename from assets/js/base/components/radio-control/types.ts rename to packages/components/radio-control/types.ts