Browse Source

Merge pull request #804 from NastiaS/minorFixesBranch

translated error wired into receive modal and the Upgrade Firmware ca…
master
Gaëtan Renaudeau 7 years ago
committed by GitHub
parent
commit
016462b2ab
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 17
      src/commands/getAddress.js
  2. 2
      src/components/SettingsPage/ResetButton.js
  3. 14
      src/components/modals/Receive/index.js
  4. 13
      src/components/modals/Receive/steps/03-step-confirm-address.js
  5. 3
      static/i18n/en/app.yml
  6. 6
      static/i18n/en/errors.yml

17
src/commands/getAddress.js

@ -6,6 +6,11 @@ import { fromPromise } from 'rxjs/observable/fromPromise'
import { withDevice } from 'helpers/deviceAccess' import { withDevice } from 'helpers/deviceAccess'
import getAddressForCurrency from 'helpers/getAddressForCurrency' import getAddressForCurrency from 'helpers/getAddressForCurrency'
import { createCustomErrorClass } from 'helpers/errors'
const DeviceAppVerifyNotSupported = createCustomErrorClass('DeviceAppVerifyNotSupported')
const UserRefusedAddress = createCustomErrorClass('UserRefusedAddress')
type Input = { type Input = {
currencyId: string, currencyId: string,
devicePath: string, devicePath: string,
@ -26,7 +31,17 @@ const cmd: Command<Input, Result> = createCommand(
fromPromise( fromPromise(
withDevice(devicePath)(transport => withDevice(devicePath)(transport =>
getAddressForCurrency(transport, getCryptoCurrencyById(currencyId), path, options), getAddressForCurrency(transport, getCryptoCurrencyById(currencyId), path, options),
), ).catch(e => {
if (e && e.name === 'TransportStatusError') {
if (e.statusCode === 0x6b00 && options.verify) {
throw new DeviceAppVerifyNotSupported()
}
if (e.statusCode === 0x6985) {
throw new UserRefusedAddress()
}
}
throw e
}),
), ),
) )

2
src/components/SettingsPage/ResetButton.js

@ -75,7 +75,7 @@ export const IconWrapperCircle = styled(Box)`
height: 50px; height: 50px;
border-radius: 50%; border-radius: 50%;
background: #ea2e4919; background: #ea2e4919;
text-align: center; align-items: center;
justify-content: center; justify-content: center;
` `

14
src/components/modals/Receive/index.js

@ -41,6 +41,7 @@ type State = {
isAddressVerified: ?boolean, isAddressVerified: ?boolean,
disabledSteps: number[], disabledSteps: number[],
errorSteps: number[], errorSteps: number[],
verifyAddressError: ?Error,
} }
export type StepProps = DefaultStepProps & { export type StepProps = DefaultStepProps & {
@ -49,12 +50,13 @@ export type StepProps = DefaultStepProps & {
closeModal: void => void, closeModal: void => void,
isAppOpened: boolean, isAppOpened: boolean,
isAddressVerified: ?boolean, isAddressVerified: ?boolean,
verifyAddressError: ?Error,
onRetry: void => void, onRetry: void => void,
onSkipConfirm: void => void, onSkipConfirm: void => void,
onResetSkip: void => void, onResetSkip: void => void,
onChangeAccount: (?Account) => void, onChangeAccount: (?Account) => void,
onChangeAppOpened: boolean => void, onChangeAppOpened: boolean => void,
onChangeAddressVerified: (?boolean) => void, onChangeAddressVerified: (?boolean, ?Error) => void,
} }
const createSteps = ({ t }: { t: T }) => [ const createSteps = ({ t }: { t: T }) => [
@ -102,6 +104,7 @@ const INITIAL_STATE = {
isAddressVerified: null, isAddressVerified: null,
disabledSteps: [], disabledSteps: [],
errorSteps: [], errorSteps: [],
verifyAddressError: null,
} }
class ReceiveModal extends PureComponent<Props, State> { class ReceiveModal extends PureComponent<Props, State> {
@ -127,16 +130,17 @@ class ReceiveModal extends PureComponent<Props, State> {
handleStepChange = step => this.setState({ stepId: step.id }) handleStepChange = step => this.setState({ stepId: step.id })
handleChangeAccount = (account: ?Account) => this.setState({ account }) handleChangeAccount = (account: ?Account) => this.setState({ account })
handleChangeAppOpened = (isAppOpened: boolean) => this.setState({ isAppOpened }) handleChangeAppOpened = (isAppOpened: boolean) => this.setState({ isAppOpened })
handleChangeAddressVerified = (isAddressVerified: boolean) => { handleChangeAddressVerified = (isAddressVerified: boolean, err: ?Error) => {
if (isAddressVerified) { if (isAddressVerified) {
this.setState({ isAddressVerified }) this.setState({ isAddressVerified, verifyAddressError: err })
} else if (isAddressVerified === null) { } else if (isAddressVerified === null) {
this.setState({ isAddressVerified: null, errorSteps: [] }) this.setState({ isAddressVerified: null, errorSteps: [], verifyAddressError: err })
} else { } else {
const confirmStepIndex = this.STEPS.findIndex(step => step.id === 'confirm') const confirmStepIndex = this.STEPS.findIndex(step => step.id === 'confirm')
if (confirmStepIndex > -1) { if (confirmStepIndex > -1) {
this.setState({ this.setState({
isAddressVerified, isAddressVerified,
verifyAddressError: err,
errorSteps: [confirmStepIndex], errorSteps: [confirmStepIndex],
}) })
} }
@ -161,6 +165,7 @@ class ReceiveModal extends PureComponent<Props, State> {
isAddressVerified, isAddressVerified,
disabledSteps, disabledSteps,
errorSteps, errorSteps,
verifyAddressError,
} = this.state } = this.state
const addtionnalProps = { const addtionnalProps = {
@ -168,6 +173,7 @@ class ReceiveModal extends PureComponent<Props, State> {
account, account,
isAppOpened, isAppOpened,
isAddressVerified, isAddressVerified,
verifyAddressError,
closeModal: this.handleCloseModal, closeModal: this.handleCloseModal,
onRetry: this.handleRetry, onRetry: this.handleRetry,
onSkipConfirm: this.handleSkipConfirm, onSkipConfirm: this.handleSkipConfirm,

13
src/components/modals/Receive/steps/03-step-confirm-address.js

@ -15,6 +15,7 @@ import CurrentAddressForAccount from 'components/CurrentAddressForAccount'
import { WrongDeviceForAccount } from 'components/EnsureDeviceApp' import { WrongDeviceForAccount } from 'components/EnsureDeviceApp'
import type { StepProps } from '../index' import type { StepProps } from '../index'
import TranslatedError from '../../../TranslatedError'
export default class StepConfirmAddress extends PureComponent<StepProps> { export default class StepConfirmAddress extends PureComponent<StepProps> {
componentDidMount() { componentDidMount() {
@ -43,12 +44,12 @@ export default class StepConfirmAddress extends PureComponent<StepProps> {
onChangeAddressVerified(true) onChangeAddressVerified(true)
transitionTo('receive') transitionTo('receive')
} catch (err) { } catch (err) {
onChangeAddressVerified(false) onChangeAddressVerified(false, err)
} }
} }
render() { render() {
const { t, device, account, isAddressVerified } = this.props const { t, device, account, isAddressVerified, verifyAddressError } = this.props
invariant(account, 'No account given') invariant(account, 'No account given')
invariant(device, 'No device given') invariant(device, 'No device given')
return ( return (
@ -56,8 +57,12 @@ export default class StepConfirmAddress extends PureComponent<StepProps> {
<TrackPage category="Receive" name="Step3" /> <TrackPage category="Receive" name="Step3" />
{isAddressVerified === false ? ( {isAddressVerified === false ? (
<Fragment> <Fragment>
<Title>{t('app:receive.steps.confirmAddress.error.title')}</Title> <Title>
<Text mb={5}>{t('app:receive.steps.confirmAddress.error.text')}</Text> <TranslatedError error={verifyAddressError} />
</Title>
<Text mb={5}>
<TranslatedError error={verifyAddressError} field="description" />
</Text>
<DeviceConfirm error /> <DeviceConfirm error />
</Fragment> </Fragment>
) : ( ) : (

3
static/i18n/en/app.yml

@ -250,9 +250,6 @@ receive:
action: Confirm address on device action: Confirm address on device
text: Verify that the address below matches the address displayed on your device text: Verify that the address below matches the address displayed on your device
support: Contact us support: Contact us
error:
title: Receive address rejected
text: Please try again or contact Support when in doubt
receiveFunds: receiveFunds:
title: Receive title: Receive
label: Amount (optional) label: Amount (optional)

6
static/i18n/en/errors.yml

@ -83,6 +83,9 @@ TransportStatusError:
UserRefusedOnDevice: UserRefusedOnDevice:
title: Transaction refused on device title: Transaction refused on device
description: Please retry or contact Ledger Support in case of doubt. description: Please retry or contact Ledger Support in case of doubt.
UserRefusedAddress:
title: Receive address rejected
description: Please try again or contact Support
WebsocketConnectionError: WebsocketConnectionError:
title: Sorry, try again (websocket error). title: Sorry, try again (websocket error).
description: #context description: #context
@ -95,3 +98,6 @@ WrongAppOpened:
WrongDeviceForAccount: WrongDeviceForAccount:
title: Oops, wrong device for ‘{{accountName}}’. title: Oops, wrong device for ‘{{accountName}}’.
description: The connected device is not associated with the account you selected. Please connect the right device. description: The connected device is not associated with the account you selected. Please connect the right device.
DeviceAppVerifyNotSupported:
title: Open Manager to update this App
description: The app verification is not supported

Loading…
Cancel
Save