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>

114 lines 16.9 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 _excluded = ["affixed", "children", "className", "collapsed", "collapsible", "onCollapseChange"]; 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 _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 _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 _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; } 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 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"), _defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "".concat(prefix, "-aside_affixed"), affixed && headerAffixed), "".concat(prefix, "-aside_affixed_alone"), affixed && !headerAffixed), "".concat(prefix, "-aside_collapsed"), collapsed), "".concat(prefix, "-aside_collapsible"), collapsible)) }, 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","_ref","affixed","children","className","collapsed","collapsible","onCollapseChange","otherProps","_objectWithoutProperties","_excluded","_useContext","headerAffixed","asideRef","asideContentRef","handleScroll","current","style","maxHeight","scrollY","concat","handleCollapseChange","bool","bindScrollEvent","window","addEventListener","setTimeout","passive","removeEventListener","offsetTop","asideContent","createElement","_extends","_defineProperty","ref","onClick","role","theme","leftIcon","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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","ignoreList":[]}