UNPKG

adui

Version:

<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>

121 lines 18.2 kB
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } var _document; function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } import * as React from "react"; import * as ReactDOM from "react-dom"; import shallowEqual from "shallowequal"; var cannotCreatePortal = typeof ReactDOM.createPortal !== "function"; var maybeAddClass = function maybeAddClass(classList, className) { if (className != null && className !== "") { classList.add.apply(classList, _toConsumableArray(className.split(" "))); } }; var Portal = function (_React$Component) { function Portal() { var _this; _classCallCheck(this, Portal); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, Portal, [].concat(args)); _this.state = { hasMounted: false }; _this.portalElement = void 0; _this.shouldComponentUpdate = function (nextProps, nextState) { return !shallowEqual(_this.props, nextProps) || !shallowEqual(_this.state, nextState); }; _this.componentDidMount = function () { var _this$props = _this.props, containerProp = _this$props.container, getContainer = _this$props.getContainer, onChildrenMount = _this$props.onChildrenMount; var container = getContainer && getContainer() || containerProp; if (!container) { return; } _this.portalElement = _this.createContainerElement(); container.appendChild(_this.portalElement); _this.setState({ hasMounted: true }, onChildrenMount); if (cannotCreatePortal) { _this.unstableRenderNoPortal(); } }; _this.componentDidUpdate = function (_ref) { var prevClassName = _ref.className; var className = _this.props.className; if (_this.portalElement != null && prevClassName !== className) { if (prevClassName) { _this.portalElement.classList.remove(prevClassName); } maybeAddClass(_this.portalElement.classList, className); } if (cannotCreatePortal) { _this.unstableRenderNoPortal(); } }; return _this; } _inherits(Portal, _React$Component); return _createClass(Portal, [{ key: "render", value: function render() { var children = this.props.children; var hasMounted = this.state.hasMounted; if (cannotCreatePortal || typeof document === "undefined" || !hasMounted) { return null; } return React.createElement(React.Fragment, null, ReactDOM.createPortal(children, this.portalElement)); } }, { key: "componentWillUnmount", value: function componentWillUnmount() { if (this.portalElement != null) { if (cannotCreatePortal) { ReactDOM.unmountComponentAtNode(this.portalElement); } this.portalElement.remove(); } } }, { key: "createContainerElement", value: function createContainerElement() { var className = this.props.className; var container = document.createElement("div"); container.classList.add("adui-portal"); maybeAddClass(container.classList, className); return container; } }, { key: "unstableRenderNoPortal", value: function unstableRenderNoPortal() { var children = this.props.children; ReactDOM.unstable_renderSubtreeIntoContainer(this, React.createElement("div", null, children), this.portalElement); } }]); }(React.Component); Portal.displayName = "aduiPortal"; Portal.defaultProps = { container: ((_document = document) === null || _document === void 0 ? void 0 : _document.body) || null }; export { Portal as default }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","ReactDOM","shallowEqual","cannotCreatePortal","createPortal","maybeAddClass","classList","className","add","apply","_toConsumableArray","split","Portal","_React$Component","_this","_classCallCheck","_len","arguments","length","args","Array","_key","_callSuper","concat","state","hasMounted","portalElement","shouldComponentUpdate","nextProps","nextState","props","componentDidMount","_this$props","containerProp","container","getContainer","onChildrenMount","createContainerElement","appendChild","setState","unstableRenderNoPortal","componentDidUpdate","_ref","prevClassName","remove","_inherits","_createClass","key","value","render","children","document","createElement","Fragment","componentWillUnmount","unmountComponentAtNode","unstable_renderSubtreeIntoContainer","Component","displayName","defaultProps","_document","body","default"],"sources":["../../components/portal/Portal.tsx"],"sourcesContent":["import * as React from \"react\"\nimport * as ReactDOM from \"react-dom\"\nimport shallowEqual from \"shallowequal\"\n\n/** Detect if `React.createPortal()` API method does not exist. */\nconst cannotCreatePortal = typeof ReactDOM.createPortal !== \"function\"\n\nconst maybeAddClass = (classList: DOMTokenList, className?: string) => {\n  if (className != null && className !== \"\") {\n    classList.add(...className.split(\" \"))\n  }\n}\n\nexport interface IPortalProps {\n  /**\n   * 附加类名，此类名会增加到最外层的包含块上\n   */\n  className?: string\n  /**\n   * 当 Portal 的 children 被加入到 DOM 时的钩子\n   */\n  onChildrenMount?: () => void\n\n  /**\n   * children mounted to\n   * @default document.body\n   */\n  container?: HTMLElement\n\n  /**\n   * get container when mounted\n   */\n  getContainer?: () => HTMLElement | undefined\n}\n\nexport interface IPortalState {\n  hasMounted: boolean\n}\n\n/**\n * Portal 将子组件从组件层级（component hierarchy）中分离，并添加到指定的 container 中\n * 你应该用于那些受 z-index、overflow、position:absolute 等约束的组件中\n */\nexport default class Portal extends React.Component<\n  IPortalProps,\n  IPortalState\n> {\n  public static displayName = `aduiPortal`\n\n  public static defaultProps: IPortalProps = {\n    container: document?.body || null,\n  }\n\n  public state: IPortalState = { hasMounted: false }\n\n  private portalElement: HTMLElement\n\n  public render() {\n    const { children } = this.props\n    const { hasMounted } = this.state\n    if (cannotCreatePortal || typeof document === \"undefined\" || !hasMounted) {\n      return null\n    }\n\n    return <>{ReactDOM.createPortal(children, this.portalElement)}</>\n  }\n\n  public shouldComponentUpdate = (\n    nextProps: IPortalProps,\n    nextState: IPortalState\n  ) =>\n    !shallowEqual(this.props, nextProps) || !shallowEqual(this.state, nextState)\n\n  public componentDidMount = () => {\n    const {\n      container: containerProp,\n      getContainer,\n      onChildrenMount,\n    } = this.props\n    const container = (getContainer && getContainer()) || containerProp\n    if (!container) {\n      return\n    }\n    this.portalElement = this.createContainerElement()\n    container.appendChild(this.portalElement)\n    this.setState({ hasMounted: true }, onChildrenMount)\n    if (cannotCreatePortal) {\n      this.unstableRenderNoPortal()\n    }\n  }\n\n  public componentDidUpdate = ({ className: prevClassName }: IPortalProps) => {\n    const { className } = this.props\n    if (this.portalElement != null && prevClassName !== className) {\n      if (prevClassName) {\n        this.portalElement.classList.remove(prevClassName)\n      }\n      maybeAddClass(this.portalElement.classList, className)\n    }\n    if (cannotCreatePortal) {\n      this.unstableRenderNoPortal()\n    }\n  }\n\n  public componentWillUnmount() {\n    if (this.portalElement != null) {\n      if (cannotCreatePortal) {\n        ReactDOM.unmountComponentAtNode(this.portalElement)\n      }\n      this.portalElement.remove()\n    }\n  }\n\n  private createContainerElement() {\n    const { className } = this.props\n    const container = document.createElement(\"div\")\n    container.classList.add(\"adui-portal\")\n    maybeAddClass(container.classList, className)\n    return container\n  }\n\n  private unstableRenderNoPortal() {\n    const { children } = this.props\n    ReactDOM.unstable_renderSubtreeIntoContainer(\n      this,\n      <div>{children}</div>,\n      this.portalElement\n    )\n  }\n}\n"],"mappings":"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","ignoreList":[]}