|
@ -57,6 +57,7 @@ type Step = { |
|
|
canNext: (State<*>) => boolean, |
|
|
canNext: (State<*>) => boolean, |
|
|
canPrev: (State<*>) => boolean, |
|
|
canPrev: (State<*>) => boolean, |
|
|
canClose: (State<*>) => boolean, |
|
|
canClose: (State<*>) => boolean, |
|
|
|
|
|
hasError: (State<*>) => boolean, |
|
|
prevStep?: number, |
|
|
prevStep?: number, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -91,6 +92,7 @@ class SendModal extends Component<Props, State<*>> { |
|
|
bridge && account && transaction |
|
|
bridge && account && transaction |
|
|
? bridge.isValidTransaction(account, transaction) |
|
|
? bridge.isValidTransaction(account, transaction) |
|
|
: false, |
|
|
: false, |
|
|
|
|
|
hasError: () => false, |
|
|
}, |
|
|
}, |
|
|
{ |
|
|
{ |
|
|
label: t('app:send.steps.connectDevice.title'), |
|
|
label: t('app:send.steps.connectDevice.title'), |
|
@ -99,6 +101,7 @@ class SendModal extends Component<Props, State<*>> { |
|
|
deviceSelected !== null && appStatus === 'success', |
|
|
deviceSelected !== null && appStatus === 'success', |
|
|
prevStep: 0, |
|
|
prevStep: 0, |
|
|
canPrev: () => true, |
|
|
canPrev: () => true, |
|
|
|
|
|
hasError: () => false, |
|
|
}, |
|
|
}, |
|
|
{ |
|
|
{ |
|
|
label: t('app:send.steps.verification.title'), |
|
|
label: t('app:send.steps.verification.title'), |
|
@ -106,6 +109,7 @@ class SendModal extends Component<Props, State<*>> { |
|
|
canNext: () => true, |
|
|
canNext: () => true, |
|
|
canPrev: ({ error }) => !!error, |
|
|
canPrev: ({ error }) => !!error, |
|
|
prevStep: 0, |
|
|
prevStep: 0, |
|
|
|
|
|
hasError: ({ error }) => (error && error.name === 'UserRefusedOnDevice') || false, |
|
|
}, |
|
|
}, |
|
|
{ |
|
|
{ |
|
|
label: t('app:send.steps.confirmation.title'), |
|
|
label: t('app:send.steps.confirmation.title'), |
|
@ -113,6 +117,7 @@ class SendModal extends Component<Props, State<*>> { |
|
|
canClose: () => true, |
|
|
canClose: () => true, |
|
|
canPrev: () => true, |
|
|
canPrev: () => true, |
|
|
canNext: () => false, |
|
|
canNext: () => false, |
|
|
|
|
|
hasError: ({ error }) => (error && error.name !== 'UserRefusedOnDevice') || false, |
|
|
}, |
|
|
}, |
|
|
] |
|
|
] |
|
|
} |
|
|
} |
|
@ -273,6 +278,13 @@ class SendModal extends Component<Props, State<*>> { |
|
|
const canNext = step.canNext(this.state) |
|
|
const canNext = step.canNext(this.state) |
|
|
const canPrev = step.canPrev(this.state) |
|
|
const canPrev = step.canPrev(this.state) |
|
|
|
|
|
|
|
|
|
|
|
const stepsErrors = [] |
|
|
|
|
|
this.steps.forEach((s, i) => { |
|
|
|
|
|
if (s.hasError(this.state)) { |
|
|
|
|
|
stepsErrors.push(i) |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<Modal |
|
|
<Modal |
|
|
name={MODAL_SEND} |
|
|
name={MODAL_SEND} |
|
@ -290,7 +302,13 @@ class SendModal extends Component<Props, State<*>> { |
|
|
</ModalTitle> |
|
|
</ModalTitle> |
|
|
|
|
|
|
|
|
<ModalContent> |
|
|
<ModalContent> |
|
|
<Breadcrumb t={t} mb={6} currentStep={stepIndex} items={this.steps} /> |
|
|
<Breadcrumb |
|
|
|
|
|
t={t} |
|
|
|
|
|
mb={6} |
|
|
|
|
|
currentStep={stepIndex} |
|
|
|
|
|
stepsErrors={stepsErrors} |
|
|
|
|
|
items={this.steps} |
|
|
|
|
|
/> |
|
|
|
|
|
|
|
|
<ChildSwitch index={stepIndex}> |
|
|
<ChildSwitch index={stepIndex}> |
|
|
<StepAmount |
|
|
<StepAmount |
|
|