-
Notifications
You must be signed in to change notification settings - Fork 842
/
Copy pathpopover_htmlelement_anchor.js
55 lines (44 loc) · 1.54 KB
/
popover_htmlelement_anchor.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
51
52
53
54
55
import React, { useState, useEffect } from 'react';
import { render, unmountComponentAtNode } from 'react-dom';
import { EuiWrappingPopover } from '../../../../src/components';
const PopoverApp = (props) => {
const [isPopoverOpen, setIsPopoverOpen] = useState(false);
useEffect(() => {
props.anchor.addEventListener('click', onButtonClick);
return () => props.anchor.removeEventListener('click', onButtonClick);
}, [props.anchor]);
const onButtonClick = () =>
setIsPopoverOpen((isPopoverOpen) => !isPopoverOpen);
const closePopover = () => setIsPopoverOpen(false);
return (
<EuiWrappingPopover
button={props.anchor}
isOpen={isPopoverOpen}
closePopover={closePopover}
>
<div>Normal JSX content populates the popover.</div>
</EuiWrappingPopover>
);
};
export default () => {
useEffect(() => {
const thisAnchor = document.querySelector('#popoverAnchorButton');
// `container` can be created here or use an existing DOM element
// the popover DOM is positioned independently of where the container exists
const container = document.createElement('div');
document.body.appendChild(container);
render(<PopoverApp anchor={thisAnchor} />, container);
return () => unmountComponentAtNode(container);
}, []);
return (
<div
dangerouslySetInnerHTML={{
__html: `
<button id="popoverAnchorButton" class="EuiButtonEmpty EuiButtonEmpty--primary">
<span class="EuiButtonEmpty__content">This is an HTML button</span>
</button>
`,
}}
/>
);
};