-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathportaled-sidebar.js
50 lines (46 loc) · 1.07 KB
/
portaled-sidebar.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import React, { Fragment, useEffect } from "react"
import { Portal } from "react-portal"
import { PortalSidebox, DisabledOverlay } from "./styled"
const ESCAPE_KEY = 27
export const PortalSidebar = ({
children,
className,
closeOnEsc = false,
closeOnOverlayClick = false,
onClose = () => {},
right = false,
Wrapper = Fragment,
...rest
}) => {
useEffect(() => {
const evHandler = event => {
if (event.keyCode === ESCAPE_KEY && closeOnEsc) {
onClose()
}
}
document.addEventListener("keydown", evHandler)
return () => {
document.removeEventListener("keydown", evHandler)
}
}, [closeOnEsc, onClose])
const handleOverlayClick = () => {
if (closeOnOverlayClick) {
onClose()
}
}
return (
<Portal>
<DisabledOverlay onClick={handleOverlayClick} />
<Wrapper>
<PortalSidebox
className={className}
shadowSide={right}
side={right ? "right" : "left"}
{...rest}
>
{children}
</PortalSidebox>
</Wrapper>
</Portal>
)
}