Gaëtan Renaudeau
7 years ago
committed by
GitHub
20 changed files with 939 additions and 227 deletions
@ -1,62 +0,0 @@ |
|||||
// @flow
|
|
||||
|
|
||||
import React from 'react' |
|
||||
import styled from 'styled-components' |
|
||||
|
|
||||
import Box from 'components/base/Box' |
|
||||
import IconNanoS from 'icons/device/NanoS' |
|
||||
import IconBlue from 'icons/device/Blue' |
|
||||
import { Title, Description, Inner } from '../helperComponents' |
|
||||
|
|
||||
import type { StepProps } from '..' |
|
||||
|
|
||||
export default (props: StepProps) => { |
|
||||
const { nextStep } = props |
|
||||
|
|
||||
return ( |
|
||||
<Box sticky alignItems="center" justifyContent="center"> |
|
||||
<Box align="center"> |
|
||||
<Title>This is the title of the screen. 1 line is the maximum</Title> |
|
||||
<Description> |
|
||||
This is a long text, please replace it with the final wording once it’s done. |
|
||||
<br /> |
|
||||
Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
|
||||
</Description> |
|
||||
<Box> |
|
||||
<Inner> |
|
||||
<DeviceContainer onClick={() => nextStep()}> |
|
||||
<DeviceIcon> |
|
||||
<IconNanoS size={46} /> |
|
||||
</DeviceIcon> |
|
||||
<Title>Ledger Nano S</Title> |
|
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
|
||||
</DeviceContainer> |
|
||||
<DeviceContainer> |
|
||||
<DeviceIcon> |
|
||||
<IconBlue size={46} /> |
|
||||
</DeviceIcon> |
|
||||
<Title>Ledger Blue</Title> |
|
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
|
||||
</DeviceContainer> |
|
||||
</Inner> |
|
||||
</Box> |
|
||||
</Box> |
|
||||
</Box> |
|
||||
) |
|
||||
} |
|
||||
|
|
||||
const DeviceContainer = styled(Box).attrs({ |
|
||||
alignItems: 'center', |
|
||||
justifyContent: 'center', |
|
||||
})` |
|
||||
width: 218px; |
|
||||
height: 204px; |
|
||||
border: 1px solid #d8d8d8; |
|
||||
` |
|
||||
const DeviceIcon = styled(Box).attrs({ |
|
||||
alignItems: 'center', |
|
||||
justifyContent: 'center', |
|
||||
color: 'graphite', |
|
||||
})` |
|
||||
width: 55px; |
|
||||
` |
|
@ -1,33 +0,0 @@ |
|||||
// @flow
|
|
||||
|
|
||||
import React from 'react' |
|
||||
|
|
||||
import Box from 'components/base/Box' |
|
||||
import Button from 'components/base/Button' |
|
||||
import { Title, Description, OnboardingFooter } from '../helperComponents' |
|
||||
|
|
||||
import type { StepProps } from '..' |
|
||||
|
|
||||
export default (props: StepProps) => { |
|
||||
const { nextStep, prevStep } = props |
|
||||
return ( |
|
||||
<Box sticky alignItems="center" justifyContent="center"> |
|
||||
<Box align="center"> |
|
||||
<Title>This is CHOOSE PIN screen. 1 line is the maximum</Title> |
|
||||
<Description> |
|
||||
This is a long text, please replace it with the final wording once it’s done. |
|
||||
<br /> |
|
||||
Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
|
||||
</Description> |
|
||||
</Box> |
|
||||
<OnboardingFooter horizontal align="center" justify="flex-end" flow={2}> |
|
||||
<Button small outline onClick={() => prevStep()}> |
|
||||
Go Back |
|
||||
</Button> |
|
||||
<Button small primary onClick={() => nextStep()}> |
|
||||
Continue |
|
||||
</Button> |
|
||||
</OnboardingFooter> |
|
||||
</Box> |
|
||||
) |
|
||||
} |
|
@ -1,34 +1,93 @@ |
|||||
// @flow
|
// @flow
|
||||
|
|
||||
import React from 'react' |
import React from 'react' |
||||
|
import { shell } from 'electron' |
||||
|
import styled from 'styled-components' |
||||
|
|
||||
import Box from 'components/base/Box' |
import Box from 'components/base/Box' |
||||
import Button from 'components/base/Button' |
import Button from 'components/base/Button' |
||||
import Text from 'components/base/Text' |
|
||||
|
|
||||
import IconFinishOnboarding from 'icons/LockScreen' |
import IconCheckCircle from 'icons/CheckCircle' |
||||
|
import IconSocialTwitter from 'icons/Eye' |
||||
|
import IconSocialReddit from 'icons/User' |
||||
|
import IconSocialGithub from 'icons/Share' |
||||
|
|
||||
import type { StepProps } from '..' |
import type { StepProps } from '..' |
||||
import { Title, Description } from '../helperComponents' |
import { Title, Description } from '../helperComponents' |
||||
|
|
||||
|
const socialMedia = [ |
||||
|
{ |
||||
|
key: 'twitter', |
||||
|
url: 'https://twitter.com/LedgerHQ', |
||||
|
icon: <IconSocialTwitter size={24} />, |
||||
|
onClick: url => shell.openExternal(url), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'reddit', |
||||
|
url: 'https://www.reddit.com/r/ledgerwallet/', |
||||
|
icon: <IconSocialReddit size={24} />, |
||||
|
onClick: url => shell.openExternal(url), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'github', |
||||
|
url: 'https://github.com/LedgerHQ', |
||||
|
icon: <IconSocialGithub size={24} />, |
||||
|
onClick: url => shell.openExternal(url), |
||||
|
}, |
||||
|
] |
||||
|
|
||||
export default (props: StepProps) => { |
export default (props: StepProps) => { |
||||
const { finish, jumpStep } = props |
const { finish, t } = props |
||||
return ( |
return ( |
||||
<Box sticky alignItems="center" justifyContent="center"> |
<Box sticky alignItems="center" justifyContent="center"> |
||||
<Box align="center"> |
<Box align="center" alignItems="center"> |
||||
<Title>This is ENJOY THE APP screen. 1 line is the maximum</Title> |
<Box color="positiveGreen"> |
||||
<Description> |
<IconCheckCircle size={44} /> |
||||
This is a long text, please replace it with the final wording once it’s done. |
</Box> |
||||
<br /> |
<Box style={{ paddingTop: '20px', maxWidth: 536 }} align="center" mb={5}> |
||||
Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
<Title>{t('onboarding:finish.title')}</Title> |
||||
</Description> |
<Description>{t('onboarding:finish.desc')}</Description> |
||||
<IconFinishOnboarding size={136} /> |
</Box> |
||||
<Button small primary onClick={() => finish()}> |
<Button primary onClick={() => finish()}> |
||||
Open App |
{t('onboarding:finish.openAppButton')} |
||||
</Button> |
</Button> |
||||
<Box onClick={() => jumpStep('start')} style={{ padding: 15 }}> |
<Box alignItems="center" mt={7}> |
||||
<Text color="smoke">I want to go back to Onboarding</Text> |
<FollowUsDesc>{t('onboarding:finish.followUsLabel')}</FollowUsDesc> |
||||
|
</Box> |
||||
|
<Box horizontal flow={5} color="grey"> |
||||
|
{socialMedia.map(socMed => <SocialMediaBox key={socMed.key} socMed={socMed} />)} |
||||
</Box> |
</Box> |
||||
</Box> |
</Box> |
||||
</Box> |
</Box> |
||||
) |
) |
||||
} |
} |
||||
|
|
||||
|
type SocMed = { |
||||
|
icon: any, |
||||
|
url: string, |
||||
|
onClick: string => void, |
||||
|
} |
||||
|
|
||||
|
export function SocialMediaBox({ socMed }: { socMed: SocMed }) { |
||||
|
const { icon, url, onClick } = socMed |
||||
|
return ( |
||||
|
<Box |
||||
|
horizontal |
||||
|
style={{ |
||||
|
cursor: 'pointer', |
||||
|
}} |
||||
|
onClick={() => onClick(url)} |
||||
|
> |
||||
|
{icon} |
||||
|
</Box> |
||||
|
) |
||||
|
} |
||||
|
|
||||
|
export const FollowUsDesc = styled(Box).attrs({ |
||||
|
ff: 'Museo Sans|Regular', |
||||
|
fontSize: 4, |
||||
|
textAlign: 'center', |
||||
|
color: 'grey', |
||||
|
})` |
||||
|
margin: 10px auto; |
||||
|
` |
||||
|
@ -1,90 +1,109 @@ |
|||||
// @flow
|
// @flow
|
||||
|
|
||||
import React from 'react' |
import React from 'react' |
||||
import styled from 'styled-components' |
|
||||
import { shell } from 'electron' |
import { shell } from 'electron' |
||||
|
|
||||
import Box from 'components/base/Box' |
import styled from 'styled-components' |
||||
|
import Box, { Card } from 'components/base/Box' |
||||
import IconUser from 'icons/User' |
import IconUser from 'icons/User' |
||||
import { Title, Description, Inner } from '../helperComponents' |
import IconChevronRight from 'icons/ChevronRight' |
||||
|
import { Title } from '../helperComponents' |
||||
|
|
||||
import type { StepProps } from '..' |
import type { StepProps } from '..' |
||||
|
|
||||
export default (props: StepProps) => { |
export default (props: StepProps) => { |
||||
const { nextStep, jumpStep } = props |
const { nextStep, jumpStep, t } = props |
||||
const handleOpenLink = (url: string) => () => shell.openExternal(url) |
const optionCards = [ |
||||
/* TODO: all titles, descriptions to be wrapped in a translation tag once defined */ |
{ |
||||
|
key: 'newDevice', |
||||
|
icon: <IconUser size={22} />, |
||||
|
title: t('onboarding:init.newDevice.title'), |
||||
|
desc: t('onboarding:init.newDevice.desc'), |
||||
|
onClick: () => nextStep(), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'restoreDevice', |
||||
|
icon: <IconUser size={22} />, |
||||
|
title: t('onboarding:init.restoreDevice.title'), |
||||
|
desc: t('onboarding:init.restoreDevice.desc'), |
||||
|
onClick: () => jumpStep('choosePIN'), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'initializedDevice', |
||||
|
icon: <IconUser size={22} />, |
||||
|
title: t('onboarding:init.initializedDevice.title'), |
||||
|
desc: t('onboarding:init.initializedDevice.desc'), |
||||
|
onClick: () => jumpStep('choosePIN'), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'noDevice', |
||||
|
icon: <IconUser size={22} />, |
||||
|
title: t('onboarding:init.noDevice.title'), |
||||
|
desc: t('onboarding:init.noDevice.desc'), |
||||
|
onClick: () => shell.openExternal('https://www.ledger.fr/'), |
||||
|
}, |
||||
|
] |
||||
|
|
||||
return ( |
return ( |
||||
<Box sticky alignItems="center" justifyContent="center"> |
<Box sticky alignItems="center" justifyContent="center"> |
||||
<Box align="center"> |
<Box align="center"> |
||||
<Title>This is the title of the screen. 1 line is the maximum</Title> |
<Box color="wallet"> |
||||
<Description> |
<IconUser size={36} /> |
||||
This is a long text, please replace it with the final wording once it’s done. |
</Box> |
||||
<br /> |
<Box style={{ padding: 20, maxWidth: 650 }}> |
||||
Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
<Title>{t('onboarding:init.title')}</Title> |
||||
</Description> |
</Box> |
||||
<Box style={{ paddingBottom: 10 }}> |
<Box mt={5} flow={5}> |
||||
<Inner> |
{optionCards.map(card => <OptionFlowCard key={card.key} card={card} />)} |
||||
<DeviceContainer onClick={() => nextStep()}> |
</Box> |
||||
{/* colors are temp, we don't have icons now */} |
</Box> |
||||
<DeviceIcon style={{ color: '#66be54' }}> |
|
||||
<IconUser size={24} /> |
|
||||
</DeviceIcon> |
|
||||
<TrackChoiceTitle>Clean Nano S setup</TrackChoiceTitle> |
|
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
|
||||
</DeviceContainer> |
|
||||
<DeviceContainer onClick={() => jumpStep('choosePIN')}> |
|
||||
<DeviceIcon style={{ color: '#66be54' }}> |
|
||||
<IconUser size={24} /> |
|
||||
</DeviceIcon> |
|
||||
<TrackChoiceTitle>Existing seed + Clean setup</TrackChoiceTitle> |
|
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
|
||||
</DeviceContainer> |
|
||||
</Inner> |
|
||||
</Box> |
</Box> |
||||
<Box> |
) |
||||
<Inner> |
} |
||||
<DeviceContainer onClick={() => nextStep()}> |
|
||||
<DeviceIcon style={{ color: '#6490f1' }}> |
type CardType = { |
||||
<IconUser size={24} /> |
icon: any, |
||||
</DeviceIcon> |
desc: any, |
||||
<TrackChoiceTitle>Migrate accounts</TrackChoiceTitle> |
title: any, |
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
onClick: Function, |
||||
</DeviceContainer> |
} |
||||
<DeviceContainer onClick={handleOpenLink('https://www.ledger.fr/')}> |
|
||||
<DeviceIcon style={{ color: '#ea2e41' }}> |
export function OptionFlowCard({ card }: { card: CardType }) { |
||||
<IconUser size={24} /> |
const { icon, desc, title, onClick } = card |
||||
</DeviceIcon> |
return ( |
||||
<TrackChoiceTitle>Not a user, but would love to</TrackChoiceTitle> |
<Card |
||||
<Description>Please replace it with the final wording once it’s done.</Description> |
horizontal |
||||
</DeviceContainer> |
p={5} |
||||
</Inner> |
style={{ |
||||
|
cursor: 'pointer', |
||||
|
border: 'solid 1px #d8d8d8', |
||||
|
minWidth: '533px', |
||||
|
maxHeight: '80px', |
||||
|
}} |
||||
|
onClick={onClick} |
||||
|
> |
||||
|
<Box justify="center" color="grey" style={{ width: 50 }}> |
||||
|
{icon} |
||||
</Box> |
</Box> |
||||
|
<Box ff="Open Sans|Regular" justify="center" fontSize={4} grow> |
||||
|
<CardTitle>{title}</CardTitle> |
||||
|
<CardDescription>{desc}</CardDescription> |
||||
</Box> |
</Box> |
||||
|
<Box justify="center" color="grey"> |
||||
|
<IconChevronRight size={22} /> |
||||
</Box> |
</Box> |
||||
|
</Card> |
||||
) |
) |
||||
} |
} |
||||
|
|
||||
const DeviceContainer = styled(Box).attrs({ |
export const CardDescription = styled(Box).attrs({ |
||||
alignItems: 'center', |
ff: 'Open Sans|Regular', |
||||
justifyContent: 'center', |
fontSize: 4, |
||||
})` |
textAlign: 'left', |
||||
width: 218px; |
color: 'grey', |
||||
height: 204px; |
})`` |
||||
border: 1px solid #d8d8d8; |
export const CardTitle = styled(Box).attrs({ |
||||
` |
ff: 'Open Sans|SemiBold', |
||||
const DeviceIcon = styled(Box).attrs({ |
fontSize: 4, |
||||
alignItems: 'center', |
textAlign: 'left', |
||||
justifyContent: 'center', |
|
||||
color: 'graphite', |
|
||||
})` |
|
||||
width: 55px; |
|
||||
padding: 10px; |
|
||||
` |
|
||||
export const TrackChoiceTitle = styled(Box).attrs({ |
|
||||
width: 152, |
|
||||
height: 27, |
|
||||
ff: 'Museo Sans|Regular', |
|
||||
fontSize: 5, |
|
||||
color: 'dark', |
|
||||
})`` |
})`` |
||||
|
@ -0,0 +1,79 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
import styled from 'styled-components' |
||||
|
|
||||
|
import Box from 'components/base/Box' |
||||
|
import IconLedgerNano from 'icons/onboarding/LedgerNano' |
||||
|
import IconLedgerBlue from 'icons/onboarding/LedgerBlue' |
||||
|
import { Title, Description, Inner } from '../helperComponents' |
||||
|
|
||||
|
import type { StepProps } from '..' |
||||
|
|
||||
|
export default (props: StepProps) => { |
||||
|
const { nextStep, t } = props |
||||
|
|
||||
|
return ( |
||||
|
<Box sticky alignItems="center" justifyContent="center"> |
||||
|
<Box align="center"> |
||||
|
<Title>{t('onboarding:selectDevice.title')}</Title> |
||||
|
<Description style={{ maxWidth: 714 }}>{t('onboarding:selectDevice.desc')}</Description> |
||||
|
<Box> |
||||
|
<Inner> |
||||
|
<DeviceContainer onClick={() => nextStep()}> |
||||
|
<DeviceIcon> |
||||
|
<IconLedgerNano /> |
||||
|
</DeviceIcon> |
||||
|
<BlockTitle pb={3}>{t('onboarding:selectDevice.ledgerNanoCard.title')}</BlockTitle> |
||||
|
<BlockDescription> |
||||
|
{t('onboarding:selectDevice.ledgerNanoCard.desc')} |
||||
|
</BlockDescription> |
||||
|
</DeviceContainer> |
||||
|
<DeviceContainer> |
||||
|
<DeviceIcon> |
||||
|
<IconLedgerBlue /> |
||||
|
</DeviceIcon> |
||||
|
<BlockTitle pb={3}>{t('onboarding:selectDevice.ledgerBlueCard.title')}</BlockTitle> |
||||
|
<BlockDescription> |
||||
|
{t('onboarding:selectDevice.ledgerBlueCard.desc')} |
||||
|
</BlockDescription> |
||||
|
</DeviceContainer> |
||||
|
</Inner> |
||||
|
</Box> |
||||
|
</Box> |
||||
|
</Box> |
||||
|
) |
||||
|
} |
||||
|
|
||||
|
const DeviceContainer = styled(Box).attrs({ |
||||
|
alignItems: 'center', |
||||
|
justifyContent: 'center', |
||||
|
})` |
||||
|
width: 218px; |
||||
|
height: 204px; |
||||
|
border: 1px solid #d8d8d8; |
||||
|
&:hover, |
||||
|
&:focus { |
||||
|
opacity: 0.5; |
||||
|
cursor: pointer; |
||||
|
} |
||||
|
` |
||||
|
const DeviceIcon = styled(Box).attrs({ |
||||
|
alignItems: 'center', |
||||
|
justifyContent: 'center', |
||||
|
color: 'graphite', |
||||
|
})` |
||||
|
width: 55px; |
||||
|
min-height: 80px; |
||||
|
` |
||||
|
export const BlockDescription = styled(Box).attrs({ |
||||
|
ff: 'Open Sans|Regular', |
||||
|
fontSize: 4, |
||||
|
textAlign: 'center', |
||||
|
color: 'grey', |
||||
|
})`` |
||||
|
export const BlockTitle = styled(Box).attrs({ |
||||
|
ff: 'Open Sans|SemiBold', |
||||
|
fontSize: 4, |
||||
|
textAlign: 'center', |
||||
|
})`` |
@ -0,0 +1,72 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
import Box from 'components/base/Box' |
||||
|
|
||||
|
import IconSelectPIN from 'icons/onboarding/SelectPIN' |
||||
|
import { |
||||
|
Title, |
||||
|
Description, |
||||
|
Inner, |
||||
|
InstructionStep, |
||||
|
IconInstructionStep, |
||||
|
} from '../helperComponents' |
||||
|
import OnboardingFooter from '../OnboardingFooter' |
||||
|
|
||||
|
import type { StepProps } from '..' |
||||
|
|
||||
|
export default (props: StepProps) => { |
||||
|
const { nextStep, prevStep, t } = props |
||||
|
const steps = [ |
||||
|
{ |
||||
|
key: 'step1', |
||||
|
icon: <IconInstructionStep>1</IconInstructionStep>, |
||||
|
desc: t('onboarding:selectPIN.instructions.step1'), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'step2', |
||||
|
icon: <IconInstructionStep>2</IconInstructionStep>, |
||||
|
desc: t('onboarding:selectPIN.instructions.step2'), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'step3', |
||||
|
icon: <IconInstructionStep>3</IconInstructionStep>, |
||||
|
desc: t('onboarding:selectPIN.instructions.step3'), |
||||
|
}, |
||||
|
{ |
||||
|
key: 'step4', |
||||
|
icon: <IconInstructionStep>4</IconInstructionStep>, |
||||
|
desc: t('onboarding:selectPIN.instructions.step4'), |
||||
|
}, |
||||
|
] |
||||
|
return ( |
||||
|
<Box sticky> |
||||
|
<Box grow alignItems="center" justifyContent="center"> |
||||
|
<Box align="center" mb={5}> |
||||
|
<Title>{t('onboarding:selectPIN.title')}</Title> |
||||
|
<Description style={{ maxWidth: 714 }}>{t('onboarding:selectPIN.desc')}</Description> |
||||
|
</Box> |
||||
|
<Box> |
||||
|
<Inner style={{ width: 760 }}> |
||||
|
<Box style={{ width: 260 }} mt={5}> |
||||
|
<IconSelectPIN /> |
||||
|
</Box> |
||||
|
|
||||
|
<Box shrink grow flow={5}> |
||||
|
{steps.map(step => <InstructionStep key={step.key} step={step} />)} |
||||
|
</Box> |
||||
|
</Inner> |
||||
|
</Box> |
||||
|
</Box> |
||||
|
<OnboardingFooter |
||||
|
horizontal |
||||
|
align="center" |
||||
|
flow={2} |
||||
|
t={t} |
||||
|
nextStep={nextStep} |
||||
|
prevStep={prevStep} |
||||
|
/> |
||||
|
</Box> |
||||
|
) |
||||
|
} |
@ -0,0 +1,79 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
export default () => ( |
||||
|
<svg width="113" height="109"> |
||||
|
<g fill="none" fillRule="evenodd"> |
||||
|
<rect |
||||
|
width="1.44" |
||||
|
height="5.6" |
||||
|
y="16.6" |
||||
|
fill="#1D2028" |
||||
|
rx=".72" |
||||
|
transform="matrix(-1 0 0 1 1.44 0)" |
||||
|
/> |
||||
|
<rect |
||||
|
width="1.44" |
||||
|
height="5.6" |
||||
|
y="34.8" |
||||
|
fill="#1D2028" |
||||
|
rx=".72" |
||||
|
transform="matrix(-1 0 0 1 1.44 0)" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".1" |
||||
|
stroke="#1D2028" |
||||
|
strokeWidth="2" |
||||
|
d="M16.592 12c.225 0 .408.183.408.408v95.184a.408.408 0 0 1-.408.408H2.128a.408.408 0 0 1-.408-.408V12.408c0-.225.183-.408.408-.408h14.464z" |
||||
|
/> |
||||
|
<rect |
||||
|
width="7.64" |
||||
|
height="27" |
||||
|
x="5.513" |
||||
|
y="18.522" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
rx=".704" |
||||
|
transform="matrix(-1 0 0 1 18.665 0)" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#FFF" |
||||
|
stroke="#1D2028" |
||||
|
strokeWidth="2" |
||||
|
d="M9.36 54A7.64 7.64 0 0 1 17 61.64v45.952a.408.408 0 0 1-.408.408H2.128a.408.408 0 0 1-.408-.408V61.64A7.64 7.64 0 0 1 9.36 54z" |
||||
|
/> |
||||
|
<ellipse |
||||
|
cx="9.36" |
||||
|
cy="61.4" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
rx="3.82" |
||||
|
ry="3.7" |
||||
|
transform="matrix(-1 0 0 1 18.72 0)" |
||||
|
/> |
||||
|
<rect width="3.137" height="9.306" x="109.863" y="13.959" fill="#1D2028" rx="1.569" /> |
||||
|
<rect |
||||
|
width="76.431" |
||||
|
height="106.571" |
||||
|
x="34" |
||||
|
y="1" |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".1" |
||||
|
stroke="#1D2027" |
||||
|
strokeWidth="2" |
||||
|
rx="5.44" |
||||
|
/> |
||||
|
<rect |
||||
|
width="52.333" |
||||
|
height="79.653" |
||||
|
x="46.043" |
||||
|
y="15.235" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
rx="4.08" |
||||
|
/> |
||||
|
</g> |
||||
|
</svg> |
||||
|
) |
@ -0,0 +1,32 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
export default () => ( |
||||
|
<svg width="41" height="56"> |
||||
|
<g fill="none" fillRule="evenodd"> |
||||
|
<rect width="1.608" height="4.8" x="39.392" y="7.2" fill="#1D2028" rx=".804" /> |
||||
|
<rect |
||||
|
width="38.696" |
||||
|
height="54.5" |
||||
|
x=".75" |
||||
|
y=".75" |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".1" |
||||
|
stroke="#1D2027" |
||||
|
strokeWidth="1.5" |
||||
|
rx="3.2" |
||||
|
/> |
||||
|
<rect |
||||
|
width="26.833" |
||||
|
height="41.1" |
||||
|
x="6.678" |
||||
|
y="7.85" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
strokeWidth=".5" |
||||
|
rx="2.4" |
||||
|
/> |
||||
|
</g> |
||||
|
</svg> |
||||
|
) |
@ -0,0 +1,36 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
export default () => ( |
||||
|
<svg width="112" height="20"> |
||||
|
<g fill="none" fillRule="evenodd" transform="rotate(-90 10 10)"> |
||||
|
<rect width="1.6" height="6.4" x="18.4" y="6.4" fill="#1D2028" rx=".8" /> |
||||
|
<rect width="1.6" height="6.4" x="18.4" y="27.2" fill="#1D2028" rx=".8" /> |
||||
|
<path |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".1" |
||||
|
stroke="#1D2028" |
||||
|
strokeWidth="1.5" |
||||
|
d="M1.6.75a.85.85 0 0 0-.85.85v108.8c0 .47.38.85.85.85h16c.47 0 .85-.38.85-.85V1.6a.85.85 0 0 0-.85-.85h-16z" |
||||
|
/> |
||||
|
<rect |
||||
|
width="9.1" |
||||
|
height="31.5" |
||||
|
x="5.081" |
||||
|
y="8.275" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
strokeWidth=".5" |
||||
|
rx=".8" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#FFF" |
||||
|
stroke="#1D2028" |
||||
|
strokeWidth="1.5" |
||||
|
d="M9.6 48.75A8.85 8.85 0 0 0 .75 57.6v52.8c0 .47.38.85.85.85h16c.47 0 .85-.38.85-.85V57.6a8.85 8.85 0 0 0-8.85-8.85z" |
||||
|
/> |
||||
|
<circle cx="9.6" cy="57.6" r="4.55" fill="#FFF" stroke="#6490F1" strokeWidth=".5" /> |
||||
|
</g> |
||||
|
</svg> |
||||
|
) |
@ -0,0 +1,75 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
export default () => ( |
||||
|
<svg width="260" height="129"> |
||||
|
<defs> |
||||
|
<linearGradient id="a" x1="50%" x2="50%" y1="100%" y2="0%"> |
||||
|
<stop offset="1.367%" stopColor="#FFF" /> |
||||
|
<stop offset="100%" stopColor="#1D2027" /> |
||||
|
</linearGradient> |
||||
|
<path |
||||
|
id="b" |
||||
|
d="M91 0h33.711a4 4 0 0 1 4 4v108.144c0 11.519-9.337 20.856-20.855 20.856C96.337 133 87 123.663 87 112.144V4a4 4 0 0 1 4-4z" |
||||
|
/> |
||||
|
</defs> |
||||
|
<g fill="none" fillRule="evenodd"> |
||||
|
<path |
||||
|
stroke="#1D2027" |
||||
|
strokeWidth="2" |
||||
|
d="M126.962 31.06a1 1 0 0 1-1 1H99.737a5 5 0 0 1-5-5v-8.485a5 5 0 0 1 5-5h26.225a1 1 0 0 1 1 1V31.06zm-32.608-5.208h-10.93v-6.435h10.93v6.435z" |
||||
|
/> |
||||
|
<path |
||||
|
stroke="#1D2027" |
||||
|
d="M127.53 28.836V16.58h11.076a1.5 1.5 0 0 1 1.5 1.5v9.256a1.5 1.5 0 0 1-1.5 1.5H127.53z" |
||||
|
/> |
||||
|
<path |
||||
|
d="M138.202 19.495h-6.794m6.794 6.208h-6.794" |
||||
|
stroke="#1D2027" |
||||
|
strokeLinecap="round" |
||||
|
strokeLinejoin="round" |
||||
|
/> |
||||
|
<path |
||||
|
stroke="url(#a)" |
||||
|
strokeWidth="2.772" |
||||
|
d="M8.222 59.31h.23l-.23-.23v-1.155l-.578.577-.578-.577v1.155l-.23.23h.23v79.88h-.23l.23.23v1.156l.578-.578.578.578v-1.156l.23-.23h-.23V59.31zm5.657 0h.23l-.23-.23v-1.155l-.578.577-.578-.577v1.155l-.23.23h.23v79.88h-.23l.23.23v1.156l.578-.578.578.578v-1.156l.23-.23h-.23V59.31z" |
||||
|
transform="matrix(0 -1 -1 0 140.606 33.06)" |
||||
|
/> |
||||
|
<g transform="rotate(-90 128.59 1.975)"> |
||||
|
<rect width="4.492" height="17.12" x="125.336" y="15.505" fill="#142533" rx="2" /> |
||||
|
<rect width="4.492" height="17.12" x="125.336" y="70.094" fill="#142533" rx="2" /> |
||||
|
<use fill="#FFF" xlinkHref="#b" /> |
||||
|
<path |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".15" |
||||
|
stroke="#142533" |
||||
|
strokeLinejoin="square" |
||||
|
strokeWidth="2" |
||||
|
d="M91 1a3 3 0 0 0-3 3v108.144C88 123.11 96.89 132 107.856 132c10.966 0 19.855-8.89 19.855-19.856V4a3 3 0 0 0-3-3H91z" |
||||
|
/> |
||||
|
<rect |
||||
|
width="20.176" |
||||
|
height="61.019" |
||||
|
x="97.5" |
||||
|
y="21.5" |
||||
|
fill="#FFF" |
||||
|
stroke="#6490F1" |
||||
|
rx="1.6" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#6490F1" |
||||
|
fillRule="nonzero" |
||||
|
d="M103.735 40.983v21.563c0 .397.225.719.502.719h6.526c.277 0 .502-.322.502-.719V40.983c0-.396-.225-.718-.502-.718h-6.526c-.277 0-.502.322-.502.718zm3.976 16.332c.04 0 .073.032.073.072v.73c0 .03.018.057.046.069a.08.08 0 0 0 .082-.016l.517-.515a.073.073 0 0 1 .105 0l.299.295a.077.077 0 0 1 0 .105l-.517.515a.075.075 0 0 0 .052.127h.73c.042 0 .076.034.076.075v.418a.075.075 0 0 1-.075.075h-.73a.075.075 0 1 0-.053.127l.517.515a.077.077 0 0 1 0 .105l-.299.295a.073.073 0 0 1-.105 0l-.517-.515a.076.076 0 0 0-.128.053v.727a.072.072 0 0 1-.073.075h-.422a.073.073 0 0 1-.073-.075v-.727a.076.076 0 0 0-.128-.052l-.517.514a.073.073 0 0 1-.105 0l-.299-.292a.077.077 0 0 1 0-.105l.517-.515a.075.075 0 0 0-.052-.128h-.73a.075.075 0 0 1-.076-.075v-.427c0-.042.034-.075.075-.075h.73c.03 0 .058-.019.07-.047a.075.075 0 0 0-.017-.08l-.517-.516a.077.077 0 0 1 0-.105l.299-.295a.073.073 0 0 1 .105 0l.517.515a.076.076 0 0 0 .128-.052v-.73c0-.04.033-.073.073-.073l.422.008zm0-4.718c.04.002.073.035.073.075v.728c0 .03.018.057.046.068.028.011.06.005.082-.016l.517-.515a.078.078 0 0 1 .105 0l.299.298a.077.077 0 0 1 0 .105l-.517.515a.075.075 0 0 0 .052.127h.73c.041 0 .075.032.076.073v.42a.075.075 0 0 1-.075.072h-.73a.075.075 0 1 0-.053.127l.517.516a.077.077 0 0 1 0 .105l-.299.297a.078.078 0 0 1-.105 0l-.517-.515a.076.076 0 0 0-.128.053v.727c0 .04-.033.074-.073.075h-.422a.075.075 0 0 1-.073-.075v-.727a.076.076 0 0 0-.128-.052l-.517.514a.078.078 0 0 1-.105 0l-.299-.297a.077.077 0 0 1 0-.105l.517-.515a.075.075 0 0 0-.052-.128h-.73a.075.075 0 0 1-.076-.072v-.42a.075.075 0 0 1 .075-.073h.73c.03 0 .058-.018.07-.046a.075.075 0 0 0-.017-.081l-.517-.515a.077.077 0 0 1 0-.105l.299-.298a.078.078 0 0 1 .105 0l.517.515a.076.076 0 0 0 .128-.052v-.728c0-.04.033-.073.073-.075h.422zm0-4.715a.073.073 0 0 1 .073.075v.728c0 .03.018.057.046.068.028.011.06.005.082-.016l.517-.515a.073.073 0 0 1 .105 0l.299.293a.077.077 0 0 1 0 .105l-.517.515a.075.075 0 0 0 .052.127h.73c.042 0 .076.034.076.075v.428a.075.075 0 0 1-.075.075h-.73a.075.075 0 1 0-.053.127l.517.515a.077.077 0 0 1 0 .105l-.299.295a.073.073 0 0 1-.105 0l-.517-.515a.076.076 0 0 0-.128.053v.722c0 .04-.033.073-.073.073h-.422a.073.073 0 0 1-.073-.073v-.73a.076.076 0 0 0-.128-.052l-.517.515a.073.073 0 0 1-.105 0l-.299-.295a.077.077 0 0 1 0-.105l.517-.515a.075.075 0 0 0-.052-.128h-.73a.075.075 0 0 1-.076-.075v-.417c0-.042.034-.075.075-.075h.73c.03 0 .058-.019.07-.047a.075.075 0 0 0-.017-.08l-.517-.516a.077.077 0 0 1 0-.105l.299-.295a.073.073 0 0 1 .105 0l.517.515a.076.076 0 0 0 .128-.052v-.728a.072.072 0 0 1 .073-.075h.422zm0-5a.073.073 0 0 1 .073.075v.728c0 .03.018.057.046.068.028.011.06.005.082-.016l.517-.515a.073.073 0 0 1 .105 0l.299.293a.077.077 0 0 1 0 .105l-.517.515a.075.075 0 0 0 .052.127h.73c.042 0 .076.034.076.075v.428a.075.075 0 0 1-.075.075h-.73a.075.075 0 1 0-.053.127l.517.515a.077.077 0 0 1 0 .105l-.299.295a.073.073 0 0 1-.105 0l-.517-.515a.076.076 0 0 0-.128.053v.722c0 .04-.033.073-.073.073h-.422a.073.073 0 0 1-.073-.073v-.73a.076.076 0 0 0-.128-.052l-.517.515a.073.073 0 0 1-.105 0l-.299-.295a.077.077 0 0 1 0-.105l.517-.515a.075.075 0 0 0-.052-.128h-.73a.075.075 0 0 1-.076-.075v-.417c0-.042.034-.075.075-.075h.73c.03 0 .058-.019.07-.047a.075.075 0 0 0-.017-.08l-.517-.516a.077.077 0 0 1 0-.105l.299-.295a.073.073 0 0 1 .105 0l.517.515a.076.076 0 0 0 .128-.052v-.728a.072.072 0 0 1 .073-.075h.422z" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#FFF" |
||||
|
stroke="#142533" |
||||
|
strokeWidth="2" |
||||
|
d="M123.166 125.105c7.049-8.4 5.953-20.925-2.447-27.974l-90.824-76.21a3 3 0 0 0-4.227.37L4 47.115a3 3 0 0 0 .37 4.227l90.824 76.21c8.4 7.049 20.924 5.953 27.973-2.447z" |
||||
|
/> |
||||
|
<ellipse cx="108.016" cy="111.123" stroke="#6490F1" rx="10.57" ry="10.644" /> |
||||
|
</g> |
||||
|
</g> |
||||
|
</svg> |
||||
|
) |
@ -0,0 +1,197 @@ |
|||||
|
// @flow
|
||||
|
|
||||
|
import React from 'react' |
||||
|
|
||||
|
export default () => ( |
||||
|
<svg width="157" height="144"> |
||||
|
<defs> |
||||
|
<rect id="b" width="42" height="10" y="45" rx="2" /> |
||||
|
<filter |
||||
|
id="a" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="d" width="42" height="10" x="67" y="35" rx="2" /> |
||||
|
<filter |
||||
|
id="c" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="f" width="42" height="10" x="31" y="11" rx="2" /> |
||||
|
<filter |
||||
|
id="e" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="h" width="42" height="10" x="103" rx="2" /> |
||||
|
<filter |
||||
|
id="g" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="j" width="42" height="10" x="104" y="55" rx="2" /> |
||||
|
<filter |
||||
|
id="i" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="l" width="42" height="10" x="31" y="67" rx="2" /> |
||||
|
<filter |
||||
|
id="k" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="n" width="42" height="10" x="11" y="96" rx="2" /> |
||||
|
<filter |
||||
|
id="m" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="p" width="42" height="10" x="109" y="103" rx="2" /> |
||||
|
<filter |
||||
|
id="o" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
<rect id="r" width="42" height="10" x="78" y="83" rx="2" /> |
||||
|
<filter |
||||
|
id="q" |
||||
|
width="123.8%" |
||||
|
height="200%" |
||||
|
x="-11.9%" |
||||
|
y="-40%" |
||||
|
filterUnits="objectBoundingBox" |
||||
|
> |
||||
|
<feOffset dy="1" in="SourceAlpha" result="shadowOffsetOuter1" /> |
||||
|
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="1.5" /> |
||||
|
<feColorMatrix |
||||
|
in="shadowBlurOuter1" |
||||
|
values="0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 0 0.847058824 0 0 0 1 0" |
||||
|
/> |
||||
|
</filter> |
||||
|
</defs> |
||||
|
<g fill="none" fillRule="evenodd" transform="translate(3 2)"> |
||||
|
<circle |
||||
|
cx="79" |
||||
|
cy="72" |
||||
|
r="57" |
||||
|
fill="#6490F1" |
||||
|
fillOpacity=".1" |
||||
|
stroke="#142533" |
||||
|
strokeWidth="2" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#6490F1" |
||||
|
fillRule="nonzero" |
||||
|
stroke="#142533" |
||||
|
d="M88.63 118.285h-1.07v-6.596c0-4.791-3.846-8.689-8.574-8.689s-8.574 3.898-8.574 8.69v6.595H69.34c-1.844 0-3.339 1.515-3.339 3.384v15.695c0 1.869 1.495 3.384 3.339 3.384h19.292c1.843 0 3.339-1.515 3.339-3.384V121.67c0-1.87-1.495-3.384-3.34-3.384zm-15.22-6.596c0-3.115 2.502-5.649 5.576-5.649 3.072 0 5.573 2.534 5.573 5.65v6.595H73.41v-6.596z" |
||||
|
/> |
||||
|
<path |
||||
|
fill="#FFF" |
||||
|
d="M80.694 129.345v4.225a1.72 1.72 0 0 1-1.709 1.73 1.72 1.72 0 0 1-1.708-1.73v-4.225a3.08 3.08 0 0 1-1.325-2.54c0-1.698 1.358-3.074 3.033-3.074 1.675 0 3.033 1.377 3.033 3.075a3.083 3.083 0 0 1-1.325 2.54z" |
||||
|
/> |
||||
|
<use fill="#000" filter="url(#a)" xlinkHref="#b" /> |
||||
|
<use fill="#FFF" xlinkHref="#b" /> |
||||
|
<use fill="#000" filter="url(#c)" xlinkHref="#d" /> |
||||
|
<use fill="#FFF" xlinkHref="#d" /> |
||||
|
<use fill="#000" filter="url(#e)" xlinkHref="#f" /> |
||||
|
<use fill="#FFF" xlinkHref="#f" /> |
||||
|
<use fill="#000" filter="url(#g)" xlinkHref="#h" /> |
||||
|
<use fill="#FFF" xlinkHref="#h" /> |
||||
|
<use fill="#000" filter="url(#i)" xlinkHref="#j" /> |
||||
|
<use fill="#FFF" xlinkHref="#j" /> |
||||
|
<use fill="#000" filter="url(#k)" xlinkHref="#l" /> |
||||
|
<use fill="#FFF" xlinkHref="#l" /> |
||||
|
<use fill="#000" filter="url(#m)" xlinkHref="#n" /> |
||||
|
<use fill="#FFF" xlinkHref="#n" /> |
||||
|
<g> |
||||
|
<use fill="#000" filter="url(#o)" xlinkHref="#p" /> |
||||
|
<use fill="#FFF" xlinkHref="#p" /> |
||||
|
</g> |
||||
|
<g> |
||||
|
<use fill="#000" filter="url(#q)" xlinkHref="#r" /> |
||||
|
<use fill="#FFF" xlinkHref="#r" /> |
||||
|
</g> |
||||
|
</g> |
||||
|
</svg> |
||||
|
) |
@ -0,0 +1,48 @@ |
|||||
|
start: |
||||
|
title: Welcome to the new Ledger Live Desktop app. |
||||
|
desc: Let’s get started! |
||||
|
init: |
||||
|
title: Welcome to Ledger Live, the computer companion app to your Ledger device. Please select one of the options below |
||||
|
newDevice: |
||||
|
title: Initialize your new Ledger device |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
restoreDevice: |
||||
|
title: Restore a Ledger device |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
initializedDevice: |
||||
|
title: I have already initialized my device |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
noDevice: |
||||
|
title: Do not have a Ledger device yet? Buy one |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
selectDevice: |
||||
|
title: To get started, select your device |
||||
|
desc: This is a long text, please replace it with the final wording once it’s done. Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
||||
|
ledgerNanoCard: |
||||
|
title: Ledger Nano S |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
ledgerBlueCard: |
||||
|
title: Ledger Blue |
||||
|
desc: Please replace it with the final wording once it’s done. |
||||
|
selectPIN: |
||||
|
title: Select PIN code |
||||
|
desc: This is a long text, please replace it with the final wording once it’s done. Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
||||
|
instructions: |
||||
|
step1: Connect your Ledger Nano S to your computer using the supplied micro USB cable. |
||||
|
step2: Press both buttons simultaneously as instructed on your Ledger Nano S screen. |
||||
|
step3: Select Configure as new device on your Ledger Nano S by pressing the right button, located above the validation icon. |
||||
|
step4: Choose a PIN code between 4 and 8 digits long. |
||||
|
writeSeed: |
||||
|
title: 24-Word Recovery phrase |
||||
|
desc: The 24 words that constitute your recovery phrase will now be displayed one by one on the Ledger Nano S screen. These 24 words will be displayed only once during this initialization. |
||||
|
instructions: |
||||
|
step1: Copy the first word (Word \#1) in position 1 on the blank Recovery sheet included in the box. |
||||
|
step2: Move to Word \#2 by pressing the right button, copy it in position 2 on the Recovery sheet. |
||||
|
step3: Repeat the process until all 24 words are copied on the Recovery sheet. |
||||
|
step4: To confirm, use the right or left button to select each of the 24 words in the right order. |
||||
|
step5: Validate each word by simultaneously pressing both buttons. |
||||
|
finish: |
||||
|
title: This is the title of the screen. 1 line is the maximum |
||||
|
desc: This is a long text, please replace it with the final wording once it’s done.
Lorem ipsum dolor amet ledger lorem dolor ipsum amet |
||||
|
openAppButton: Open app |
||||
|
followUsLabel: Follow us to stay updated |
Loading…
Reference in new issue