@sdata/web-vue 1.14.0 → 1.19.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.
- package/dist/sd.css +364 -1
- package/dist/sd.min.css +1 -1
- package/es/_components/picker/input-range.vue.d.ts +2 -2
- package/es/_components/picker/input.vue.d.ts +1 -1
- package/es/_components/resize-trigger.vue_vue_type_script_lang.js +1 -1
- package/es/_components/select-view/select-view.d.ts +2 -2
- package/es/_components/virtual-list/virtual-list.vue.d.ts +3 -3
- package/es/_hooks/use-popup-manager.js +2 -4
- package/es/_utils/dom.d.ts +5 -2
- package/es/_utils/dom.js +1 -1
- package/es/anchor/anchor.vue.d.ts +2 -2
- package/es/anchor/index.d.ts +9 -9
- package/es/auto-complete/auto-complete.d.ts +3 -3
- package/es/auto-complete/index.d.ts +9 -9
- package/es/button/button.vue.d.ts +2 -2
- package/es/button/index.d.ts +6 -6
- package/es/calendar/calendar.d.ts +1 -1
- package/es/calendar/index.d.ts +3 -3
- package/es/card/card.d.ts +4 -4
- package/es/card/index.d.ts +9 -9
- package/es/carousel/carousel-arrow.vue.d.ts +1 -1
- package/es/carousel/carousel-indicator.vue.d.ts +1 -1
- package/es/carousel/carousel.d.ts +3 -3
- package/es/carousel/index.d.ts +9 -9
- package/es/cascader/base-cascader-panel.d.ts +1 -1
- package/es/cascader/cascader-search-panel.d.ts +1 -1
- package/es/cascader/cascader.vue.d.ts +14 -14
- package/es/checkbox/checkbox-group.d.ts +1 -1
- package/es/checkbox/index.d.ts +1 -1
- package/es/color-picker/color-picker.d.ts +5 -5
- package/es/color-picker/index.d.ts +15 -15
- package/es/color-picker/panel.d.ts +2 -2
- package/es/components.d.ts +1 -0
- package/es/config-provider/config-provider.vue.d.ts +8 -2
- package/es/config-provider/config-provider.vue_vue_type_script_lang.js +6 -0
- package/es/config-provider/context.d.ts +3 -0
- package/es/config-provider/index.d.ts +13 -3
- package/es/cropper/cropper.vue.d.ts +1 -1
- package/es/cropper/index.d.ts +3 -3
- package/es/date-picker/index.d.ts +94 -94
- package/es/date-picker/panels/date/index.vue.d.ts +15 -15
- package/es/date-picker/panels/footer.vue.d.ts +15 -15
- package/es/date-picker/panels/shortcuts.vue.d.ts +6 -6
- package/es/date-picker/panels/week/index.vue.d.ts +16 -16
- package/es/date-picker/picker-panel.vue.d.ts +54 -54
- package/es/date-picker/picker.vue.d.ts +87 -87
- package/es/date-picker/pickers/date-picker.d.ts +1 -1
- package/es/date-picker/pickers/week-picker.d.ts +1 -1
- package/es/date-picker/range-picker-panel.vue.d.ts +55 -55
- package/es/date-picker/range-picker.vue.d.ts +90 -90
- package/es/descriptions/descriptions.d.ts +1 -1
- package/es/descriptions/index.d.ts +3 -3
- package/es/drawer/drawer.vue.d.ts +11 -11
- package/es/drawer/index.d.ts +27 -27
- package/es/dropdown/dropdown-button.vue.d.ts +24 -24
- package/es/dropdown/dropdown-submenu.vue.d.ts +17 -17
- package/es/dropdown/dropdown.vue.d.ts +16 -16
- package/es/dropdown/index.d.ts +74 -74
- package/es/ellipsis/ellipsis.vue.d.ts +43 -43
- package/es/ellipsis/index.d.ts +182 -182
- package/es/ellipsis/performant-ellipsis.vue.d.ts +44 -44
- package/es/form/form-item-label.vue.d.ts +36 -36
- package/es/form/form-item.vue.d.ts +40 -40
- package/es/form/index.d.ts +40 -40
- package/es/grid/grid-row.vue.d.ts +3 -3
- package/es/grid/index.d.ts +3 -3
- package/es/image/image.vue.d.ts +38 -38
- package/es/image/preview-action.d.ts +36 -36
- package/es/image/preview-group.vue.d.ts +41 -41
- package/es/image/preview-toolbar.vue.d.ts +36 -36
- package/es/image/preview.vue.d.ts +38 -38
- package/es/index.css +364 -1
- package/es/index.d.ts +5 -1
- package/es/index.js +17 -15
- package/es/index.scss +1 -0
- package/es/input/index.d.ts +9 -9
- package/es/input/input-password.vue.d.ts +2 -2
- package/es/input/input-search.d.ts +1 -1
- package/es/input/input.d.ts +2 -2
- package/es/input-number/index.d.ts +9 -9
- package/es/input-number/input-number.d.ts +3 -3
- package/es/input-tag/index.d.ts +6 -6
- package/es/input-tag/input-tag.d.ts +2 -2
- package/es/json-form/index.d.ts +112 -0
- package/es/json-form/index.js +11 -0
- package/es/json-form/json-form-component.js +5 -0
- package/es/json-form/json-form-component.vue.d.ts +24 -0
- package/es/json-form/json-form-component.vue_vue_type_script_setup_true_lang.js +89 -0
- package/es/json-form/json-form-item.js +5 -0
- package/es/json-form/json-form-item.vue.d.ts +32 -0
- package/es/json-form/json-form-item.vue_vue_type_script_setup_true_lang.js +213 -0
- package/es/json-form/json-form.js +5 -0
- package/es/json-form/json-form.vue.d.ts +42 -0
- package/es/json-form/json-form.vue_vue_type_script_setup_true_lang.js +142 -0
- package/es/json-form/style/css.js +2 -0
- package/es/json-form/style/index.css +31 -0
- package/es/json-form/style/index.d.ts +2 -0
- package/es/json-form/style/index.js +2 -0
- package/es/json-form/style/index.scss +25 -0
- package/es/json-form/style/token.scss +8 -0
- package/es/json-form/types.d.ts +291 -0
- package/es/json-form/types.js +43 -0
- package/es/json-form/utils.d.ts +11 -0
- package/es/json-form/utils.js +336 -0
- package/es/layout/header.js +2 -18
- package/es/layout/header.vue.d.ts +38 -3
- package/es/layout/header.vue_vue_type_script_setup_true_lang.js +350 -0
- package/es/layout/index.d.ts +1029 -49
- package/es/layout/interface.d.ts +40 -0
- package/es/layout/sider.js +38 -9
- package/es/layout/sider.vue.d.ts +950 -39
- package/es/layout/sider.vue_vue_type_script_lang.js +304 -31
- package/es/layout/style/index.css +155 -1
- package/es/layout/style/index.scss +198 -16
- package/es/layout/style/token.scss +13 -0
- package/es/link/index.d.ts +9 -9
- package/es/link/link.vue.d.ts +3 -3
- package/es/list/index.d.ts +3 -3
- package/es/list/list.d.ts +1 -1
- package/es/mention/index.d.ts +12 -12
- package/es/mention/mention.d.ts +4 -4
- package/es/menu/base-menu.vue.d.ts +24 -5
- package/es/menu/base-menu.vue_vue_type_script_lang.js +19 -1
- package/es/menu/context.d.ts +1 -1
- package/es/menu/index.d.ts +1 -1
- package/es/menu/interface.d.ts +8 -0
- package/es/menu/item-group.js +9 -2
- package/es/menu/item-group.vue.d.ts +2894 -0
- package/es/menu/item-group.vue_vue_type_script_lang.js +7 -2
- package/es/menu/item.d.ts +1 -1
- package/es/menu/item.js +10 -3
- package/es/menu/menu.d.ts +54 -5
- package/es/menu/menu.js +8 -0
- package/es/menu/style/css.js +1 -0
- package/es/menu/style/index.css +194 -0
- package/es/menu/style/index.d.ts +1 -0
- package/es/menu/style/index.js +1 -0
- package/es/menu/style/index.scss +48 -1
- package/es/menu/sub-menu-inline.js +24 -3
- package/es/menu/sub-menu-inline.vue.d.ts +2894 -0
- package/es/menu/sub-menu-inline.vue_vue_type_script_lang.js +4 -1
- package/es/menu/sub-menu-pop.js +29 -2
- package/es/menu/sub-menu-pop.vue.d.ts +2924 -22
- package/es/menu/sub-menu-pop.vue_vue_type_script_lang.js +3 -1
- package/es/menu/sub-menu.d.ts +1 -1
- package/es/message/message-list.d.ts +1 -1
- package/es/message/message.vue.d.ts +1 -1
- package/es/modal/index.d.ts +27 -27
- package/es/modal/modal.vue.d.ts +11 -11
- package/es/notification/notification.vue.d.ts +1 -1
- package/es/overflow-list/index.d.ts +3 -3
- package/es/overflow-list/overflow-list.d.ts +1 -1
- package/es/pagination/page-jumper.vue.d.ts +9 -9
- package/es/pagination/page-options.vue.d.ts +66 -66
- package/es/popconfirm/index.d.ts +51 -51
- package/es/popconfirm/popconfirm.vue.d.ts +24 -24
- package/es/popover/index.d.ts +33 -33
- package/es/popover/popover.vue.d.ts +16 -16
- package/es/progress/circle.vue.d.ts +2 -2
- package/es/progress/index.d.ts +13 -13
- package/es/progress/line.vue.d.ts +1 -1
- package/es/progress/progress.vue.d.ts +6 -6
- package/es/progress/steps.vue.d.ts +2 -2
- package/es/radio/index.d.ts +4 -4
- package/es/radio/radio-group.d.ts +1 -1
- package/es/radio/radio.d.ts +1 -1
- package/es/sd-vue.js +17 -14
- package/es/select/index.d.ts +66 -66
- package/es/select/option.vue.d.ts +2 -2
- package/es/select/select-dropdown.vue.d.ts +4 -4
- package/es/select/select.d.ts +27 -27
- package/es/skeleton/index.d.ts +1 -1
- package/es/skeleton/shape.vue.d.ts +1 -1
- package/es/slider/index.d.ts +97 -97
- package/es/slider/slider-button.vue.d.ts +38 -38
- package/es/slider/slider-input.vue.d.ts +9 -9
- package/es/slider/slider.vue.d.ts +48 -48
- package/es/spin/index.d.ts +3 -3
- package/es/spin/spin.d.ts +1 -1
- package/es/statistic/index.d.ts +6 -6
- package/es/statistic/statistic.vue.d.ts +2 -2
- package/es/steps/index.d.ts +6 -6
- package/es/steps/steps.vue.d.ts +2 -2
- package/es/style/theme/z-index.d.ts +8 -0
- package/es/style/theme/z-index.js +7 -0
- package/es/switch/index.d.ts +21 -6
- package/es/switch/switch.vue.d.ts +11 -2
- package/es/switch/switch.vue_vue_type_script_lang.js +30 -5
- package/es/table/index.d.ts +15 -15
- package/es/table/table-operation-td.d.ts +5 -5
- package/es/table/table-th.js +1 -1
- package/es/table/table.d.ts +5 -5
- package/es/tabs/index.d.ts +9 -9
- package/es/tabs/tabs.d.ts +3 -3
- package/es/tag/index.d.ts +922 -922
- package/es/tag/tag.vue.d.ts +367 -367
- package/es/textarea/index.d.ts +6 -6
- package/es/textarea/textarea.vue.d.ts +2 -2
- package/es/time-picker/index.d.ts +104 -104
- package/es/time-picker/panel.vue.d.ts +14 -14
- package/es/time-picker/range-panel.d.ts +14 -14
- package/es/time-picker/time-picker.vue.d.ts +50 -50
- package/es/timeline/index.d.ts +9 -9
- package/es/timeline/timeline.d.ts +4 -4
- package/es/tooltip/index.d.ts +36 -36
- package/es/tooltip/tooltip.vue.d.ts +17 -17
- package/es/transfer/index.d.ts +37 -37
- package/es/transfer/transfer-list-item.d.ts +2 -2
- package/es/transfer/transfer-view.vue.d.ts +8 -8
- package/es/transfer/transfer-view.vue_vue_type_script_lang.js +1 -1
- package/es/transfer/transfer.vue.d.ts +17 -17
- package/es/tree/base-node.vue.d.ts +2 -2
- package/es/tree/base-node.vue_vue_type_script_lang.js +1 -1
- package/es/tree/node-switcher.vue_vue_type_script_lang.js +1 -1
- package/es/tree/transition-node-list.vue.d.ts +2 -2
- package/es/tree/tree.vue.d.ts +27 -27
- package/es/tree/tree.vue_vue_type_script_lang.js +3 -3
- package/es/tree-select/tree-select.vue.d.ts +30 -30
- package/es/tree-select/tree-select.vue_vue_type_script_lang.js +2 -2
- package/es/trigger/index.d.ts +15 -15
- package/es/trigger/trigger.d.ts +5 -5
- package/es/typography/base.d.ts +1 -1
- package/es/typography/edit-content.vue.d.ts +27 -27
- package/es/typography/operations.vue.d.ts +36 -36
- package/es/upload/index.d.ts +6 -6
- package/es/upload/upload-button.d.ts +1 -1
- package/es/upload/upload.d.ts +2 -2
- package/es/watermark/index.d.ts +3 -3
- package/es/watermark/watermark.d.ts +1 -1
- package/json/vetur-attributes.json +150 -7
- package/json/vetur-tags.json +45 -4
- package/json/web-types.json +316 -19
- 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: {
|
|
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, "
|
|
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
|
-
|
|
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:
|
|
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 }) {
|
package/es/menu/style/css.js
CHANGED
package/es/menu/style/index.css
CHANGED
|
@@ -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;
|
package/es/menu/style/index.d.ts
CHANGED
package/es/menu/style/index.js
CHANGED
package/es/menu/style/index.scss
CHANGED
|
@@ -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
|
-
$
|
|
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),
|
|
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]])]),
|