|
@ -11,6 +11,7 @@ import type { T } from 'types/common' |
|
|
import { updateGenuineCheck } from 'reducers/onboarding' |
|
|
import { updateGenuineCheck } from 'reducers/onboarding' |
|
|
|
|
|
|
|
|
import Box from 'components/base/Box' |
|
|
import Box from 'components/base/Box' |
|
|
|
|
|
import FakeLink from 'components/base/FakeLink' |
|
|
import Button from 'components/base/Button' |
|
|
import Button from 'components/base/Button' |
|
|
import RadioGroup from 'components/base/RadioGroup' |
|
|
import RadioGroup from 'components/base/RadioGroup' |
|
|
import GenuineCheckModal from 'components/GenuineCheckModal' |
|
|
import GenuineCheckModal from 'components/GenuineCheckModal' |
|
@ -18,12 +19,14 @@ import GenuineCheckModal from 'components/GenuineCheckModal' |
|
|
import IconLedgerNanoError from 'icons/illustrations/LedgerNanoError' |
|
|
import IconLedgerNanoError from 'icons/illustrations/LedgerNanoError' |
|
|
import IconLedgerBlueError from 'icons/illustrations/LedgerBlueError' |
|
|
import IconLedgerBlueError from 'icons/illustrations/LedgerBlueError' |
|
|
import IconCheck from 'icons/Check' |
|
|
import IconCheck from 'icons/Check' |
|
|
|
|
|
import IconCross from 'icons/Cross' |
|
|
|
|
|
|
|
|
import { |
|
|
import { |
|
|
Title, |
|
|
Title, |
|
|
Description, |
|
|
Description, |
|
|
IconOptionRow, |
|
|
IconOptionRow, |
|
|
FixedTopContainer, |
|
|
FixedTopContainer, |
|
|
|
|
|
StepContainerInner, |
|
|
OnboardingFooterWrapper, |
|
|
OnboardingFooterWrapper, |
|
|
} from '../helperComponents' |
|
|
} from '../helperComponents' |
|
|
|
|
|
|
|
@ -88,7 +91,15 @@ class GenuineCheck extends PureComponent<StepProps, State> { |
|
|
|
|
|
|
|
|
handleOpenGenuineCheckModal = () => this.setState({ isGenuineCheckModalOpened: true }) |
|
|
handleOpenGenuineCheckModal = () => this.setState({ isGenuineCheckModalOpened: true }) |
|
|
handleCloseGenuineCheckModal = (cb?: Function) => |
|
|
handleCloseGenuineCheckModal = (cb?: Function) => |
|
|
this.setState(state => ({ ...state, isGenuineCheckModalOpened: false }), () => cb && cb()) |
|
|
this.setState( |
|
|
|
|
|
state => ({ ...state, isGenuineCheckModalOpened: false }), |
|
|
|
|
|
() => { |
|
|
|
|
|
// FIXME: meh
|
|
|
|
|
|
if (cb && typeof cb === 'function') { |
|
|
|
|
|
cb() |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
handleGenuineCheckPass = () => { |
|
|
handleGenuineCheckPass = () => { |
|
|
this.handleCloseGenuineCheckModal(() => { |
|
|
this.handleCloseGenuineCheckModal(() => { |
|
@ -101,6 +112,7 @@ class GenuineCheck extends PureComponent<StepProps, State> { |
|
|
handleGenuineCheckFailed = () => { |
|
|
handleGenuineCheckFailed = () => { |
|
|
this.handleCloseGenuineCheckModal(() => { |
|
|
this.handleCloseGenuineCheckModal(() => { |
|
|
this.props.updateGenuineCheck({ |
|
|
this.props.updateGenuineCheck({ |
|
|
|
|
|
isGenuineFail: true, |
|
|
isDeviceGenuine: false, |
|
|
isDeviceGenuine: false, |
|
|
genuineCheckUnavailable: null, |
|
|
genuineCheckUnavailable: null, |
|
|
}) |
|
|
}) |
|
@ -146,7 +158,7 @@ class GenuineCheck extends PureComponent<StepProps, State> { |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<FixedTopContainer> |
|
|
<FixedTopContainer> |
|
|
<Box grow alignItems="center"> |
|
|
<StepContainerInner> |
|
|
<Title>{t('onboarding:genuineCheck.title')}</Title> |
|
|
<Title>{t('onboarding:genuineCheck.title')}</Title> |
|
|
{onboarding.isLedgerNano ? ( |
|
|
{onboarding.isLedgerNano ? ( |
|
|
<Description>{t('onboarding:genuineCheck.descNano')}</Description> |
|
|
<Description>{t('onboarding:genuineCheck.descNano')}</Description> |
|
@ -211,6 +223,20 @@ class GenuineCheck extends PureComponent<StepProps, State> { |
|
|
{t('onboarding:genuineCheck.isGenuinePassed')} |
|
|
{t('onboarding:genuineCheck.isGenuinePassed')} |
|
|
</GenuineSuccessText> |
|
|
</GenuineSuccessText> |
|
|
</Box> |
|
|
</Box> |
|
|
|
|
|
) : genuine.genuineCheckUnavailable ? ( |
|
|
|
|
|
<Box horizontal align="center" flow={1} color={colors.alertRed}> |
|
|
|
|
|
<IconCross size={16} /> |
|
|
|
|
|
<Box ff="Open Sans|Regular" fontSize={4}> |
|
|
|
|
|
{t('onboarding:genuineCheck.isGenuineUnavailable')} |
|
|
|
|
|
<FakeLink |
|
|
|
|
|
color="alertRed" |
|
|
|
|
|
underline |
|
|
|
|
|
onClick={this.handleOpenGenuineCheckModal} |
|
|
|
|
|
> |
|
|
|
|
|
{t('app:common.retry')} |
|
|
|
|
|
</FakeLink> |
|
|
|
|
|
</Box> |
|
|
|
|
|
</Box> |
|
|
) : ( |
|
|
) : ( |
|
|
<Button |
|
|
<Button |
|
|
primary |
|
|
primary |
|
@ -224,7 +250,7 @@ class GenuineCheck extends PureComponent<StepProps, State> { |
|
|
)} |
|
|
)} |
|
|
</CardWrapper> |
|
|
</CardWrapper> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</StepContainerInner> |
|
|
<OnboardingFooter |
|
|
<OnboardingFooter |
|
|
horizontal |
|
|
horizontal |
|
|
align="center" |
|
|
align="center" |
|
@ -301,6 +327,7 @@ export const GenuineSuccessText = styled(Box).attrs({ |
|
|
ff: 'Open Sans|Regular', |
|
|
ff: 'Open Sans|Regular', |
|
|
fontSize: 4, |
|
|
fontSize: 4, |
|
|
})`` |
|
|
})`` |
|
|
|
|
|
|
|
|
export const CardTitle = styled(Box).attrs({ |
|
|
export const CardTitle = styled(Box).attrs({ |
|
|
ff: 'Open Sans|SemiBold', |
|
|
ff: 'Open Sans|SemiBold', |
|
|
fontSize: 4, |
|
|
fontSize: 4, |
|
@ -323,7 +350,6 @@ const CardWrapper = styled(Box).attrs({ |
|
|
background-color: ${p => (p.isDisabled ? p.theme.colors.lightGrey : p.theme.colors.white)}; |
|
|
background-color: ${p => (p.isDisabled ? p.theme.colors.lightGrey : p.theme.colors.white)}; |
|
|
opacity: ${p => (p.isDisabled ? 0.7 : 1)}; |
|
|
opacity: ${p => (p.isDisabled ? 0.7 : 1)}; |
|
|
&:hover { |
|
|
&:hover { |
|
|
cursor: pointer; |
|
|
|
|
|
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.05); |
|
|
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.05); |
|
|
} |
|
|
} |
|
|
` |
|
|
` |
|
|