SubMenu.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. "use client";
  2. import * as React from 'react';
  3. import classNames from 'classnames';
  4. import { SubMenu as RcSubMenu, useFullPath } from 'rc-menu';
  5. import omit from "rc-util/es/omit";
  6. import { useZIndex } from '../_util/hooks/useZIndex';
  7. import { cloneElement } from '../_util/reactNode';
  8. import MenuContext from './MenuContext';
  9. const SubMenu = props => {
  10. var _a;
  11. const {
  12. popupClassName,
  13. icon,
  14. title,
  15. theme: customTheme
  16. } = props;
  17. const context = React.useContext(MenuContext);
  18. const {
  19. prefixCls,
  20. inlineCollapsed,
  21. theme: contextTheme
  22. } = context;
  23. const parentPath = useFullPath();
  24. let titleNode;
  25. if (!icon) {
  26. titleNode = inlineCollapsed && !parentPath.length && title && typeof title === 'string' ? (/*#__PURE__*/React.createElement("div", {
  27. className: `${prefixCls}-inline-collapsed-noicon`
  28. }, title.charAt(0))) : (/*#__PURE__*/React.createElement("span", {
  29. className: `${prefixCls}-title-content`
  30. }, title));
  31. } else {
  32. // inline-collapsed.md demo 依赖 span 来隐藏文字,有 icon 属性,则内部包裹一个 span
  33. // ref: https://github.com/ant-design/ant-design/pull/23456
  34. const titleIsSpan = /*#__PURE__*/React.isValidElement(title) && title.type === 'span';
  35. titleNode = /*#__PURE__*/React.createElement(React.Fragment, null, cloneElement(icon, {
  36. className: classNames(/*#__PURE__*/React.isValidElement(icon) ? (_a = icon.props) === null || _a === void 0 ? void 0 : _a.className : undefined, `${prefixCls}-item-icon`)
  37. }), titleIsSpan ? title : /*#__PURE__*/React.createElement("span", {
  38. className: `${prefixCls}-title-content`
  39. }, title));
  40. }
  41. const contextValue = React.useMemo(() => Object.assign(Object.assign({}, context), {
  42. firstLevel: false
  43. }), [context]);
  44. // ============================ zIndex ============================
  45. const [zIndex] = useZIndex('Menu');
  46. return /*#__PURE__*/React.createElement(MenuContext.Provider, {
  47. value: contextValue
  48. }, /*#__PURE__*/React.createElement(RcSubMenu, Object.assign({}, omit(props, ['icon']), {
  49. title: titleNode,
  50. popupClassName: classNames(prefixCls, popupClassName, `${prefixCls}-${customTheme || contextTheme}`),
  51. popupStyle: Object.assign({
  52. zIndex
  53. }, props.popupStyle)
  54. })));
  55. };
  56. export default SubMenu;