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>
303 lines (253 loc) • 36.5 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 _rcMotion = _interopRequireDefault(require("rc-motion"));
var _getScrollBarSize = _interopRequireDefault(require("rc-util/lib/getScrollBarSize"));
var _button = _interopRequireDefault(require("../button"));
var _portal = _interopRequireDefault(require("../portal"));
require("./style");
var _excluded = ["afterClose", "bodyScrollable", "children", "className", "destroyAfterClose", "escapeKeyClosable", "headerContent", "headerElement", "headerStyle", "maskClassName", "maskClosable", "maskStyle", "maskVisible", "maskMotionName", "getMotionName", "onClose", "placement", "size", "style", "visible", "zIndex"];
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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
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 _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _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(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
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-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 = (0, _react.useState)(visible),
_useState2 = _slicedToArray(_useState, 2),
hasEverOpened = _useState2[0],
setHasEverOpened = _useState2[1];
var wrapperRef = (0, _react.useRef)(null);
var scrollbarWidth = (0, _react.useMemo)(_getScrollBarSize["default"], []);
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 = "";
};
(0, _react.useEffect)(function () {
if (visible && wrapperRef.current) {
setScrollbarPadding({
bodyScrollable: bodyScrollable
});
}
}, [visible]);
(0, _react.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 = (0, _classnames["default"])(className, "".concat(prefix, "-").concat(placement), "".concat(prefix, "-").concat(size), "".concat(prefix, "-inner"));
var getComponent = function getComponent() {
return _react["default"].createElement("div", {
className: "".concat(prefix, "-wrapper"),
ref: wrapperRef,
style: {
display: visible ? "block" : "",
zIndex: zIndex
},
tabIndex: 0,
role: "none",
onKeyDown: handleKeyDown
}, _react["default"].createElement(_rcMotion["default"], {
motionName: maskMotionName || "".concat(prefix, "-mask"),
visible: visible && maskVisible
}, function (_ref3, ref) {
var cls = _ref3.className;
return _react["default"].createElement("div", {
ref: ref,
className: (0, _classnames["default"])("".concat(prefix, "-mask"), maskClassName, cls),
role: "none",
style: maskStyle,
onClick: function onClick() {
if (maskClosable) {
handleClose();
}
}
});
}), _react["default"].createElement(_rcMotion["default"], {
onAppearStart: handleEnter,
onEnterStart: handleEnter,
onLeaveEnd: handleLeave,
motionName: getMotionName(placement) || "".concat(prefix, "-").concat(placement),
visible: visible
}, function (_ref4, ref) {
var cls = _ref4.className;
return _react["default"].createElement("div", _extends({
ref: ref,
className: (0, _classnames["default"])(classSet, cls),
style: _objectSpread({
margin: "auto",
zIndex: 1
}, style)
}, otherProps), headerElement === null ? null : headerElement || _react["default"].createElement("div", {
className: "".concat(prefix, "-header"),
style: headerStyle
}, _react["default"].createElement(_button["default"], {
theme: "light",
size: "medium",
leftIcon: "cancel",
className: "".concat(prefix, "-header-close"),
onClick: function onClick() {
return handleClose();
}
}), _react["default"].createElement("i", {
className: "".concat(prefix, "-header-divider")
}), headerContent && _react["default"].createElement("div", {
className: "".concat(prefix, "-header-content")
}, headerContent)), _react["default"].createElement("div", {
className: "".concat(prefix, "-body")
}, children));
}));
};
if (!hasEverOpened) {
return null;
}
return _react["default"].createElement(_portal["default"], {
onChildrenMount: handleChildrenMount
}, getComponent());
};
Drawer.displayName = "Drawer";
Drawer.propTypes = {
afterClose: _propTypes["default"].func,
bodyScrollable: _propTypes["default"].bool,
children: _propTypes["default"].node,
className: _propTypes["default"].string,
destroyAfterClose: _propTypes["default"].bool,
escapeKeyClosable: _propTypes["default"].bool,
headerContent: _propTypes["default"].node,
headerElement: _propTypes["default"].node,
headerStyle: _propTypes["default"].object,
maskClassName: _propTypes["default"].string,
maskClosable: _propTypes["default"].bool,
maskStyle: _propTypes["default"].object,
maskVisible: _propTypes["default"].bool,
onClose: _propTypes["default"].func,
placement: _propTypes["default"].oneOf(["top", "right", "bottom", "left"]),
size: _propTypes["default"].oneOf(["mini", "small", "medium", "large"]),
visible: _propTypes["default"].bool,
zIndex: _propTypes["default"].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)"
};
var _default = Drawer;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","Drawer","afterClose","bodyScrollable","children","className","destroyAfterClose","escapeKeyClosable","headerContent","headerElement","headerStyle","maskClassName","maskClosable","maskStyle","maskVisible","maskMotionName","getMotionName","onClose","placement","size","style","visible","zIndexProp","zIndex","otherProps","useState","hasEverOpened","setHasEverOpened","wrapperRef","useRef","scrollbarWidth","useMemo","getScrollBarSize","bodyIsOverflowing","setScrollbarPadding","bodyScrollableParam","window","innerWidth","document","body","clientWidth","paddingRight","undefined","classList","add","overflow","resetScrollbarPadding","remove","useEffect","current","handleChildrenMount","handleClose","handleKeyDown","e","key","stopPropagation","handleEnter","focus","handleLeave","display","classSet","classNames","getComponent","ref","cls","margin","displayName","propTypes","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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"}