/*
	GoToSocial
	Copyright (C) GoToSocial Authors admin@gotosocial.org
	SPDX-License-Identifier: AGPL-3.0-or-later
	This program is free software: you can redistribute it and/or modify
	it under the terms of the GNU Affero General Public License as published by
	the Free Software Foundation, either version 3 of the License, or
	(at your option) any later version.
	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU Affero General Public License for more details.
	You should have received a copy of the GNU Affero General Public License
	along with this program.  If not, see .
*/
import { SerializedError } from "@reduxjs/toolkit";
import { FetchBaseQueryError } from "@reduxjs/toolkit/query";
import React, { ReactNode } from "react";
function ErrorFallback({ error, resetErrorBoundary }) {
	return (
		
	);
}
interface GtsError {
	/**
	 * Error message returned from the API.
	 */
	error: string;
	/**
	 * For OAuth errors: description of the error.
	 */
	error_description?: string;
}
interface ErrorProps {
	error: FetchBaseQueryError | SerializedError | Error | undefined;
	
	/**
	 * Optional function to clear the error.
	 * If provided, rendered error will have
	 * a "dismiss" button.
	 */
	reset?: () => void;
}
function Error({ error, reset }: ErrorProps) {
	if (error === undefined) {
		return null;
	}
	
	/* eslint-disable-next-line no-console */
	console.error("caught error: ", error);
	
	let message: ReactNode;
	if ("status" in error) {
		if (typeof error.status === "number") {
			// Error containing GTS API error data.
			const gtsError = error.data as GtsError;
			const errMsg = gtsError.error_description ?? gtsError.error;
			message = <>Code {error.status}: {errMsg}>;
		} else {
			// RTK Query fetching / parsing / timeout error.
			message = <>{error.status}: {error.error}>;
		}
	} else {
		// SerializedError or Error.
		const errMsg = error.message ?? JSON.stringify(error);
		message = (
			<>{error.name && `${error.name}: `}{errMsg}>
		);
	}
	let className = "error";
	if (reset) {
		className += " with-dismiss";
	}
	return (
		
			{message}
			{ reset && 
				 {
						e.preventDefault();
						e.stopPropagation();
						reset();
					}}
					role="button"
					tabIndex={0}
				>
					Dismiss
					
				
			}
		
	);
}
export { ErrorFallback, Error };