mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-25 11:28:51 +01:00
130 lines
4.1 KiB
JavaScript
130 lines
4.1 KiB
JavaScript
|
import React, { useEffect } from 'react';
|
||
|
import PropTypes from 'prop-types';
|
||
|
import { useLocation } from 'react-router-dom';
|
||
|
import { useDispatch, useSelector } from 'react-redux';
|
||
|
import { useI18nContext } from '../../../hooks/useI18nContext';
|
||
|
import {
|
||
|
ADD_NETWORK_ROUTE,
|
||
|
NETWORKS_FORM_ROUTE,
|
||
|
} from '../../../helpers/constants/routes';
|
||
|
import { setSelectedSettingsRpcUrl } from '../../../store/actions';
|
||
|
import Button from '../../../components/ui/button';
|
||
|
import { getEnvironmentType } from '../../../../app/scripts/lib/util';
|
||
|
import { ENVIRONMENT_TYPE_FULLSCREEN } from '../../../../shared/constants/app';
|
||
|
import {
|
||
|
getFrequentRpcListDetail,
|
||
|
getNetworksTabSelectedRpcUrl,
|
||
|
getProvider,
|
||
|
} from '../../../selectors';
|
||
|
import { NETWORK_TYPE_RPC } from '../../../../shared/constants/network';
|
||
|
import { defaultNetworksData } from './networks-tab.constants';
|
||
|
import NetworksTabContent from './networks-tab-content';
|
||
|
import NetworksForm from './networks-form';
|
||
|
import NetworksFormSubheader from './networks-tab-subheader';
|
||
|
|
||
|
const defaultNetworks = defaultNetworksData.map((network) => ({
|
||
|
...network,
|
||
|
viewOnly: true,
|
||
|
}));
|
||
|
|
||
|
const NetworksTab = ({ addNewNetwork }) => {
|
||
|
const t = useI18nContext();
|
||
|
const dispatch = useDispatch();
|
||
|
const { pathname } = useLocation();
|
||
|
|
||
|
const environmentType = getEnvironmentType();
|
||
|
const isFullScreen = environmentType === ENVIRONMENT_TYPE_FULLSCREEN;
|
||
|
const shouldRenderNetworkForm =
|
||
|
isFullScreen || Boolean(pathname.match(NETWORKS_FORM_ROUTE));
|
||
|
|
||
|
const frequentRpcListDetail = useSelector(getFrequentRpcListDetail);
|
||
|
const provider = useSelector(getProvider);
|
||
|
const networksTabSelectedRpcUrl = useSelector(getNetworksTabSelectedRpcUrl);
|
||
|
|
||
|
const frequentRpcNetworkListDetails = frequentRpcListDetail.map((rpc) => {
|
||
|
return {
|
||
|
label: rpc.nickname,
|
||
|
iconColor: '#6A737D',
|
||
|
providerType: NETWORK_TYPE_RPC,
|
||
|
rpcUrl: rpc.rpcUrl,
|
||
|
chainId: rpc.chainId,
|
||
|
ticker: rpc.ticker,
|
||
|
blockExplorerUrl: rpc.rpcPrefs?.blockExplorerUrl || '',
|
||
|
};
|
||
|
});
|
||
|
|
||
|
const networksToRender = [
|
||
|
...defaultNetworks,
|
||
|
...frequentRpcNetworkListDetails,
|
||
|
];
|
||
|
let selectedNetwork =
|
||
|
networksToRender.find(
|
||
|
(network) => network.rpcUrl === networksTabSelectedRpcUrl,
|
||
|
) || {};
|
||
|
const networkIsSelected = Boolean(selectedNetwork.rpcUrl);
|
||
|
|
||
|
let networkDefaultedToProvider = false;
|
||
|
if (!networkIsSelected) {
|
||
|
selectedNetwork =
|
||
|
networksToRender.find((network) => {
|
||
|
return (
|
||
|
network.rpcUrl === provider.rpcUrl ||
|
||
|
(network.providerType !== NETWORK_TYPE_RPC &&
|
||
|
network.providerType === provider.type)
|
||
|
);
|
||
|
}) || {};
|
||
|
networkDefaultedToProvider = true;
|
||
|
}
|
||
|
|
||
|
useEffect(() => {
|
||
|
return () => {
|
||
|
dispatch(setSelectedSettingsRpcUrl(''));
|
||
|
};
|
||
|
}, [dispatch]);
|
||
|
|
||
|
return (
|
||
|
<div className="networks-tab__body">
|
||
|
{isFullScreen ? (
|
||
|
<NetworksFormSubheader addNewNetwork={addNewNetwork} />
|
||
|
) : null}
|
||
|
<div className="networks-tab__content">
|
||
|
{addNewNetwork ? (
|
||
|
<NetworksForm
|
||
|
networksToRender={networksToRender}
|
||
|
addNewNetwork={addNewNetwork}
|
||
|
/>
|
||
|
) : (
|
||
|
<>
|
||
|
<NetworksTabContent
|
||
|
networkDefaultedToProvider={networkDefaultedToProvider}
|
||
|
networkIsSelected={networkIsSelected}
|
||
|
networksToRender={networksToRender}
|
||
|
providerUrl={provider.rpcUrl}
|
||
|
selectedNetwork={selectedNetwork}
|
||
|
shouldRenderNetworkForm={shouldRenderNetworkForm}
|
||
|
/>
|
||
|
{!isFullScreen && !shouldRenderNetworkForm ? (
|
||
|
<div className="networks-tab__networks-list-popup-footer">
|
||
|
<Button
|
||
|
type="primary"
|
||
|
onClick={(event) => {
|
||
|
event.preventDefault();
|
||
|
global.platform.openExtensionInBrowser(ADD_NETWORK_ROUTE);
|
||
|
}}
|
||
|
>
|
||
|
{t('addNetwork')}
|
||
|
</Button>
|
||
|
</div>
|
||
|
) : null}
|
||
|
</>
|
||
|
)}
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
NetworksTab.propTypes = {
|
||
|
addNewNetwork: PropTypes.bool,
|
||
|
};
|
||
|
export default NetworksTab;
|