36 lines
766 B
JavaScript
36 lines
766 B
JavaScript
import FocusTrap from 'focus-trap-react'
|
|
import React, { Component } from 'react'
|
|
import './Overlay.css'
|
|
import { SimpleButton } from './ui/Button'
|
|
|
|
export default class Overlay extends Component {
|
|
render() {
|
|
const { onClose, children, otherProps } = this.props
|
|
return (
|
|
<div id="overlayWrapper" onClick={onClose}>
|
|
<FocusTrap
|
|
focusTrapOptions={{
|
|
onDeactivate: onClose
|
|
}}>
|
|
<div
|
|
aria-modal="true"
|
|
id="overlayContent"
|
|
{...otherProps}
|
|
onClick={e => {
|
|
e.preventDefault()
|
|
e.stopPropagation()
|
|
}}>
|
|
{children}
|
|
<SimpleButton
|
|
aria-label="close"
|
|
onClick={onClose}
|
|
id="overlayCloseButton">
|
|
x
|
|
</SimpleButton>
|
|
</div>
|
|
</FocusTrap>
|
|
</div>
|
|
)
|
|
}
|
|
}
|