bm-admin-ui 1.0.2-alpha → 1.0.5-alpha

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 (40) hide show
  1. package/es/components/multi-cascader-compose/index.d.ts +29 -0
  2. package/es/components/multi-cascader-compose/index.js +51 -53
  3. package/es/components/multi-cascader-compose/src/multi-cascader-compose.vue.d.ts +29 -0
  4. package/es/components/multi-cascader-compose/src/props.d.ts +10 -2
  5. package/es/components/search-filter/index.d.ts +1 -3
  6. package/es/components/search-filter/index.js +53 -54
  7. package/es/components/search-filter/src/search-filter.vue.d.ts +1 -3
  8. package/es/components/shops-filter/index.js +92 -102
  9. package/es/components/staffs-selector/index.js +62 -41
  10. package/es/components/upload/index.js +6 -19
  11. package/index.esm.js +41510 -4174
  12. package/index.js +41509 -4173
  13. package/lib/components/multi-cascader-compose/index.d.ts +29 -0
  14. package/lib/components/multi-cascader-compose/index.js +50 -52
  15. package/lib/components/multi-cascader-compose/src/multi-cascader-compose.vue.d.ts +29 -0
  16. package/lib/components/multi-cascader-compose/src/props.d.ts +10 -2
  17. package/lib/components/search-filter/index.d.ts +1 -3
  18. package/lib/components/search-filter/index.js +52 -53
  19. package/lib/components/search-filter/src/search-filter.vue.d.ts +1 -3
  20. package/lib/components/shops-filter/index.js +91 -101
  21. package/lib/components/staffs-selector/index.js +62 -41
  22. package/lib/components/upload/index.js +6 -19
  23. package/package.json +29 -30
  24. package/theme-chalk/button.css +1 -1
  25. package/theme-chalk/float-table.css +1 -1
  26. package/theme-chalk/floating-vue.css +1 -1
  27. package/theme-chalk/flow-designer.css +1 -1
  28. package/theme-chalk/index.css +1 -1
  29. package/theme-chalk/multi-cascader-compose.css +1 -1
  30. package/theme-chalk/over-tooltips.css +1 -1
  31. package/theme-chalk/search-filter.css +1 -1
  32. package/theme-chalk/timeline.css +1 -1
  33. package/theme-chalk/upload.css +1 -1
  34. package/types/components/multi-cascader-compose/index.d.ts +29 -0
  35. package/types/components/multi-cascader-compose/src/multi-cascader-compose.vue.d.ts +29 -0
  36. package/types/components/multi-cascader-compose/src/props.d.ts +10 -2
  37. package/types/components/search-filter/index.d.ts +1 -3
  38. package/types/components/search-filter/src/search-filter.vue.d.ts +1 -3
  39. package/pnpm-global/5/node_modules/.pnpm/lock.yaml +0 -3
  40. package/pnpm-global/5/pnpm-lock.yaml +0 -4
@@ -27,6 +27,14 @@ declare const BmMultiCascaderCompose: import("bm-admin-ui/es/utils/with-install"
27
27
  type: BooleanConstructor;
28
28
  default: boolean;
29
29
  };
30
+ emptyImage: {
31
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
32
+ [key: string]: any;
33
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
34
+ [key: string]: any;
35
+ }> | null | undefined)[]>;
36
+ default: undefined;
37
+ };
30
38
  }, {
31
39
  props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
32
40
  options: {
@@ -57,6 +65,14 @@ declare const BmMultiCascaderCompose: import("bm-admin-ui/es/utils/with-install"
57
65
  type: BooleanConstructor;
58
66
  default: boolean;
59
67
  };
68
+ emptyImage: {
69
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
70
+ [key: string]: any;
71
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
72
+ [key: string]: any;
73
+ }> | null | undefined)[]>;
74
+ default: undefined;
75
+ };
60
76
  }>> & {
61
77
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
62
78
  onChange?: ((...args: any[]) => any) | undefined;
@@ -119,6 +135,14 @@ declare const BmMultiCascaderCompose: import("bm-admin-ui/es/utils/with-install"
119
135
  type: BooleanConstructor;
120
136
  default: boolean;
121
137
  };
138
+ emptyImage: {
139
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
140
+ [key: string]: any;
141
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
142
+ [key: string]: any;
143
+ }> | null | undefined)[]>;
144
+ default: undefined;
145
+ };
122
146
  }>> & {
123
147
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
124
148
  onChange?: ((...args: any[]) => any) | undefined;
@@ -130,6 +154,11 @@ declare const BmMultiCascaderCompose: import("bm-admin-ui/es/utils/with-install"
130
154
  maxTagCount: number;
131
155
  placeholder: string;
132
156
  allowClear: boolean;
157
+ emptyImage: JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
158
+ [key: string]: any;
159
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
160
+ [key: string]: any;
161
+ }> | null | undefined)[];
133
162
  }>>;
134
163
  export { BmMultiCascaderCompose };
135
164
  export default BmMultiCascaderCompose;
@@ -1,5 +1,5 @@
1
1
  import { withInstall } from 'bm-admin-ui/es/utils/with-install';
2
- import { h, nextTick, createVNode, defineComponent, ref, computed, resolveComponent, openBlock, createElementBlock, withCtx, Fragment, renderList, unref, createCommentVNode, createElementVNode, withModifiers, normalizeClass, toDisplayString, createBlock } from 'vue';
2
+ import { h, nextTick, createVNode, defineComponent, ref, computed, resolveComponent, openBlock, createElementBlock, withCtx, Fragment, renderList, unref, createCommentVNode, createElementVNode, withModifiers, normalizeClass, toDisplayString, createBlock, renderSlot } from 'vue';
3
3
 
4
4
  /**
5
5
  * Take input from [0, n] and return it as [0, 1]
@@ -65,7 +65,7 @@ function boundAlpha(a) {
65
65
  */
66
66
  function convertToPercentage(n) {
67
67
  if (n <= 1) {
68
- return "".concat(Number(n) * 100, "%");
68
+ return Number(n) * 100 + "%";
69
69
  }
70
70
  return n;
71
71
  }
@@ -447,12 +447,12 @@ var CSS_INTEGER = '[-\\+]?\\d+%?';
447
447
  // <http://www.w3.org/TR/css3-values/#number-value>
448
448
  var CSS_NUMBER = '[-\\+]?\\d*\\.\\d+%?';
449
449
  // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.
450
- var CSS_UNIT = "(?:".concat(CSS_NUMBER, ")|(?:").concat(CSS_INTEGER, ")");
450
+ var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")";
451
451
  // Actual matching.
452
452
  // Parentheses and commas are optional, but not required.
453
453
  // Whitespace can take the place of commas or opening paren
454
- var PERMISSIVE_MATCH3 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
455
- var PERMISSIVE_MATCH4 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
454
+ var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
455
+ var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
456
456
  var matchers = {
457
457
  CSS_UNIT: new RegExp(CSS_UNIT),
458
458
  rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),
@@ -777,19 +777,6 @@ Object.keys(presetPrimaryColors).forEach(function (key) {
777
777
  });
778
778
  presetDarkPalettes[key].primary = presetDarkPalettes[key][5];
779
779
  });
780
- presetPalettes.red;
781
- presetPalettes.volcano;
782
- presetPalettes.gold;
783
- presetPalettes.orange;
784
- presetPalettes.yellow;
785
- presetPalettes.lime;
786
- presetPalettes.green;
787
- presetPalettes.cyan;
788
- presetPalettes.blue;
789
- presetPalettes.geekblue;
790
- presetPalettes.purple;
791
- presetPalettes.magenta;
792
- presetPalettes.grey;
793
780
 
794
781
  // https://github.com/substack/insert-css
795
782
  var containers = []; // will store container HTMLElement references
@@ -1186,40 +1173,46 @@ RightOutlined.displayName = 'RightOutlined';
1186
1173
  RightOutlined.inheritAttrs = false;
1187
1174
  var RightOutlined$1 = RightOutlined;
1188
1175
 
1189
- const propsConfig = {
1190
- options: {
1191
- type: Array,
1192
- default() {
1193
- return [];
1176
+ function multiCascaderComposeProps() {
1177
+ return {
1178
+ options: {
1179
+ type: Array,
1180
+ default() {
1181
+ return [];
1182
+ },
1194
1183
  },
1195
- },
1196
- modelValue: {
1197
- type: Array,
1198
- default() {
1199
- return [];
1184
+ modelValue: {
1185
+ type: Array,
1186
+ default() {
1187
+ return [];
1188
+ },
1200
1189
  },
1201
- },
1202
- optionValueName: {
1203
- type: String,
1204
- default: 'value',
1205
- },
1206
- optionLabelName: {
1207
- type: String,
1208
- default: 'label',
1209
- },
1210
- maxTagCount: {
1211
- type: Number,
1212
- default: 1,
1213
- },
1214
- placeholder: {
1215
- type: String,
1216
- default: '请选择',
1217
- },
1218
- allowClear: {
1219
- type: Boolean,
1220
- default: true,
1221
- },
1222
- };
1190
+ optionValueName: {
1191
+ type: String,
1192
+ default: 'value',
1193
+ },
1194
+ optionLabelName: {
1195
+ type: String,
1196
+ default: 'label',
1197
+ },
1198
+ maxTagCount: {
1199
+ type: Number,
1200
+ default: 1,
1201
+ },
1202
+ placeholder: {
1203
+ type: String,
1204
+ default: '请选择',
1205
+ },
1206
+ allowClear: {
1207
+ type: Boolean,
1208
+ default: true,
1209
+ },
1210
+ emptyImage: {
1211
+ type: [String, Object],
1212
+ default: undefined,
1213
+ },
1214
+ };
1215
+ }
1223
1216
 
1224
1217
  var _export_sfc = (sfc, props) => {
1225
1218
  const target = sfc.__vccOpts || sfc;
@@ -1268,7 +1261,7 @@ const __default__ = {
1268
1261
  };
1269
1262
  const _sfc_main = /* @__PURE__ */ defineComponent({
1270
1263
  ...__default__,
1271
- props: propsConfig,
1264
+ props: multiCascaderComposeProps(),
1272
1265
  emits: ["update:modelValue", "change"],
1273
1266
  setup(__props, { emit: emits }) {
1274
1267
  const props = __props;
@@ -1646,7 +1639,12 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
1646
1639
  }), 128))
1647
1640
  ])) : (openBlock(), createElementBlock("div", _hoisted_18, [
1648
1641
  createElementVNode("div", _hoisted_19, [
1649
- createVNode(_component_a_empty, { class: "bm-multi-cascader-popover-empty" })
1642
+ renderSlot(_ctx.$slots, "empty", {}, () => [
1643
+ createVNode(_component_a_empty, {
1644
+ class: "bm-multi-cascader-popover-empty",
1645
+ image: props.emptyImage
1646
+ }, null, 8, ["image"])
1647
+ ])
1650
1648
  ])
1651
1649
  ]))
1652
1650
  ]),
@@ -1686,7 +1684,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
1686
1684
  ])
1687
1685
  ])
1688
1686
  ]),
1689
- _: 1
1687
+ _: 3
1690
1688
  })
1691
1689
  ]);
1692
1690
  };
@@ -28,6 +28,14 @@ declare const _default: import("vue").DefineComponent<{
28
28
  type: BooleanConstructor;
29
29
  default: boolean;
30
30
  };
31
+ emptyImage: {
32
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
33
+ [key: string]: any;
34
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
35
+ [key: string]: any;
36
+ }> | null | undefined)[]>;
37
+ default: undefined;
38
+ };
31
39
  }, {
32
40
  props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
33
41
  options: {
@@ -58,6 +66,14 @@ declare const _default: import("vue").DefineComponent<{
58
66
  type: BooleanConstructor;
59
67
  default: boolean;
60
68
  };
69
+ emptyImage: {
70
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
71
+ [key: string]: any;
72
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
73
+ [key: string]: any;
74
+ }> | null | undefined)[]>;
75
+ default: undefined;
76
+ };
61
77
  }>> & {
62
78
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
63
79
  onChange?: ((...args: any[]) => any) | undefined;
@@ -120,6 +136,14 @@ declare const _default: import("vue").DefineComponent<{
120
136
  type: BooleanConstructor;
121
137
  default: boolean;
122
138
  };
139
+ emptyImage: {
140
+ type: import("vue").PropType<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
141
+ [key: string]: any;
142
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
143
+ [key: string]: any;
144
+ }> | null | undefined)[]>;
145
+ default: undefined;
146
+ };
123
147
  }>> & {
124
148
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
125
149
  onChange?: ((...args: any[]) => any) | undefined;
@@ -131,5 +155,10 @@ declare const _default: import("vue").DefineComponent<{
131
155
  maxTagCount: number;
132
156
  placeholder: string;
133
157
  allowClear: boolean;
158
+ emptyImage: JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
159
+ [key: string]: any;
160
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
161
+ [key: string]: any;
162
+ }> | null | undefined)[];
134
163
  }>;
135
164
  export default _default;
@@ -1,6 +1,8 @@
1
- import type { PropType } from 'vue';
1
+ import type { PropType, ExtractPropTypes, VNode } from 'vue';
2
2
  import { MutilCascaderItem } from '../types';
3
- export declare const propsConfig: {
3
+ declare type VNodeChildAtom = VNode | string | number | boolean | null | undefined | void;
4
+ declare type VueNode = VNodeChildAtom | VNodeChildAtom[] | JSX.Element;
5
+ export declare function multiCascaderComposeProps(): {
4
6
  options: {
5
7
  type: PropType<MutilCascaderItem[]>;
6
8
  default(): MutilCascaderItem[];
@@ -29,4 +31,10 @@ export declare const propsConfig: {
29
31
  type: BooleanConstructor;
30
32
  default: boolean;
31
33
  };
34
+ emptyImage: {
35
+ type: PropType<VueNode>;
36
+ default: undefined;
37
+ };
32
38
  };
39
+ export declare type MultiCascaderComposeProps = Partial<ExtractPropTypes<ReturnType<typeof multiCascaderComposeProps>>>;
40
+ export {};
@@ -72,9 +72,7 @@ declare const BmSearchFilter: import("bm-admin-ui/es/utils/with-install").SFCWit
72
72
  gutter: number[];
73
73
  };
74
74
  form: {
75
- labelCol: {
76
- [x: string]: any;
77
- };
75
+ labelCol: Record<string, any>;
78
76
  labelAlign: string;
79
77
  wrapperCol: {
80
78
  span: number;
@@ -1,5 +1,5 @@
1
1
  import { withInstall } from 'bm-admin-ui/es/utils/with-install';
2
- import { h, nextTick, createVNode, defineComponent, ref, resolveComponent, openBlock, createElementBlock, createTextVNode, toDisplayString, createBlock, unref, normalizeStyle, createCommentVNode, withCtx, computed, Fragment, renderList, createElementVNode, withModifiers, normalizeClass, reactive, onBeforeUnmount, watch } from 'vue';
2
+ import { h, nextTick, createVNode, defineComponent, ref, resolveComponent, openBlock, createElementBlock, createTextVNode, toDisplayString, createBlock, unref, normalizeStyle, createCommentVNode, withCtx, computed, Fragment, renderList, createElementVNode, withModifiers, normalizeClass, renderSlot, reactive, onBeforeUnmount, watch } from 'vue';
3
3
  import FormCreateCtr from '@form-create/ant-design-vue';
4
4
 
5
5
  /**
@@ -66,7 +66,7 @@ function boundAlpha(a) {
66
66
  */
67
67
  function convertToPercentage(n) {
68
68
  if (n <= 1) {
69
- return "".concat(Number(n) * 100, "%");
69
+ return Number(n) * 100 + "%";
70
70
  }
71
71
  return n;
72
72
  }
@@ -448,12 +448,12 @@ var CSS_INTEGER = '[-\\+]?\\d+%?';
448
448
  // <http://www.w3.org/TR/css3-values/#number-value>
449
449
  var CSS_NUMBER = '[-\\+]?\\d*\\.\\d+%?';
450
450
  // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.
451
- var CSS_UNIT = "(?:".concat(CSS_NUMBER, ")|(?:").concat(CSS_INTEGER, ")");
451
+ var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")";
452
452
  // Actual matching.
453
453
  // Parentheses and commas are optional, but not required.
454
454
  // Whitespace can take the place of commas or opening paren
455
- var PERMISSIVE_MATCH3 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
456
- var PERMISSIVE_MATCH4 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
455
+ var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
456
+ var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
457
457
  var matchers = {
458
458
  CSS_UNIT: new RegExp(CSS_UNIT),
459
459
  rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),
@@ -778,19 +778,6 @@ Object.keys(presetPrimaryColors).forEach(function (key) {
778
778
  });
779
779
  presetDarkPalettes[key].primary = presetDarkPalettes[key][5];
780
780
  });
781
- presetPalettes.red;
782
- presetPalettes.volcano;
783
- presetPalettes.gold;
784
- presetPalettes.orange;
785
- presetPalettes.yellow;
786
- presetPalettes.lime;
787
- presetPalettes.green;
788
- presetPalettes.cyan;
789
- presetPalettes.blue;
790
- presetPalettes.geekblue;
791
- presetPalettes.purple;
792
- presetPalettes.magenta;
793
- presetPalettes.grey;
794
781
 
795
782
  // https://github.com/substack/insert-css
796
783
  var containers = []; // will store container HTMLElement references
@@ -1249,6 +1236,7 @@ const _hoisted_1$2 = { class: "bm-search-filter-btn" };
1249
1236
  const _hoisted_2$1 = /* @__PURE__ */ createTextVNode("\u67E5\u8BE2");
1250
1237
  const _hoisted_3$1 = /* @__PURE__ */ createTextVNode("\u91CD\u7F6E");
1251
1238
  const _sfc_main$2 = /* @__PURE__ */ defineComponent({
1239
+ __name: "search-reset-btn",
1252
1240
  props: searchResetBtnProps,
1253
1241
  emits: ["submit", "reset", "expand"],
1254
1242
  setup(__props, { emit: emits }) {
@@ -1306,40 +1294,46 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
1306
1294
  });
1307
1295
  var SearchResetBtn = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__file", "search-reset-btn.vue"]]);
1308
1296
 
1309
- const propsConfig = {
1310
- options: {
1311
- type: Array,
1312
- default() {
1313
- return [];
1297
+ function multiCascaderComposeProps() {
1298
+ return {
1299
+ options: {
1300
+ type: Array,
1301
+ default() {
1302
+ return [];
1303
+ },
1314
1304
  },
1315
- },
1316
- modelValue: {
1317
- type: Array,
1318
- default() {
1319
- return [];
1305
+ modelValue: {
1306
+ type: Array,
1307
+ default() {
1308
+ return [];
1309
+ },
1320
1310
  },
1321
- },
1322
- optionValueName: {
1323
- type: String,
1324
- default: 'value',
1325
- },
1326
- optionLabelName: {
1327
- type: String,
1328
- default: 'label',
1329
- },
1330
- maxTagCount: {
1331
- type: Number,
1332
- default: 1,
1333
- },
1334
- placeholder: {
1335
- type: String,
1336
- default: '请选择',
1337
- },
1338
- allowClear: {
1339
- type: Boolean,
1340
- default: true,
1341
- },
1342
- };
1311
+ optionValueName: {
1312
+ type: String,
1313
+ default: 'value',
1314
+ },
1315
+ optionLabelName: {
1316
+ type: String,
1317
+ default: 'label',
1318
+ },
1319
+ maxTagCount: {
1320
+ type: Number,
1321
+ default: 1,
1322
+ },
1323
+ placeholder: {
1324
+ type: String,
1325
+ default: '请选择',
1326
+ },
1327
+ allowClear: {
1328
+ type: Boolean,
1329
+ default: true,
1330
+ },
1331
+ emptyImage: {
1332
+ type: [String, Object],
1333
+ default: undefined,
1334
+ },
1335
+ };
1336
+ }
1343
1337
 
1344
1338
  const _hoisted_1$1 = { class: "bm-multi-cascader-wrapper" };
1345
1339
  const _hoisted_2 = { class: "bm-multi-cascader" };
@@ -1380,7 +1374,7 @@ const __default__$1 = {
1380
1374
  };
1381
1375
  const _sfc_main$1 = /* @__PURE__ */ defineComponent({
1382
1376
  ...__default__$1,
1383
- props: propsConfig,
1377
+ props: multiCascaderComposeProps(),
1384
1378
  emits: ["update:modelValue", "change"],
1385
1379
  setup(__props, { emit: emits }) {
1386
1380
  const props = __props;
@@ -1758,7 +1752,12 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
1758
1752
  }), 128))
1759
1753
  ])) : (openBlock(), createElementBlock("div", _hoisted_18, [
1760
1754
  createElementVNode("div", _hoisted_19, [
1761
- createVNode(_component_a_empty, { class: "bm-multi-cascader-popover-empty" })
1755
+ renderSlot(_ctx.$slots, "empty", {}, () => [
1756
+ createVNode(_component_a_empty, {
1757
+ class: "bm-multi-cascader-popover-empty",
1758
+ image: props.emptyImage
1759
+ }, null, 8, ["image"])
1760
+ ])
1762
1761
  ])
1763
1762
  ]))
1764
1763
  ]),
@@ -1798,7 +1797,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
1798
1797
  ])
1799
1798
  ])
1800
1799
  ]),
1801
- _: 1
1800
+ _: 3
1802
1801
  })
1803
1802
  ]);
1804
1803
  };
@@ -1912,7 +1911,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
1912
1911
  "onUpdate:api": _cache[0] || (_cache[0] = ($event) => fApi.value = $event),
1913
1912
  "model-value": _ctx.value,
1914
1913
  rule: unref(rule),
1915
- option: unref(option),
1914
+ option,
1916
1915
  onChange: handleChange
1917
1916
  }, null, 8, ["api", "model-value", "rule", "option"])
1918
1917
  ]);
@@ -72,9 +72,7 @@ declare const _default: import("vue").DefineComponent<{
72
72
  gutter: number[];
73
73
  };
74
74
  form: {
75
- labelCol: {
76
- [x: string]: any;
77
- };
75
+ labelCol: Record<string, any>;
78
76
  labelAlign: string;
79
77
  wrapperCol: {
80
78
  span: number;