Handle Signer Rejection // Real Custom Errors #3153

This commit is contained in:
Nicolas Gotchac
2016-11-16 18:55:53 +01:00
parent 18f570327e
commit 7144da5d7e
8 changed files with 151 additions and 17 deletions

View File

@@ -26,6 +26,8 @@ import ErrorStep from './ErrorStep';
import styles from './deployContract.css';
import { ERROR_CODES } from '../../api/transport/error';
const steps = ['contract details', 'deployment', 'completed'];
export default class DeployContract extends Component {
@@ -63,7 +65,8 @@ export default class DeployContract extends Component {
params: [],
paramsError: [],
step: 0,
deployError: null
deployError: null,
rejected: false
}
componentWillMount () {
@@ -92,15 +95,20 @@ export default class DeployContract extends Component {
}
render () {
const { step, deployError } = this.state;
const { step, deployError, rejected } = this.state;
const realSteps = deployError || rejected ? null : steps;
const title = realSteps
? null
: (deployError ? 'deployment failed' : 'rejected');
return (
<Modal
actions={ this.renderDialogActions() }
current={ step }
steps={ deployError ? null : steps }
title={ deployError ? 'deployment failed' : null }
waiting={ [1] }
steps={ realSteps }
title={ title }
waiting={ realSteps ? [1] : null }
visible
scroll>
{ this.renderStep() }
@@ -158,7 +166,7 @@ export default class DeployContract extends Component {
renderStep () {
const { accounts, readOnly } = this.props;
const { address, deployError, step, deployState, txhash } = this.state;
const { address, deployError, step, deployState, txhash, rejected } = this.state;
if (deployError) {
return (
@@ -166,6 +174,15 @@ export default class DeployContract extends Component {
);
}
if (rejected) {
return (
<BusyStep
title='The deployment has been rejected'
state='You can safely close this window, the contract deployment will not occur.'
/>
);
}
switch (step) {
case 0:
return (
@@ -273,6 +290,11 @@ export default class DeployContract extends Component {
});
})
.catch((error) => {
if (error.code === ERROR_CODES.REQUEST_REJECTED) {
this.setState({ rejected: true });
return false;
}
console.error('error deploying contract', error);
this.setState({ deployError: error });
store.dispatch({ type: 'newError', error });