2022-06-01 13:28:05 +00:00
|
|
|
import { h } from 'preact';
|
2022-06-01 00:41:24 +00:00
|
|
|
import { useCallback } from 'preact/hooks';
|
|
|
|
import { Modal, ModalContent, ModalFooter } from './Modal';
|
|
|
|
|
2023-01-12 02:14:44 +00:00
|
|
|
import styles from './css/ErrorModal.module.scss';
|
2022-06-03 22:30:39 +00:00
|
|
|
|
2022-06-01 00:41:24 +00:00
|
|
|
export interface ErrorProps {
|
2022-06-01 13:28:05 +00:00
|
|
|
error: unknown | undefined;
|
2022-06-01 00:41:24 +00:00
|
|
|
setError: (error: string | undefined) => void;
|
|
|
|
}
|
|
|
|
|
2022-06-01 13:28:05 +00:00
|
|
|
export const ErrorModal = ({ error, setError }: ErrorProps) => {
|
2022-06-01 00:41:24 +00:00
|
|
|
const onClose = useCallback(() => setError(undefined), [setError]);
|
2022-06-01 13:28:05 +00:00
|
|
|
let errorStr = null;
|
|
|
|
if (error) {
|
|
|
|
if (error instanceof Error) {
|
|
|
|
errorStr = error.message;
|
|
|
|
} else if (typeof error === 'string') {
|
|
|
|
errorStr = error;
|
|
|
|
} else {
|
|
|
|
errorStr = 'Unknown Error';
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
}
|
2022-06-01 00:41:24 +00:00
|
|
|
|
2022-06-01 13:28:05 +00:00
|
|
|
if (errorStr) {
|
|
|
|
return (
|
|
|
|
<Modal
|
|
|
|
title="Error"
|
|
|
|
icon="triangle-exclamation"
|
|
|
|
isOpen={true}
|
|
|
|
onClose={onClose}
|
|
|
|
>
|
|
|
|
<ModalContent>
|
2022-06-03 22:30:39 +00:00
|
|
|
<div className={styles.errorModal}>
|
2022-06-01 13:28:05 +00:00
|
|
|
{errorStr}
|
|
|
|
</div>
|
|
|
|
</ModalContent>
|
|
|
|
<ModalFooter>
|
|
|
|
<button onClick={onClose}>OK</button>
|
|
|
|
</ModalFooter>
|
|
|
|
</Modal>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
2022-06-01 00:41:24 +00:00
|
|
|
};
|