woocommerce-paypal-payments/modules/ppcp-applepay/resources/js/Block/hooks/useApplepayScript.js
2024-10-11 11:13:15 +02:00

65 lines
1.5 KiB
JavaScript

import { useState, useEffect } from '@wordpress/element';
import { loadCustomScript } from '@paypal/paypal-js';
const useApplepayScript = (
componentDocument,
buttonConfig,
isPayPalLoaded
) => {
const [ isApplepayLoaded, setIsApplepayLoaded ] = useState( false );
useEffect( () => {
if ( ! componentDocument ) {
return;
}
const injectScriptToFrame = ( scriptSrc ) => {
if ( document === componentDocument ) {
return;
}
const script = document.querySelector(
`script[src^="${ scriptSrc }"]`
);
if ( script ) {
const newScript = componentDocument.createElement( 'script' );
newScript.src = script.src;
newScript.async = script.async;
newScript.type = script.type;
componentDocument.head.appendChild( newScript );
} else {
console.error( 'Script not found in the document:', scriptSrc );
}
};
const loadApplepayScript = async () => {
if ( ! isPayPalLoaded ) {
return;
}
if ( ! buttonConfig || ! buttonConfig.sdk_url ) {
console.error( 'Invalid buttonConfig or missing sdk_url' );
return;
}
try {
await loadCustomScript( { url: buttonConfig.sdk_url } ).then(
() => {
injectScriptToFrame( buttonConfig.sdk_url );
}
);
setIsApplepayLoaded( true );
} catch ( error ) {
console.error( 'Failed to load Applepay script:', error );
}
};
loadApplepayScript();
}, [ componentDocument, buttonConfig, isPayPalLoaded ] );
return isApplepayLoaded;
};
export default useApplepayScript;