|
@ -20,7 +20,8 @@ import Box from 'components/base/Box' |
|
|
type Props = { |
|
|
type Props = { |
|
|
isOpened?: boolean, |
|
|
isOpened?: boolean, |
|
|
onClose: Function, |
|
|
onClose: Function, |
|
|
preventBackdropClick: boolean, |
|
|
preventBackdropClick?: boolean, |
|
|
|
|
|
preventSideMargin?: boolean, |
|
|
render: Function, |
|
|
render: Function, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -73,13 +74,14 @@ const Wrapper = styled(Box).attrs({ |
|
|
transform: `translate3d(0, ${p.offset}px, 0)`, |
|
|
transform: `translate3d(0, ${p.offset}px, 0)`, |
|
|
}), |
|
|
}), |
|
|
})` |
|
|
})` |
|
|
width: 430px; |
|
|
margin-left: ${p => (p.preventSideMargin ? 0 : p.theme.sizes.sideBarWidth)}px; |
|
|
|
|
|
width: 570px; |
|
|
z-index: 2; |
|
|
z-index: 2; |
|
|
` |
|
|
` |
|
|
|
|
|
|
|
|
const Body = styled(Box).attrs({ |
|
|
const Body = styled(Box).attrs({ |
|
|
bg: p => p.theme.colors.white, |
|
|
bg: p => p.theme.colors.white, |
|
|
p: 20, |
|
|
p: 3, |
|
|
})` |
|
|
})` |
|
|
border-radius: 5px; |
|
|
border-radius: 5px; |
|
|
` |
|
|
` |
|
@ -87,12 +89,13 @@ const Body = styled(Box).attrs({ |
|
|
export class Modal extends PureComponent<Props> { |
|
|
export class Modal extends PureComponent<Props> { |
|
|
static defaultProps = { |
|
|
static defaultProps = { |
|
|
onClose: noop, |
|
|
onClose: noop, |
|
|
preventBackdropClick: true, |
|
|
preventBackdropClick: false, |
|
|
|
|
|
preventSideMargin: false, |
|
|
isOpened: false, |
|
|
isOpened: false, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { preventBackdropClick, isOpened, onClose, render } = this.props |
|
|
const { preventBackdropClick, preventSideMargin, isOpened, onClose, render } = this.props |
|
|
return ( |
|
|
return ( |
|
|
<Mortal |
|
|
<Mortal |
|
|
isOpened={isOpened} |
|
|
isOpened={isOpened} |
|
@ -105,7 +108,7 @@ export class Modal extends PureComponent<Props> { |
|
|
{(m, isVisible) => ( |
|
|
{(m, isVisible) => ( |
|
|
<Container isVisible={isVisible}> |
|
|
<Container isVisible={isVisible}> |
|
|
<Backdrop op={m.opacity} onClick={preventBackdropClick ? undefined : onClose} /> |
|
|
<Backdrop op={m.opacity} onClick={preventBackdropClick ? undefined : onClose} /> |
|
|
<Wrapper op={m.opacity} offset={m.y}> |
|
|
<Wrapper preventSideMargin={preventSideMargin} op={m.opacity} offset={m.y}> |
|
|
{render({ onClose })} |
|
|
{render({ onClose })} |
|
|
</Wrapper> |
|
|
</Wrapper> |
|
|
</Container> |
|
|
</Container> |
|
|