UNPKG

@fruits-chain/react-native-xiaoshu

Version:
57 lines (55 loc) • 2.61 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _portalConsumer = _interopRequireDefault(require("./portal-consumer.js")); var _portalHost = _interopRequireWildcard(require("./portal-host.js")); var _jsxRuntime = require("react/jsx-runtime"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* eslint-disable @typescript-eslint/explicit-member-accessibility */ /* eslint-disable @typescript-eslint/consistent-type-definitions */ /** * Portal allows to render a component at a different place in the parent tree. * You can use it to render content which should appear above other elements, similar to `Modal`. * It requires a `Portal.Host` component to be rendered somewhere in the parent tree. * * ## Usage * ```js * import * as React from 'react'; * import { Text } from 'react-native'; * import { Portal } from '@fruits-chain/react-native-xiaoshu'; * * export default class MyComponent extends React.Component { * render() { * const { visible } = this.state; * return ( * <Portal> * <Text>This is rendered at a different place</Text> * </Portal> * ); * } * } * ``` */ class Portal extends _react.Component { static Host = _portalHost.default; static add = _portalHost.portal.add; static remove = _portalHost.portal.remove; render() { const { children } = this.props; return /*#__PURE__*/(0, _jsxRuntime.jsx)(_portalHost.PortalContext.Consumer, { children: manager => /*#__PURE__*/(0, _jsxRuntime.jsx)(_portalConsumer.default, { manager: manager, children: children }) }); } } var _default = exports.default = Portal; //# sourceMappingURL=portal.js.map