Fix infinite spinner on failed transactions

feature/default_network_editable
Alexander Tseung 6 years ago
parent 0259eb0214
commit f78dc96a2c
  1. 4
      ui/app/actions.js
  2. 2
      ui/app/components/confirm-page-container/confirm-page-container-content/confirm-page-container-error/confirm-page-container-error.component.js
  3. 8
      ui/app/components/confirm-page-container/confirm-page-container-content/confirm-page-container-error/index.scss
  4. 11
      ui/app/components/pages/confirm-transaction-base/confirm-transaction-base.component.js

@ -1147,6 +1147,10 @@ function updateAndApproveTx (txData) {
return txData return txData
}) })
.catch((err) => {
dispatch(actions.hideLoadingIndication())
return Promise.reject(err)
})
} }
} }

@ -11,8 +11,10 @@ const ConfirmPageContainerError = (props, context) => {
src="/images/alert-red.svg" src="/images/alert-red.svg"
className="confirm-page-container-error__icon" className="confirm-page-container-error__icon"
/> />
<div className="confirm-page-container-error__text">
{ `ALERT: ${error}` } { `ALERT: ${error}` }
</div> </div>
</div>
) )
} }

@ -1,5 +1,5 @@
.confirm-page-container-error { .confirm-page-container-error {
height: 32px; min-height: 32px;
border: 1px solid $monzo; border: 1px solid $monzo;
color: $monzo; color: $monzo;
background: lighten($monzo, 56%); background: lighten($monzo, 56%);
@ -8,10 +8,14 @@
display: flex; display: flex;
justify-content: flex-start; justify-content: flex-start;
align-items: center; align-items: center;
padding-left: 16px; padding: 8px 16px;
&__icon { &__icon {
margin-right: 8px; margin-right: 8px;
flex: 0 0 auto; flex: 0 0 auto;
} }
&__text {
overflow: auto;
}
} }

@ -73,6 +73,7 @@ export default class ConfirmTransactionBase extends Component {
state = { state = {
submitting: false, submitting: false,
submitError: null,
} }
componentDidUpdate () { componentDidUpdate () {
@ -268,7 +269,7 @@ export default class ConfirmTransactionBase extends Component {
return return
} }
this.setState({ submitting: true }) this.setState({ submitting: true, submitError: null })
if (onSubmit) { if (onSubmit) {
Promise.resolve(onSubmit(txData)) Promise.resolve(onSubmit(txData))
@ -280,7 +281,9 @@ export default class ConfirmTransactionBase extends Component {
this.setState({ submitting: false }) this.setState({ submitting: false })
history.push(DEFAULT_ROUTE) history.push(DEFAULT_ROUTE)
}) })
.catch(() => this.setState({ submitting: false })) .catch(error => {
this.setState({ submitting: false, submitError: error.message })
})
} }
} }
@ -309,7 +312,7 @@ export default class ConfirmTransactionBase extends Component {
nonce, nonce,
warning, warning,
} = this.props } = this.props
const { submitting } = this.state const { submitting, submitError } = this.state
const { name } = methodData const { name } = methodData
const fiatConvertedAmount = formatCurrency(fiatTransactionAmount, currentCurrency) const fiatConvertedAmount = formatCurrency(fiatTransactionAmount, currentCurrency)
@ -332,7 +335,7 @@ export default class ConfirmTransactionBase extends Component {
contentComponent={contentComponent} contentComponent={contentComponent}
nonce={nonce} nonce={nonce}
identiconAddress={identiconAddress} identiconAddress={identiconAddress}
errorMessage={errorMessage} errorMessage={errorMessage || submitError}
errorKey={propsErrorKey || errorKey} errorKey={propsErrorKey || errorKey}
warning={warning} warning={warning}
disabled={!propsValid || !valid || submitting} disabled={!propsValid || !valid || submitting}

Loading…
Cancel
Save