Gaëtan Renaudeau
7 years ago
committed by
GitHub
34 changed files with 743 additions and 473 deletions
@ -1,122 +0,0 @@ |
|||
// @flow
|
|||
|
|||
import React, { Fragment } from 'react' |
|||
|
|||
import Box from 'components/base/Box' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import IconLedgerNanoSelectPIN from 'icons/onboarding/LedgerNanoSelectPIN' |
|||
import IconLedgerBlueSelectPIN from 'icons/onboarding/LedgerBlueSelectPIN' |
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { Title, Inner, OptionRow, IconOptionRow, DisclaimerBox } from '../helperComponents' |
|||
import OnboardingFooter from '../OnboardingFooter' |
|||
|
|||
import type { StepProps } from '..' |
|||
|
|||
export default (props: StepProps) => { |
|||
const { nextStep, prevStep, t, onboarding } = props |
|||
const stepsLedgerNano = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step3'), |
|||
}, |
|||
{ |
|||
key: 'step4', |
|||
icon: <IconOptionRow>4.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step4'), |
|||
}, |
|||
] |
|||
|
|||
const stepsLedgerBlue = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step3'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note3'), |
|||
}, |
|||
] |
|||
return ( |
|||
<Box sticky pt={150}> |
|||
<Box grow alignItems="center"> |
|||
<Box align="center" mb={5}> |
|||
<Title>{t('onboarding:selectPIN.title')}</Title> |
|||
</Box> |
|||
<Box align="center" mt={5}> |
|||
{onboarding.isLedgerNano ? ( |
|||
<Fragment> |
|||
<Inner style={{ width: 680 }}> |
|||
<Box style={{ width: 260 }} mt={5}> |
|||
<IconLedgerNanoSelectPIN /> |
|||
</Box> |
|||
|
|||
<Box shrink grow flow={4}> |
|||
{stepsLedgerNano.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
</Fragment> |
|||
) : ( |
|||
<Fragment> |
|||
<Inner style={{ width: 680 }}> |
|||
<Box style={{ width: 260, alignItems: 'center' }}> |
|||
<IconLedgerBlueSelectPIN /> |
|||
</Box> |
|||
|
|||
<Box shrink grow flow={4}> |
|||
{stepsLedgerBlue.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
</Fragment> |
|||
)} |
|||
|
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
</Box> |
|||
<OnboardingFooter |
|||
horizontal |
|||
align="center" |
|||
flow={2} |
|||
t={t} |
|||
nextStep={nextStep} |
|||
prevStep={prevStep} |
|||
/> |
|||
</Box> |
|||
) |
|||
} |
@ -0,0 +1,77 @@ |
|||
// @flow
|
|||
import React, { PureComponent } from 'react' |
|||
import { translate } from 'react-i18next' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import Box from 'components/base/Box' |
|||
|
|||
import type { T } from 'types/common' |
|||
import IconLedgerBlueSelectPIN from 'icons/illustrations/LedgerBlueSelectPIN' |
|||
|
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { IconOptionRow, DisclaimerBox, OptionRow, Inner } from '../../helperComponents' |
|||
|
|||
type Props = { |
|||
t: T, |
|||
} |
|||
|
|||
class SelectPIN extends PureComponent<Props, *> { |
|||
render() { |
|||
const { t } = this.props |
|||
|
|||
const stepsLedgerBlue = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerBlue.step3'), |
|||
}, |
|||
] |
|||
|
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note3'), |
|||
}, |
|||
] |
|||
|
|||
return ( |
|||
<Box align="center"> |
|||
<Inner style={{ width: 700 }}> |
|||
<Box style={{ width: 260, justifyContent: 'center', alignItems: 'center' }} mt={2}> |
|||
<IconLedgerBlueSelectPIN /> |
|||
</Box> |
|||
<Box mt={4}> |
|||
<Box shrink grow flow={4}> |
|||
{stepsLedgerBlue.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
) |
|||
} |
|||
} |
|||
|
|||
export default translate()(SelectPIN) |
@ -0,0 +1,79 @@ |
|||
// @flow
|
|||
import React, { PureComponent } from 'react' |
|||
import { translate } from 'react-i18next' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import Box from 'components/base/Box' |
|||
|
|||
import type { T } from 'types/common' |
|||
import IconLedgerNanoSelectPIN from 'icons/illustrations/LedgerNanoSelectPIN' |
|||
|
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { IconOptionRow, DisclaimerBox, OptionRow, Inner } from '../../helperComponents' |
|||
|
|||
type Props = { |
|||
t: T, |
|||
} |
|||
|
|||
class SelectPINnano extends PureComponent<Props, *> { |
|||
render() { |
|||
const { t } = this.props |
|||
|
|||
const stepsLedgerNano = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step3'), |
|||
}, |
|||
{ |
|||
key: 'step4', |
|||
icon: <IconOptionRow>4.</IconOptionRow>, |
|||
desc: t('onboarding:selectPIN.instructions.ledgerNano.step4'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:selectPIN.disclaimer.note3'), |
|||
}, |
|||
] |
|||
|
|||
return ( |
|||
<Box align="center" mt={3}> |
|||
<Inner style={{ width: 700 }}> |
|||
<Box style={{ width: 260, justifyContent: 'center', alignItems: 'center' }} mt={5}> |
|||
<IconLedgerNanoSelectPIN /> |
|||
</Box> |
|||
<Box shrink grow flow={4}> |
|||
{stepsLedgerNano.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
) |
|||
} |
|||
} |
|||
|
|||
export default translate()(SelectPINnano) |
@ -0,0 +1,28 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
import Box from 'components/base/Box' |
|||
|
|||
import { Title } from '../../helperComponents' |
|||
import OnboardingFooter from '../../OnboardingFooter' |
|||
import SelectPINnano from './SelectPINnano' |
|||
import SelectPINblue from './SelectPINblue' |
|||
|
|||
import type { StepProps } from '../..' |
|||
|
|||
export default (props: StepProps) => { |
|||
const { nextStep, prevStep, t, onboarding } = props |
|||
|
|||
return ( |
|||
<Box sticky pt={170}> |
|||
<Box grow alignItems="center"> |
|||
<Title>{t('onboarding:selectPIN.title')}</Title> |
|||
<Box align="center" mt={7}> |
|||
{onboarding.isLedgerNano ? <SelectPINnano /> : <SelectPINblue />} |
|||
</Box> |
|||
</Box> |
|||
<OnboardingFooter horizontal flow={2} t={t} nextStep={nextStep} prevStep={prevStep} /> |
|||
</Box> |
|||
) |
|||
} |
@ -1,87 +0,0 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
import Box from 'components/base/Box' |
|||
import IconWriteSeed from 'icons/onboarding/WriteSeed' |
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import { |
|||
Title, |
|||
Description, |
|||
Inner, |
|||
OptionRow, |
|||
IconOptionRow, |
|||
DisclaimerBox, |
|||
} from '../helperComponents' |
|||
import OnboardingFooter from '../OnboardingFooter' |
|||
|
|||
import type { StepProps } from '..' |
|||
|
|||
export default (props: StepProps) => { |
|||
const { nextStep, prevStep, t } = props |
|||
const steps = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.instructions.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.instructions.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.instructions.step3'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note3'), |
|||
}, |
|||
] |
|||
return ( |
|||
<Box sticky pt={150}> |
|||
<Box grow alignItems="center"> |
|||
<Box align="center" mb={5}> |
|||
<Title>{t('onboarding:writeSeed.title')}</Title> |
|||
<Description>{t('onboarding:writeSeed.desc')}</Description> |
|||
</Box> |
|||
<Box align="center"> |
|||
<Inner style={{ width: 760 }}> |
|||
<Box style={{ width: 260, alignItems: 'center' }}> |
|||
<IconWriteSeed /> |
|||
</Box> |
|||
<Box shrink grow flow={4}> |
|||
{steps.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
</Box> |
|||
<OnboardingFooter |
|||
horizontal |
|||
align="center" |
|||
flow={2} |
|||
t={t} |
|||
nextStep={nextStep} |
|||
prevStep={prevStep} |
|||
/> |
|||
</Box> |
|||
) |
|||
} |
@ -0,0 +1,91 @@ |
|||
// @flow
|
|||
import React, { PureComponent, Fragment } from 'react' |
|||
import { translate } from 'react-i18next' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import type { T } from 'types/common' |
|||
|
|||
import Box from 'components/base/Box' |
|||
import IconWriteSeed from 'icons/illustrations/WriteSeed' |
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { |
|||
Title, |
|||
Description, |
|||
IconOptionRow, |
|||
DisclaimerBox, |
|||
OptionRow, |
|||
Inner, |
|||
} from '../../helperComponents' |
|||
|
|||
type Props = { |
|||
t: T, |
|||
} |
|||
|
|||
class WriteSeedBlue extends PureComponent<Props, *> { |
|||
render() { |
|||
const { t } = this.props |
|||
|
|||
const steps = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.blue.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.blue.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.blue.step3'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note3'), |
|||
}, |
|||
{ |
|||
key: 'note4', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note4'), |
|||
}, |
|||
] |
|||
|
|||
return ( |
|||
<Fragment> |
|||
<Box mb={3}> |
|||
<Title>{t('onboarding:writeSeed.blue.title')}</Title> |
|||
<Description>{t('onboarding:writeSeed.blue.desc')}</Description> |
|||
</Box> |
|||
<Box align="center"> |
|||
<Inner style={{ width: 760 }}> |
|||
<Box style={{ width: 260, justifyContent: 'center', alignItems: 'center' }}> |
|||
<IconWriteSeed /> |
|||
</Box> |
|||
<Box shrink flow={2} m={0}> |
|||
{steps.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
</Fragment> |
|||
) |
|||
} |
|||
} |
|||
|
|||
export default translate()(WriteSeedBlue) |
@ -0,0 +1,91 @@ |
|||
// @flow
|
|||
import React, { PureComponent, Fragment } from 'react' |
|||
import { translate } from 'react-i18next' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import type { T } from 'types/common' |
|||
|
|||
import Box from 'components/base/Box' |
|||
import IconWriteSeed from 'icons/illustrations/WriteSeed' |
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { |
|||
Title, |
|||
Description, |
|||
IconOptionRow, |
|||
DisclaimerBox, |
|||
OptionRow, |
|||
Inner, |
|||
} from '../../helperComponents' |
|||
|
|||
type Props = { |
|||
t: T, |
|||
} |
|||
|
|||
class WriteSeedNano extends PureComponent<Props, *> { |
|||
render() { |
|||
const { t } = this.props |
|||
|
|||
const steps = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.nano.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.nano.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.nano.step3'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note3'), |
|||
}, |
|||
{ |
|||
key: 'note4', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note4'), |
|||
}, |
|||
] |
|||
|
|||
return ( |
|||
<Fragment> |
|||
<Box mb={3}> |
|||
<Title>{t('onboarding:writeSeed.nano.title')}</Title> |
|||
<Description>{t('onboarding:writeSeed.nano.desc')}</Description> |
|||
</Box> |
|||
<Box align="center"> |
|||
<Inner style={{ width: 760 }}> |
|||
<Box style={{ width: 260, justifyContent: 'center', alignItems: 'center' }}> |
|||
<IconWriteSeed /> |
|||
</Box> |
|||
<Box shrink flow={2} m={0}> |
|||
{steps.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
</Fragment> |
|||
) |
|||
} |
|||
} |
|||
|
|||
export default translate()(WriteSeedNano) |
@ -0,0 +1,97 @@ |
|||
// @flow
|
|||
import React, { PureComponent, Fragment } from 'react' |
|||
import { translate } from 'react-i18next' |
|||
import { colors } from 'styles/theme' |
|||
|
|||
import Box from 'components/base/Box' |
|||
|
|||
import type { T } from 'types/common' |
|||
import IconWriteSeed from 'icons/illustrations/WriteSeed' |
|||
|
|||
import IconChevronRight from 'icons/ChevronRight' |
|||
|
|||
import { |
|||
Title, |
|||
Description, |
|||
IconOptionRow, |
|||
DisclaimerBox, |
|||
OptionRow, |
|||
Inner, |
|||
} from '../../helperComponents' |
|||
|
|||
type Props = { |
|||
t: T, |
|||
} |
|||
|
|||
class WriteSeedRestore extends PureComponent<Props, *> { |
|||
render() { |
|||
const { t } = this.props |
|||
|
|||
const steps = [ |
|||
{ |
|||
key: 'step1', |
|||
icon: <IconOptionRow>1.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.restore.step1'), |
|||
}, |
|||
{ |
|||
key: 'step2', |
|||
icon: <IconOptionRow>2.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.restore.step2'), |
|||
}, |
|||
{ |
|||
key: 'step3', |
|||
icon: <IconOptionRow>3.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.restore.step3'), |
|||
}, |
|||
{ |
|||
key: 'step4', |
|||
icon: <IconOptionRow>4.</IconOptionRow>, |
|||
desc: t('onboarding:writeSeed.restore.step4'), |
|||
}, |
|||
] |
|||
const disclaimerNotes = [ |
|||
{ |
|||
key: 'note1', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note1'), |
|||
}, |
|||
{ |
|||
key: 'note2', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note2'), |
|||
}, |
|||
{ |
|||
key: 'note3', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note3'), |
|||
}, |
|||
{ |
|||
key: 'note4', |
|||
icon: <IconChevronRight size={12} style={{ color: colors.smoke }} />, |
|||
desc: t('onboarding:writeSeed.disclaimer.note4'), |
|||
}, |
|||
] |
|||
|
|||
return ( |
|||
<Fragment> |
|||
<Box mb={3}> |
|||
<Title>{t('onboarding:writeSeed.restore.title')}</Title> |
|||
<Description>{t('onboarding:writeSeed.restore.desc')}</Description> |
|||
</Box> |
|||
<Box align="center"> |
|||
<Inner style={{ width: 760 }}> |
|||
<Box style={{ width: 260, justifyContent: 'center', alignItems: 'center' }}> |
|||
<IconWriteSeed /> |
|||
</Box> |
|||
<Box shrink flow={2} m={0}> |
|||
{steps.map(step => <OptionRow key={step.key} step={step} />)} |
|||
</Box> |
|||
</Inner> |
|||
<DisclaimerBox mt={6} disclaimerNotes={disclaimerNotes} /> |
|||
</Box> |
|||
</Fragment> |
|||
) |
|||
} |
|||
} |
|||
|
|||
export default translate()(WriteSeedRestore) |
@ -0,0 +1,39 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
import Box from 'components/base/Box' |
|||
|
|||
import OnboardingFooter from '../../OnboardingFooter' |
|||
|
|||
import WriteSeedNano from './WriteSeedNano' |
|||
import WriteSeedBlue from './WriteSeedBlue' |
|||
import WriteSeedRestore from './WriteSeedRestore' |
|||
|
|||
import type { StepProps } from '../..' |
|||
|
|||
export default (props: StepProps) => { |
|||
const { nextStep, prevStep, t, onboarding } = props |
|||
|
|||
return ( |
|||
<Box sticky pt={170}> |
|||
<Box grow alignItems="center"> |
|||
{onboarding.flowType === 'restoreDevice' ? ( |
|||
<WriteSeedRestore /> |
|||
) : onboarding.isLedgerNano ? ( |
|||
<WriteSeedNano /> |
|||
) : ( |
|||
<WriteSeedBlue /> |
|||
)} |
|||
</Box> |
|||
<OnboardingFooter |
|||
horizontal |
|||
align="center" |
|||
flow={2} |
|||
t={t} |
|||
nextStep={nextStep} |
|||
prevStep={prevStep} |
|||
/> |
|||
</Box> |
|||
) |
|||
} |
@ -0,0 +1,16 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
const path = ( |
|||
<path |
|||
fill="currentColor" |
|||
d="M12 7.5v1a.376.376 0 0 1-.375.375h-2.75v2.75A.376.376 0 0 1 8.5 12h-1a.376.376 0 0 1-.375-.375v-2.75h-2.75A.376.376 0 0 1 4 8.5v-1c0-.206.169-.375.375-.375h2.75v-2.75c0-.206.169-.375.375-.375h1c.206 0 .375.169.375.375v2.75h2.75c.206 0 .375.169.375.375zm3.75.5A7.749 7.749 0 0 1 8 15.75 7.749 7.749 0 0 1 .25 8 7.749 7.749 0 0 1 8 .25 7.749 7.749 0 0 1 15.75 8zm-1.5 0A6.248 6.248 0 0 0 8 1.75 6.248 6.248 0 0 0 1.75 8 6.248 6.248 0 0 0 8 14.25 6.248 6.248 0 0 0 14.25 8z" |
|||
/> |
|||
) |
|||
|
|||
export default ({ size, ...p }: { size: number }) => ( |
|||
<svg viewBox="0 0 16 16" height={size} width={size} {...p}> |
|||
{path} |
|||
</svg> |
|||
) |
@ -1,81 +0,0 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
export default () => ( |
|||
<svg width="136" height="52"> |
|||
<g fill="none" fillRule="evenodd"> |
|||
<g fill="#6490F1" fillRule="nonzero" transform="translate(50 18)"> |
|||
<path |
|||
fillOpacity=".4" |
|||
d="M3.794 8.937l3.96-4.06a2.296 2.296 0 0 1-.797-.818l-3.96 4.062c.329.199.603.48.797.816z" |
|||
/> |
|||
<ellipse cx="1.856" cy="10.109" rx="1.408" ry="1.444" /> |
|||
<ellipse cx="8.895" cy="2.888" rx="1.408" ry="1.444" /> |
|||
<path |
|||
fillOpacity=".4" |
|||
d="M10.474 4.534l3.302 2.032c.11-.38.312-.72.58-.99l-3.302-2.033c-.11.38-.311.72-.58.99zM20.922 2.39l-3.638 2.984c.303.234.547.543.705.901l3.637-2.985a2.307 2.307 0 0 1-.704-.9z" |
|||
/> |
|||
<ellipse cx="15.935" cy="7.221" rx="1.408" ry="1.444" /> |
|||
<ellipse cx="22.975" cy="1.444" rx="1.408" ry="1.444" /> |
|||
<path |
|||
fillOpacity=".4" |
|||
d="M23.937 3.53l4.25 5.232c.223-.316.52-.571.866-.74l-4.251-5.231c-.222.316-.52.57-.865.74z" |
|||
/> |
|||
<ellipse cx="30.015" cy="10.109" rx="1.408" ry="1.444" /> |
|||
<path |
|||
fillOpacity=".4" |
|||
d="M32.068 9.163l3.638-2.985a2.313 2.313 0 0 1-.705-.9l-3.638 2.984c.304.234.548.543.705.901z" |
|||
/> |
|||
<ellipse cx="37.054" cy="4.332" rx="1.408" ry="1.444" /> |
|||
</g> |
|||
<g transform="translate(109 4)"> |
|||
<path |
|||
fill="#CCC" |
|||
fillRule="nonzero" |
|||
d="M6.325 38.352l.614-.636c.254-.263.712-.233 1.023.067.31.3.356.757.102 1.02l-.614.636.643.62c.267.258.242.715-.055 1.022-.296.307-.753.348-1.019.09l-.643-.62-.614.635c-.254.264-.712.234-1.023-.066-.31-.3-.356-.757-.102-1.02l.614-.636-.643-.62c-.266-.258-.242-.715.055-1.022.296-.308.753-.348 1.02-.09l.642.62z" |
|||
/> |
|||
<ellipse cx="1.224" cy="24.349" stroke="#E2E2E2" strokeWidth=".8" rx="1.146" ry="1.133" /> |
|||
<ellipse cx="21.21" cy="23.216" stroke="#E2E2E2" strokeWidth=".8" rx="1.564" ry="1.546" /> |
|||
<path |
|||
fill="#EEE" |
|||
fillRule="nonzero" |
|||
d="M11.558 12.189l.917-.95c.281-.291.677-.366.883-.167.206.2.145.597-.136.888l-.917.95.96.928c.295.284.375.68.178.884-.197.204-.596.139-.89-.146l-.961-.927-.917.95c-.281.29-.677.365-.883.166-.206-.2-.145-.597.136-.888l.917-.95-.96-.928c-.295-.284-.375-.68-.178-.884.197-.204.596-.139.89.146l.961.928z" |
|||
/> |
|||
<path |
|||
fill="#CCC" |
|||
fillRule="nonzero" |
|||
d="M25.03 3.01l.71-.736c.251-.26.657-.277.905-.037.249.24.246.646-.005.907l-.71.734.744.718c.263.255.285.66.047.906-.237.246-.643.239-.907-.016l-.743-.718-.71.735c-.251.26-.657.277-.906.037-.248-.24-.246-.646.006-.906l.71-.735-.744-.718c-.263-.255-.285-.66-.047-.906.237-.246.643-.238.907.016l.743.718z" |
|||
/> |
|||
</g> |
|||
<g transform="translate(1 -1)"> |
|||
<path |
|||
fill="#CCC" |
|||
fillRule="nonzero" |
|||
d="M20.486 48.016l.621-.643c.257-.267.72-.238 1.033.065.314.303.36.764.102 1.03l-.621.644.648.626c.269.26.243.722-.057 1.033-.3.31-.761.352-1.03.093l-.648-.627-.622.644c-.257.266-.72.237-1.033-.066-.313-.302-.359-.764-.102-1.03l.622-.643-.649-.627c-.268-.26-.243-.721.057-1.032.3-.311.762-.353 1.03-.093l.649.626z" |
|||
/> |
|||
<ellipse cx="3.155" cy="37.389" stroke="#CCC" strokeWidth=".8" rx="3.155" ry="3.13" /> |
|||
<ellipse cx="18.932" cy="29.564" stroke="#E2E2E2" strokeWidth=".8" rx="1.578" ry="1.565" /> |
|||
<path |
|||
fill="#EEE" |
|||
fillRule="nonzero" |
|||
d="M9.447 16.156l1.118-1.158c.343-.356.825-.447 1.075-.205.251.242.176.726-.167 1.081l-1.118 1.158 1.167 1.128c.358.346.454.828.214 1.076-.24.249-.725.17-1.084-.176l-1.167-1.127-1.118 1.158c-.343.355-.825.447-1.075.205-.251-.242-.176-.727.167-1.082l1.118-1.158L7.41 15.93c-.358-.346-.454-.828-.214-1.077.24-.248.725-.17 1.084.176l1.167 1.128z" |
|||
/> |
|||
<path |
|||
fill="#CCC" |
|||
fillRule="nonzero" |
|||
d="M22.47 2.013l.699-.724c.214-.222.515-.28.672-.128.156.151.11.454-.105.676l-.699.724.73.704c.224.216.283.518.133.673-.15.156-.453.106-.677-.11l-.73-.704-.698.723c-.215.222-.515.28-.672.128-.157-.15-.11-.454.104-.676l.7-.723-.73-.705c-.224-.216-.284-.517-.134-.673.15-.155.453-.106.677.11l.73.705z" |
|||
/> |
|||
</g> |
|||
<g fillRule="nonzero" transform="translate(36 1)"> |
|||
<ellipse cx="37.488" cy="45.422" fill="#000" rx="1.037" ry="1.036" /> |
|||
<ellipse cx="33.5" cy="45.422" fill="#000" rx="1.037" ry="1.036" /> |
|||
<ellipse cx="29.512" cy="45.422" fill="#000" rx="1.037" ry="1.036" /> |
|||
<path |
|||
fill="#142533" |
|||
d="M65.405 40.242h-2.792V9.562c0-7.251-5.982-9.164-9.173-9.164H13.56c-3.191 0-9.173 1.913-9.173 9.165v30.68H1.595C.957 40.242.4 40.8.4 41.436c0 3.188 1.914 9.165 9.172 9.165H57.43c7.258 0 9.172-5.977 9.172-9.164 0-.638-.558-1.196-1.196-1.196zM6.78 9.562c0-6.534 6.062-6.773 6.78-6.773h39.88c.718 0 6.78.24 6.78 6.774v30.68H6.78V9.562zm50.649 38.649H9.57c-5.025 0-6.3-3.586-6.7-5.578h61.18c-.32 1.912-1.595 5.578-6.62 5.578z" |
|||
/> |
|||
</g> |
|||
</g> |
|||
</svg> |
|||
) |
@ -1,24 +0,0 @@ |
|||
// @flow
|
|||
|
|||
import React from 'react' |
|||
|
|||
export default () => ( |
|||
<svg width="28" height="31"> |
|||
<g fill="none"> |
|||
<path |
|||
fill="#EA2E49" |
|||
fillOpacity=".1" |
|||
d="M14.135 1C14.045 17.38 14 27.046 14 30h.271C21.448 28.36 27 21.552 27 14.24V6.295L14.135 1z" |
|||
/> |
|||
<path |
|||
stroke="#142533" |
|||
strokeWidth="1.5" |
|||
d="M14 1L1 6.296v7.943C1 21.552 6.474 28.361 13.863 30h.274C21.389 28.36 27 21.552 27 14.24V6.295L14 1z" |
|||
/> |
|||
<path |
|||
fill="#EA2E49" |
|||
d="M18.538 10.727c-.44 0-.799.338-.799.755l-.014 3.386s.001.237-.24.237c-.245 0-.238-.237-.238-.237V9.983c0-.417-.354-.74-.794-.74-.442 0-.756.323-.756.74v4.885s-.027.239-.264.239c-.235 0-.253-.239-.253-.239V9.17c0-.417-.333-.733-.774-.733-.44 0-.776.316-.776.733v5.7s-.012.228-.266.228c-.25 0-.25-.229-.25-.229v-4.233c0-.417-.346-.679-.787-.679-.442 0-.764.262-.764.679v6.187s-.044.275-.46-.18c-1.07-1.163-1.629-1.394-1.629-1.394s-1.015-.47-1.465.378c-.326.616.02.65.552 1.405.472.67 1.963 2.43 1.963 2.43s1.768 2.358 4.155 2.358c0 0 4.674.189 4.674-4.182l-.016-6.155c0-.417-.358-.755-.799-.755" |
|||
/> |
|||
</g> |
|||
</svg> |
|||
) |
Loading…
Reference in new issue