Browse Source

Use Pills in SettingsPage, and remove Tabs component

master
meriadec 7 years ago
committed by Loëck Vézien
parent
commit
f08efce182
No known key found for this signature in database GPG Key ID: CBCDCE384E853AC4
  1. 59
      src/components/SettingsPage/index.js
  2. 68
      src/components/base/Tabs/index.js
  3. 31
      src/components/base/Tabs/stories.js

59
src/components/SettingsPage/index.js

@ -13,9 +13,8 @@ import type { FetchCounterValues } from 'actions/counterValues'
import { saveSettings } from 'actions/settings' import { saveSettings } from 'actions/settings'
import { fetchCounterValues } from 'actions/counterValues' import { fetchCounterValues } from 'actions/counterValues'
import Pills from 'components/base/Pills'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Text from 'components/base/Text'
import Tabs from 'components/base/Tabs'
import TabDisplay from './Display' import TabDisplay from './Display'
import TabProfile from './Profile' import TabProfile from './Profile'
@ -48,7 +47,12 @@ class SettingsPage extends PureComponent<Props, State> {
tab: 0, tab: 0,
} }
handleChangeTab = (tab: number) => this.setState({ tab }) _items = []
handleChangeTab = (item: any) => {
const tab = this._items.indexOf(item)
this.setState({ tab })
}
handleSaveSettings = newSettings => { handleSaveSettings = newSettings => {
const { fetchCounterValues, saveSettings, i18n, settings } = this.props const { fetchCounterValues, saveSettings, i18n, settings } = this.props
@ -75,53 +79,56 @@ class SettingsPage extends PureComponent<Props, State> {
onSaveSettings: this.handleSaveSettings, onSaveSettings: this.handleSaveSettings,
} }
return ( this._items = [
<Box flow={6}>
<Text fontSize={7}>{t('settings:title')}</Text>
<Tabs
index={tab}
onTabClick={this.handleChangeTab}
items={[
{ {
key: 'display', key: 'display',
title: t('settings:tabs.display'), label: t('settings:tabs.display'),
render: () => <TabDisplay {...props} />, value: () => <TabDisplay {...props} />,
}, },
{ {
key: 'money', key: 'money',
title: t('settings:tabs.money'), label: t('settings:tabs.money'),
render: () => <TabMoney {...props} />, value: () => <TabMoney {...props} />,
}, },
{ {
key: 'material', key: 'material',
isDisabled: true, isDisabled: true,
title: t('settings:tabs.material'), label: t('settings:tabs.material'),
render: () => <div>{'Matériel'}</div>, value: () => <div>{'Matériel'}</div>,
}, },
{ {
key: 'app', key: 'app',
isDisabled: true, isDisabled: true,
title: t('settings:tabs.app'), label: t('settings:tabs.app'),
render: () => <div>{'App (beta)'}</div>, value: () => <div>{'App (beta)'}</div>,
}, },
{ {
key: 'tools', key: 'tools',
title: t('settings:tabs.tools'), label: t('settings:tabs.tools'),
render: () => <TabTools {...props} />, value: () => <TabTools {...props} />,
}, },
{ {
key: 'blockchain', key: 'blockchain',
isDisabled: true, isDisabled: true,
title: t('settings:tabs.blockchain'), label: t('settings:tabs.blockchain'),
render: () => <div>{'Blockchain'}</div>, value: () => <div>{'Blockchain'}</div>,
}, },
{ {
key: 'profile', key: 'profile',
title: t('settings:tabs.profile'), label: t('settings:tabs.profile'),
render: () => <TabProfile {...props} />, value: () => <TabProfile {...props} />,
}, },
]} ]
/>
const item = this._items[tab]
return (
<Box>
<Box fontSize={7} mb={4}>
{t('settings:title')}
</Box>
<Pills mb={6} items={this._items} activeKey={item.key} onChange={this.handleChangeTab} />
{item.value && item.value()}
</Box> </Box>
) )
} }

68
src/components/base/Tabs/index.js

@ -1,68 +0,0 @@
// @flow
import React, { Fragment } from 'react'
import styled from 'styled-components'
import type { Element } from 'react'
import Box, { Tabbable } from 'components/base/Box'
const WrapperTab = styled(Box).attrs({
horizontal: true,
})`
border-bottom: 1px solid ${p => p.theme.colors.fog};
`
const Tab = styled(Tabbable).attrs({
flex: 1,
pb: 2,
alignItems: 'center',
justifyContent: 'center',
fontSize: 3,
})`
border-bottom: 2px solid transparent;
border-bottom-color: ${p => (p.isActive ? p.theme.colors.wallet : '')};
color: ${p =>
p.isActive
? p.theme.colors.wallet
: p.isDisabled
? p.theme.colors.grey
: p.theme.colors.graphite};
margin-bottom: -1px;
outline: none;
cursor: ${p => (p.isActive ? 'default' : p.isDisabled ? 'not-allowed' : 'pointer')};
max-width: 200px;
`
type Item = {
key: string | number,
isDisabled?: boolean,
title: string | Element<any>,
render: () => Element<any>,
}
type Props = {
items: Array<Item>,
index: number,
onTabClick: number => void,
}
const Tabs = ({ items, index, onTabClick }: Props) => (
<Fragment>
<WrapperTab>
{items.map((item, i) => (
<Tab
key={item.key}
isDisabled={item.isDisabled}
isActive={index === i}
onClick={item.isDisabled ? void 0 : () => onTabClick(i)}
>
{item.title}
</Tab>
))}
</WrapperTab>
{items[index] && items[index].render()}
</Fragment>
)
export default Tabs

31
src/components/base/Tabs/stories.js

@ -1,31 +0,0 @@
import React from 'react'
import { number } from '@storybook/addon-knobs'
import { action } from '@storybook/addon-actions'
import { storiesOf } from '@storybook/react'
import Tabs from 'components/base/Tabs'
const stories = storiesOf('Components/base', module)
stories.add('Tabs', () => (
<Tabs
index={number('index', 0, {
min: 0,
max: 1,
})}
onTabClick={action('onTabClick')}
items={[
{
key: 'first',
title: 'first tab',
render: () => <div>{'first tab content'}</div>,
},
{
key: 'second',
title: 'second tab',
render: () => <div>{'second tab content'}</div>,
},
]}
/>
))
Loading…
Cancel
Save