File "boot.js"

Full Path: /home/siazco/grocery.siazco.se/wp-content/plugins/woocommerce-paypal-payments/modules/ppcp-googlepay/resources/js/boot.js
File size: 2.64 KB
MIME-type: text/x-java
Charset: utf-8

/**
 * Initialize the GooglePay module in the front end.
 * In some cases, this module is loaded when the `window.PayPalCommerceGateway` object is not
 * present. In that case, the page does not contain a Google Pay button, but some other logic
 * that is related to Google Pay (e.g., the CheckoutBootstrap module)
 *
 * @file
 */

import { loadCustomScript } from '@paypal/paypal-js';
import { loadPayPalScript } from '../../../ppcp-button/resources/js/modules/Helper/PayPalScriptLoading';
import GooglepayManager from './GooglepayManager';
import { setupButtonEvents } from '../../../ppcp-button/resources/js/modules/Helper/ButtonRefreshHelper';
import { CheckoutBootstrap } from './ContextBootstrap/CheckoutBootstrap';
import moduleStorage from './Helper/GooglePayStorage';

( function ( { buttonConfig, ppcpConfig = {} } ) {
	const context = ppcpConfig.context;
	const namespace = 'ppcpPaypalGooglepay';

	function bootstrapPayButton() {
		if ( ! buttonConfig || ! ppcpConfig ) {
			return;
		}

		const manager = new GooglepayManager(
			namespace,
			buttonConfig,
			ppcpConfig
		);

		setupButtonEvents( function () {
			manager.reinit();
		} );
	}

	function bootstrapCheckout() {
		if (
			context &&
			! [ 'checkout' ].includes( context ) &&
			! ( context === 'mini-cart' && ppcpConfig.continuation )
		) {
			// Context must be missing/empty, or "checkout"/checkout continuation to proceed.
			return;
		}
		if ( ! CheckoutBootstrap.isPageWithCheckoutForm() ) {
			return;
		}

		const checkoutBootstrap = new CheckoutBootstrap( moduleStorage );
		checkoutBootstrap.init();
	}

	function bootstrap() {
		bootstrapPayButton();
		bootstrapCheckout();
	}

	document.addEventListener( 'DOMContentLoaded', () => {
		if ( ! buttonConfig || ! ppcpConfig ) {
			/*
			 * No PayPal buttons present on this page, but maybe a bootstrap module needs to be
			 * initialized. Skip loading the SDK or gateway configuration, and directly initialize
			 * the module.
			 */
			bootstrap();

			return;
		}

		let bootstrapped = false;
		let paypalLoaded = false;
		let googlePayLoaded = false;

		const tryToBoot = () => {
			if ( ! bootstrapped && paypalLoaded && googlePayLoaded ) {
				bootstrapped = true;
				bootstrap();
			}
		};

		// Load GooglePay SDK
		loadCustomScript( { url: buttonConfig.sdk_url } ).then( () => {
			googlePayLoaded = true;
			tryToBoot();
		} );

		// Load PayPal
		loadPayPalScript( namespace, ppcpConfig )
			.then( () => {
				paypalLoaded = true;
				tryToBoot();
			} )
			.catch( ( error ) => {
				console.error( 'Failed to load PayPal script: ', error );
			} );
	} );
} )( {
	buttonConfig: window.wc_ppcp_googlepay,
	ppcpConfig: window.PayPalCommerceGateway,
} );