mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-26 12:29:06 +01:00
a01e4fa00a
Co-authored-by: georgewrmarshall <george.marshall@consensys.net>
92 lines
2.8 KiB
JavaScript
92 lines
2.8 KiB
JavaScript
import React, { memo } from 'react';
|
|
import { useSelector } from 'react-redux';
|
|
import { isEqual } from 'lodash';
|
|
import PropTypes from 'prop-types';
|
|
import {
|
|
getMemoizedMetaMaskIdentities,
|
|
getAccountName,
|
|
} from '../../../../selectors';
|
|
import Address from '../../transaction-decoding/components/decoding/address';
|
|
import {
|
|
isValidHexAddress,
|
|
toChecksumHexAddress,
|
|
} from '../../../../../shared/modules/hexstring-utils';
|
|
import {
|
|
Display,
|
|
FontWeight,
|
|
TextVariant,
|
|
TextColor,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import { sanitizeString } from '../../../../helpers/utils/util';
|
|
import { Box, Text } from '../../../component-library';
|
|
|
|
function SignatureRequestData({ data }) {
|
|
const identities = useSelector(getMemoizedMetaMaskIdentities);
|
|
|
|
return (
|
|
<Box as="ul" className="signature-request-data__node">
|
|
{Object.entries(data).map(([label, { value, type }], i) => (
|
|
<Box
|
|
as="li"
|
|
className="signature-request-data__node"
|
|
marginBottom={2}
|
|
key={`${label}-${i}`}
|
|
paddingLeft={2}
|
|
display={
|
|
typeof value !== 'object' || value === null ? Display.Flex : null
|
|
}
|
|
>
|
|
<Text
|
|
as="div"
|
|
color={TextColor.textDefault}
|
|
marginLeft={4}
|
|
fontWeight={
|
|
typeof value === 'object' ? FontWeight.Bold : FontWeight.Normal
|
|
}
|
|
>
|
|
{sanitizeString(label.charAt(0).toUpperCase() + label.slice(1))}:{' '}
|
|
</Text>
|
|
{typeof value === 'object' && value !== null ? (
|
|
<SignatureRequestData data={value} />
|
|
) : (
|
|
<Text
|
|
as="div"
|
|
color={TextColor.textDefault}
|
|
marginLeft={4}
|
|
className="signature-request-data__node__value"
|
|
>
|
|
{type === 'address' &&
|
|
isValidHexAddress(value, {
|
|
mixedCaseUseChecksum: true,
|
|
}) ? (
|
|
<Text
|
|
variant={TextVariant.bodySm}
|
|
as="div"
|
|
color={TextColor.infoDefault}
|
|
className="signature-request-data__node__value__address"
|
|
>
|
|
<Address
|
|
addressOnly
|
|
checksummedRecipientAddress={toChecksumHexAddress(value)}
|
|
recipientName={getAccountName(identities, value)}
|
|
/>
|
|
</Text>
|
|
) : (
|
|
sanitizeString(`${value}`)
|
|
)}
|
|
</Text>
|
|
)}
|
|
</Box>
|
|
))}
|
|
</Box>
|
|
);
|
|
}
|
|
|
|
SignatureRequestData.propTypes = {
|
|
data: PropTypes.oneOfType([PropTypes.object, PropTypes.array]).isRequired,
|
|
};
|
|
|
|
export default memo(SignatureRequestData, (prevProps, nextProps) => {
|
|
return isEqual(prevProps.data, nextProps.data);
|
|
});
|