HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ns3133907 6.8.0-86-generic #87-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 22 18:03:36 UTC 2025 x86_64
User: cssnetorguk (1024)
PHP: 8.2.28
Disabled: NONE
Upload Files
File: //home/pbyh.co.uk/public_html/wp-content/plugins/complianz-gdpr/settings/src/utils/ErrorBoundary.js
import React, { Component } from 'react';
import PropTypes from 'prop-types';

class ErrorBoundary extends Component {
	constructor(props) {
		super(props);
		this.state = { hasError: false, error: null, errorInfo: null };
		this.resetError = this.resetError.bind(this);
	}

	static getDerivedStateFromError(error) {
		return { hasError: true };
	}


	componentDidCatch(error, errorInfo) {
		this.setState({ error, errorInfo });
		// You can also log the error to an error reporting service
		console.log('ErrorBoundary', error, errorInfo);
	}


	resetError() {
		this.setState({ hasError: false, error: null, errorInfo: null });
	}

	render() {
		if (this.state.hasError) {
			return (
				<div className="cmplz-error-boundary">
					<h3 className="cmplz-h4">Something went wrong.</h3>

					{/* You can render any custom fallback UI */}
					<p>{this.props.fallback}</p>
					<button className="button button-primary" onClick={(e) => function() {window.location.reload()}} >Try Again</button>
				</div>
			);
		}

		return this.props.children;
	}
}

ErrorBoundary.propTypes = {
	children: PropTypes.node,
	fallback: PropTypes.node,
};

export default ErrorBoundary;