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

147 lines
4.1 KiB
JavaScript
Raw Normal View History

import React, { PureComponent } from 'react';
import PropTypes from 'prop-types';
import Button from '../../ui/button';
import LoadingScreen from '../../ui/loading-screen';
import { SECOND } from '../../../../shared/constants/time';
export default class LoadingNetworkScreen extends PureComponent {
state = {
showErrorScreen: false,
};
static contextTypes = {
t: PropTypes.func,
};
static propTypes = {
loadingMessage: PropTypes.string,
cancelTime: PropTypes.number,
provider: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
providerId: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
showNetworkDropdown: PropTypes.func,
setProviderArgs: PropTypes.array,
setProviderType: PropTypes.func,
rollbackToPreviousProvider: PropTypes.func,
isNetworkLoading: PropTypes.bool,
};
componentDidMount = () => {
2020-11-03 00:41:28 +01:00
this.cancelCallTimeout = setTimeout(
this.cancelCall,
this.props.cancelTime || SECOND * 15,
);
};
getConnectingLabel = function (loadingMessage) {
if (loadingMessage) {
return loadingMessage;
}
const { provider, providerId } = this.props;
const providerName = provider.type;
let name;
if (providerName === 'mainnet') {
name = this.context.t('connectingToMainnet');
} else if (providerName === 'ropsten') {
name = this.context.t('connectingToRopsten');
} else if (providerName === 'kovan') {
name = this.context.t('connectingToKovan');
} else if (providerName === 'rinkeby') {
name = this.context.t('connectingToRinkeby');
2019-04-17 19:34:49 +02:00
} else if (providerName === 'goerli') {
name = this.context.t('connectingToGoerli');
} else if (providerName === 'sepolia') {
name = this.context.t('connectingToSepolia');
} else {
name = this.context.t('connectingTo', [providerId]);
}
return name;
};
renderErrorScreenContent = () => {
2022-07-31 20:26:40 +02:00
const { showNetworkDropdown, setProviderArgs, setProviderType } =
this.props;
return (
<div className="loading-overlay__error-screen">
<span className="loading-overlay__emoji">&#128542;</span>
2020-11-03 00:41:28 +01:00
<span>{this.context.t('somethingWentWrong')}</span>
<div className="loading-overlay__error-buttons">
<Button
type="secondary"
onClick={() => {
window.clearTimeout(this.cancelCallTimeout);
showNetworkDropdown();
}}
>
2020-11-03 00:41:28 +01:00
{this.context.t('switchNetworks')}
</Button>
<Button
type="primary"
onClick={() => {
this.setState({ showErrorScreen: false });
setProviderType(...setProviderArgs);
window.clearTimeout(this.cancelCallTimeout);
2020-11-03 00:41:28 +01:00
this.cancelCallTimeout = setTimeout(
this.cancelCall,
this.props.cancelTime || SECOND * 15,
);
}}
>
2020-11-03 00:41:28 +01:00
{this.context.t('tryAgain')}
</Button>
</div>
</div>
);
};
cancelCall = () => {
const { isNetworkLoading } = this.props;
if (isNetworkLoading) {
this.setState({ showErrorScreen: true });
}
};
componentDidUpdate = (prevProps) => {
const { provider } = this.props;
const { provider: prevProvider } = prevProps;
if (provider.type !== prevProvider.type) {
window.clearTimeout(this.cancelCallTimeout);
this.setState({ showErrorScreen: false });
2020-11-03 00:41:28 +01:00
this.cancelCallTimeout = setTimeout(
this.cancelCall,
this.props.cancelTime || SECOND * 15,
);
}
};
componentWillUnmount = () => {
window.clearTimeout(this.cancelCallTimeout);
};
2020-11-03 00:41:28 +01:00
render() {
const { rollbackToPreviousProvider } = this.props;
return (
<LoadingScreen
2020-11-03 00:41:28 +01:00
header={
<div
className="page-container__header-close"
onClick={rollbackToPreviousProvider}
/>
2020-11-03 00:41:28 +01:00
}
showLoadingSpinner={!this.state.showErrorScreen}
2020-11-03 00:41:28 +01:00
loadingMessage={
this.state.showErrorScreen
? this.renderErrorScreenContent()
: this.getConnectingLabel(this.props.loadingMessage)
}
/>
);
}
}