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>
213 lines • 34.5 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); }
var _excluded = ["children", "className", "style", "width"];
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
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 PropTypes from "prop-types";
import classNames from "classnames";
import shallowequal from "shallowequal";
import addEventListener from "rc-util/lib/Dom/addEventListener";
import omit from "../_util/omit";
import ResizeObserver from "../resize-observer";
import "./style";
var prefix = "adui-affix";
var Affix = function (_React$Component) {
function Affix(_props) {
var _this;
_classCallCheck(this, Affix);
_this = _callSuper(this, Affix, [_props]);
_this.fixedNode = void 0;
_this.placeholderNode = void 0;
_this.scrollEventHandler = void 0;
_this.componentDidMount = function () {
var getTarget = _this.props.getTarget;
var target = getTarget ? getTarget() : window;
_this.scrollEventHandler = addEventListener(target, "scroll", _this.updatePosition);
_this.updatePosition();
_this.syncPlaceholderStyle();
};
_this.componentWillUnmount = function () {
if (_this.scrollEventHandler) {
_this.scrollEventHandler.remove();
}
};
_this.setAffixStyle = function (newAffixStyle) {
var onChange = _this.props.onChange;
var affixStyle = _this.state.affixStyle;
if (!shallowequal(affixStyle, newAffixStyle)) {
_this.setState({
affixStyle: newAffixStyle
});
}
if (!!affixStyle !== !!newAffixStyle && onChange) {
onChange(!!newAffixStyle);
}
};
_this.updatePosition = function () {
var _this2 = _this,
fixedNode = _this2.fixedNode,
placeholderNode = _this2.placeholderNode,
props = _this2.props;
var getContainer = props.getContainer,
getTarget = props.getTarget,
offsetBottom = props.offsetBottom,
offsetTop = props.offsetTop;
var target = getTarget ? getTarget() : window;
if (target && placeholderNode && fixedNode) {
var documentRect = document.body.getBoundingClientRect();
var placeholderRect = placeholderNode.getBoundingClientRect();
var fixedRect = fixedNode.getBoundingClientRect();
var targetRect = getTarget ? getTarget().getBoundingClientRect() : documentRect;
var documentRectLeft = documentRect.left;
var placeholderRectLeft = placeholderRect.left;
var targetTop = getTarget ? targetRect.top : 0;
var targetHeight = getTarget ? targetRect.height : window.innerHeight;
var affixStyle = {
left: documentRectLeft + placeholderRectLeft,
position: "fixed",
width: fixedRect.width
};
if (offsetBottom !== null && offsetBottom !== undefined && !isNaN(offsetBottom)) {
setTimeout(function () {
placeholderRect = placeholderNode.getBoundingClientRect();
if (placeholderRect.bottom > targetHeight - offsetBottom + targetTop) {
if (getContainer && getContainer()) {
var containerRect = getContainer().getBoundingClientRect();
var bottom = targetHeight - containerRect.top - placeholderRect.height + targetTop;
if (bottom <= offsetBottom) {
if (placeholderRect.height) {
affixStyle.bottom = bottom + placeholderRect.height < 0 ? -placeholderRect.height : bottom;
}
} else {
affixStyle.bottom = offsetBottom + window.innerHeight - targetTop - targetHeight;
}
} else {
affixStyle.bottom = offsetBottom + window.innerHeight - targetTop - targetHeight;
}
_this.setAffixStyle(affixStyle);
} else {
_this.setAffixStyle(null);
}
}, 0);
} else if (placeholderRect.top < (offsetTop || 0) + targetTop) {
if (getContainer && getContainer()) {
var containerRect = getContainer().getBoundingClientRect();
var top = containerRect.height + containerRect.top - placeholderRect.height - targetTop;
if (offsetTop !== undefined && top <= offsetTop) {
affixStyle.top = top + placeholderRect.height < 0 ? -placeholderRect.height : top;
} else {
affixStyle.top = targetTop + (offsetTop || 0);
}
} else {
affixStyle.top = targetTop + (offsetTop || 0);
}
_this.setAffixStyle(affixStyle);
} else {
_this.setAffixStyle(null);
}
}
};
_this.syncPlaceholderStyle = function () {
_this.updatePosition();
var affixStyle = _this.state.affixStyle;
if (_this.placeholderNode && affixStyle) {
var widthPrev = _this.placeholderNode.style.width;
_this.placeholderNode.style.width = "";
var width = _this.placeholderNode.offsetWidth;
_this.setAffixStyle(_objectSpread(_objectSpread({}, affixStyle), {}, {
width: width
}));
if (!width) {
_this.placeholderNode.style.width = widthPrev;
}
}
};
_this.savePlaceholderNode = function (node) {
_this.placeholderNode = node;
};
_this.saveFixedNode = function (node) {
_this.fixedNode = node;
};
_this.state = {
affixStyle: undefined
};
return _this;
}
_inherits(Affix, _React$Component);
return _createClass(Affix, [{
key: "render",
value: function render() {
var _this3 = this;
var _this$props = this.props,
children = _this$props.children,
className = _this$props.className,
style = _this$props.style,
widthProp = _this$props.width,
otherProps = _objectWithoutProperties(_this$props, _excluded);
var restProps = omit(otherProps, ["getContainer", "getTarget", "offsetBottom", "offsetTop", "onChange"]);
var affixStyle = this.state.affixStyle;
var classSet = classNames(className, "".concat(prefix, "-base"));
return React.createElement("div", {
ref: this.savePlaceholderNode,
style: {
width: widthProp
}
}, React.createElement(ResizeObserver, {
onResize: function onResize(_ref) {
var width = _ref.width,
height = _ref.height;
_this3.updatePosition();
_this3.syncPlaceholderStyle();
if (_this3.placeholderNode && width && height) {
if (!widthProp) {
_this3.placeholderNode.style.width = "".concat(width, "px");
}
_this3.placeholderNode.style.height = "".concat(height, "px");
}
}
}, React.createElement("div", _extends({
className: classSet,
ref: this.saveFixedNode,
style: _objectSpread(_objectSpread({}, affixStyle), style)
}, restProps), children)));
}
}]);
}(React.Component);
Affix.propTypes = {
children: PropTypes.node,
className: PropTypes.string,
getContainer: PropTypes.func,
getTarget: PropTypes.func,
offsetBottom: PropTypes.number,
offsetTop: PropTypes.number,
onChange: PropTypes.func,
style: PropTypes.object
};
Affix.defaultProps = {
children: "",
className: undefined,
getContainer: null,
getTarget: null,
offsetBottom: null,
offsetTop: 0,
onChange: null,
style: {}
};
export { Affix as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropTypes","classNames","shallowequal","addEventListener","omit","ResizeObserver","prefix","Affix","_React$Component","props","_this","_classCallCheck","_callSuper","fixedNode","placeholderNode","scrollEventHandler","componentDidMount","getTarget","target","window","updatePosition","syncPlaceholderStyle","componentWillUnmount","remove","setAffixStyle","newAffixStyle","onChange","affixStyle","state","setState","_this2","getContainer","offsetBottom","offsetTop","documentRect","document","body","getBoundingClientRect","placeholderRect","fixedRect","targetRect","documentRectLeft","left","placeholderRectLeft","targetTop","top","targetHeight","height","innerHeight","position","width","undefined","isNaN","setTimeout","bottom","containerRect","widthPrev","style","offsetWidth","_objectSpread","savePlaceholderNode","node","saveFixedNode","_inherits","_createClass","key","value","render","_this3","_this$props","children","className","widthProp","otherProps","_objectWithoutProperties","_excluded","restProps","classSet","concat","createElement","ref","onResize","_ref","_extends","Component","propTypes","string","func","number","object","defaultProps","default"],"sources":["../../components/affix/Affix.tsx"],"sourcesContent":["/**\n * Affix 组件将不会修改成 FunctionComponent，\n * 因为我（Yijie）尝试过发现会一直触发 onChange, affixStyle 明明有，但是在 onChange 时一直是 undefined\n */\nimport * as React from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport shallowequal from \"shallowequal\"\nimport addEventListener from \"rc-util/lib/Dom/addEventListener\"\nimport omit from \"../_util/omit\"\nimport ResizeObserver from \"../resize-observer\"\nimport \"./style\"\n\nconst prefix = \"adui-affix\"\n\nexport interface IAffixProps {\n  [key: string]: any\n  children?: React.ReactNode\n  className?: string\n  getContainer?: (() => HTMLElement) | null\n  getTarget?: (() => HTMLElement) | null\n  offsetBottom?: number | null\n  offsetTop?: number\n  onChange?: ((affixed: boolean) => void) | null\n  style?: React.CSSProperties\n  // 20240701 增加 width prop，如果外部指定了 width，则不再在内部动态计算宽度\n  width?: React.CSSProperties[\"width\"]\n}\n\nexport interface IAffixState {\n  affixStyle?: React.CSSProperties | null\n}\n\n/**\n * 固钉\n */\nexport default class Affix extends React.Component<IAffixProps, IAffixState> {\n  public static propTypes = {\n    /**\n     * 子节点\n     */\n    children: PropTypes.node,\n    /**\n     * 附加类名\n     */\n    className: PropTypes.string,\n    /**\n     * () => HTMLElement 固钉的显示区域，永远会在此方法传回的元素内\n     */\n    getContainer: PropTypes.func,\n    /**\n     * () => HTMLElement 监听滚动的元素，默认在 window 上\n     */\n    getTarget: PropTypes.func,\n    /**\n     * 距离窗口顶部达到指定偏移量后触发，如果传入了 offsetBottom，Affix 会忽略 offsetTop\n     */\n    offsetBottom: PropTypes.number,\n    /**\n     * 距离窗口顶部达到指定偏移量后触发\n     */\n    offsetTop: PropTypes.number,\n    /**\n     * 固定状态改变时的 handler\n     */\n    onChange: PropTypes.func,\n    /**\n     * 附加样式\n     */\n    style: PropTypes.object,\n  }\n\n  public static defaultProps: IAffixProps = {\n    children: \"\",\n    className: undefined,\n    getContainer: null,\n    getTarget: null,\n    offsetBottom: null,\n    offsetTop: 0,\n    onChange: null,\n    style: {},\n  }\n\n  public fixedNode: HTMLDivElement\n\n  public placeholderNode: HTMLDivElement\n\n  private scrollEventHandler: any\n\n  constructor(props: IAffixProps) {\n    super(props)\n    this.state = {\n      affixStyle: undefined,\n    }\n  }\n\n  public componentDidMount = () => {\n    const { getTarget } = this.props\n    const target = getTarget ? getTarget() : window\n    this.scrollEventHandler = addEventListener(\n      target,\n      \"scroll\",\n      this.updatePosition\n    )\n    this.updatePosition()\n    this.syncPlaceholderStyle()\n  }\n\n  public componentWillUnmount = () => {\n    if (this.scrollEventHandler) {\n      this.scrollEventHandler.remove()\n    }\n  }\n\n  public setAffixStyle = (newAffixStyle: React.CSSProperties | null) => {\n    const { onChange } = this.props\n    const { affixStyle } = this.state\n    if (!shallowequal(affixStyle, newAffixStyle)) {\n      this.setState({ affixStyle: newAffixStyle })\n    }\n    if (!!affixStyle !== !!newAffixStyle && onChange) {\n      onChange(!!newAffixStyle)\n    }\n  }\n\n  public updatePosition = () => {\n    const { fixedNode, placeholderNode, props } = this\n    const { getContainer, getTarget, offsetBottom, offsetTop } = props\n    const target = getTarget ? getTarget() : window\n\n    // 每次使用 ref 都要进行判断\n    if (target && placeholderNode && fixedNode) {\n      // documentRect 是一定需要的，为了设置正确的 left 值\n      const documentRect = document.body.getBoundingClientRect()\n      let placeholderRect = placeholderNode.getBoundingClientRect()\n      const fixedRect = fixedNode.getBoundingClientRect()\n\n      // 判断是否是 window\n      const targetRect = getTarget\n        ? getTarget().getBoundingClientRect()\n        : documentRect\n      const documentRectLeft = documentRect.left\n      const placeholderRectLeft = placeholderRect.left\n\n      const targetTop = getTarget ? targetRect.top : 0\n      const targetHeight = getTarget ? targetRect.height : window.innerHeight\n\n      const affixStyle: React.CSSProperties = {\n        left: documentRectLeft + placeholderRectLeft,\n        position: \"fixed\",\n        width: fixedRect.width,\n      }\n\n      // 如果传入了 offsetBottom，则会忽略 offsetTop\n      if (\n        offsetBottom !== null &&\n        offsetBottom !== undefined &&\n        !isNaN(offsetBottom)\n      ) {\n        setTimeout(() => {\n          placeholderRect = placeholderNode.getBoundingClientRect()\n          if (\n            placeholderRect.bottom >\n            targetHeight - offsetBottom + targetTop\n          ) {\n            if (getContainer && getContainer()) {\n              const containerRect = getContainer().getBoundingClientRect()\n              const bottom =\n                targetHeight -\n                containerRect.top -\n                placeholderRect.height +\n                targetTop\n              if (bottom <= offsetBottom) {\n                if (placeholderRect.height) {\n                  affixStyle.bottom =\n                    bottom + placeholderRect.height < 0\n                      ? -placeholderRect.height\n                      : bottom\n                }\n              } else {\n                affixStyle.bottom =\n                  offsetBottom + window.innerHeight - targetTop - targetHeight\n              }\n            } else {\n              affixStyle.bottom =\n                offsetBottom + window.innerHeight - targetTop - targetHeight\n            }\n            this.setAffixStyle(affixStyle)\n          } else {\n            this.setAffixStyle(null)\n          }\n        }, 0)\n      } else if (placeholderRect.top < (offsetTop || 0) + targetTop) {\n        if (getContainer && getContainer()) {\n          const containerRect = getContainer().getBoundingClientRect()\n          const top =\n            containerRect.height +\n            containerRect.top -\n            placeholderRect.height -\n            targetTop\n          if (offsetTop !== undefined && top <= offsetTop) {\n            affixStyle.top =\n              top + placeholderRect.height < 0 ? -placeholderRect.height : top\n          } else {\n            affixStyle.top = targetTop + (offsetTop || 0)\n          }\n        } else {\n          affixStyle.top = targetTop + (offsetTop || 0)\n        }\n        this.setAffixStyle(affixStyle)\n      } else {\n        this.setAffixStyle(null)\n      }\n    }\n  }\n\n  public syncPlaceholderStyle = () => {\n    this.updatePosition()\n    const { affixStyle } = this.state\n    // 条件判断：\n    // 1. 每次使用 ref 都要进行判断 2. 判断有 affixStyle 说明现在正处于固定状态中\n    if (this.placeholderNode && affixStyle) {\n      const widthPrev = this.placeholderNode.style.width\n      this.placeholderNode.style.width = \"\"\n      const width = this.placeholderNode.offsetWidth\n      this.setAffixStyle({\n        ...affixStyle,\n        width,\n      })\n      if (!width) {\n        this.placeholderNode.style.width = widthPrev\n      }\n    }\n  }\n\n  public savePlaceholderNode = (node: HTMLDivElement) => {\n    this.placeholderNode = node\n  }\n\n  public saveFixedNode = (node: HTMLDivElement) => {\n    this.fixedNode = node\n  }\n\n  public render() {\n    const {\n      children,\n      className,\n      style,\n      width: widthProp,\n      ...otherProps\n    } = this.props\n\n    const restProps = omit(otherProps, [\n      \"getContainer\",\n      \"getTarget\",\n      \"offsetBottom\",\n      \"offsetTop\",\n      \"onChange\",\n    ])\n\n    const { affixStyle } = this.state\n\n    const classSet = classNames(className, `${prefix}-base`)\n\n    return (\n      <div\n        ref={this.savePlaceholderNode}\n        style={{\n          width: widthProp,\n        }}\n      >\n        <ResizeObserver\n          onResize={({ width, height }) => {\n            this.updatePosition()\n            this.syncPlaceholderStyle()\n            if (this.placeholderNode && width && height) {\n              if (!widthProp) {\n                this.placeholderNode.style.width = `${width}px`\n              }\n              this.placeholderNode.style.height = `${height}px`\n            }\n          }}\n        >\n          <div\n            className={classSet}\n            ref={this.saveFixedNode}\n            style={{\n              ...affixStyle,\n              ...style,\n            }}\n            {...restProps}\n          >\n            {children}\n          </div>\n        </ResizeObserver>\n      </div>\n    )\n  }\n}\n"],"mappings":"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","ignoreList":[]}