Browse Source

Merge pull request #301 from meriadec/onboarding

Implement Onboarding boilerplate
master
Meriadec Pillet 7 years ago
committed by GitHub
parent
commit
2e66c7e429
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 3
      src/components/App.js
  2. 145
      src/components/Onboarding/index.js
  3. 1
      src/reducers/settings.js
  4. 1
      src/types/common.js

3
src/components/App.js

@ -12,6 +12,8 @@ import theme from 'styles/theme'
import i18n from 'renderer/i18n/electron' import i18n from 'renderer/i18n/electron'
import Onboarding from 'components/Onboarding'
import ThrowBlock from 'components/ThrowBlock' import ThrowBlock from 'components/ThrowBlock'
import Default from 'components/layout/Default' import Default from 'components/layout/Default'
import Dev from 'components/layout/Dev' import Dev from 'components/layout/Dev'
@ -32,6 +34,7 @@ const App = ({
<I18nextProvider i18n={i18n} initialLanguage={language}> <I18nextProvider i18n={i18n} initialLanguage={language}>
<ThemeProvider theme={theme}> <ThemeProvider theme={theme}>
<ThrowBlock> <ThrowBlock>
<Onboarding />
<ConnectedRouter history={history}> <ConnectedRouter history={history}>
<Switch> <Switch>
{(__DEV__ || DEV_TOOLS) && <Route path="/dev" component={Dev} />} {(__DEV__ || DEV_TOOLS) && <Route path="/dev" component={Dev} />}

145
src/components/Onboarding/index.js

@ -0,0 +1,145 @@
// @flow
import React, { PureComponent } from 'react'
import { compose } from 'redux'
import { translate } from 'react-i18next'
import { connect } from 'react-redux'
import styled from 'styled-components'
import type { T } from 'types/common'
import { saveSettings } from 'actions/settings'
import Box from 'components/base/Box'
import Button from 'components/base/Button'
const STEPS = [
{
title: ({ t }) => t('onboarding:step1.title'),
render: ({ t }: StepProps) => <Box>{t('onboarding:step1.greetings')}</Box>,
},
{
title: ({ t }) => t('onboarding:step2.title'),
render: ({ t }: StepProps) => <Box>{t('onboarding:step2.greetings')}</Box>,
},
{
title: ({ t }) => t('onboarding:step3.title'),
render: ({ t }: StepProps) => (
<Box>
{t('onboarding:step3.greetings')}
<Box bg="grey" align="center" justify="center" style={{ width: 200, height: 200 }}>
{'step 3 image'}
</Box>
{t('onboarding:step3.description')}
</Box>
),
},
{
title: ({ t }) => t('onboarding:step4.title'),
render: ({ t }: StepProps) => <Box>{t('onboarding:step4.greetings')}</Box>,
},
]
const mapStateToProps = state => ({
hasCompletedOnboarding: state.settings.hasCompletedOnboarding,
})
const mapDispatchToProps = {
saveSettings,
}
type Props = {
t: T,
hasCompletedOnboarding: boolean,
saveSettings: Function,
}
type StepProps = {
t: T,
}
type State = {
stepIndex: number,
}
class Onboarding extends PureComponent<Props, State> {
state = {
stepIndex: 0,
}
prev = () => this.setState({ stepIndex: Math.max(0, this.state.stepIndex - 1) })
next = () => this.setState({ stepIndex: Math.min(STEPS.length - 1, this.state.stepIndex + 1) })
finish = () => this.props.saveSettings({ hasCompletedOnboarding: true })
render() {
const { hasCompletedOnboarding, t } = this.props
const { stepIndex } = this.state
if (hasCompletedOnboarding) {
return null
}
const step = STEPS[stepIndex]
if (!step) {
return null
}
const stepProps = {
t,
}
return (
<Container>
<Inner>
<Box horizontal flow={2}>
<Button primary onClick={this.prev}>
{'prev step'}
</Button>
{stepIndex === STEPS.length - 1 ? (
<Button danger onClick={this.finish}>
{'finish'}
</Button>
) : (
<Button primary onClick={this.next}>
{'next step'}
</Button>
)}
</Box>
<StepTitle>{step.title(stepProps)}</StepTitle>
{step.render(stepProps)}
</Inner>
</Container>
)
}
}
const Container = styled(Box).attrs({
bg: 'white',
p: 6,
align: 'center',
justify: 'center',
})`
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 100;
`
const Inner = styled(Box).attrs({
bg: 'lightGraphite',
p: 4,
})`
border: 1px solid rgba(0, 0, 0, 0.1);
height: 400px;
width: 400px;
border-radius: 3px;
`
const StepTitle = styled(Box).attrs({
fontSize: 8,
})``
export default compose(connect(mapStateToProps, mapDispatchToProps), translate())(Onboarding)

1
src/reducers/settings.js

@ -12,6 +12,7 @@ import type { State } from 'reducers'
export type SettingsState = Object export type SettingsState = Object
const defaultState: SettingsState = { const defaultState: SettingsState = {
hasCompletedOnboarding: false,
username: 'Anonymous', username: 'Anonymous',
counterValue: 'USD', counterValue: 'USD',
language: 'en', language: 'en',

1
src/types/common.js

@ -29,6 +29,7 @@ export type CurrenciesSettings = {
} }
export type Settings = { export type Settings = {
hasCompletedOnboarding: boolean,
language: string, language: string,
orderAccounts: string, orderAccounts: string,
username: string, username: string,

Loading…
Cancel
Save