File "status-page.js"

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

import { setVisibleByClass } from '../../../ppcp-button/resources/js/modules/Helper/Hiding';

document.addEventListener( 'DOMContentLoaded', () => {
	const resubscribeBtn = jQuery(
		PayPalCommerceGatewayWebhooksStatus.resubscribe.button
	);

	resubscribeBtn.click( async () => {
		resubscribeBtn.prop( 'disabled', true );

		const response = await fetch(
			PayPalCommerceGatewayWebhooksStatus.resubscribe.endpoint,
			{
				method: 'POST',
				credentials: 'same-origin',
				headers: {
					'content-type': 'application/json',
				},
				body: JSON.stringify( {
					nonce: PayPalCommerceGatewayWebhooksStatus.resubscribe
						.nonce,
				} ),
			}
		);

		const reportError = ( error ) => {
			const msg =
				PayPalCommerceGatewayWebhooksStatus.resubscribe.failureMessage +
				' ' +
				error;
			alert( msg );
		};

		if ( ! response.ok ) {
			try {
				const result = await response.json();
				reportError( result.data );
			} catch ( exc ) {
				console.error( exc );
				reportError( response.status );
			}
		}

		window.location.reload();
	} );

	function sleep( ms ) {
		return new Promise( ( resolve ) => setTimeout( resolve, ms ) );
	}

	const simulateBtn = jQuery(
		PayPalCommerceGatewayWebhooksStatus.simulation.start.button
	);
	simulateBtn.click( async () => {
		simulateBtn.prop( 'disabled', true );

		try {
			const response = await fetch(
				PayPalCommerceGatewayWebhooksStatus.simulation.start.endpoint,
				{
					method: 'POST',
					credentials: 'same-origin',
					headers: {
						'content-type': 'application/json',
					},
					body: JSON.stringify( {
						nonce: PayPalCommerceGatewayWebhooksStatus.simulation
							.start.nonce,
					} ),
				}
			);

			const reportError = ( error ) => {
				const msg =
					PayPalCommerceGatewayWebhooksStatus.simulation.start
						.failureMessage +
					' ' +
					error;
				alert( msg );
			};

			if ( ! response.ok ) {
				try {
					const result = await response.json();
					reportError( result.data );
				} catch ( exc ) {
					console.error( exc );
					reportError( response.status );
				}

				return;
			}

			const showStatus = ( html ) => {
				let statusBlock = simulateBtn.siblings(
					'.ppcp-webhooks-status-text'
				);
				if ( ! statusBlock.length ) {
					statusBlock = jQuery(
						'<div class="ppcp-webhooks-status-text"></div>'
					).insertAfter( simulateBtn );
				}
				statusBlock.html( html );
			};

			simulateBtn.siblings( '.description' ).hide();

			showStatus(
				PayPalCommerceGatewayWebhooksStatus.simulation.state
					.waitingMessage +
					'<span class="spinner is-active" style="float: none;"></span>'
			);

			const delay = 2000;
			const retriesBeforeErrorMessage = 15;
			const maxRetries = 30;

			for ( let i = 0; i < maxRetries; i++ ) {
				await sleep( delay );

				const stateResponse = await fetch(
					PayPalCommerceGatewayWebhooksStatus.simulation.state
						.endpoint,
					{
						method: 'GET',
						credentials: 'same-origin',
					}
				);

				try {
					const result = await stateResponse.json();

					if ( ! stateResponse.ok || ! result.success ) {
						console.error(
							'Simulation state query failed: ' + result.data
						);
						continue;
					}

					const state = result.data.state;
					if (
						state ===
						PayPalCommerceGatewayWebhooksStatus.simulation.state
							.successState
					) {
						showStatus(
							'<span class="success">' +
								'✔️ ' +
								PayPalCommerceGatewayWebhooksStatus.simulation
									.state.successMessage +
								'</span>'
						);
						return;
					}
				} catch ( exc ) {
					console.error( exc );
				}

				if ( i === retriesBeforeErrorMessage ) {
					showStatus(
						'<span class="error">' +
							PayPalCommerceGatewayWebhooksStatus.simulation.state
								.tooLongDelayMessage +
							'</span>'
					);
				}
			}
		} finally {
			simulateBtn.prop( 'disabled', false );
		}
	} );

	const sandboxCheckbox = document.querySelector( '#ppcp-sandbox_on' );
	if ( sandboxCheckbox ) {
		const setWebhooksVisibility = ( show ) => {
			[
				'#field-webhook_status_heading',
				'#field-webhooks_list',
				'#field-webhooks_resubscribe',
				'#field-webhooks_simulate',
			].forEach( ( selector ) => {
				setVisibleByClass( selector, show, 'hide' );
			} );
		};

		const serverSandboxState =
			PayPalCommerceGatewayWebhooksStatus.environment === 'sandbox';
		setWebhooksVisibility( serverSandboxState === sandboxCheckbox.checked );
		sandboxCheckbox.addEventListener( 'click', () => {
			setWebhooksVisibility(
				serverSandboxState === sandboxCheckbox.checked
			);
		} );
	}
} );