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>

246 lines 36 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 = ["afterClose", "bodyScrollable", "children", "className", "destroyAfterClose", "escapeKeyClosable", "headerContent", "headerElement", "headerStyle", "maskClassName", "maskClosable", "maskStyle", "maskVisible", "maskMotionName", "getMotionName", "onClose", "placement", "size", "style", "visible", "zIndex"]; 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 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 _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 _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } 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, { useEffect, useMemo, useRef, useState } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import CSSMotion from "rc-motion"; import getScrollBarSize from "rc-util/lib/getScrollBarSize"; import Button from "../button"; import Portal from "../portal"; import "./style"; var prefix = "adui-drawer"; var Drawer = function Drawer(_ref) { var afterClose = _ref.afterClose, bodyScrollable = _ref.bodyScrollable, children = _ref.children, className = _ref.className, destroyAfterClose = _ref.destroyAfterClose, escapeKeyClosable = _ref.escapeKeyClosable, headerContent = _ref.headerContent, headerElement = _ref.headerElement, headerStyle = _ref.headerStyle, maskClassName = _ref.maskClassName, maskClosable = _ref.maskClosable, maskStyle = _ref.maskStyle, maskVisible = _ref.maskVisible, maskMotionName = _ref.maskMotionName, _ref$getMotionName = _ref.getMotionName, getMotionName = _ref$getMotionName === void 0 ? function () { return ""; } : _ref$getMotionName, onClose = _ref.onClose, _ref$placement = _ref.placement, placement = _ref$placement === void 0 ? "right" : _ref$placement, size = _ref.size, style = _ref.style, visible = _ref.visible, zIndexProp = _ref.zIndex, otherProps = _objectWithoutProperties(_ref, _excluded); var zIndex = zIndexProp; var _useState = useState(visible), _useState2 = _slicedToArray(_useState, 2), hasEverOpened = _useState2[0], setHasEverOpened = _useState2[1]; var wrapperRef = useRef(null); var scrollbarWidth = useMemo(getScrollBarSize, []); var bodyIsOverflowing = false; var setScrollbarPadding = function setScrollbarPadding(_ref2) { var bodyScrollableParam = _ref2.bodyScrollable; var _window = window, innerWidth = _window.innerWidth; bodyIsOverflowing = document.body.clientWidth < innerWidth; if (bodyIsOverflowing && !document.body.style.paddingRight) { if (scrollbarWidth !== undefined) { document.body.style.paddingRight = "".concat(scrollbarWidth, "px"); } } if (bodyScrollableParam) { document.body.classList.add("adui-scrollbar-hidden"); } else { document.body.style.overflow = "hidden"; } }; var resetScrollbarPadding = function resetScrollbarPadding() { document.body.classList.remove("adui-scrollbar-hidden"); document.body.style.overflow = ""; document.body.style.paddingRight = ""; }; useEffect(function () { if (visible && wrapperRef.current) { setScrollbarPadding({ bodyScrollable: bodyScrollable }); } }, [visible]); useEffect(function () { return resetScrollbarPadding; }, []); if (visible && !hasEverOpened) { setHasEverOpened(true); } var handleChildrenMount = function handleChildrenMount() { if (visible) { setScrollbarPadding({ bodyScrollable: bodyScrollable }); } }; var handleClose = function handleClose() { if (onClose) { onClose(); } }; var handleKeyDown = function handleKeyDown(e) { if (escapeKeyClosable && e.key === "Escape") { e.stopPropagation(); handleClose(); } }; var handleEnter = function handleEnter() { if (escapeKeyClosable && wrapperRef.current) { wrapperRef.current.focus(); } }; var handleLeave = function handleLeave() { if (wrapperRef.current) { wrapperRef.current.style.display = "none"; } resetScrollbarPadding(); if (afterClose) { afterClose(); } if (destroyAfterClose) { setHasEverOpened(false); } }; var classSet = classNames(className, "".concat(prefix, "-").concat(placement), "".concat(prefix, "-").concat(size), "".concat(prefix, "-inner")); var getComponent = function getComponent() { return React.createElement("div", { className: "".concat(prefix, "-wrapper"), ref: wrapperRef, style: { display: visible ? "block" : "", zIndex: zIndex }, tabIndex: 0, role: "none", onKeyDown: handleKeyDown }, React.createElement(CSSMotion, { motionName: maskMotionName || "".concat(prefix, "-mask"), visible: visible && maskVisible }, function (_ref3, ref) { var cls = _ref3.className; return React.createElement("div", { ref: ref, className: classNames("".concat(prefix, "-mask"), maskClassName, cls), role: "none", style: maskStyle, onClick: function onClick() { if (maskClosable) { handleClose(); } } }); }), React.createElement(CSSMotion, { onAppearStart: handleEnter, onEnterStart: handleEnter, onLeaveEnd: handleLeave, motionName: getMotionName(placement) || "".concat(prefix, "-").concat(placement), visible: visible }, function (_ref4, ref) { var cls = _ref4.className; return React.createElement("div", _extends({ ref: ref, className: classNames(classSet, cls), style: _objectSpread({ margin: "auto", zIndex: 1 }, style) }, otherProps), headerElement === null ? null : headerElement || React.createElement("div", { className: "".concat(prefix, "-header"), style: headerStyle }, React.createElement(Button, { theme: "light", size: "medium", leftIcon: "cancel", className: "".concat(prefix, "-header-close"), onClick: function onClick() { return handleClose(); } }), React.createElement("i", { className: "".concat(prefix, "-header-divider") }), headerContent && React.createElement("div", { className: "".concat(prefix, "-header-content") }, headerContent)), React.createElement("div", { className: "".concat(prefix, "-body") }, children)); })); }; if (!hasEverOpened) { return null; } return React.createElement(Portal, { onChildrenMount: handleChildrenMount }, getComponent()); }; Drawer.displayName = "Drawer"; Drawer.propTypes = { afterClose: PropTypes.func, bodyScrollable: PropTypes.bool, children: PropTypes.node, className: PropTypes.string, destroyAfterClose: PropTypes.bool, escapeKeyClosable: PropTypes.bool, headerContent: PropTypes.node, headerElement: PropTypes.node, headerStyle: PropTypes.object, maskClassName: PropTypes.string, maskClosable: PropTypes.bool, maskStyle: PropTypes.object, maskVisible: PropTypes.bool, onClose: PropTypes.func, placement: PropTypes.oneOf(["top", "right", "bottom", "left"]), size: PropTypes.oneOf(["mini", "small", "medium", "large"]), visible: PropTypes.bool, zIndex: PropTypes.any }; Drawer.defaultProps = { afterClose: null, bodyScrollable: true, children: null, className: undefined, destroyAfterClose: false, escapeKeyClosable: true, headerContent: null, headerElement: undefined, headerStyle: {}, maskClassName: undefined, maskClosable: false, maskStyle: {}, maskVisible: false, maskMotionName: "", getMotionName: function getMotionName() { return ""; }, onClose: null, placement: "right", size: "medium", visible: false, zIndex: "var(--z-index-dialog)" }; export default Drawer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useEffect","useMemo","useRef","useState","PropTypes","classNames","CSSMotion","getScrollBarSize","Button","Portal","prefix","Drawer","_ref","afterClose","bodyScrollable","children","className","destroyAfterClose","escapeKeyClosable","headerContent","headerElement","headerStyle","maskClassName","maskClosable","maskStyle","maskVisible","maskMotionName","_ref$getMotionName","getMotionName","onClose","_ref$placement","placement","size","style","visible","zIndexProp","zIndex","otherProps","_objectWithoutProperties","_excluded","_useState","_useState2","_slicedToArray","hasEverOpened","setHasEverOpened","wrapperRef","scrollbarWidth","bodyIsOverflowing","setScrollbarPadding","_ref2","bodyScrollableParam","_window","window","innerWidth","document","body","clientWidth","paddingRight","undefined","concat","classList","add","overflow","resetScrollbarPadding","remove","current","handleChildrenMount","handleClose","handleKeyDown","e","key","stopPropagation","handleEnter","focus","handleLeave","display","classSet","getComponent","createElement","ref","tabIndex","role","onKeyDown","motionName","_ref3","cls","onClick","onAppearStart","onEnterStart","onLeaveEnd","_ref4","_extends","_objectSpread","margin","theme","leftIcon","onChildrenMount","displayName","propTypes","func","bool","node","string","object","oneOf","any","defaultProps"],"sources":["../../components/drawer/Drawer.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport CSSMotion from \"rc-motion\"\nimport getScrollBarSize from \"rc-util/lib/getScrollBarSize\"\nimport Button from \"../button\"\nimport Portal from \"../portal\"\nimport \"./style\"\n\nconst prefix = \"adui-drawer\"\n\ntype TPlacement = \"top\" | \"right\" | \"bottom\" | \"left\"\n\nexport interface IDrawerProps {\n  [key: string]: any\n  /**\n   * 关闭后（transition 结束后）的 handler\n   */\n  afterClose?: (() => void) | null\n  /**\n   * visible 时页面能否滚动\n   */\n  bodyScrollable?: boolean\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名，注意 Drawer 所有的属性会附加到内部的内容元素上，而不是包含 mask 的最外层元素\n   */\n  className?: string\n  /**\n   * 是否每次 visible: false 都销毁 dom\n   */\n  destroyAfterClose?: boolean\n  /**\n   * 是否支持 ESC 关闭\n   */\n  escapeKeyClosable?: boolean\n  /**\n   * header 标题栏内部的内容\n   */\n  headerContent?: React.ReactNode\n  /**\n   * 完全自定义 header 的内容\n   */\n  headerElement?: React.ReactNode\n  /**\n   * 设置 header 样式\n   */\n  headerStyle?: React.CSSProperties\n  /**\n   * mask 的类名\n   */\n  maskClassName?: string\n  /**\n   * 点击 mask 是否触发 cancel 事件\n   */\n  maskClosable?: boolean\n  /**\n   * mask 的样式\n   */\n  maskStyle?: React.CSSProperties\n  /**\n   * 是否显示 mask\n   */\n  maskVisible?: boolean\n  /**\n   * 设置 mask 的 CSS Motion name\n   */\n  maskMotionName?: string\n  /**\n   * 设置 dialog 的 CSS Motion name\n   */\n  getMotionName?: (placement: TPlacement) => string\n  /**\n   * 关闭时的 handler\n   */\n  onClose?: (() => void) | null\n  /**\n   * 位置\n   */\n  placement?: TPlacement\n  /**\n   * 尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 外部控制：是否显示\n   */\n  visible?: boolean\n  /**\n   * 设置 z-index 层级，默认为 var(--z-index-dialog)\n   */\n  zIndex?: React.ReactNode\n}\n\n/**\n * 浮层覆盖在页面内容上，并固定在屏幕的边缘。\n */\nconst Drawer: React.FC<IDrawerProps> = ({\n  afterClose,\n  bodyScrollable,\n  children,\n  className,\n  destroyAfterClose,\n  escapeKeyClosable,\n  headerContent,\n  headerElement,\n  headerStyle,\n  maskClassName,\n  maskClosable,\n  maskStyle,\n  maskVisible,\n  maskMotionName,\n  getMotionName = () => \"\",\n  onClose,\n  placement = \"right\",\n  size,\n  style,\n  visible,\n  zIndex: zIndexProp,\n  ...otherProps\n}: IDrawerProps) => {\n  const zIndex = zIndexProp as React.CSSProperties[\"zIndex\"]\n  const [hasEverOpened, setHasEverOpened] = useState(visible)\n  const wrapperRef = useRef<HTMLDivElement>(null)\n\n  const scrollbarWidth = useMemo(getScrollBarSize, [])\n  let bodyIsOverflowing = false\n\n  const setScrollbarPadding = ({\n    bodyScrollable: bodyScrollableParam,\n  }: {\n    bodyScrollable?: boolean\n  }) => {\n    const { innerWidth } = window\n    bodyIsOverflowing = document.body.clientWidth < innerWidth\n    if (bodyIsOverflowing && !document.body.style.paddingRight) {\n      if (scrollbarWidth !== undefined) {\n        document.body.style.paddingRight = `${scrollbarWidth}px`\n      }\n    }\n\n    if (bodyScrollableParam) {\n      document.body.classList.add(\"adui-scrollbar-hidden\")\n    } else {\n      document.body.style.overflow = \"hidden\"\n    }\n  }\n\n  const resetScrollbarPadding = () => {\n    document.body.classList.remove(\"adui-scrollbar-hidden\")\n    document.body.style.overflow = \"\"\n    document.body.style.paddingRight = \"\"\n  }\n\n  useEffect(() => {\n    if (visible && wrapperRef.current) {\n      setScrollbarPadding({ bodyScrollable })\n    }\n  }, [visible])\n\n  useEffect(() => resetScrollbarPadding, [])\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (visible && !hasEverOpened) {\n    setHasEverOpened(true)\n  }\n\n  const handleChildrenMount = () => {\n    if (visible) {\n      setScrollbarPadding({ bodyScrollable })\n    }\n  }\n\n  const handleClose = () => {\n    if (onClose) {\n      onClose()\n    }\n  }\n\n  const handleKeyDown = (e: React.KeyboardEvent) => {\n    if (escapeKeyClosable && e.key === \"Escape\") {\n      e.stopPropagation()\n      handleClose()\n    }\n  }\n\n  const handleEnter = () => {\n    if (escapeKeyClosable && wrapperRef.current) {\n      wrapperRef.current.focus()\n    }\n  }\n\n  const handleLeave = () => {\n    if (wrapperRef.current) {\n      wrapperRef.current.style.display = \"none\"\n    }\n    resetScrollbarPadding()\n\n    if (afterClose) {\n      afterClose()\n    }\n\n    if (destroyAfterClose) {\n      setHasEverOpened(false)\n    }\n  }\n\n  const classSet = classNames(\n    className,\n    `${prefix}-${placement}`,\n    `${prefix}-${size}`,\n    `${prefix}-inner`\n  )\n\n  const getComponent = () => {\n    return (\n      <div\n        className={`${prefix}-wrapper`}\n        ref={wrapperRef}\n        style={{\n          display: visible ? \"block\" : \"\",\n          zIndex,\n        }}\n        tabIndex={0}\n        role=\"none\"\n        onKeyDown={handleKeyDown}\n      >\n        <CSSMotion\n          motionName={maskMotionName || `${prefix}-mask`}\n          visible={visible && maskVisible}\n        >\n          {({ className: cls }, ref) => (\n            <div\n              ref={ref}\n              className={classNames(`${prefix}-mask`, maskClassName, cls)}\n              role=\"none\"\n              style={maskStyle}\n              onClick={() => {\n                if (maskClosable) {\n                  handleClose()\n                }\n              }}\n            />\n          )}\n        </CSSMotion>\n        <CSSMotion\n          onAppearStart={handleEnter}\n          onEnterStart={handleEnter}\n          onLeaveEnd={handleLeave}\n          motionName={getMotionName(placement) || `${prefix}-${placement}`}\n          visible={visible}\n        >\n          {({ className: cls }, ref) => (\n            <div\n              ref={ref}\n              className={classNames(classSet, cls)}\n              style={{\n                margin: \"auto\",\n                zIndex: 1,\n                ...style,\n              }}\n              {...otherProps}\n            >\n              {headerElement === null\n                ? null\n                : headerElement || (\n                    <div className={`${prefix}-header`} style={headerStyle}>\n                      <Button\n                        theme=\"light\"\n                        size=\"medium\"\n                        leftIcon=\"cancel\"\n                        className={`${prefix}-header-close`}\n                        onClick={() => handleClose()}\n                      />\n                      <i className={`${prefix}-header-divider`} />\n                      {headerContent && (\n                        <div className={`${prefix}-header-content`}>\n                          {headerContent}\n                        </div>\n                      )}\n                    </div>\n                  )}\n              <div className={`${prefix}-body`}>{children}</div>\n            </div>\n          )}\n        </CSSMotion>\n      </div>\n    )\n  }\n\n  if (!hasEverOpened) {\n    return null\n  }\n\n  return <Portal onChildrenMount={handleChildrenMount}>{getComponent()}</Portal>\n}\n\nDrawer.displayName = \"Drawer\"\n\nDrawer.propTypes = {\n  /**\n   * 关闭后（transition 结束后）的 handler\n   */\n  afterClose: PropTypes.func,\n  /**\n   * visible 时页面能否滚动\n   */\n  bodyScrollable: PropTypes.bool,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名，注意 Dialog 所有的属性会附加到内部的内容元素上，而不是包含 mask 的最外层元素\n   */\n  className: PropTypes.string,\n  /**\n   * 是否每次 visible: false 都销毁 dom\n   */\n  destroyAfterClose: PropTypes.bool,\n  /**\n   * 是否支持 ESC 关闭\n   */\n  escapeKeyClosable: PropTypes.bool,\n  /**\n   * header 标题栏内部的内容\n   */\n  headerContent: PropTypes.node,\n  /**\n   * 完全自定义 header 的内容\n   */\n  headerElement: PropTypes.node,\n  /**\n   * 设置 header 样式\n   */\n  headerStyle: PropTypes.object,\n  /**\n   * mask 的类名\n   */\n  maskClassName: PropTypes.string,\n  /**\n   * 点击 mask 是否触发 cancel 事件\n   */\n  maskClosable: PropTypes.bool,\n  /**\n   * mask 的样式\n   */\n  maskStyle: PropTypes.object,\n  /**\n   * 是否显示 mask\n   */\n  maskVisible: PropTypes.bool,\n  /**\n   * 关闭时的 handler\n   */\n  onClose: PropTypes.func,\n  /**\n   * 位置\n   */\n  placement: PropTypes.oneOf([\"top\", \"right\", \"bottom\", \"left\"]),\n  /**\n   * 尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 外部控制：是否显示\n   */\n  visible: PropTypes.bool,\n  /**\n   * 设置 z-index 层级，默认为 var(--z-index-dialog)\n   */\n  zIndex: PropTypes.any,\n}\n\nDrawer.defaultProps = {\n  afterClose: null,\n  bodyScrollable: true,\n  children: null,\n  className: undefined,\n  destroyAfterClose: false,\n  escapeKeyClosable: true,\n  headerContent: null,\n  headerElement: undefined,\n  headerStyle: {},\n  maskClassName: undefined,\n  maskClosable: false,\n  maskStyle: {},\n  maskVisible: false,\n  maskMotionName: \"\",\n  getMotionName: () => \"\",\n  onClose: null,\n  placement: \"right\",\n  size: \"medium\",\n  visible: false,\n  zIndex: \"var(--z-index-dialog)\",\n}\n\nexport default Drawer\n"],"mappings":"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","ignoreList":[]}