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>
279 lines (243 loc) • 34.4 kB
JavaScript
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() { _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; }
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","afterClose","bodyScrollable","children","className","destroyAfterClose","escapeKeyClosable","headerContent","headerElement","headerStyle","maskClassName","maskClosable","maskStyle","maskVisible","maskMotionName","getMotionName","onClose","placement","size","style","visible","zIndexProp","zIndex","otherProps","hasEverOpened","setHasEverOpened","wrapperRef","scrollbarWidth","bodyIsOverflowing","setScrollbarPadding","bodyScrollableParam","window","innerWidth","document","body","clientWidth","paddingRight","undefined","classList","add","overflow","resetScrollbarPadding","remove","current","handleChildrenMount","handleClose","handleKeyDown","e","key","stopPropagation","handleEnter","focus","handleLeave","display","classSet","getComponent","ref","cls","margin","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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"}