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>
133 lines (112 loc) • 15.9 kB
JavaScript
var _excluded = ["affixed", "children", "className", "collapsed", "collapsible", "onCollapseChange"];
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; }
import React, { useContext, useEffect, useRef } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";
import Button from "../button";
import Affix from "../affix";
import { detectStickySupport } from "../_util/detectStickySupport";
import { preventOuterScroll } from "../_util/preventOuterScroll";
import { LayoutContext } from "./Context";
import "./style";
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 = useContext(LayoutContext),
headerAffixed = _useContext.headerAffixed;
var asideRef = useRef(null);
var asideContentRef = 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);
}
};
useEffect(function () {
setTimeout(bindScrollEvent, 0);
if (asideContentRef !== null && asideContentRef !== void 0 && asideContentRef.current) {
asideContentRef.current.addEventListener("wheel", preventOuterScroll, {
passive: false
});
}
return function () {
window.removeEventListener("scroll", handleScroll);
};
}, []);
var offsetTop;
if (affixed && headerAffixed) {
offsetTop = 72;
}
if (affixed && !headerAffixed) {
offsetTop = 0;
}
var asideContent = React.createElement("aside", _extends({
className: classNames(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.createElement("div", {
className: classNames("".concat(prefix, "-asideInner"))
}, collapsible && React.createElement("div", {
className: "".concat(prefix, "-asideBackButton"),
onClick: function onClick() {
return handleCollapseChange(true);
},
role: "none"
}, React.createElement(Button, {
theme: "light",
leftIcon: "arrow-back"
})), React.createElement("div", {
className: "".concat(prefix, "-asideContent"),
ref: asideContentRef
}, children)), React.createElement("div", {
className: "".concat(prefix, "-asideMask"),
onClick: function onClick() {
return handleCollapseChange(true);
},
role: "none"
}));
if (affixed && !Aside.stickable) {
return React.createElement(Affix, {
offsetTop: offsetTop
}, asideContent);
}
return asideContent;
};
Aside.stickable = detectStickySupport();
Aside.propTypes = {
affixed: PropTypes.bool,
children: PropTypes.node,
className: PropTypes.string,
collapsed: PropTypes.bool,
collapsible: PropTypes.bool,
onCollapseChange: PropTypes.func
};
Aside.defaultProps = {
affixed: false,
children: "",
className: undefined,
collapsed: false,
collapsible: false,
onCollapseChange: function onCollapseChange() {}
};
export default Aside;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","useEffect","useRef","PropTypes","classNames","Button","Affix","detectStickySupport","preventOuterScroll","LayoutContext","prefix","Aside","affixed","children","className","collapsed","collapsible","onCollapseChange","otherProps","headerAffixed","asideRef","asideContentRef","handleScroll","current","style","maxHeight","scrollY","handleCollapseChange","bool","bindScrollEvent","window","addEventListener","setTimeout","passive","removeEventListener","offsetTop","asideContent","stickable","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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"}