woocommerce-paypal-payments/modules/ppcp-blocks/resources/js/Components/CardFields.js

102 lines
2.9 KiB
JavaScript
Raw Normal View History

2024-04-17 16:20:42 +02:00
import {useEffect} from '@wordpress/element';
2024-04-17 17:35:30 +02:00
export function CardFields({config, eventRegistration, emitResponse}) {
const {onPaymentSetup, onCheckoutFail, onCheckoutValidation} = eventRegistration;
const {responseTypes} = emitResponse;
const createOrder = async () => {
try {
const res = await fetch(config.scriptData.ajax.create_order.endpoint, {
method: 'POST',
credentials: 'same-origin',
body: JSON.stringify({
nonce: config.scriptData.ajax.create_order.nonce,
context: config.scriptData.context,
payment_method: 'ppcp-credit-card-gateway',
createaccount: false
}),
});
const json = await res.json();
if (!json.success) {
console.error(json)
}
console.log(json.data.id)
return json.data.id;
} catch (err) {
console.error(err);
}
};
const handleApprove = async (data, actions) => {
try {
const res = await fetch(config.scriptData.ajax.approve_order.endpoint, {
method: 'POST',
credentials: 'same-origin',
body: JSON.stringify({
nonce: config.scriptData.ajax.approve_order.nonce,
order_id: data.orderID,
})
});
const json = await res.json();
if (!json.success) {
console.error(json)
}
console.log(json)
} catch (err) {
console.error(err);
}
};
2024-04-17 16:20:42 +02:00
const cardField = paypal.CardFields({
2024-04-17 17:35:30 +02:00
createOrder: () => {
return createOrder();
},
onApprove: (data, actions) => {
return handleApprove(data, actions);
},
2024-04-17 16:20:42 +02:00
onError: function (error) {
console.error(error)
}
});
2024-04-17 17:35:30 +02:00
useEffect(() => {
const unsubscribe = onPaymentSetup(() => {
cardField.submit()
.catch((error) => {
console.error(error)
return {type: responseTypes.ERROR};
});
return true;
});
return unsubscribe;
}, [onPaymentSetup]);
2024-04-17 16:20:42 +02:00
useEffect(() => {
if (cardField.isEligible()) {
const numberField = cardField.NumberField();
numberField.render("#card-number-field-container");
const cvvField = cardField.CVVField();
cvvField.render("#card-cvv-field-container");
const expiryField = cardField.ExpiryField();
expiryField.render("#card-expiry-field-container");
}
}, []);
return (
<>
<div id="card-number-field-container"></div>
<div id="card-expiry-field-container"></div>
<div id="card-cvv-field-container"></div>
</>
)
}