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>
151 lines • 21.1 kB
JavaScript
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); }
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); }
import * as React from "react";
import ResizeObserver from "resize-observer-polyfill";
import findDOMNode from "rc-util/lib/Dom/findDOMNode";
import toArray from "rc-util/lib/Children/toArray";
import { composeRef } from "rc-util/lib/ref";
import warning from "../_util/warning";
var supportRef = function supportRef(nodeOrComponent) {
var _nodeOrComponent$type;
if ((_nodeOrComponent$type = nodeOrComponent.type) !== null && _nodeOrComponent$type !== void 0 && _nodeOrComponent$type.$$typeof && nodeOrComponent.type.$$typeof.toString().includes("forward_ref")) {
return false;
}
if (nodeOrComponent.type && nodeOrComponent.type.prototype && !nodeOrComponent.type.prototype.render) {
return false;
}
if (typeof nodeOrComponent === "function") {
return false;
}
return true;
};
var ReactResizeObserver = function (_React$Component) {
function ReactResizeObserver() {
var _this;
_classCallCheck(this, ReactResizeObserver);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _callSuper(this, ReactResizeObserver, [].concat(args));
_this.resizeObserver = null;
_this.childNode = null;
_this.currentElement = null;
_this.state = {
width: 0,
height: 0
};
_this.onResize = function (entries) {
var onResize = _this.props.onResize;
var _this$state = _this.state,
widthState = _this$state.width,
heightState = _this$state.height;
var target = entries[0].target;
var _target$getBoundingCl = target.getBoundingClientRect(),
width = _target$getBoundingCl.width,
height = _target$getBoundingCl.height;
var _ref = [Math.floor(width), Math.floor(height)],
fixedWidth = _ref[0],
fixedHeight = _ref[1];
if (widthState !== fixedWidth || heightState !== fixedHeight) {
var size = {
width: fixedWidth,
height: fixedHeight
};
_this.setState(size);
if (onResize) {
onResize(size);
}
}
};
_this.setChildNode = function (node) {
_this.childNode = node;
};
return _this;
}
_inherits(ReactResizeObserver, _React$Component);
return _createClass(ReactResizeObserver, [{
key: "componentDidMount",
value: function componentDidMount() {
this.onComponentUpdated();
}
}, {
key: "componentDidUpdate",
value: function componentDidUpdate() {
this.onComponentUpdated();
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
this.destroyObserver();
}
}, {
key: "onComponentUpdated",
value: function onComponentUpdated() {
var disabled = this.props.disabled;
if (disabled) {
this.destroyObserver();
return;
}
var element = findDOMNode(this.childNode || this);
var elementChanged = element !== this.currentElement;
if (elementChanged) {
this.destroyObserver();
this.currentElement = element;
}
if (!this.resizeObserver && element) {
this.resizeObserver = new ResizeObserver(this.onResize);
this.resizeObserver.observe(element);
}
}
}, {
key: "destroyObserver",
value: function destroyObserver() {
if (this.resizeObserver) {
this.resizeObserver.disconnect();
this.resizeObserver = null;
}
}
}, {
key: "render",
value: function render() {
var children = this.props.children;
var childNodes = toArray(children);
if (childNodes.length > 1) {
warning(false, "ResizeObserver", "有多个 children,将只会在第一个元素上监听");
} else if (childNodes.length === 0) {
warning(false, "ResizeObserver", "没有 children");
return null;
}
var childNode = childNodes[0];
if (React.isValidElement(childNode) && supportRef(childNode)) {
var _ref2 = childNode,
ref = _ref2.ref;
childNodes[0] = React.cloneElement(childNode, {
ref: composeRef(ref, this.setChildNode)
});
}
return React.createElement(React.Fragment, null, childNodes.length === 1 ? childNodes[0] : childNodes.map(function (node, index) {
if (!React.isValidElement(node) || "key" in node && node.key !== null) {
return node;
}
return React.cloneElement(node, {
key: "adui-observer-key-".concat(index)
});
}));
}
}]);
}(React.Component);
ReactResizeObserver.displayName = "ResizeObserver";
export default ReactResizeObserver;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","ResizeObserver","findDOMNode","toArray","composeRef","warning","supportRef","nodeOrComponent","_nodeOrComponent$type","type","$$typeof","toString","includes","prototype","render","ReactResizeObserver","_React$Component","_this","_classCallCheck","_len","arguments","length","args","Array","_key","_callSuper","concat","resizeObserver","childNode","currentElement","state","width","height","onResize","entries","props","_this$state","widthState","heightState","target","_target$getBoundingCl","getBoundingClientRect","_ref","Math","floor","fixedWidth","fixedHeight","size","setState","setChildNode","node","_inherits","_createClass","key","value","componentDidMount","onComponentUpdated","componentDidUpdate","componentWillUnmount","destroyObserver","disabled","element","elementChanged","observe","disconnect","children","childNodes","isValidElement","_ref2","ref","cloneElement","createElement","Fragment","map","index","Component","displayName"],"sources":["../../components/resize-observer/ResizeObserver.tsx"],"sourcesContent":["/**\n * ResizeObserver 会以 class 组件的形式存在，\n * 因为其使用 findDomNode(this) 实现 children 为 fc 时不能给 ref 的情况\n * 如果 ResizeObserver 也是 fc，就没有办法在不添加额外结构的情况下拿到 dom 了\n */\n/* eslint-disable */\n// @ts-nocheck\nimport * as React from \"react\"\nimport ResizeObserver from \"resize-observer-polyfill\"\nimport findDOMNode from \"rc-util/lib/Dom/findDOMNode\"\nimport toArray from \"rc-util/lib/Children/toArray\"\nimport { composeRef } from \"rc-util/lib/ref\"\nimport warning from \"../_util/warning\"\n\ninterface ResizeObserverEntry {\n  readonly borderBoxSize: ResizeObserverEntryBoxSize\n  readonly contentBoxSize: ResizeObserverEntryBoxSize\n  readonly contentRect: any\n  readonly target: Element\n}\ninterface ResizeObserverEntryBoxSize {\n  blockSize: number\n  inlineSize: number\n}\n\nconst supportRef = (nodeOrComponent) => {\n  if (\n    nodeOrComponent.type?.$$typeof &&\n    nodeOrComponent.type.$$typeof.toString().includes(\"forward_ref\")\n  ) {\n    return false\n  }\n\n  // Function component node\n  if (\n    nodeOrComponent.type &&\n    nodeOrComponent.type.prototype &&\n    !nodeOrComponent.type.prototype.render\n  ) {\n    return false\n  }\n\n  // Class component\n  if (typeof nodeOrComponent === \"function\") {\n    return false\n  }\n\n  return true\n}\n\nexport interface IResizeObserverProps {\n  children: React.ReactNode\n  disabled?: boolean\n  onResize?: (size: { width: number; height: number }) => void\n}\n\ninterface ResizeObserverState {\n  height: number\n  width: number\n}\n\ntype RefNode = React.ReactInstance | HTMLElement | null\n\nclass ReactResizeObserver extends React.Component<\n  IResizeObserverProps,\n  ResizeObserverState\n> {\n  static displayName = \"ResizeObserver\"\n\n  resizeObserver: ResizeObserver | null = null\n\n  childNode: RefNode = null\n\n  currentElement: Element | null = null\n\n  state = {\n    width: 0,\n    height: 0,\n  }\n\n  componentDidMount() {\n    this.onComponentUpdated()\n  }\n\n  componentDidUpdate() {\n    this.onComponentUpdated()\n  }\n\n  componentWillUnmount() {\n    this.destroyObserver()\n  }\n\n  onComponentUpdated() {\n    const { disabled } = this.props\n\n    // Unregister if disabled\n    if (disabled) {\n      this.destroyObserver()\n      return\n    }\n\n    const element = findDOMNode(this.childNode || this) as Element\n    const elementChanged = element !== this.currentElement\n    if (elementChanged) {\n      this.destroyObserver()\n      this.currentElement = element\n    }\n\n    if (!this.resizeObserver && element) {\n      this.resizeObserver = new ResizeObserver(this.onResize)\n      this.resizeObserver.observe(element)\n    }\n  }\n\n  onResize = (entries: ResizeObserverEntry[]) => {\n    const { onResize } = this.props\n    const { width: widthState, height: heightState } = this.state\n\n    const { target } = entries[0]\n\n    const { width, height } = target.getBoundingClientRect()\n    const [fixedWidth, fixedHeight] = [Math.floor(width), Math.floor(height)]\n\n    if (widthState !== fixedWidth || heightState !== fixedHeight) {\n      const size = { width: fixedWidth, height: fixedHeight }\n\n      this.setState(size)\n\n      if (onResize) {\n        onResize(size)\n      }\n    }\n  }\n\n  setChildNode = (node: RefNode) => {\n    this.childNode = node\n  }\n\n  destroyObserver() {\n    if (this.resizeObserver) {\n      this.resizeObserver.disconnect()\n      this.resizeObserver = null\n    }\n  }\n\n  render() {\n    const { children } = this.props\n    const childNodes = toArray(children)\n\n    if (childNodes.length > 1) {\n      warning(\n        false,\n        \"ResizeObserver\",\n        \"有多个 children，将只会在第一个元素上监听\"\n      )\n    } else if (childNodes.length === 0) {\n      warning(false, \"ResizeObserver\", \"没有 children\")\n\n      return null\n    }\n\n    const childNode = childNodes[0]\n\n    if (React.isValidElement(childNode) && supportRef(childNode)) {\n      const { ref } = childNode as any\n\n      childNodes[0] = React.cloneElement(childNode as any, {\n        ref: composeRef(ref, this.setChildNode),\n      })\n    }\n\n    return (\n      <>\n        {childNodes.length === 1\n          ? childNodes[0]\n          : childNodes.map((node, index) => {\n              if (\n                !React.isValidElement(node) ||\n                (\"key\" in node && node.key !== null)\n              ) {\n                return node\n              }\n\n              return React.cloneElement(node, {\n                key: `adui-observer-key-${index}`,\n              })\n            })}\n      </>\n    )\n  }\n}\n\nexport default ReactResizeObserver\n"],"mappings":"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","ignoreList":[]}