1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/components/multichain/network-list-item/network-list-item.js

152 lines
3.6 KiB
JavaScript
Raw Normal View History

import React, { useEffect, useRef } from 'react';
2023-03-31 19:58:25 +02:00
import classnames from 'classnames';
import PropTypes from 'prop-types';
import {
AlignItems,
IconColor,
BorderRadius,
Color,
Size,
JustifyContent,
TextColor,
BackgroundColor,
BlockSize,
Display,
2023-03-31 19:58:25 +02:00
} from '../../../helpers/constants/design-system';
import {
AvatarNetwork,
ButtonIcon,
Text,
IconName,
Box,
} from '../../component-library';
2023-03-31 19:58:25 +02:00
import { useI18nContext } from '../../../hooks/useI18nContext';
import Tooltip from '../../ui/tooltip/tooltip';
import {
GOERLI_DISPLAY_NAME,
LINEA_GOERLI_DISPLAY_NAME,
SEPOLIA_DISPLAY_NAME,
} from '../../../../shared/constants/network';
2023-03-31 19:58:25 +02:00
const MAXIMUM_CHARACTERS_WITHOUT_TOOLTIP = 20;
2023-03-31 19:58:25 +02:00
function getAvatarNetworkColor(name) {
switch (name) {
case GOERLI_DISPLAY_NAME:
return BackgroundColor.goerli;
case LINEA_GOERLI_DISPLAY_NAME:
return BackgroundColor.lineaGoerli;
case SEPOLIA_DISPLAY_NAME:
return BackgroundColor.sepolia;
default:
return undefined;
}
}
2023-03-31 19:58:25 +02:00
export const NetworkListItem = ({
name,
iconSrc,
selected = false,
onClick,
onDeleteClick,
}) => {
const t = useI18nContext();
const networkRef = useRef();
useEffect(() => {
if (networkRef.current && selected) {
networkRef.current.focus();
}
}, [networkRef, selected]);
2023-03-31 19:58:25 +02:00
return (
<Box
onClick={onClick}
padding={4}
gap={2}
backgroundColor={selected ? Color.primaryMuted : Color.transparent}
className={classnames('multichain-network-list-item', {
'multichain-network-list-item--selected': selected,
})}
display={Display.Flex}
2023-03-31 19:58:25 +02:00
alignItems={AlignItems.center}
justifyContent={JustifyContent.spaceBetween}
width={BlockSize.Full}
2023-03-31 19:58:25 +02:00
>
{selected && (
<Box
className="multichain-network-list-item__selected-indicator"
borderRadius={BorderRadius.pill}
backgroundColor={Color.primaryDefault}
/>
)}
<AvatarNetwork
backgroundColor={getAvatarNetworkColor(name)}
name={name}
src={iconSrc}
/>
2023-03-31 19:58:25 +02:00
<Box className="multichain-network-list-item__network-name">
<Text
ref={networkRef}
as="button"
onClick={(e) => {
e.stopPropagation();
onClick();
}}
color={TextColor.textDefault}
backgroundColor={BackgroundColor.transparent}
ellipsis
>
2023-03-31 19:58:25 +02:00
{name.length > MAXIMUM_CHARACTERS_WITHOUT_TOOLTIP ? (
<Tooltip
title={name}
position="bottom"
wrapperClassName="multichain-network-list-item__tooltip"
>
{name}
</Tooltip>
) : (
name
)}
</Text>
2023-03-31 19:58:25 +02:00
</Box>
{onDeleteClick ? (
<ButtonIcon
className="multichain-network-list-item__delete"
color={IconColor.errorDefault}
iconName={IconName.Trash}
2023-03-31 19:58:25 +02:00
ariaLabel={t('deleteNetwork')}
size={Size.SM}
onClick={(e) => {
e.stopPropagation();
onDeleteClick();
}}
/>
) : null}
</Box>
);
};
NetworkListItem.propTypes = {
/**
* The name of the network
*/
name: PropTypes.string.isRequired,
/**
* Path to the Icon image
*/
iconSrc: PropTypes.string,
/**
* Represents if the network item is selected
*/
selected: PropTypes.bool,
/**
* Executes when the item is clicked
*/
onClick: PropTypes.func.isRequired,
/**
* Executes when the delete icon is clicked
*/
onDeleteClick: PropTypes.func,
};