@sdata/web-vue 1.14.0 → 1.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (233) hide show
  1. package/dist/sd.css +364 -1
  2. package/dist/sd.min.css +1 -1
  3. package/es/_components/picker/input-range.vue.d.ts +2 -2
  4. package/es/_components/picker/input.vue.d.ts +1 -1
  5. package/es/_components/resize-trigger.vue_vue_type_script_lang.js +1 -1
  6. package/es/_components/select-view/select-view.d.ts +2 -2
  7. package/es/_components/virtual-list/virtual-list.vue.d.ts +3 -3
  8. package/es/_hooks/use-popup-manager.js +2 -4
  9. package/es/_utils/dom.d.ts +5 -2
  10. package/es/_utils/dom.js +1 -1
  11. package/es/anchor/anchor.vue.d.ts +2 -2
  12. package/es/anchor/index.d.ts +9 -9
  13. package/es/auto-complete/auto-complete.d.ts +3 -3
  14. package/es/auto-complete/index.d.ts +9 -9
  15. package/es/button/button.vue.d.ts +2 -2
  16. package/es/button/index.d.ts +6 -6
  17. package/es/calendar/calendar.d.ts +1 -1
  18. package/es/calendar/index.d.ts +3 -3
  19. package/es/card/card.d.ts +4 -4
  20. package/es/card/index.d.ts +9 -9
  21. package/es/carousel/carousel-arrow.vue.d.ts +1 -1
  22. package/es/carousel/carousel-indicator.vue.d.ts +1 -1
  23. package/es/carousel/carousel.d.ts +3 -3
  24. package/es/carousel/index.d.ts +9 -9
  25. package/es/cascader/base-cascader-panel.d.ts +1 -1
  26. package/es/cascader/cascader-search-panel.d.ts +1 -1
  27. package/es/cascader/cascader.vue.d.ts +14 -14
  28. package/es/checkbox/checkbox-group.d.ts +1 -1
  29. package/es/checkbox/index.d.ts +1 -1
  30. package/es/color-picker/color-picker.d.ts +5 -5
  31. package/es/color-picker/index.d.ts +15 -15
  32. package/es/color-picker/panel.d.ts +2 -2
  33. package/es/components.d.ts +1 -0
  34. package/es/config-provider/config-provider.vue.d.ts +8 -2
  35. package/es/config-provider/config-provider.vue_vue_type_script_lang.js +6 -0
  36. package/es/config-provider/context.d.ts +3 -0
  37. package/es/config-provider/index.d.ts +13 -3
  38. package/es/cropper/cropper.vue.d.ts +1 -1
  39. package/es/cropper/index.d.ts +3 -3
  40. package/es/date-picker/index.d.ts +94 -94
  41. package/es/date-picker/panels/date/index.vue.d.ts +15 -15
  42. package/es/date-picker/panels/footer.vue.d.ts +15 -15
  43. package/es/date-picker/panels/shortcuts.vue.d.ts +6 -6
  44. package/es/date-picker/panels/week/index.vue.d.ts +16 -16
  45. package/es/date-picker/picker-panel.vue.d.ts +54 -54
  46. package/es/date-picker/picker.vue.d.ts +87 -87
  47. package/es/date-picker/pickers/date-picker.d.ts +1 -1
  48. package/es/date-picker/pickers/week-picker.d.ts +1 -1
  49. package/es/date-picker/range-picker-panel.vue.d.ts +55 -55
  50. package/es/date-picker/range-picker.vue.d.ts +90 -90
  51. package/es/descriptions/descriptions.d.ts +1 -1
  52. package/es/descriptions/index.d.ts +3 -3
  53. package/es/drawer/drawer.vue.d.ts +11 -11
  54. package/es/drawer/index.d.ts +27 -27
  55. package/es/dropdown/dropdown-button.vue.d.ts +24 -24
  56. package/es/dropdown/dropdown-submenu.vue.d.ts +17 -17
  57. package/es/dropdown/dropdown.vue.d.ts +16 -16
  58. package/es/dropdown/index.d.ts +74 -74
  59. package/es/ellipsis/ellipsis.vue.d.ts +43 -43
  60. package/es/ellipsis/index.d.ts +182 -182
  61. package/es/ellipsis/performant-ellipsis.vue.d.ts +44 -44
  62. package/es/form/form-item-label.vue.d.ts +36 -36
  63. package/es/form/form-item.vue.d.ts +40 -40
  64. package/es/form/index.d.ts +40 -40
  65. package/es/grid/grid-row.vue.d.ts +3 -3
  66. package/es/grid/index.d.ts +3 -3
  67. package/es/image/image.vue.d.ts +38 -38
  68. package/es/image/preview-action.d.ts +36 -36
  69. package/es/image/preview-group.vue.d.ts +41 -41
  70. package/es/image/preview-toolbar.vue.d.ts +36 -36
  71. package/es/image/preview.vue.d.ts +38 -38
  72. package/es/index.css +364 -1
  73. package/es/index.d.ts +5 -1
  74. package/es/index.js +17 -15
  75. package/es/index.scss +1 -0
  76. package/es/input/index.d.ts +9 -9
  77. package/es/input/input-password.vue.d.ts +2 -2
  78. package/es/input/input-search.d.ts +1 -1
  79. package/es/input/input.d.ts +2 -2
  80. package/es/input-number/index.d.ts +9 -9
  81. package/es/input-number/input-number.d.ts +3 -3
  82. package/es/input-tag/index.d.ts +6 -6
  83. package/es/input-tag/input-tag.d.ts +2 -2
  84. package/es/json-form/index.d.ts +112 -0
  85. package/es/json-form/index.js +11 -0
  86. package/es/json-form/json-form-component.js +5 -0
  87. package/es/json-form/json-form-component.vue.d.ts +24 -0
  88. package/es/json-form/json-form-component.vue_vue_type_script_setup_true_lang.js +89 -0
  89. package/es/json-form/json-form-item.js +5 -0
  90. package/es/json-form/json-form-item.vue.d.ts +32 -0
  91. package/es/json-form/json-form-item.vue_vue_type_script_setup_true_lang.js +213 -0
  92. package/es/json-form/json-form.js +5 -0
  93. package/es/json-form/json-form.vue.d.ts +42 -0
  94. package/es/json-form/json-form.vue_vue_type_script_setup_true_lang.js +142 -0
  95. package/es/json-form/style/css.js +2 -0
  96. package/es/json-form/style/index.css +31 -0
  97. package/es/json-form/style/index.d.ts +2 -0
  98. package/es/json-form/style/index.js +2 -0
  99. package/es/json-form/style/index.scss +25 -0
  100. package/es/json-form/style/token.scss +8 -0
  101. package/es/json-form/types.d.ts +291 -0
  102. package/es/json-form/types.js +43 -0
  103. package/es/json-form/utils.d.ts +11 -0
  104. package/es/json-form/utils.js +336 -0
  105. package/es/layout/header.js +2 -18
  106. package/es/layout/header.vue.d.ts +38 -3
  107. package/es/layout/header.vue_vue_type_script_setup_true_lang.js +350 -0
  108. package/es/layout/index.d.ts +1029 -49
  109. package/es/layout/interface.d.ts +40 -0
  110. package/es/layout/sider.js +38 -9
  111. package/es/layout/sider.vue.d.ts +950 -39
  112. package/es/layout/sider.vue_vue_type_script_lang.js +304 -31
  113. package/es/layout/style/index.css +155 -1
  114. package/es/layout/style/index.scss +198 -16
  115. package/es/layout/style/token.scss +13 -0
  116. package/es/link/index.d.ts +9 -9
  117. package/es/link/link.vue.d.ts +3 -3
  118. package/es/list/index.d.ts +3 -3
  119. package/es/list/list.d.ts +1 -1
  120. package/es/mention/index.d.ts +12 -12
  121. package/es/mention/mention.d.ts +4 -4
  122. package/es/menu/base-menu.vue.d.ts +24 -5
  123. package/es/menu/base-menu.vue_vue_type_script_lang.js +19 -1
  124. package/es/menu/context.d.ts +1 -1
  125. package/es/menu/index.d.ts +1 -1
  126. package/es/menu/interface.d.ts +8 -0
  127. package/es/menu/item-group.js +9 -2
  128. package/es/menu/item-group.vue.d.ts +2894 -0
  129. package/es/menu/item-group.vue_vue_type_script_lang.js +7 -2
  130. package/es/menu/item.d.ts +1 -1
  131. package/es/menu/item.js +10 -3
  132. package/es/menu/menu.d.ts +54 -5
  133. package/es/menu/menu.js +8 -0
  134. package/es/menu/style/css.js +1 -0
  135. package/es/menu/style/index.css +194 -0
  136. package/es/menu/style/index.d.ts +1 -0
  137. package/es/menu/style/index.js +1 -0
  138. package/es/menu/style/index.scss +48 -1
  139. package/es/menu/sub-menu-inline.js +24 -3
  140. package/es/menu/sub-menu-inline.vue.d.ts +2894 -0
  141. package/es/menu/sub-menu-inline.vue_vue_type_script_lang.js +4 -1
  142. package/es/menu/sub-menu-pop.js +29 -2
  143. package/es/menu/sub-menu-pop.vue.d.ts +2924 -22
  144. package/es/menu/sub-menu-pop.vue_vue_type_script_lang.js +3 -1
  145. package/es/menu/sub-menu.d.ts +1 -1
  146. package/es/message/message-list.d.ts +1 -1
  147. package/es/message/message.vue.d.ts +1 -1
  148. package/es/modal/index.d.ts +27 -27
  149. package/es/modal/modal.vue.d.ts +11 -11
  150. package/es/notification/notification.vue.d.ts +1 -1
  151. package/es/overflow-list/index.d.ts +3 -3
  152. package/es/overflow-list/overflow-list.d.ts +1 -1
  153. package/es/pagination/page-jumper.vue.d.ts +9 -9
  154. package/es/pagination/page-options.vue.d.ts +66 -66
  155. package/es/popconfirm/index.d.ts +51 -51
  156. package/es/popconfirm/popconfirm.vue.d.ts +24 -24
  157. package/es/popover/index.d.ts +33 -33
  158. package/es/popover/popover.vue.d.ts +16 -16
  159. package/es/progress/circle.vue.d.ts +2 -2
  160. package/es/progress/index.d.ts +13 -13
  161. package/es/progress/line.vue.d.ts +1 -1
  162. package/es/progress/progress.vue.d.ts +6 -6
  163. package/es/progress/steps.vue.d.ts +2 -2
  164. package/es/radio/index.d.ts +4 -4
  165. package/es/radio/radio-group.d.ts +1 -1
  166. package/es/radio/radio.d.ts +1 -1
  167. package/es/sd-vue.js +17 -14
  168. package/es/select/index.d.ts +66 -66
  169. package/es/select/option.vue.d.ts +2 -2
  170. package/es/select/select-dropdown.vue.d.ts +4 -4
  171. package/es/select/select.d.ts +27 -27
  172. package/es/skeleton/index.d.ts +1 -1
  173. package/es/skeleton/shape.vue.d.ts +1 -1
  174. package/es/slider/index.d.ts +97 -97
  175. package/es/slider/slider-button.vue.d.ts +38 -38
  176. package/es/slider/slider-input.vue.d.ts +9 -9
  177. package/es/slider/slider.vue.d.ts +48 -48
  178. package/es/spin/index.d.ts +3 -3
  179. package/es/spin/spin.d.ts +1 -1
  180. package/es/statistic/index.d.ts +6 -6
  181. package/es/statistic/statistic.vue.d.ts +2 -2
  182. package/es/steps/index.d.ts +6 -6
  183. package/es/steps/steps.vue.d.ts +2 -2
  184. package/es/style/theme/z-index.d.ts +8 -0
  185. package/es/style/theme/z-index.js +7 -0
  186. package/es/switch/index.d.ts +21 -6
  187. package/es/switch/switch.vue.d.ts +11 -2
  188. package/es/switch/switch.vue_vue_type_script_lang.js +30 -5
  189. package/es/table/index.d.ts +15 -15
  190. package/es/table/table-operation-td.d.ts +5 -5
  191. package/es/table/table-th.js +1 -1
  192. package/es/table/table.d.ts +5 -5
  193. package/es/tabs/index.d.ts +9 -9
  194. package/es/tabs/tabs.d.ts +3 -3
  195. package/es/tag/index.d.ts +922 -922
  196. package/es/tag/tag.vue.d.ts +367 -367
  197. package/es/textarea/index.d.ts +6 -6
  198. package/es/textarea/textarea.vue.d.ts +2 -2
  199. package/es/time-picker/index.d.ts +104 -104
  200. package/es/time-picker/panel.vue.d.ts +14 -14
  201. package/es/time-picker/range-panel.d.ts +14 -14
  202. package/es/time-picker/time-picker.vue.d.ts +50 -50
  203. package/es/timeline/index.d.ts +9 -9
  204. package/es/timeline/timeline.d.ts +4 -4
  205. package/es/tooltip/index.d.ts +36 -36
  206. package/es/tooltip/tooltip.vue.d.ts +17 -17
  207. package/es/transfer/index.d.ts +37 -37
  208. package/es/transfer/transfer-list-item.d.ts +2 -2
  209. package/es/transfer/transfer-view.vue.d.ts +8 -8
  210. package/es/transfer/transfer-view.vue_vue_type_script_lang.js +1 -1
  211. package/es/transfer/transfer.vue.d.ts +17 -17
  212. package/es/tree/base-node.vue.d.ts +2 -2
  213. package/es/tree/base-node.vue_vue_type_script_lang.js +1 -1
  214. package/es/tree/node-switcher.vue_vue_type_script_lang.js +1 -1
  215. package/es/tree/transition-node-list.vue.d.ts +2 -2
  216. package/es/tree/tree.vue.d.ts +27 -27
  217. package/es/tree/tree.vue_vue_type_script_lang.js +3 -3
  218. package/es/tree-select/tree-select.vue.d.ts +30 -30
  219. package/es/tree-select/tree-select.vue_vue_type_script_lang.js +2 -2
  220. package/es/trigger/index.d.ts +15 -15
  221. package/es/trigger/trigger.d.ts +5 -5
  222. package/es/typography/base.d.ts +1 -1
  223. package/es/typography/edit-content.vue.d.ts +27 -27
  224. package/es/typography/operations.vue.d.ts +36 -36
  225. package/es/upload/index.d.ts +6 -6
  226. package/es/upload/upload-button.d.ts +1 -1
  227. package/es/upload/upload.d.ts +2 -2
  228. package/es/watermark/index.d.ts +3 -3
  229. package/es/watermark/watermark.d.ts +1 -1
  230. package/json/vetur-attributes.json +150 -7
  231. package/json/vetur-tags.json +45 -4
  232. package/json/web-types.json +316 -19
  233. package/package.json +2 -1
@@ -1,3 +1,4 @@
1
+ import Ellipsis from "../ellipsis/index.js";
1
2
  import useLevel, { provideLevel } from "./hooks/use-level.js";
2
3
  import useMenuContext from "./hooks/use-menu-context.js";
3
4
  import indent_default from "./indent.js";
@@ -5,7 +6,10 @@ import { computed, defineComponent } from "vue";
5
6
  //#region components/menu/item-group.vue?vue&type=script&lang.ts
6
7
  var item_group_vue_vue_type_script_lang_default = defineComponent({
7
8
  name: "MenuItemGroup",
8
- components: { MenuIndent: indent_default },
9
+ components: {
10
+ Ellipsis,
11
+ MenuIndent: indent_default
12
+ },
9
13
  props: {
10
14
  /**
11
15
  * @zh 菜单组的标题
@@ -25,7 +29,8 @@ title: { type: String } },
25
29
  return {
26
30
  prefixCls,
27
31
  classNames: computed(() => [`${prefixCls.value}-group`]),
28
- level
32
+ level,
33
+ menuContext
29
34
  };
30
35
  }
31
36
  });
package/es/menu/item.d.ts CHANGED
@@ -4,7 +4,7 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
4
4
  default: boolean;
5
5
  };
6
6
  }>, {
7
- menuContext: Partial<Readonly<Pick<import("./interface").InternalMenuProps, "mode" | "triggerProps" | "popupMaxHeight" | "theme" | "tooltipProps" | "levelIndent" | "autoScrollIntoView" | "scrollConfig" | "inTrigger"> & {
7
+ menuContext: Partial<Readonly<Pick<import("./interface").InternalMenuProps, "ellipsis" | "triggerProps" | "mode" | "theme" | "popupMaxHeight" | "tooltipProps" | "levelIndent" | "autoScrollIntoView" | "scrollConfig" | "inTrigger" | "ellipsisProps"> & {
8
8
  selectedKeys: string[];
9
9
  openKeys: string[];
10
10
  prefixCls: string;
package/es/menu/item.js CHANGED
@@ -1,14 +1,18 @@
1
1
  import { _objectSpread2 } from "../_virtual/_@oxc-project_runtime@0.130.0/helpers/objectSpread2.js";
2
2
  import { omit } from "../_utils/omit.js";
3
3
  import Tooltip from "../tooltip/index.js";
4
+ import Ellipsis from "../ellipsis/index.js";
4
5
  import useLevel from "./hooks/use-level.js";
5
6
  import useMenu from "./hooks/use-menu.js";
6
7
  import useMenuContext from "./hooks/use-menu-context.js";
7
8
  import { useMenuDataCollectorContext } from "./hooks/use-menu-data-collector.js";
8
9
  import indent_default from "./indent.js";
9
- import { computed, createVNode, defineComponent, mergeProps, onMounted, onUnmounted, ref, watch } from "vue";
10
+ import { computed, createVNode, defineComponent, isVNode, mergeProps, onMounted, onUnmounted, ref, watch } from "vue";
10
11
  import scrollIntoView from "scroll-into-view-if-needed";
11
12
  //#region components/menu/item.tsx
13
+ function _isSlot(s) {
14
+ return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
15
+ }
12
16
  var item_default = /* @__PURE__ */ defineComponent({
13
17
  name: "MenuItem",
14
18
  inheritAttrs: false,
@@ -82,17 +86,20 @@ disabled: {
82
86
  const children = ((_this$$slots$default = (_this$$slots = this.$slots).default) === null || _this$$slots$default === void 0 ? void 0 : _this$$slots$default.call(_this$$slots)) || [];
83
87
  const showIndent = needTextIndent && !inTrigger && !collapsed;
84
88
  const iconElement = this.$slots.icon && this.$slots.icon();
89
+ const titleClassNames = [`${prefixCls}-item-inner`, { [`${prefixCls}-title`]: iconElement }];
90
+ const titleElement = menuContext.ellipsis ? createVNode("span", { "class": [titleClassNames, `${prefixCls}-ellipsis-wrapper`] }, [createVNode(Ellipsis, mergeProps({ "class": `${prefixCls}-ellipsis` }, menuContext.ellipsisProps || {}), _isSlot(children) ? children : { default: () => [children] })]) : showIndent || iconElement ? createVNode("span", { "class": titleClassNames }, [children]) : children;
85
91
  const content = [
86
92
  showIndent && createVNode(indent_default, { "level": level }, null),
87
93
  iconElement && createVNode("span", { "class": `${prefixCls}-icon` }, [iconElement]),
88
- showIndent || iconElement ? createVNode("span", { "class": [`${prefixCls}-item-inner`, { [`${prefixCls}-title`]: iconElement }] }, [children]) : children
94
+ titleElement
89
95
  ].filter(Boolean);
90
96
  const itemElement = createVNode("div", mergeProps({
91
97
  "ref": "refItemElement",
92
98
  "class": [`${prefixCls}-item`, {
93
99
  [`${prefixCls}-disabled`]: disabled,
94
100
  [`${prefixCls}-selected`]: isSelected,
95
- [`${prefixCls}-has-icon`]: iconElement
101
+ [`${prefixCls}-has-icon`]: iconElement,
102
+ [`${prefixCls}-item-indented`]: showIndent
96
103
  }]
97
104
  }, this.$attrs, { "onClick": onClick }), [content, isSelected && mode === "horizontal" && createVNode("div", { "class": `${prefixCls}-selected-label` }, null)]);
98
105
  if (needTooltip) return createVNode(Tooltip, mergeProps({
package/es/menu/menu.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { PropType } from 'vue';
2
+ import { EllipsisTooltipProps } from '../ellipsis';
2
3
  declare const _default: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
3
4
  theme: {
4
5
  type: PropType<"light" | "dark">;
@@ -7,6 +8,18 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
7
8
  type: PropType<"vertical" | "horizontal" | "pop" | "popButton">;
8
9
  default: string;
9
10
  };
11
+ ellipsis: {
12
+ type: BooleanConstructor;
13
+ default: boolean;
14
+ };
15
+ ellipsisProps: {
16
+ type: PropType<{
17
+ lineClamp?: number | string;
18
+ expandTrigger?: "click";
19
+ tooltip?: boolean | EllipsisTooltipProps;
20
+ }>;
21
+ default: undefined;
22
+ };
10
23
  }>, () => import("vue/jsx-runtime").JSX.Element, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
11
24
  theme: {
12
25
  type: PropType<"light" | "dark">;
@@ -15,8 +28,26 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
15
28
  type: PropType<"vertical" | "horizontal" | "pop" | "popButton">;
16
29
  default: string;
17
30
  };
31
+ ellipsis: {
32
+ type: BooleanConstructor;
33
+ default: boolean;
34
+ };
35
+ ellipsisProps: {
36
+ type: PropType<{
37
+ lineClamp?: number | string;
38
+ expandTrigger?: "click";
39
+ tooltip?: boolean | EllipsisTooltipProps;
40
+ }>;
41
+ default: undefined;
42
+ };
18
43
  }>> & Readonly<{}>, {
44
+ ellipsis: boolean;
19
45
  mode: "pop" | "horizontal" | "vertical" | "popButton";
46
+ ellipsisProps: {
47
+ lineClamp?: number | string;
48
+ expandTrigger?: "click";
49
+ tooltip?: boolean | EllipsisTooltipProps;
50
+ };
20
51
  }, {}, {
21
52
  BaseMenu: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
22
53
  style: {
@@ -80,6 +111,14 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
80
111
  tooltipProps: {
81
112
  type: ObjectConstructor;
82
113
  };
114
+ ellipsis: {
115
+ type: BooleanConstructor;
116
+ default: boolean;
117
+ };
118
+ ellipsisProps: {
119
+ type: PropType<import("./interface").MenuEllipsisProps>;
120
+ default: undefined;
121
+ };
83
122
  autoOpenSelected: {
84
123
  type: BooleanConstructor;
85
124
  };
@@ -113,7 +152,7 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
113
152
  computedCollapsed: import("vue").ComputedRef<boolean>;
114
153
  computedHasCollapseButton: import("vue").ComputedRef<boolean>;
115
154
  onCollapseBtnClick: () => void;
116
- }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("collapse" | "update:collapsed" | "update:selectedKeys" | "update:openKeys" | "menu-item-click" | "sub-menu-click")[], "collapse" | "update:collapsed" | "update:selectedKeys" | "update:openKeys" | "menu-item-click" | "sub-menu-click", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
155
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("collapse" | "update:selectedKeys" | "update:collapsed" | "update:openKeys" | "menu-item-click" | "sub-menu-click")[], "collapse" | "update:selectedKeys" | "update:collapsed" | "update:openKeys" | "menu-item-click" | "sub-menu-click", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
117
156
  style: {
118
157
  type: PropType<import("vue").StyleValue>;
119
158
  };
@@ -175,6 +214,14 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
175
214
  tooltipProps: {
176
215
  type: ObjectConstructor;
177
216
  };
217
+ ellipsis: {
218
+ type: BooleanConstructor;
219
+ default: boolean;
220
+ };
221
+ ellipsisProps: {
222
+ type: PropType<import("./interface").MenuEllipsisProps>;
223
+ default: undefined;
224
+ };
178
225
  autoOpenSelected: {
179
226
  type: BooleanConstructor;
180
227
  };
@@ -198,25 +245,27 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
198
245
  type: BooleanConstructor;
199
246
  };
200
247
  }>> & Readonly<{
248
+ "onUpdate:selectedKeys"?: ((...args: any[]) => any) | undefined;
201
249
  onCollapse?: ((...args: any[]) => any) | undefined;
202
250
  "onUpdate:collapsed"?: ((...args: any[]) => any) | undefined;
203
- "onUpdate:selectedKeys"?: ((...args: any[]) => any) | undefined;
204
251
  "onUpdate:openKeys"?: ((...args: any[]) => any) | undefined;
205
252
  "onMenu-item-click"?: ((...args: any[]) => any) | undefined;
206
253
  "onSub-menu-click"?: ((...args: any[]) => any) | undefined;
207
254
  }>, {
255
+ ellipsis: boolean;
208
256
  mode: "pop" | "horizontal" | "vertical" | "popButton";
257
+ collapsed: boolean;
258
+ defaultSelectedKeys: string[];
259
+ theme: "dark" | "light";
209
260
  popupMaxHeight: number | boolean;
210
261
  accordion: boolean;
211
- theme: "dark" | "light";
212
- collapsed: boolean;
213
262
  defaultCollapsed: boolean;
214
263
  autoScrollIntoView: boolean;
215
264
  inTrigger: boolean;
265
+ ellipsisProps: import("./interface").MenuEllipsisProps;
216
266
  autoOpen: boolean;
217
267
  autoOpenSelected: boolean;
218
268
  showCollapseButton: boolean;
219
- defaultSelectedKeys: string[];
220
269
  defaultOpenKeys: string[];
221
270
  siderCollapsed: boolean;
222
271
  isRoot: boolean;
package/es/menu/menu.js CHANGED
@@ -15,6 +15,14 @@ var menu_default = /* @__PURE__ */ defineComponent({
15
15
  mode: {
16
16
  type: String,
17
17
  default: "vertical"
18
+ },
19
+ ellipsis: {
20
+ type: Boolean,
21
+ default: false
22
+ },
23
+ ellipsisProps: {
24
+ type: Object,
25
+ default: void 0
18
26
  }
19
27
  },
20
28
  setup(props, { attrs, slots }) {
@@ -1,3 +1,4 @@
1
1
  import "../../dropdown/style/index.js";
2
+ import "../../ellipsis/style/index.js";
2
3
  import "../../style/index.css";
3
4
  import "./index.css";
@@ -61,6 +61,15 @@
61
61
  display: inline-block;
62
62
  width: 20px;
63
63
  }
64
+ .sd-menu-ellipsis-wrapper {
65
+ display: inline-flex;
66
+ flex: 1;
67
+ min-width: 0;
68
+ }
69
+ .sd-menu-ellipsis {
70
+ width: 100%;
71
+ min-width: 0;
72
+ }
64
73
  .sd-menu .sd-menu-item,
65
74
  .sd-menu .sd-menu-group-title,
66
75
  .sd-menu .sd-menu-pop-header,
@@ -108,6 +117,86 @@
108
117
  .sd-menu-light {
109
118
  background-color: var(--color-menu-light-bg);
110
119
  }
120
+ .sd-menu-light .sd-menu-item,
121
+ .sd-menu-light .sd-menu-group-title,
122
+ .sd-menu-light .sd-menu-pop-header,
123
+ .sd-menu-light .sd-menu-inline-header {
124
+ color: var(--color-text-2);
125
+ background-color: var(--color-menu-light-bg);
126
+ }
127
+ .sd-menu-light .sd-menu-item .sd-icon,
128
+ .sd-menu-light .sd-menu-item .sd-menu-icon,
129
+ .sd-menu-light .sd-menu-group-title .sd-icon,
130
+ .sd-menu-light .sd-menu-group-title .sd-menu-icon,
131
+ .sd-menu-light .sd-menu-pop-header .sd-icon,
132
+ .sd-menu-light .sd-menu-pop-header .sd-menu-icon,
133
+ .sd-menu-light .sd-menu-inline-header .sd-icon,
134
+ .sd-menu-light .sd-menu-inline-header .sd-menu-icon {
135
+ color: var(--color-text-3);
136
+ }
137
+ .sd-menu-light .sd-menu-item:hover,
138
+ .sd-menu-light .sd-menu-group-title:hover,
139
+ .sd-menu-light .sd-menu-pop-header:hover,
140
+ .sd-menu-light .sd-menu-inline-header:hover {
141
+ color: var(--color-text-2);
142
+ background-color: var(--color-fill-2);
143
+ }
144
+ .sd-menu-light .sd-menu-item:hover .sd-icon,
145
+ .sd-menu-light .sd-menu-item:hover .sd-menu-icon,
146
+ .sd-menu-light .sd-menu-group-title:hover .sd-icon,
147
+ .sd-menu-light .sd-menu-group-title:hover .sd-menu-icon,
148
+ .sd-menu-light .sd-menu-pop-header:hover .sd-icon,
149
+ .sd-menu-light .sd-menu-pop-header:hover .sd-menu-icon,
150
+ .sd-menu-light .sd-menu-inline-header:hover .sd-icon,
151
+ .sd-menu-light .sd-menu-inline-header:hover .sd-menu-icon {
152
+ color: var(--color-text-3);
153
+ }
154
+ .sd-menu-light .sd-menu-item.sd-menu-selected,
155
+ .sd-menu-light .sd-menu-group-title.sd-menu-selected,
156
+ .sd-menu-light .sd-menu-pop-header.sd-menu-selected,
157
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected {
158
+ color: rgb(var(--primary-6));
159
+ }
160
+ .sd-menu-light .sd-menu-item.sd-menu-selected .sd-icon,
161
+ .sd-menu-light .sd-menu-item.sd-menu-selected .sd-menu-icon,
162
+ .sd-menu-light .sd-menu-group-title.sd-menu-selected .sd-icon,
163
+ .sd-menu-light .sd-menu-group-title.sd-menu-selected .sd-menu-icon,
164
+ .sd-menu-light .sd-menu-pop-header.sd-menu-selected .sd-icon,
165
+ .sd-menu-light .sd-menu-pop-header.sd-menu-selected .sd-menu-icon,
166
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected .sd-icon,
167
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected .sd-menu-icon {
168
+ color: rgb(var(--primary-6));
169
+ }
170
+ .sd-menu-light .sd-menu-item.sd-menu-disabled,
171
+ .sd-menu-light .sd-menu-group-title.sd-menu-disabled,
172
+ .sd-menu-light .sd-menu-pop-header.sd-menu-disabled,
173
+ .sd-menu-light .sd-menu-inline-header.sd-menu-disabled {
174
+ color: var(--color-text-4);
175
+ background-color: var(--color-menu-light-bg);
176
+ }
177
+ .sd-menu-light .sd-menu-item.sd-menu-disabled .sd-icon,
178
+ .sd-menu-light .sd-menu-item.sd-menu-disabled .sd-menu-icon,
179
+ .sd-menu-light .sd-menu-group-title.sd-menu-disabled .sd-icon,
180
+ .sd-menu-light .sd-menu-group-title.sd-menu-disabled .sd-menu-icon,
181
+ .sd-menu-light .sd-menu-pop-header.sd-menu-disabled .sd-icon,
182
+ .sd-menu-light .sd-menu-pop-header.sd-menu-disabled .sd-menu-icon,
183
+ .sd-menu-light .sd-menu-inline-header.sd-menu-disabled .sd-icon,
184
+ .sd-menu-light .sd-menu-inline-header.sd-menu-disabled .sd-menu-icon {
185
+ color: var(--color-text-4);
186
+ }
187
+ .sd-menu-light .sd-menu-item.sd-menu-selected {
188
+ background-color: var(--color-fill-2);
189
+ }
190
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected {
191
+ color: rgb(var(--primary-6));
192
+ }
193
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected .sd-icon,
194
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected .sd-menu-icon {
195
+ color: rgb(var(--primary-6));
196
+ }
197
+ .sd-menu-light .sd-menu-inline-header.sd-menu-selected:hover {
198
+ background-color: var(--color-fill-2);
199
+ }
111
200
  .sd-menu-light.sd-menu-horizontal .sd-menu-item.sd-menu-selected,
112
201
  .sd-menu-light.sd-menu-horizontal .sd-menu-group-title.sd-menu-selected,
113
202
  .sd-menu-light.sd-menu-horizontal .sd-menu-pop-header.sd-menu-selected,
@@ -115,6 +204,12 @@
115
204
  background: none;
116
205
  transition: color 0.2s cubic-bezier(0, 0, 1, 1);
117
206
  }
207
+ .sd-menu-light.sd-menu-horizontal .sd-menu-item.sd-menu-selected:hover,
208
+ .sd-menu-light.sd-menu-horizontal .sd-menu-group-title.sd-menu-selected:hover,
209
+ .sd-menu-light.sd-menu-horizontal .sd-menu-pop-header.sd-menu-selected:hover,
210
+ .sd-menu-light.sd-menu-horizontal .sd-menu-inline-header.sd-menu-selected:hover {
211
+ background-color: var(--color-fill-2);
212
+ }
118
213
  .sd-menu-light .sd-menu-group-title {
119
214
  color: var(--color-text-3);
120
215
  pointer-events: none;
@@ -123,9 +218,92 @@
123
218
  color: var(--color-text-3);
124
219
  background-color: var(--color-fill-1);
125
220
  }
221
+ .sd-menu-light .sd-menu-collapse-button:hover {
222
+ background-color: var(--color-fill-3);
223
+ }
126
224
  .sd-menu-dark {
127
225
  background-color: var(--color-menu-dark-bg);
128
226
  }
227
+ .sd-menu-dark .sd-menu-item,
228
+ .sd-menu-dark .sd-menu-group-title,
229
+ .sd-menu-dark .sd-menu-pop-header,
230
+ .sd-menu-dark .sd-menu-inline-header {
231
+ color: var(--color-text-4);
232
+ background-color: var(--color-menu-dark-bg);
233
+ }
234
+ .sd-menu-dark .sd-menu-item .sd-icon,
235
+ .sd-menu-dark .sd-menu-item .sd-menu-icon,
236
+ .sd-menu-dark .sd-menu-group-title .sd-icon,
237
+ .sd-menu-dark .sd-menu-group-title .sd-menu-icon,
238
+ .sd-menu-dark .sd-menu-pop-header .sd-icon,
239
+ .sd-menu-dark .sd-menu-pop-header .sd-menu-icon,
240
+ .sd-menu-dark .sd-menu-inline-header .sd-icon,
241
+ .sd-menu-dark .sd-menu-inline-header .sd-menu-icon {
242
+ color: var(--color-text-3);
243
+ }
244
+ .sd-menu-dark .sd-menu-item:hover,
245
+ .sd-menu-dark .sd-menu-group-title:hover,
246
+ .sd-menu-dark .sd-menu-pop-header:hover,
247
+ .sd-menu-dark .sd-menu-inline-header:hover {
248
+ color: var(--color-text-4);
249
+ background-color: var(--color-menu-dark-hover);
250
+ }
251
+ .sd-menu-dark .sd-menu-item:hover .sd-icon,
252
+ .sd-menu-dark .sd-menu-item:hover .sd-menu-icon,
253
+ .sd-menu-dark .sd-menu-group-title:hover .sd-icon,
254
+ .sd-menu-dark .sd-menu-group-title:hover .sd-menu-icon,
255
+ .sd-menu-dark .sd-menu-pop-header:hover .sd-icon,
256
+ .sd-menu-dark .sd-menu-pop-header:hover .sd-menu-icon,
257
+ .sd-menu-dark .sd-menu-inline-header:hover .sd-icon,
258
+ .sd-menu-dark .sd-menu-inline-header:hover .sd-menu-icon {
259
+ color: var(--color-text-3);
260
+ }
261
+ .sd-menu-dark .sd-menu-item.sd-menu-selected,
262
+ .sd-menu-dark .sd-menu-group-title.sd-menu-selected,
263
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-selected,
264
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected {
265
+ color: var(--color-white);
266
+ }
267
+ .sd-menu-dark .sd-menu-item.sd-menu-selected .sd-icon,
268
+ .sd-menu-dark .sd-menu-item.sd-menu-selected .sd-menu-icon,
269
+ .sd-menu-dark .sd-menu-group-title.sd-menu-selected .sd-icon,
270
+ .sd-menu-dark .sd-menu-group-title.sd-menu-selected .sd-menu-icon,
271
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-selected .sd-icon,
272
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-selected .sd-menu-icon,
273
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected .sd-icon,
274
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected .sd-menu-icon {
275
+ color: var(--color-white);
276
+ }
277
+ .sd-menu-dark .sd-menu-item.sd-menu-disabled,
278
+ .sd-menu-dark .sd-menu-group-title.sd-menu-disabled,
279
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-disabled,
280
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-disabled {
281
+ color: var(--color-text-2);
282
+ background-color: var(--color-menu-dark-bg);
283
+ }
284
+ .sd-menu-dark .sd-menu-item.sd-menu-disabled .sd-icon,
285
+ .sd-menu-dark .sd-menu-item.sd-menu-disabled .sd-menu-icon,
286
+ .sd-menu-dark .sd-menu-group-title.sd-menu-disabled .sd-icon,
287
+ .sd-menu-dark .sd-menu-group-title.sd-menu-disabled .sd-menu-icon,
288
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-disabled .sd-icon,
289
+ .sd-menu-dark .sd-menu-pop-header.sd-menu-disabled .sd-menu-icon,
290
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-disabled .sd-icon,
291
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-disabled .sd-menu-icon {
292
+ color: var(--color-text-2);
293
+ }
294
+ .sd-menu-dark .sd-menu-item.sd-menu-selected {
295
+ background-color: var(--color-menu-dark-hover);
296
+ }
297
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected {
298
+ color: rgb(var(--primary-6));
299
+ }
300
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected .sd-icon,
301
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected .sd-menu-icon {
302
+ color: rgb(var(--primary-6));
303
+ }
304
+ .sd-menu-dark .sd-menu-inline-header.sd-menu-selected:hover {
305
+ background-color: var(--color-menu-dark-hover);
306
+ }
129
307
  .sd-menu-dark.sd-menu-horizontal .sd-menu-item.sd-menu-selected,
130
308
  .sd-menu-dark.sd-menu-horizontal .sd-menu-group-title.sd-menu-selected,
131
309
  .sd-menu-dark.sd-menu-horizontal .sd-menu-pop-header.sd-menu-selected,
@@ -133,6 +311,12 @@
133
311
  background: none;
134
312
  transition: color 0.2s cubic-bezier(0, 0, 1, 1);
135
313
  }
314
+ .sd-menu-dark.sd-menu-horizontal .sd-menu-item.sd-menu-selected:hover,
315
+ .sd-menu-dark.sd-menu-horizontal .sd-menu-group-title.sd-menu-selected:hover,
316
+ .sd-menu-dark.sd-menu-horizontal .sd-menu-pop-header.sd-menu-selected:hover,
317
+ .sd-menu-dark.sd-menu-horizontal .sd-menu-inline-header.sd-menu-selected:hover {
318
+ background-color: var(--color-menu-dark-hover);
319
+ }
136
320
  .sd-menu-dark .sd-menu-group-title {
137
321
  color: var(--color-text-3);
138
322
  pointer-events: none;
@@ -141,6 +325,9 @@
141
325
  color: var(--color-white);
142
326
  background-color: rgb(var(--primary-6));
143
327
  }
328
+ .sd-menu-dark .sd-menu-collapse-button:hover {
329
+ background-color: rgb(var(--primary-7));
330
+ }
144
331
  .sd-menu a,
145
332
  .sd-menu a:hover,
146
333
  .sd-menu a:focus,
@@ -243,11 +430,18 @@
243
430
  }
244
431
  .sd-menu-vertical .sd-menu-item.sd-menu-item-indented {
245
432
  display: flex;
433
+ align-items: center;
246
434
  }
247
435
  .sd-menu-vertical .sd-menu-pop-header,
248
436
  .sd-menu-vertical .sd-menu-inline-header {
249
437
  padding-right: 28px;
250
438
  }
439
+ .sd-menu-vertical .sd-menu-pop-header.sd-menu-ellipsis-enabled,
440
+ .sd-menu-vertical .sd-menu-inline-header.sd-menu-ellipsis-enabled,
441
+ .sd-menu-vertical .sd-menu-group-title.sd-menu-ellipsis-enabled {
442
+ display: flex;
443
+ align-items: center;
444
+ }
251
445
  .sd-menu-horizontal {
252
446
  width: 100%;
253
447
  height: auto;
@@ -1,4 +1,5 @@
1
1
  import '../../style/index.scss';
2
2
  import '../../dropdown/style';
3
+ import '../../ellipsis/style';
3
4
  import '../../tooltip/style';
4
5
  import './index.scss';
@@ -1,3 +1,4 @@
1
1
  import "../../dropdown/style/index.js";
2
+ import "../../ellipsis/style/index.js";
2
3
  import "../../style/index.scss";
3
4
  import "./index.scss";
@@ -14,8 +14,36 @@ $trigger-menu-prefix-cls: string.unquote('#{theme.$prefix}-trigger-menu');
14
14
 
15
15
  $token-vars: map.merge(meta.module-variables('dropdownToken'), meta.module-variables('token'));
16
16
 
17
+ @function str-replace($input, $search, $replace: '') {
18
+ $index: string.index($input, $search);
19
+
20
+ @if $index == null {
21
+ @return $input;
22
+ }
23
+
24
+ @return string.slice($input, 1, $index - 1) + $replace +
25
+ str-replace(string.slice($input, $index + string.length($search)), $search, $replace);
26
+ }
27
+
17
28
  @function token-var($name, $fallback: null) {
18
- $value: map.get($token-vars, $name);
29
+ $lookup-name: string.unquote('#{$name}');
30
+ $value: map.get($token-vars, $lookup-name);
31
+
32
+ @if $value == null {
33
+ $dash-key: str-replace($lookup-name, '_', '-');
34
+
35
+ @if $dash-key != $lookup-name {
36
+ $value: map.get($token-vars, $dash-key);
37
+ }
38
+ }
39
+
40
+ @if $value == null {
41
+ $underscore-key: str-replace($lookup-name, '-', '_');
42
+
43
+ @if $underscore-key != $lookup-name {
44
+ $value: map.get($token-vars, $underscore-key);
45
+ }
46
+ }
19
47
 
20
48
  @if $value == null {
21
49
  @return $fallback;
@@ -249,6 +277,17 @@ $token-vars: map.merge(meta.module-variables('dropdownToken'), meta.module-varia
249
277
  width: $menu-item-indent-spacing;
250
278
  }
251
279
 
280
+ &-ellipsis-wrapper {
281
+ display: inline-flex;
282
+ flex: 1;
283
+ min-width: 0;
284
+ }
285
+
286
+ &-ellipsis {
287
+ width: 100%;
288
+ min-width: 0;
289
+ }
290
+
252
291
  @include menu-item-base();
253
292
  @include menu-theme(light);
254
293
  @include menu-theme(dark);
@@ -286,6 +325,7 @@ $token-vars: map.merge(meta.module-variables('dropdownToken'), meta.module-varia
286
325
 
287
326
  .#{$menu-prefix-cls}-item.#{$menu-prefix-cls}-item-indented {
288
327
  display: flex;
328
+ align-items: center;
289
329
  }
290
330
 
291
331
  // 为 header 右侧预留下放置 suffixIcon 的空间
@@ -293,6 +333,13 @@ $token-vars: map.merge(meta.module-variables('dropdownToken'), meta.module-varia
293
333
  .#{$menu-prefix-cls}-inline-header {
294
334
  padding-right: $menu-vertical-item-padding-horizontal + 16;
295
335
  }
336
+
337
+ .#{$menu-prefix-cls}-pop-header.#{$menu-prefix-cls}-ellipsis-enabled,
338
+ .#{$menu-prefix-cls}-inline-header.#{$menu-prefix-cls}-ellipsis-enabled,
339
+ .#{$menu-prefix-cls}-group-title.#{$menu-prefix-cls}-ellipsis-enabled {
340
+ display: flex;
341
+ align-items: center;
342
+ }
296
343
  }
297
344
 
298
345
  // 水平菜单中,仅允许出现普通 item 和 popSubMenu
@@ -1,19 +1,40 @@
1
1
  import _plugin_vue_export_helper_default from "../_virtual/_plugin-vue_export-helper.js";
2
2
  import sub_menu_inline_vue_vue_type_script_lang_default from "./sub-menu-inline.vue_vue_type_script_lang.js";
3
- import { Fragment, createElementBlock, createElementVNode, createTextVNode, createVNode, normalizeClass, openBlock, renderSlot, resolveComponent, toDisplayString, vShow, withCtx, withDirectives } from "vue";
3
+ import { Fragment, createElementBlock, createElementVNode, createTextVNode, createVNode, mergeProps, normalizeClass, openBlock, renderSlot, resolveComponent, toDisplayString, vShow, withCtx, withDirectives } from "vue";
4
4
  //#region components/menu/sub-menu-inline.vue
5
5
  function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
6
6
  const _component_MenuIndent = resolveComponent("MenuIndent");
7
+ const _component_Ellipsis = resolveComponent("Ellipsis");
7
8
  const _component_ExpandTransition = resolveComponent("ExpandTransition");
8
9
  return openBlock(), createElementBlock("div", { class: normalizeClass(_ctx.classNames) }, [createElementVNode("div", {
9
10
  class: normalizeClass([`${_ctx.prefixCls}-header`, {
10
11
  [`${_ctx.menuPrefixCls}-selected`]: _ctx.isSelected,
11
- [`${_ctx.menuPrefixCls}-has-icon`]: _ctx.$slots.icon
12
+ [`${_ctx.menuPrefixCls}-has-icon`]: _ctx.$slots.icon,
13
+ [`${_ctx.menuPrefixCls}-ellipsis-enabled`]: _ctx.menuContext.ellipsis
12
14
  }]),
13
15
  onClick: _cache[0] || (_cache[0] = (...args) => _ctx.onHeaderClick && _ctx.onHeaderClick(...args))
14
16
  }, [
15
17
  createVNode(_component_MenuIndent, { level: _ctx.level }, null, 8, ["level"]),
16
- _ctx.$slots.icon ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [createElementVNode("span", { class: normalizeClass(`${_ctx.menuPrefixCls}-icon`) }, [renderSlot(_ctx.$slots, "icon")], 2), createElementVNode("span", { class: normalizeClass(`${_ctx.menuPrefixCls}-title`) }, [renderSlot(_ctx.$slots, "title", {}, () => [createTextVNode(toDisplayString(_ctx.title), 1)])], 2)], 64)) : renderSlot(_ctx.$slots, "title", { key: 1 }, () => [createTextVNode(toDisplayString(_ctx.title), 1)]),
18
+ _ctx.$slots.icon ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [createElementVNode("span", { class: normalizeClass(`${_ctx.menuPrefixCls}-icon`) }, [renderSlot(_ctx.$slots, "icon")], 2), _ctx.menuContext.ellipsis ? (openBlock(), createElementBlock("span", {
19
+ key: 0,
20
+ class: normalizeClass([
21
+ `${_ctx.menuPrefixCls}-item-inner`,
22
+ `${_ctx.menuPrefixCls}-title`,
23
+ `${_ctx.menuPrefixCls}-ellipsis-wrapper`
24
+ ])
25
+ }, [createVNode(_component_Ellipsis, mergeProps({ class: `${_ctx.menuPrefixCls}-ellipsis` }, _ctx.menuContext.ellipsisProps), {
26
+ default: withCtx(() => [renderSlot(_ctx.$slots, "title", {}, () => [createTextVNode(toDisplayString(_ctx.title), 1)])]),
27
+ _: 3
28
+ }, 16, ["class"])], 2)) : (openBlock(), createElementBlock("span", {
29
+ key: 1,
30
+ class: normalizeClass(`${_ctx.menuPrefixCls}-title`)
31
+ }, [renderSlot(_ctx.$slots, "title", {}, () => [createTextVNode(toDisplayString(_ctx.title), 1)])], 2))], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [_ctx.menuContext.ellipsis ? (openBlock(), createElementBlock("span", {
32
+ key: 0,
33
+ class: normalizeClass([`${_ctx.menuPrefixCls}-item-inner`, `${_ctx.menuPrefixCls}-ellipsis-wrapper`])
34
+ }, [createVNode(_component_Ellipsis, mergeProps({ class: `${_ctx.menuPrefixCls}-ellipsis` }, _ctx.menuContext.ellipsisProps), {
35
+ default: withCtx(() => [renderSlot(_ctx.$slots, "title", {}, () => [createTextVNode(toDisplayString(_ctx.title), 1)])]),
36
+ _: 3
37
+ }, 16, ["class"])], 2)) : renderSlot(_ctx.$slots, "title", { key: 1 }, () => [createTextVNode(toDisplayString(_ctx.title), 1)])], 64)),
17
38
  createElementVNode("span", { class: normalizeClass([`${_ctx.menuPrefixCls}-icon-suffix`, { [`is-open`]: _ctx.isOpen }]) }, [renderSlot(_ctx.$slots, "expand-icon-down")], 2)
18
39
  ], 2), createVNode(_component_ExpandTransition, null, {
19
40
  default: withCtx(() => [withDirectives(createElementVNode("div", { class: normalizeClass(`${_ctx.prefixCls}-content`) }, [renderSlot(_ctx.$slots, "default")], 2), [[vShow, _ctx.isOpen]])]),