|
|
@ -5,6 +5,8 @@ import styled from 'styled-components' |
|
|
|
import { space, fontSize, fontWeight, color } from 'styled-system' |
|
|
|
import noop from 'lodash/noop' |
|
|
|
|
|
|
|
import { darken, lighten } from 'styles/helpers' |
|
|
|
|
|
|
|
import Box from 'components/base/Box' |
|
|
|
import Icon from 'components/base/Icon' |
|
|
|
|
|
|
@ -14,11 +16,19 @@ const Base = styled.button` |
|
|
|
${fontSize}; |
|
|
|
${fontWeight}; |
|
|
|
border-radius: 5px; |
|
|
|
border: ${p => (p.primary ? '' : `1px solid ${p.theme.colors.fog}`)}; |
|
|
|
border: ${p => |
|
|
|
p.primary ? 'none' : `2px solid ${p.disabled ? 'transparent' : p.theme.colors.grey}`}; |
|
|
|
cursor: ${p => (p.disabled ? 'default' : 'pointer')}; |
|
|
|
height: 40px; |
|
|
|
box-shadow: ${p => (p.withShadow ? 'rgba(0, 0, 0, 0.2) 0 3px 10px' : '')}; |
|
|
|
outline: none; |
|
|
|
|
|
|
|
&:hover { |
|
|
|
background: ${p => (p.primary ? lighten(p.theme.colors.wallet, 0.05) : '')}; |
|
|
|
} |
|
|
|
|
|
|
|
&:active { |
|
|
|
background: ${p => (p.primary ? darken(p.theme.colors.wallet, 0.1) : '')}; |
|
|
|
} |
|
|
|
` |
|
|
|
|
|
|
|
type Props = { |
|
|
@ -33,6 +43,7 @@ function getProps({ disabled, icon, primary }: Object) { |
|
|
|
const props = (predicate, props, defaults = {}) => (predicate ? props : defaults) |
|
|
|
|
|
|
|
return { |
|
|
|
color: 'grey', |
|
|
|
...props( |
|
|
|
icon, |
|
|
|
{ |
|
|
@ -49,7 +60,6 @@ function getProps({ disabled, icon, primary }: Object) { |
|
|
|
{ |
|
|
|
color: 'white', |
|
|
|
bg: 'wallet', |
|
|
|
withShadow: true, |
|
|
|
}, |
|
|
|
{ |
|
|
|
bg: 'transparent', |
|
|
@ -58,12 +68,13 @@ function getProps({ disabled, icon, primary }: Object) { |
|
|
|
...props(disabled, { |
|
|
|
color: 'white', |
|
|
|
bg: 'fog', |
|
|
|
withShadow: false, |
|
|
|
}), |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
const Button = ({ children, onClick, primary, icon, disabled, ...props }: Props) => { |
|
|
|
const Button = (props: Props) => { |
|
|
|
const { onClick, primary, icon, disabled } = props |
|
|
|
let { children } = props |
|
|
|
children = icon ? ( |
|
|
|
<Box alignItems="center" justifyContent="center"> |
|
|
|
<Icon name={icon} /> |
|
|
|