File "index.js"

Full Path: /home/warrior1/public_html/languages/wp-content/plugins/astra-sites/inc/lib/onboarding/assets/src/components/error/index.js
File size: 4.21 KB
MIME-type: text/html
Charset: utf-8

import React from 'react';
import { __ } from '@wordpress/i18n';
import { decodeEntities } from '@wordpress/html-entities';
import { useStateValue } from '../../store/store';
import Button from '../../components/button/button';
import './style.scss';
import { getSupportLink } from '../../utils/functions';

const ErrorScreen = () => {
	const [
		{ importErrorMessages, currentIndex, tryAgainCount, templateId },
		dispatch,
	] = useStateValue();

	const supportLink = getSupportLink(
		templateId,
		importErrorMessages.errorText
	);

	const tryAgain = () => {
		dispatch( {
			type: 'set',
			// Reset errors.
			importErrorMessages: {},
			importErrorResponse: [],
			importError: false,

			// Try again count.
			tryAgainCount: tryAgainCount + 1,

			// Reset import flags.
			xmlImportDone: false,
			resetData: [],
			importStart: false,
			importEnd: false,
			importPercent: 0,
			requiredPluginsDone: false,
			notInstalledList: [],
			notActivatedList: [],

			// Go to previous step.
			currentIndex: currentIndex - 1,
		} );
	};

	const solutionHeading = (
		<h5 className="ist-import-error-solution-heading">
			{ __( 'Still no luck? Other potential solution:', 'astra-sites' ) }
		</h5>
	);

	return (
		<div className="ist-import-error">
			<div className="ist-import-progress-info">
				<div className="ist-import-progress-info-text label-text">
					{ __( 'Sorry, something went wrong.', 'astra-sites' ) }
				</div>
			</div>
			<div className="ist-import-error-box">
				<h5 className="ist-import-error-box-heading">
					{ __( 'What went wrong?', 'astra-sites' ) }
				</h5>
				<div className="ist-import-error-wrap ist-import-error-primary-wrap">
					{ importErrorMessages.primaryText && (
						<p className="website-import-subtitle">
							{ importErrorMessages.primaryText }
						</p>
					) }
				</div>
				{ importErrorMessages.secondaryText && (
					<div className="ist-import-error-wrap ist-import-error-secondary-wrap">
						{ importErrorMessages.secondaryText && (
							<p
								dangerouslySetInnerHTML={ {
									__html: importErrorMessages.secondaryText,
								} }
							/>
						) }
					</div>
				) }
				<div className="ist-import-error-wrap ist-import-error-text-wrap">
					<h5 className="ist-import-error-text-heading">
						{ __(
							'More technical information from console:',
							'astra-sites'
						) }
					</h5>
					{ importErrorMessages.errorText &&
						'object' !== typeof importErrorMessages.errorText && (
							<p className="ist-import-error-text">
								{ importErrorMessages.errorText }
							</p>
						) }
					{ importErrorMessages.errorText &&
						'object' === typeof importErrorMessages.errorText && (
							<div className="ist-import-error-text">
								<pre>
									{ JSON.stringify(
										importErrorMessages.errorText,
										undefined,
										2
									) }
								</pre>
							</div>
						) }
				</div>
			</div>
			{ importErrorMessages.tryAgain && tryAgainCount < 3 && (
				<Button className="ist-button" after onClick={ tryAgain }>
					{ __( 'Click here and we’ll try again', 'astra-sites' ) }
				</Button>
			) }
			<div className="ist-import-error-solution-wrapper">
				{ importErrorMessages.solutionText && (
					<>
						{ solutionHeading }
						<p
							className="ist-import-error-solution"
							dangerouslySetInnerHTML={ {
								__html: importErrorMessages.solutionText,
							} }
						/>
					</>
				) }
				{ ( ! importErrorMessages.solutionText &&
					! importErrorMessages.tryAgain ) ||
					( importErrorMessages.tryAgain && tryAgainCount > 1 && (
						<>
							{ solutionHeading }
							<p className="ist-import-error-solution">
								{ decodeEntities(
									__(
										'Please report this error&nbsp;',
										'astra-sites'
									)
								) }
								<a
									href={ supportLink }
									target="_blank"
									rel="noreferrer"
								>
									{ 'here' }
								</a>
								{ decodeEntities(
									__(
										'&nbsp;so we can fix it.',
										'astra-sites'
									)
								) }
							</p>
						</>
					) ) }
			</div>
		</div>
	);
};

export default ErrorScreen;