From 6f2d4ef7e6cf0312967eb501f7172e31134ea1a9 Mon Sep 17 00:00:00 2001 From: meriadec Date: Tue, 6 Feb 2018 11:07:04 +0100 Subject: [PATCH] Refactor CheckBox a bit --- src/components/base/CheckBox/index.js | 67 +++++++++++ src/components/base/CheckBox/stories.js | 11 ++ src/components/base/Checkbox/index.js | 106 ------------------ src/components/base/Checkbox/stories.js | 11 -- .../modals/AddAccount/ImportAccounts.js | 6 +- 5 files changed, 81 insertions(+), 120 deletions(-) create mode 100644 src/components/base/CheckBox/index.js create mode 100644 src/components/base/CheckBox/stories.js delete mode 100644 src/components/base/Checkbox/index.js delete mode 100644 src/components/base/Checkbox/stories.js diff --git a/src/components/base/CheckBox/index.js b/src/components/base/CheckBox/index.js new file mode 100644 index 00000000..5865639d --- /dev/null +++ b/src/components/base/CheckBox/index.js @@ -0,0 +1,67 @@ +// @flow + +import React from 'react' +import noop from 'lodash/noop' +import styled, { keyframes } from 'styled-components' + +import { Tabbable } from 'components/base/Box' +import Icon from 'components/base/Icon' + +const bounce = keyframes` + 0% { + transform: scale(1); + } + 50% { + transform: scale(1.5); + } + 100% { + transform: scale(1); + } +` + +const Base = styled(Tabbable).attrs({ + align: 'center', + justify: 'center', +})` + cursor: pointer; + outline: none; + border-radius: 3px; + border: 1px solid transparent; + background-color: ${p => (p.isChecked ? p.theme.colors.blue : p.theme.colors.white)}; + box-shadow: 0 0 0 ${p => (p.isChecked ? 4 : 1)}px + ${p => (p.isChecked ? p.theme.colors.cream : p.theme.colors.argile)}; + font-size: 7px; + height: 19px; + width: 19px; + transition: all ease-in 0.1s; + + &:focus { + border-color: ${p => p.theme.colors.mouse}; + } +` + +const IconWrapper = styled(Icon).attrs({ + color: 'white', +})` + animation: ${bounce} ease-in-out 350ms; +` + +type Props = { + isChecked: boolean, + onChange?: Function, +} + +function CheckBox(props: Props) { + const { isChecked, onChange, ...p } = props + return ( + onChange(!isChecked)} {...p}> + {isChecked && } + + ) +} + +CheckBox.defaultProps = { + onChange: noop, +} + +export default CheckBox diff --git a/src/components/base/CheckBox/stories.js b/src/components/base/CheckBox/stories.js new file mode 100644 index 00000000..84e18e24 --- /dev/null +++ b/src/components/base/CheckBox/stories.js @@ -0,0 +1,11 @@ +// @flow + +import React from 'react' +import { storiesOf } from '@storybook/react' +import { boolean } from '@storybook/addon-knobs' + +import CheckBox from 'components/base/CheckBox' + +const stories = storiesOf('CheckBox', module) + +stories.add('basic', () => ) diff --git a/src/components/base/Checkbox/index.js b/src/components/base/Checkbox/index.js deleted file mode 100644 index 33f7c1ef..00000000 --- a/src/components/base/Checkbox/index.js +++ /dev/null @@ -1,106 +0,0 @@ -// @flow - -import React, { PureComponent } from 'react' -import styled, { keyframes } from 'styled-components' - -import Box from 'components/base/Box' -import Icon from 'components/base/Icon' - -const bounce = keyframes` - 0% { - transform: scale(1, 1); - } - - 50% { - transform: scale(1.7, 1.7); - } - - 100% { - transform: scale(1, 1); - } -` - -const Base = styled(Box).attrs({ - align: 'center', - justify: 'center', - relative: true, -})` - background-color: ${p => (p.checked ? p.theme.colors.blue : p.theme.colors.white)}; - box-shadow: 0 0 0 ${p => (p.checked ? 4 : 1)}px - ${p => (p.checked ? p.theme.colors.cream : p.theme.colors.argile)}; - font-size: 7px; - height: 19px; - width: 19px; - transition: all ease-in-out 0.1s; - - input[type='checkbox'] { - bottom: 0; - cursor: pointer; - height: 100%; - left: 0; - opacity: 0; - position: absolute; - right: 0; - top: 0; - width: 100%; - z-index: 10; - } -` - -const IconWrapper = styled(Icon).attrs({ - color: 'white', -})` - animation: ${bounce} ease-in-out 0.5s; -` - -type Props = { - checked: boolean, - onChange?: Function, -} - -type State = { - checked: boolean, -} - -class Checkbox extends PureComponent { - static defaultProps = { - checked: false, - } - - state = { - checked: this.props.checked, - } - - componentWillReceiveProps(nextProps: Props) { - this.setState({ - checked: nextProps.checked, - }) - } - - handleChange = (e: SyntheticInputEvent) => { - const { onChange } = this.props - const { checked } = e.target - - this.setState({ - checked, - }) - - if (onChange) { - onChange(checked) - } - } - - render() { - const { checked } = this.state - const { onChange, ...props } = this.props - - return ( - - - {checked && } - - ) - } -} - -export default Checkbox diff --git a/src/components/base/Checkbox/stories.js b/src/components/base/Checkbox/stories.js deleted file mode 100644 index 0841d3e9..00000000 --- a/src/components/base/Checkbox/stories.js +++ /dev/null @@ -1,11 +0,0 @@ -// @flow - -import React from 'react' -import { storiesOf } from '@storybook/react' -import { boolean } from '@storybook/addon-knobs' - -import Checkbox from 'components/base/Checkbox' - -const stories = storiesOf('Checkbox', module) - -stories.add('basic', () => ) diff --git a/src/components/modals/AddAccount/ImportAccounts.js b/src/components/modals/AddAccount/ImportAccounts.js index f6bbc805..6394af0a 100644 --- a/src/components/modals/AddAccount/ImportAccounts.js +++ b/src/components/modals/AddAccount/ImportAccounts.js @@ -9,7 +9,7 @@ import { formatBTC } from 'helpers/format' import Box from 'components/base/Box' import Button from 'components/base/Button' -import Checkbox from 'components/base/Checkbox' +import CheckBox from 'components/base/CheckBox' import Input from 'components/base/Input' type Props = { @@ -86,8 +86,8 @@ class ImportAccounts extends PureComponent { return ( -