87 lines
2.4 KiB
JavaScript
87 lines
2.4 KiB
JavaScript
/**
|
|
* External dependencies
|
|
*/
|
|
import {
|
|
useExpressPaymentMethods,
|
|
usePaymentMethodInterface,
|
|
} from '@woocommerce/base-hooks';
|
|
import {
|
|
cloneElement,
|
|
isValidElement,
|
|
useCallback,
|
|
useRef,
|
|
} from '@wordpress/element';
|
|
import {
|
|
useEditorContext,
|
|
usePaymentMethodDataContext,
|
|
} from '@woocommerce/base-context';
|
|
|
|
/**
|
|
* Internal dependencies
|
|
*/
|
|
import PaymentMethodErrorBoundary from './payment-method-error-boundary';
|
|
|
|
const ExpressPaymentMethods = () => {
|
|
const { isEditor } = useEditorContext();
|
|
const {
|
|
setActivePaymentMethod,
|
|
activePaymentMethod,
|
|
paymentMethodData,
|
|
setPaymentStatus,
|
|
} = usePaymentMethodDataContext();
|
|
const paymentMethodInterface = usePaymentMethodInterface();
|
|
const { paymentMethods } = useExpressPaymentMethods();
|
|
const previousActivePaymentMethod = useRef( activePaymentMethod );
|
|
const previousPaymentMethodData = useRef( paymentMethodData );
|
|
|
|
const onExpressPaymentClick = useCallback(
|
|
( paymentMethodId ) => () => {
|
|
previousActivePaymentMethod.current = activePaymentMethod;
|
|
previousPaymentMethodData.current = paymentMethodData;
|
|
setPaymentStatus().started();
|
|
setActivePaymentMethod( paymentMethodId );
|
|
},
|
|
[
|
|
activePaymentMethod,
|
|
paymentMethodData,
|
|
setActivePaymentMethod,
|
|
setPaymentStatus,
|
|
]
|
|
);
|
|
const onExpressPaymentClose = useCallback( () => {
|
|
setActivePaymentMethod( previousActivePaymentMethod.current );
|
|
if ( previousPaymentMethodData.current.isSavedToken ) {
|
|
setPaymentStatus().success( previousPaymentMethodData.current );
|
|
}
|
|
}, [ setActivePaymentMethod, setPaymentStatus ] );
|
|
const paymentMethodIds = Object.keys( paymentMethods );
|
|
const content =
|
|
paymentMethodIds.length > 0 ? (
|
|
paymentMethodIds.map( ( id ) => {
|
|
const expressPaymentMethod = isEditor
|
|
? paymentMethods[ id ].edit
|
|
: paymentMethods[ id ].content;
|
|
return isValidElement( expressPaymentMethod ) ? (
|
|
<li key={ id } id={ `express-payment-method-${ id }` }>
|
|
{ cloneElement( expressPaymentMethod, {
|
|
...paymentMethodInterface,
|
|
onClick: onExpressPaymentClick( id ),
|
|
onClose: onExpressPaymentClose,
|
|
} ) }
|
|
</li>
|
|
) : null;
|
|
} )
|
|
) : (
|
|
<li key="noneRegistered">No registered Payment Methods</li>
|
|
);
|
|
return (
|
|
<PaymentMethodErrorBoundary isEditor={ isEditor }>
|
|
<ul className="wc-block-components-express-payment__event-buttons">
|
|
{ content }
|
|
</ul>
|
|
</PaymentMethodErrorBoundary>
|
|
);
|
|
};
|
|
|
|
export default ExpressPaymentMethods;
|