woocommerce-paypal-payments/modules/ppcp-applepay/resources/js/ApplepayManager.js

65 lines
1.5 KiB
JavaScript
Raw Normal View History

/* global paypal */
2024-07-12 12:58:34 +02:00
import buttonModuleWatcher from '../../../ppcp-button/resources/js/modules/ButtonModuleWatcher';
import ApplePayButton from './ApplepayButton';
import ContextHandlerFactory from './Context/ContextHandlerFactory';
2023-08-31 12:48:01 +02:00
class ApplePayManager {
2024-07-12 12:58:34 +02:00
constructor( buttonConfig, ppcpConfig ) {
this.buttonConfig = buttonConfig;
this.ppcpConfig = ppcpConfig;
this.ApplePayConfig = null;
this.buttons = [];
this.onContextBootstrap = this.onContextBootstrap.bind( this );
buttonModuleWatcher.watchContextBootstrap( this.onContextBootstrap );
}
async onContextBootstrap( bootstrap ) {
this.contextHandler = ContextHandlerFactory.create(
bootstrap.context,
this.buttonConfig,
this.ppcpConfig,
bootstrap.handler
);
const button = ApplePayButton.createButton(
bootstrap.context,
bootstrap.handler,
this.buttonConfig,
this.ppcpConfig,
this.contextHandler
);
this.buttons.push( button );
// Ensure ApplePayConfig is loaded before proceeding.
await this.init();
button.configure( this.ApplePayConfig );
button.init();
2024-07-12 12:58:34 +02:00
}
async init() {
try {
if ( ! this.ApplePayConfig ) {
this.ApplePayConfig = await paypal.Applepay().config();
if ( ! this.ApplePayConfig ) {
console.error( 'No ApplePayConfig received during init' );
}
2024-07-12 12:58:34 +02:00
}
} catch ( error ) {
console.error( 'Error during initialization:', error );
}
2024-07-12 12:58:34 +02:00
}
reinit() {
for ( const button of this.buttons ) {
button.reinit();
}
}
2023-08-31 12:48:01 +02:00
}
export default ApplePayManager;