UNPKG

@navikt/ds-react

Version:

React components from the Norwegian Labour and Welfare Administration.

39 lines 2.14 kB
var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; import React, { forwardRef } from "react"; import ReactDOM from "react-dom"; import { useProvider } from "../provider/Provider.js"; import { Slot } from "../slot/Slot.js"; import { Theme, useThemeInternal } from "../theme/Theme.js"; export const Portal = forwardRef((_a, ref) => { var _b, _c, _d; var { rootElement, asChild } = _a, rest = __rest(_a, ["rootElement", "asChild"]); const themeContext = useThemeInternal(false); const contextRoot = (_b = useProvider()) === null || _b === void 0 ? void 0 : _b.rootElement; const root = (_c = rootElement !== null && rootElement !== void 0 ? rootElement : contextRoot) !== null && _c !== void 0 ? _c : (_d = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) === null || _d === void 0 ? void 0 : _d.body; const Component = asChild ? Slot : "div"; /** * Portal can be mounted outside of theme-classNames. * If a theme is present, we want to make sure that theme cascades to portaled element. */ if (themeContext === null || themeContext === void 0 ? void 0 : themeContext.isDarkside) { return root ? ReactDOM.createPortal(React.createElement(Theme, { theme: themeContext.theme, asChild: true, hasBackground: false, "data-color": themeContext.color }, React.createElement(Component, Object.assign({ ref: ref, "data-aksel-portal": "" }, rest))), root) : null; } return root ? ReactDOM.createPortal(React.createElement(Component, Object.assign({ ref: ref, "data-aksel-portal": "" }, rest)), root) : null; }); export default Portal; //# sourceMappingURL=Portal.js.map