2021-11-04 22:48:21 +01:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import { useSelector } from 'react-redux';
|
2022-12-08 17:42:23 +01:00
|
|
|
import { useHistory } from 'react-router-dom';
|
2021-11-04 22:48:21 +01:00
|
|
|
import NetworksForm from '../networks-form';
|
|
|
|
import NetworksList from '../networks-list';
|
|
|
|
import { getProvider } from '../../../../selectors';
|
|
|
|
|
2022-12-08 17:42:23 +01:00
|
|
|
import {
|
|
|
|
DEFAULT_ROUTE,
|
|
|
|
NETWORKS_ROUTE,
|
|
|
|
} from '../../../../helpers/constants/routes';
|
|
|
|
|
2021-11-04 22:48:21 +01:00
|
|
|
const NetworksTabContent = ({
|
|
|
|
networkDefaultedToProvider,
|
|
|
|
networkIsSelected,
|
|
|
|
networksToRender,
|
|
|
|
selectedNetwork,
|
|
|
|
shouldRenderNetworkForm,
|
|
|
|
}) => {
|
|
|
|
const provider = useSelector(getProvider);
|
2022-12-08 17:42:23 +01:00
|
|
|
const history = useHistory();
|
2021-11-04 22:48:21 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<NetworksList
|
|
|
|
networkDefaultedToProvider={networkDefaultedToProvider}
|
|
|
|
networkIsSelected={networkIsSelected}
|
|
|
|
networksToRender={networksToRender}
|
2023-03-09 22:00:28 +01:00
|
|
|
selectedNetworkConfigurationId={selectedNetwork.networkConfigurationId}
|
2021-11-04 22:48:21 +01:00
|
|
|
/>
|
|
|
|
{shouldRenderNetworkForm ? (
|
|
|
|
<NetworksForm
|
|
|
|
isCurrentRpcTarget={provider.rpcUrl === selectedNetwork.rpcUrl}
|
|
|
|
networksToRender={networksToRender}
|
|
|
|
selectedNetwork={selectedNetwork}
|
2022-12-08 17:42:23 +01:00
|
|
|
submitCallback={() => history.push(DEFAULT_ROUTE)}
|
|
|
|
cancelCallback={() => history.push(NETWORKS_ROUTE)}
|
2021-11-04 22:48:21 +01:00
|
|
|
/>
|
|
|
|
) : null}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
NetworksTabContent.propTypes = {
|
|
|
|
networkDefaultedToProvider: PropTypes.bool,
|
|
|
|
networkIsSelected: PropTypes.bool,
|
|
|
|
networksToRender: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
|
|
selectedNetwork: PropTypes.object,
|
|
|
|
shouldRenderNetworkForm: PropTypes.bool.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default NetworksTabContent;
|