123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- "use strict";
- "use client";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var React = _interopRequireWildcard(require("react"));
- var _LeftOutlined = _interopRequireDefault(require("@ant-design/icons/LeftOutlined"));
- var _RightOutlined = _interopRequireDefault(require("@ant-design/icons/RightOutlined"));
- var _classnames = _interopRequireDefault(require("classnames"));
- var _rcDropdown = _interopRequireDefault(require("rc-dropdown"));
- var _useEvent = _interopRequireDefault(require("rc-util/lib/hooks/useEvent"));
- var _useMergedState = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
- var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
- var _useZIndex = require("../_util/hooks/useZIndex");
- var _isPrimitive = _interopRequireDefault(require("../_util/isPrimitive"));
- var _placements = _interopRequireDefault(require("../_util/placements"));
- var _PurePanel = _interopRequireDefault(require("../_util/PurePanel"));
- var _reactNode = require("../_util/reactNode");
- var _warning = require("../_util/warning");
- var _zindexContext = _interopRequireDefault(require("../_util/zindexContext"));
- var _configProvider = require("../config-provider");
- var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls"));
- var _menu = _interopRequireDefault(require("../menu"));
- var _OverrideContext = require("../menu/OverrideContext");
- var _internal = require("../theme/internal");
- var _style = _interopRequireDefault(require("./style"));
- const _Placements = ['topLeft', 'topCenter', 'topRight', 'bottomLeft', 'bottomCenter', 'bottomRight', 'top', 'bottom'];
- const Dropdown = props => {
- var _a;
- const {
- menu,
- arrow,
- prefixCls: customizePrefixCls,
- children,
- trigger,
- disabled,
- dropdownRender,
- popupRender,
- getPopupContainer,
- overlayClassName,
- rootClassName,
- overlayStyle,
- open,
- onOpenChange,
- // Deprecated
- visible,
- onVisibleChange,
- mouseEnterDelay = 0.15,
- mouseLeaveDelay = 0.1,
- autoAdjustOverflow = true,
- placement = '',
- overlay,
- transitionName,
- destroyOnHidden,
- destroyPopupOnHide
- } = props;
- const {
- getPopupContainer: getContextPopupContainer,
- getPrefixCls,
- direction,
- dropdown
- } = React.useContext(_configProvider.ConfigContext);
- const mergedPopupRender = popupRender || dropdownRender;
- // Warning for deprecated usage
- const warning = (0, _warning.devUseWarning)('Dropdown');
- if (process.env.NODE_ENV !== 'production') {
- const deprecatedProps = {
- visible: 'open',
- onVisibleChange: 'onOpenChange',
- overlay: 'menu',
- dropdownRender: 'popupRender',
- destroyPopupOnHide: 'destroyOnHidden'
- };
- Object.entries(deprecatedProps).forEach(([deprecatedName, newName]) => {
- warning.deprecated(!(deprecatedName in props), deprecatedName, newName);
- });
- if (placement.includes('Center')) {
- warning.deprecated(!placement.includes('Center'), `placement: ${placement}`, `placement: ${placement.slice(0, placement.indexOf('Center'))}`);
- }
- }
- const memoTransitionName = React.useMemo(() => {
- const rootPrefixCls = getPrefixCls();
- if (transitionName !== undefined) {
- return transitionName;
- }
- if (placement.includes('top')) {
- return `${rootPrefixCls}-slide-down`;
- }
- return `${rootPrefixCls}-slide-up`;
- }, [getPrefixCls, placement, transitionName]);
- const memoPlacement = React.useMemo(() => {
- if (!placement) {
- return direction === 'rtl' ? 'bottomRight' : 'bottomLeft';
- }
- if (placement.includes('Center')) {
- return placement.slice(0, placement.indexOf('Center'));
- }
- return placement;
- }, [placement, direction]);
- const prefixCls = getPrefixCls('dropdown', customizePrefixCls);
- const rootCls = (0, _useCSSVarCls.default)(prefixCls);
- const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
- const [, token] = (0, _internal.useToken)();
- const child = React.Children.only((0, _isPrimitive.default)(children) ? /*#__PURE__*/React.createElement("span", null, children) : children);
- const popupTrigger = (0, _reactNode.cloneElement)(child, {
- className: (0, _classnames.default)(`${prefixCls}-trigger`, {
- [`${prefixCls}-rtl`]: direction === 'rtl'
- }, child.props.className),
- disabled: (_a = child.props.disabled) !== null && _a !== void 0 ? _a : disabled
- });
- const triggerActions = disabled ? [] : trigger;
- const alignPoint = !!(triggerActions === null || triggerActions === void 0 ? void 0 : triggerActions.includes('contextMenu'));
- // =========================== Open ============================
- const [mergedOpen, setOpen] = (0, _useMergedState.default)(false, {
- value: open !== null && open !== void 0 ? open : visible
- });
- const onInnerOpenChange = (0, _useEvent.default)(nextOpen => {
- onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(nextOpen, {
- source: 'trigger'
- });
- onVisibleChange === null || onVisibleChange === void 0 ? void 0 : onVisibleChange(nextOpen);
- setOpen(nextOpen);
- });
- // =========================== Overlay ============================
- const overlayClassNameCustomized = (0, _classnames.default)(overlayClassName, rootClassName, hashId, cssVarCls, rootCls, dropdown === null || dropdown === void 0 ? void 0 : dropdown.className, {
- [`${prefixCls}-rtl`]: direction === 'rtl'
- });
- const builtinPlacements = (0, _placements.default)({
- arrowPointAtCenter: typeof arrow === 'object' && arrow.pointAtCenter,
- autoAdjustOverflow,
- offset: token.marginXXS,
- arrowWidth: arrow ? token.sizePopupArrow : 0,
- borderRadius: token.borderRadius
- });
- const onMenuClick = (0, _useEvent.default)(() => {
- if ((menu === null || menu === void 0 ? void 0 : menu.selectable) && (menu === null || menu === void 0 ? void 0 : menu.multiple)) {
- return;
- }
- onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(false, {
- source: 'menu'
- });
- setOpen(false);
- });
- const renderOverlay = () => {
- // rc-dropdown already can process the function of overlay, but we have check logic here.
- // So we need render the element to check and pass back to rc-dropdown.
- let overlayNode;
- if (menu === null || menu === void 0 ? void 0 : menu.items) {
- overlayNode = /*#__PURE__*/React.createElement(_menu.default, Object.assign({}, menu));
- } else if (typeof overlay === 'function') {
- overlayNode = overlay();
- } else {
- overlayNode = overlay;
- }
- if (mergedPopupRender) {
- overlayNode = mergedPopupRender(overlayNode);
- }
- overlayNode = React.Children.only(typeof overlayNode === 'string' ? /*#__PURE__*/React.createElement("span", null, overlayNode) : overlayNode);
- return /*#__PURE__*/React.createElement(_OverrideContext.OverrideProvider, {
- prefixCls: `${prefixCls}-menu`,
- rootClassName: (0, _classnames.default)(cssVarCls, rootCls),
- expandIcon: /*#__PURE__*/React.createElement("span", {
- className: `${prefixCls}-menu-submenu-arrow`
- }, direction === 'rtl' ? (/*#__PURE__*/React.createElement(_LeftOutlined.default, {
- className: `${prefixCls}-menu-submenu-arrow-icon`
- })) : (/*#__PURE__*/React.createElement(_RightOutlined.default, {
- className: `${prefixCls}-menu-submenu-arrow-icon`
- }))),
- mode: "vertical",
- selectable: false,
- onClick: onMenuClick,
- validator: ({
- mode
- }) => {
- // Warning if use other mode
- process.env.NODE_ENV !== "production" ? warning(!mode || mode === 'vertical', 'usage', `mode="${mode}" is not supported for Dropdown's Menu.`) : void 0;
- }
- }, overlayNode);
- };
- // =========================== zIndex ============================
- const [zIndex, contextZIndex] = (0, _useZIndex.useZIndex)('Dropdown', overlayStyle === null || overlayStyle === void 0 ? void 0 : overlayStyle.zIndex);
- // ============================ Render ============================
- let renderNode = /*#__PURE__*/React.createElement(_rcDropdown.default, Object.assign({
- alignPoint: alignPoint
- }, (0, _omit.default)(props, ['rootClassName']), {
- mouseEnterDelay: mouseEnterDelay,
- mouseLeaveDelay: mouseLeaveDelay,
- visible: mergedOpen,
- builtinPlacements: builtinPlacements,
- arrow: !!arrow,
- overlayClassName: overlayClassNameCustomized,
- prefixCls: prefixCls,
- getPopupContainer: getPopupContainer || getContextPopupContainer,
- transitionName: memoTransitionName,
- trigger: triggerActions,
- overlay: renderOverlay,
- placement: memoPlacement,
- onVisibleChange: onInnerOpenChange,
- overlayStyle: Object.assign(Object.assign(Object.assign({}, dropdown === null || dropdown === void 0 ? void 0 : dropdown.style), overlayStyle), {
- zIndex
- }),
- autoDestroy: destroyOnHidden !== null && destroyOnHidden !== void 0 ? destroyOnHidden : destroyPopupOnHide
- }), popupTrigger);
- if (zIndex) {
- renderNode = /*#__PURE__*/React.createElement(_zindexContext.default.Provider, {
- value: contextZIndex
- }, renderNode);
- }
- return wrapCSSVar(renderNode);
- };
- // We don't care debug panel
- const PurePanel = (0, _PurePanel.default)(Dropdown, 'align', undefined, 'dropdown', prefixCls => prefixCls);
- /* istanbul ignore next */
- const WrapPurePanel = props => (/*#__PURE__*/React.createElement(PurePanel, Object.assign({}, props), /*#__PURE__*/React.createElement("span", null)));
- Dropdown._InternalPanelDoNotUseOrYouWillBeFired = WrapPurePanel;
- if (process.env.NODE_ENV !== 'production') {
- Dropdown.displayName = 'Dropdown';
- }
- var _default = exports.default = Dropdown;
|