From 7b34b4b456c772323cf38a8ae7c952738bb7dd19 Mon Sep 17 00:00:00 2001 From: lukaw3d Date: Tue, 20 Feb 2024 05:15:10 +0100 Subject: [PATCH] Show errors in runtime events --- .changelog/1278.bugfix.md | 1 + .../components/RuntimeEvents/EventError.tsx | 58 +++++++++++++++++++ .../RuntimeEvents/RuntimeEventDetails.tsx | 5 ++ src/app/components/StatusIcon/index.tsx | 2 +- src/locales/en/translation.json | 1 + 5 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 .changelog/1278.bugfix.md create mode 100644 src/app/components/RuntimeEvents/EventError.tsx diff --git a/.changelog/1278.bugfix.md b/.changelog/1278.bugfix.md new file mode 100644 index 000000000..ad35f6ed7 --- /dev/null +++ b/.changelog/1278.bugfix.md @@ -0,0 +1 @@ +Show errors in runtime events diff --git a/src/app/components/RuntimeEvents/EventError.tsx b/src/app/components/RuntimeEvents/EventError.tsx new file mode 100644 index 000000000..30d03a45e --- /dev/null +++ b/src/app/components/RuntimeEvents/EventError.tsx @@ -0,0 +1,58 @@ +import { FC } from 'react' +import { useTranslation } from 'react-i18next' +import CancelIcon from '@mui/icons-material/Cancel' +import { RuntimeEvent } from '../../../oasis-nexus/api' +import { ErrorBox, StyledBox } from '../StatusIcon' + +// eslint-disable-next-line @typescript-eslint/no-unused-vars +import { RuntimeEventType } from '../../../oasis-nexus/api' + +/** + * https://github.com/oasisprotocol/oasis-sdk/blob/9fb148a/client-sdk/go/modules/consensusaccounts/types.go#L145-L217 + * + * Can appear in: + * - {@link RuntimeEventType.consensus_accountsdeposit} + * - {@link RuntimeEventType.consensus_accountswithdraw} + * - {@link RuntimeEventType.consensus_accountsdelegate} + * - {@link RuntimeEventType.consensus_accountsundelegate_start} + */ +type ConsensusError = { + module: string + code: number +} + +type EventErrorProps = { + event: RuntimeEvent +} + +export const EventError: FC = ({ event }) => { + const { t } = useTranslation() + const error: ConsensusError | undefined = event.body.error + if (!error) return null + + const errorMessage = `${t('errors.code')} ${error.code}, ${t('errors.module')}: ${error.module}` + return ( + <> + + {t('common.failed')} +   + + + {errorMessage} + + ) +} + +export const MaybeEventErrorLine: FC = ({ event }) => { + const { t } = useTranslation() + return ( + event.body.error && ( + <> +
{t('common.status')}
+
+ +
+ + ) + ) +} diff --git a/src/app/components/RuntimeEvents/RuntimeEventDetails.tsx b/src/app/components/RuntimeEvents/RuntimeEventDetails.tsx index b9b5e2c26..a52038de4 100644 --- a/src/app/components/RuntimeEvents/RuntimeEventDetails.tsx +++ b/src/app/components/RuntimeEvents/RuntimeEventDetails.tsx @@ -28,6 +28,7 @@ import { getPreciseNumberFormat } from '../../../locales/getPreciseNumberFormat' import { UndelegateStartIcon } from '../CustomIcons/UndelegateStart' import { UndelegateFinishIcon } from '../CustomIcons/UndelegateFinish' import { DelegateIcon } from '../CustomIcons/Delegate' +import { MaybeEventErrorLine } from './EventError' export const EventTypeIcon: FC<{ eventType: RuntimeEventType @@ -244,6 +245,7 @@ export const RuntimeEventDetails: FC<{
+
{t('common.from')}
+
{t('common.from')}
+
{t('common.from')}
+
{t('common.from')}
({ +export const ErrorBox = styled(Box)(() => ({ display: 'flex', justifyContent: 'center', alignItems: 'center', diff --git a/src/locales/en/translation.json b/src/locales/en/translation.json index e564d2edb..166efb38a 100644 --- a/src/locales/en/translation.json +++ b/src/locales/en/translation.json @@ -201,6 +201,7 @@ }, "errors": { "code": "error code", + "module": "module", "error": "Error", "loadFirstPage": "load the first page", "unknown": "Unknown error",