import React from 'react'; import PropTypes from 'prop-types'; import classnames from 'classnames'; import { useSelector } from 'react-redux'; import { NETWORK_TYPES, BUILT_IN_NETWORKS, } from '../../../../shared/constants/network'; import LoadingIndicator from '../../ui/loading-indicator'; import ColorIndicator from '../../ui/color-indicator'; import { BorderColor, IconColor, Size, TypographyVariant, } from '../../../helpers/constants/design-system'; import Chip from '../../ui/chip/chip'; import IconCaretDown from '../../ui/icon/icon-caret-down'; import { useI18nContext } from '../../../hooks/useI18nContext'; import { isNetworkLoading } from '../../../selectors'; export default function NetworkDisplay({ indicatorSize, disabled, labelProps, targetNetwork, onClick, }) { const networkIsLoading = useSelector(isNetworkLoading); const currentNetwork = useSelector((state) => ({ nickname: state.metamask.provider.nickname, type: state.metamask.provider.type, })); const t = useI18nContext(); const { nickname: networkNickname, type: networkType } = targetNetwork ?? currentNetwork; return ( } rightIcon={ onClick ? ( ) : null } label={ networkType === NETWORK_TYPES.RPC ? networkNickname ?? t('privateNetwork') : t(networkType) } className={classnames('network-display', { 'network-display--disabled': disabled, 'network-display--clickable': typeof onClick === 'function', })} labelProps={{ variant: TypographyVariant.H7, ...labelProps, }} /> ); } NetworkDisplay.propTypes = { /** * The size of the indicator */ indicatorSize: PropTypes.oneOf(Object.values(Size)), /** * The label props of the label can use most of the Typography props */ labelProps: Chip.propTypes.labelProps, /** * The target network */ targetNetwork: PropTypes.shape({ type: PropTypes.oneOf([ ...Object.keys(BUILT_IN_NETWORKS), NETWORK_TYPES.RPC, ]), nickname: PropTypes.string, }), /** * Whether the NetworkDisplay is disabled */ disabled: PropTypes.bool, /** * The onClick event handler of the NetworkDisplay * if it is not passed it is assumed that the NetworkDisplay * should not be interactive and removes the caret and changes the border color * of the NetworkDisplay */ onClick: PropTypes.func, }; NetworkDisplay.defaultProps = { indicatorSize: Size.LG, };