import * as React from 'react'; const makeApi = (classes?: Array) => ({ createRoot: () => { const div = document.createElement('div'); if (classes) { classes.forEach(theme => { div.classList.add(theme); }); } document.body.appendChild(div); return div; }, removeRoot: (root: HTMLElement) => { document.body.removeChild(root); }, }); export const PopperRootContext = React.createContext(makeApi()); export type ClassyProviderProps = { classes?: Array; children?: React.ReactChildren; }; export const ClassyProvider: React.FunctionComponent = ({ classes, children, }) => { const api = React.useMemo(() => makeApi(classes), [classes]); return ( {children} ); };