Browse Source

Refactor button style

master
meriadec 7 years ago
committed by Loëck Vézien
parent
commit
5708458a99
No known key found for this signature in database GPG Key ID: CBCDCE384E853AC4
  1. 122
      src/components/base/Button/index.js
  2. 11
      src/components/base/Button/stories.js

122
src/components/base/Button/index.js

@ -9,36 +9,88 @@ import { darken, lighten } from 'styles/helpers'
import fontFamily from 'styles/styled/fontFamily' import fontFamily from 'styles/styled/fontFamily'
const buttonStyles = {
primary: {
default: p => `
background: ${p.disabled ? lighten(p.theme.colors.wallet, 0.1) : p.theme.colors.wallet};
color: white;
`,
hover: p => `
background: ${lighten(p.theme.colors.wallet, 0.05)};
`,
active: p => `
background: ${darken(p.theme.colors.wallet, 0.1)};
`,
},
danger: {
default: p => `
background: ${p.disabled ? lighten(p.theme.colors.alertRed, 0.3) : p.theme.colors.alertRed};
color: white;
`,
hover: p => `
background: ${lighten(p.theme.colors.alertRed, 0.1)};
`,
active: p => `
background: ${darken(p.theme.colors.alertRed, 0.1)};
`,
},
outline: {
default: p => `
background: transparent;
border: 1px solid ${p.theme.colors.wallet};
color: ${p.theme.colors.wallet};
`,
active: p => `
color: ${darken(p.theme.colors.wallet, 0.1)};
border-color: ${darken(p.theme.colors.wallet, 0.1)};
`,
},
icon: {
default: () => `
font-size: ${fontSize[3]}px;
padding-left: ${space[1]}px;
padding-right: ${space[1]}px;
`,
},
}
function getStyles(props, state) {
let output = ``
for (const s in buttonStyles) {
if (buttonStyles.hasOwnProperty(s) && props[s] === true) {
const style = buttonStyles[s][state]
if (style) {
output += style(props)
}
}
}
return output
}
const Base = styled.button.attrs({ const Base = styled.button.attrs({
ff: 'Museo Sans|Regular', ff: 'Museo Sans|Regular',
fontSize: p => p.fontSize || 3, fontSize: p => p.fontSize || 3,
px: p => (p.primary ? (p.small ? 2 : 3) : 2), px: 2,
color: 'grey',
})` })`
${space}; ${space};
${color}; ${color};
${fontSize}; ${fontSize};
${fontWeight}; ${fontWeight};
${fontFamily}; ${fontFamily};
border: none;
border-radius: ${p => p.theme.radii[1]}px; border-radius: ${p => p.theme.radii[1]}px;
border: ${p => (p.outline ? `1px solid ${p.theme.colors.wallet}` : 'none')};
color: ${p => (p.outline ? p.theme.colors.wallet : '')};
cursor: ${p => (p.disabled ? 'default' : 'pointer')}; cursor: ${p => (p.disabled ? 'default' : 'pointer')};
height: ${p => (p.small ? 30 : 36)}px; height: ${p => (p.small ? 30 : 36)}px;
pointer-events: ${p => (p.disabled ? 'none' : '')};
outline: none; outline: none;
${p => getStyles(p, 'default')};
&:hover { &:hover {
background: ${p => (p.disabled ? '' : p.primary ? lighten(p.theme.colors.wallet, 0.05) : '')}; ${p => getStyles(p, 'hover')};
} }
&:active { &:active {
color: ${p => ${p => getStyles(p, 'active')};
p.primary
? ''
: p.outline
? darken(p.theme.colors.wallet, 0.1)
: darken(p.theme.colors.grey, 0.2)};
border-color: ${p => (p.outline ? darken(p.theme.colors.wallet, 0.1) : '')};
background: ${p => (p.primary ? darken(p.theme.colors.wallet, 0.1) : '')};
} }
` `
@ -46,54 +98,17 @@ type Props = {
children?: any, children?: any,
icon?: string, icon?: string,
primary?: boolean, primary?: boolean,
danger?: boolean,
disabled?: boolean, disabled?: boolean,
onClick?: Function, onClick?: Function,
small?: boolean, small?: boolean,
} }
function getProps({ disabled, icon, primary }: Object) {
const props = (predicate, props, defaults = {}) => (predicate ? props : defaults)
return {
color: 'grey',
...props(
icon,
{
fontSize: 3,
px: 1,
},
{
fontSize: 4,
px: 3,
},
),
...props(
primary,
{
color: 'white',
bg: 'wallet',
},
{
bg: 'transparent',
},
),
...props(disabled, {
color: 'grey',
bg: 'lightFog',
}),
}
}
const Button = (props: Props) => { const Button = (props: Props) => {
const { onClick, children, primary, disabled } = props const { onClick, children, disabled } = props
return ( return (
<Base <Base {...props} onClick={disabled ? undefined : onClick}>
{...getProps({ primary, disabled })}
{...props}
disabled={disabled}
onClick={disabled ? undefined : onClick}
>
{children} {children}
</Base> </Base>
) )
@ -106,6 +121,7 @@ Button.defaultProps = {
onClick: noop, onClick: noop,
primary: false, primary: false,
small: false, small: false,
danger: false,
} }
export default Button export default Button

11
src/components/base/Button/stories.js

@ -47,6 +47,17 @@ stories.add('Button', () => (
</Button> </Button>
</Td> </Td>
</tr> </tr>
<tr>
<Td>danger</Td>
<Td>
<Button danger>Danger button</Button>
</Td>
<Td>
<Button danger disabled>
Danger button
</Button>
</Td>
</tr>
<tr> <tr>
<Td>outline</Td> <Td>outline</Td>
<Td> <Td>

Loading…
Cancel
Save