mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-30 16:18:07 +01:00
d154cc78e4
* snaps insight error catching and error state * revert confirm-transaction-base changes * display empty state if data is null * add loading state * reset errors and loading state on call * update hasNoData * update length check in component
154 lines
4.4 KiB
JavaScript
154 lines
4.4 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
|
|
import Preloader from '../../../ui/icon/preloader/preloader-icon.component';
|
|
import Typography from '../../../ui/typography/typography';
|
|
import {
|
|
ALIGN_ITEMS,
|
|
COLORS,
|
|
FLEX_DIRECTION,
|
|
JUSTIFY_CONTENT,
|
|
TEXT_ALIGN,
|
|
TYPOGRAPHY,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import { useI18nContext } from '../../../../hooks/useI18nContext';
|
|
import { useTransactionInsightSnap } from '../../../../hooks/flask/useTransactionInsightSnap';
|
|
import SnapContentFooter from '../../flask/snap-content-footer/snap-content-footer';
|
|
import Box from '../../../ui/box/box';
|
|
import ActionableMessage from '../../../ui/actionable-message/actionable-message';
|
|
|
|
export const SnapInsight = ({ transaction, chainId, selectedSnap }) => {
|
|
const t = useI18nContext();
|
|
const {
|
|
data: response,
|
|
error,
|
|
loading,
|
|
} = useTransactionInsightSnap({
|
|
transaction,
|
|
chainId,
|
|
snapId: selectedSnap.id,
|
|
});
|
|
|
|
const data = response?.insights;
|
|
|
|
const hasNoData =
|
|
!error && (loading || !data || (data && Object.keys(data).length === 0));
|
|
return (
|
|
<Box
|
|
flexDirection={FLEX_DIRECTION.COLUMN}
|
|
height="full"
|
|
marginTop={hasNoData && 12}
|
|
marginBottom={hasNoData && 12}
|
|
alignItems={hasNoData && ALIGN_ITEMS.CENTER}
|
|
justifyContent={hasNoData && JUSTIFY_CONTENT.CENTER}
|
|
textAlign={hasNoData && TEXT_ALIGN.CENTER}
|
|
className="snap-insight"
|
|
>
|
|
{!loading && !error && (
|
|
<Box
|
|
height="full"
|
|
flexDirection={FLEX_DIRECTION.COLUMN}
|
|
className="snap-insight__container"
|
|
>
|
|
{data && Object.keys(data).length > 0 ? (
|
|
<>
|
|
<Box
|
|
flexDirection={FLEX_DIRECTION.COLUMN}
|
|
paddingTop={0}
|
|
paddingRight={6}
|
|
paddingBottom={3}
|
|
paddingLeft={6}
|
|
className="snap-insight__container__data"
|
|
>
|
|
{Object.keys(data).map((key, i) => (
|
|
<div key={i}>
|
|
<Typography
|
|
fontWeight="bold"
|
|
marginTop={3}
|
|
variant={TYPOGRAPHY.H6}
|
|
>
|
|
{key}
|
|
</Typography>
|
|
|
|
{typeof data[key] === 'string' ? (
|
|
<Typography variant={TYPOGRAPHY.H6}>
|
|
{data[key]}
|
|
</Typography>
|
|
) : (
|
|
<Box
|
|
className="snap-insight__container__data__json"
|
|
backgroundColor={COLORS.BACKGROUND_ALTERNATIVE}
|
|
padding={3}
|
|
>
|
|
<Typography variant={TYPOGRAPHY.H7}>
|
|
<pre>{JSON.stringify(data[key], null, 2)}</pre>
|
|
</Typography>
|
|
</Box>
|
|
)}
|
|
</div>
|
|
))}
|
|
</Box>
|
|
<SnapContentFooter
|
|
snapName={selectedSnap.manifest.proposedName}
|
|
snapId={selectedSnap.id}
|
|
/>
|
|
</>
|
|
) : (
|
|
<Typography color={COLORS.TEXT_ALTERNATIVE} variant={TYPOGRAPHY.H6}>
|
|
{t('snapsNoInsight')}
|
|
</Typography>
|
|
)}
|
|
</Box>
|
|
)}
|
|
|
|
{!loading && error && (
|
|
<Box
|
|
paddingTop={0}
|
|
paddingRight={6}
|
|
paddingBottom={3}
|
|
paddingLeft={6}
|
|
className="snap-insight__container__error"
|
|
>
|
|
<ActionableMessage
|
|
message={t('snapsInsightError', [
|
|
selectedSnap.manifest.proposedName,
|
|
error.message,
|
|
])}
|
|
type="danger"
|
|
useIcon
|
|
iconFillColor="var(--color-error-default)"
|
|
/>
|
|
</Box>
|
|
)}
|
|
|
|
{loading && (
|
|
<>
|
|
<Preloader size={40} />
|
|
<Typography
|
|
marginTop={3}
|
|
color={COLORS.TEXT_ALTERNATIVE}
|
|
variant={TYPOGRAPHY.H6}
|
|
>
|
|
{t('snapsInsightLoading')}
|
|
</Typography>
|
|
</>
|
|
)}
|
|
</Box>
|
|
);
|
|
};
|
|
|
|
SnapInsight.propTypes = {
|
|
/*
|
|
* The transaction data object
|
|
*/
|
|
transaction: PropTypes.object,
|
|
/*
|
|
* CAIP2 Chain ID
|
|
*/
|
|
chainId: PropTypes.string,
|
|
/*
|
|
* The insight snap selected
|
|
*/
|
|
selectedSnap: PropTypes.object,
|
|
};
|