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>
158 lines (122 loc) • 17.7 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _button = _interopRequireDefault(require("../button"));
var _affix = _interopRequireDefault(require("../affix"));
var _detectStickySupport = require("../_util/detectStickySupport");
var _preventOuterScroll = require("../_util/preventOuterScroll");
var _Context = require("./Context");
require("./style");
var _excluded = ["affixed", "children", "className", "collapsed", "collapsible", "onCollapseChange"];
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
var prefix = "adui-layout";
var Aside = function Aside(_ref) {
var _classNames;
var affixed = _ref.affixed,
children = _ref.children,
className = _ref.className,
collapsed = _ref.collapsed,
collapsible = _ref.collapsible,
onCollapseChange = _ref.onCollapseChange,
otherProps = _objectWithoutProperties(_ref, _excluded);
var _useContext = (0, _react.useContext)(_Context.LayoutContext),
headerAffixed = _useContext.headerAffixed;
var asideRef = (0, _react.useRef)(null);
var asideContentRef = (0, _react.useRef)(null);
var handleScroll = function handleScroll() {
if (asideRef !== null && asideRef !== void 0 && asideRef.current && affixed && headerAffixed) {
asideRef.current.style.maxHeight = scrollY >= 0 && scrollY <= 72 ? "calc(100vh - ".concat(72 - scrollY, "px)") : "100vh";
}
};
var handleCollapseChange = function handleCollapseChange(bool) {
if (onCollapseChange) {
onCollapseChange(bool);
}
};
var bindScrollEvent = function bindScrollEvent() {
if (affixed && !headerAffixed) {
window.addEventListener("scroll", handleScroll);
}
};
(0, _react.useEffect)(function () {
setTimeout(bindScrollEvent, 0);
if (asideContentRef !== null && asideContentRef !== void 0 && asideContentRef.current) {
asideContentRef.current.addEventListener("wheel", _preventOuterScroll.preventOuterScroll, {
passive: false
});
}
return function () {
window.removeEventListener("scroll", handleScroll);
};
}, []);
var offsetTop;
if (affixed && headerAffixed) {
offsetTop = 72;
}
if (affixed && !headerAffixed) {
offsetTop = 0;
}
var asideContent = _react["default"].createElement("aside", _extends({
className: (0, _classnames["default"])(className, "".concat(prefix, "-aside"), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-aside_affixed"), affixed && headerAffixed), _defineProperty(_classNames, "".concat(prefix, "-aside_affixed_alone"), affixed && !headerAffixed), _defineProperty(_classNames, "".concat(prefix, "-aside_collapsed"), collapsed), _defineProperty(_classNames, "".concat(prefix, "-aside_collapsible"), collapsible), _classNames))
}, otherProps, {
ref: asideRef
}), _react["default"].createElement("div", {
className: (0, _classnames["default"])("".concat(prefix, "-asideInner"))
}, collapsible && _react["default"].createElement("div", {
className: "".concat(prefix, "-asideBackButton"),
onClick: function onClick() {
return handleCollapseChange(true);
},
role: "none"
}, _react["default"].createElement(_button["default"], {
theme: "light",
leftIcon: "arrow-back"
})), _react["default"].createElement("div", {
className: "".concat(prefix, "-asideContent"),
ref: asideContentRef
}, children)), _react["default"].createElement("div", {
className: "".concat(prefix, "-asideMask"),
onClick: function onClick() {
return handleCollapseChange(true);
},
role: "none"
}));
if (affixed && !Aside.stickable) {
return _react["default"].createElement(_affix["default"], {
offsetTop: offsetTop
}, asideContent);
}
return asideContent;
};
Aside.stickable = (0, _detectStickySupport.detectStickySupport)();
Aside.propTypes = {
affixed: _propTypes["default"].bool,
children: _propTypes["default"].node,
className: _propTypes["default"].string,
collapsed: _propTypes["default"].bool,
collapsible: _propTypes["default"].bool,
onCollapseChange: _propTypes["default"].func
};
Aside.defaultProps = {
affixed: false,
children: "",
className: undefined,
collapsed: false,
collapsible: false,
onCollapseChange: function onCollapseChange() {}
};
var _default = Aside;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","Aside","affixed","children","className","collapsed","collapsible","onCollapseChange","otherProps","useContext","LayoutContext","headerAffixed","asideRef","useRef","asideContentRef","handleScroll","current","style","maxHeight","scrollY","handleCollapseChange","bool","bindScrollEvent","window","addEventListener","useEffect","setTimeout","preventOuterScroll","passive","removeEventListener","offsetTop","asideContent","classNames","stickable","detectStickySupport","propTypes","PropTypes","node","string","func","defaultProps","undefined"],"sources":["../../components/layout/Aside.tsx"],"sourcesContent":["import React, { useContext, useEffect, useRef } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Button from \"../button\"\nimport Affix from \"../affix\"\nimport { detectStickySupport } from \"../_util/detectStickySupport\"\nimport { preventOuterScroll } from \"../_util/preventOuterScroll\"\nimport { LayoutContext } from \"./Context\"\nimport \"./style\"\n\nconst prefix = \"adui-layout\"\n\nexport interface IAsideProps {\n  [key: string]: any\n  /**\n   * 是否固定\n   */\n  affixed?: boolean\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 是否收起\n   */\n  collapsed?: boolean\n  /**\n   * 是否支持收起\n   */\n  collapsible?: boolean\n  /**\n   * 收起状态变化时的 handler\n   */\n  onCollapseChange?: (collapsed: boolean) => void\n}\n\n/**\n * 布局 - 侧边栏 `<aside />`\n */\nconst Aside: React.FC<IAsideProps> & {\n  stickable: boolean\n} = ({\n  affixed,\n  children,\n  className,\n  collapsed,\n  collapsible,\n  onCollapseChange,\n  ...otherProps\n}: IAsideProps) => {\n  const { headerAffixed } = useContext(LayoutContext)\n  const asideRef = useRef<HTMLElement>(null)\n  const asideContentRef = useRef<HTMLDivElement>(null)\n\n  const handleScroll = () => {\n    if (asideRef?.current && affixed && headerAffixed) {\n      asideRef.current.style.maxHeight =\n        scrollY >= 0 && scrollY <= 72\n          ? `calc(100vh - ${72 - scrollY}px)`\n          : \"100vh\"\n    }\n  }\n\n  const handleCollapseChange = (bool: boolean) => {\n    if (onCollapseChange) {\n      onCollapseChange(bool)\n    }\n  }\n\n  const bindScrollEvent = () => {\n    if (affixed && !headerAffixed) {\n      window.addEventListener(\"scroll\", handleScroll)\n    }\n  }\n\n  useEffect(() => {\n    setTimeout(bindScrollEvent, 0)\n    if (asideContentRef?.current) {\n      asideContentRef.current.addEventListener(\"wheel\", preventOuterScroll, {\n        passive: false,\n      })\n    }\n    return () => {\n      window.removeEventListener(\"scroll\", handleScroll)\n    }\n  }, [])\n\n  let offsetTop\n  if (affixed && headerAffixed) {\n    offsetTop = 72\n  }\n  if (affixed && !headerAffixed) {\n    offsetTop = 0\n  }\n\n  const asideContent = (\n    <aside\n      className={classNames(className, `${prefix}-aside`, {\n        [`${prefix}-aside_affixed`]: affixed && headerAffixed,\n        [`${prefix}-aside_affixed_alone`]: affixed && !headerAffixed,\n        [`${prefix}-aside_collapsed`]: collapsed,\n        [`${prefix}-aside_collapsible`]: collapsible,\n      })}\n      {...otherProps}\n      ref={asideRef}\n    >\n      <div className={classNames(`${prefix}-asideInner`)}>\n        {collapsible && (\n          <div\n            className={`${prefix}-asideBackButton`}\n            onClick={() => handleCollapseChange(true)}\n            role=\"none\"\n          >\n            <Button theme=\"light\" leftIcon=\"arrow-back\" />\n          </div>\n        )}\n        <div className={`${prefix}-asideContent`} ref={asideContentRef}>\n          {children}\n        </div>\n      </div>\n      <div\n        className={`${prefix}-asideMask`}\n        onClick={() => handleCollapseChange(true)}\n        role=\"none\"\n      />\n    </aside>\n  )\n  if (affixed && !Aside.stickable) {\n    return <Affix offsetTop={offsetTop}>{asideContent}</Affix>\n  }\n  return asideContent\n}\n\nAside.stickable = detectStickySupport()\n\nAside.propTypes = {\n  /**\n   * 是否固定\n   */\n  affixed: PropTypes.bool,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 是否收起\n   */\n  collapsed: PropTypes.bool,\n  /**\n   * 是否支持收起\n   */\n  collapsible: PropTypes.bool,\n  /**\n   * 收起状态变化时的 handler\n   */\n  onCollapseChange: PropTypes.func,\n}\n\nAside.defaultProps = {\n  affixed: false,\n  children: \"\",\n  className: undefined,\n  collapsed: false,\n  collapsible: false,\n  onCollapseChange: () => {},\n}\n\nexport default Aside\n"],"mappings":"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"}