UNPKG

linkmore-design

Version:

🌈 🚀lm组件库。🚀

184 lines (180 loc) 6.25 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classnames = _interopRequireDefault(require("classnames")); var _rcDrawer = _interopRequireDefault(require("rc-drawer")); var React = _interopRequireWildcard(require("react")); var _configProvider = require("../config-provider"); var _context = require("../form/context"); var _motion = require("../_util/motion"); var _type = require("../_util/type"); var _warning = _interopRequireDefault(require("../_util/warning")); var _iconFont = _interopRequireDefault(require("../icon-font")); var _button = _interopRequireDefault(require("../button")); var _lodash = require("lodash"); const SizeTypes = (0, _type.tuple)('default', 'large', 'vlarge'); const defaultPushState = { distance: 120 }; function Drawer(props) { const { width, height, size = 'default', closable = true, mask = true, push = defaultPushState, closeIcon = /*#__PURE__*/React.createElement(_iconFont.default, { type: "icon-a-tongyongaRX" }), bodyStyle, drawerStyle, className, visible, open, children, style, title, headerStyle, onClose, footer, footerStyle, prefixCls: customizePrefixCls, getContainer: customizeGetContainer, extra, afterVisibleChange, afterOpenChange, drawerPadding = 24, ...rest } = props; const { getPopupContainer, getPrefixCls, direction } = React.useContext(_configProvider.ConfigContext); const prefixCls = getPrefixCls('drawer', customizePrefixCls); const getContainer = // 有可能为 false,所以不能直接判断 customizeGetContainer === undefined && getPopupContainer ? () => getPopupContainer(document.body) : customizeGetContainer; const closeIconNode = closable && /*#__PURE__*/React.createElement(_button.default, { type: "text", shape: "circle", onClick: onClose, "aria-label": "Close", className: `${prefixCls}-close` }, closeIcon); [['visible', 'open'], ['afterVisibleChange', 'afterOpenChange']].forEach(([deprecatedName, newName]) => { (0, _warning.default)(!(deprecatedName in props), 'Drawer', `\`${deprecatedName}\` is deprecated which will be removed in next major version, please use \`${newName}\` instead.`); }); function renderHeader() { if (!title && !closable) { return null; } return /*#__PURE__*/React.createElement("div", { className: (0, _classnames.default)(`${prefixCls}-header`, { [`${prefixCls}-header-close-only`]: closable && !title && !extra }), style: headerStyle }, /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-header-title` }, closeIconNode, title && /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-title` }, title)), extra && /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-extra` }, extra)); } function renderFooter() { if (!footer) { return null; } const footerClassName = `${prefixCls}-footer`; return /*#__PURE__*/React.createElement("div", { className: footerClassName, style: footerStyle }, footer); } const drawerClassName = (0, _classnames.default)({ 'no-mask': !mask, [`${prefixCls}-rtl`]: direction === 'rtl' }, 'lm_drawer', className); // ============================ Size ============================ const mergedWidth = React.useMemo(() => width ?? (size === 'large' ? 720 : size === 'vlarge' ? 1152 : 440), [width, size]); const mergedHeight = React.useMemo(() => height ?? (size === 'large' ? 720 : size === 'vlarge' ? 1152 : 440), [height, size]); // =========================== Motion =========================== const maskMotion = { motionName: (0, _motion.getTransitionName)(prefixCls, 'mask-motion'), motionAppear: true, motionEnter: true, motionLeave: true, motionDeadline: 500 }; const panelMotion = motionPlacement => ({ motionName: (0, _motion.getTransitionName)(prefixCls, `panel-motion-${motionPlacement}`), motionAppear: true, motionEnter: true, motionLeave: true, motionDeadline: 500 }); // =========================== Render =========================== return /*#__PURE__*/React.createElement(_context.NoFormStyle, { status: true, override: true }, /*#__PURE__*/React.createElement(_rcDrawer.default, (0, _extends2.default)({ prefixCls: prefixCls, onClose: onClose }, rest, { open: open || visible, mask: mask, push: size === 'vlarge' ? { distance: 0 } : push, width: mergedWidth, height: mergedHeight, rootClassName: drawerClassName, getContainer: getContainer, afterOpenChange: isOpen => { afterOpenChange?.(isOpen); afterVisibleChange?.(isOpen); }, maskMotion: maskMotion, motion: panelMotion, rootStyle: style, contentWrapperStyle: (0, _lodash.assign)({ ...rest.contentWrapperStyle }, drawerPadding ? rest.placement === 'top' ? { top: `${drawerPadding}px`, right: `${drawerPadding}px`, left: `${drawerPadding}px` } : rest.placement === 'left' ? { top: `${drawerPadding}px`, left: `${drawerPadding}px`, bottom: `${drawerPadding}px` } : rest.placement === 'bottom' ? { bottom: `${drawerPadding}px`, right: `${drawerPadding}px`, left: `${drawerPadding}px` } : { top: `${drawerPadding}px`, right: `${drawerPadding}px`, bottom: `${drawerPadding}px` } : {}) }), /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-wrapper-body`, style: { ...drawerStyle } }, renderHeader(), /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-body`, style: bodyStyle }, children), renderFooter()))); } if (process.env.NODE_ENV !== 'production') { Drawer.displayName = 'Drawer'; } var _default = Drawer; exports.default = _default;