bm-admin-ui 1.1.15-alpha → 1.1.17-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 (27) hide show
  1. package/es/components/float-table/index.d.ts +2 -2
  2. package/es/components/float-table/src/float-table.vue.d.ts +2 -2
  3. package/es/components/form-create/index.js +115 -47
  4. package/es/components/form-designer/index.js +43 -13
  5. package/es/components/staffs-selector/index.d.ts +4 -4
  6. package/es/components/staffs-selector/index.js +2 -2
  7. package/es/components/staffs-selector/src/departmentCmp.vue.d.ts +2 -2
  8. package/es/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  9. package/es/components/staffs-selector/src/staffs-selector.vue.d.ts +4 -4
  10. package/es/utils/isNull.js +1 -1
  11. package/lib/components/float-table/index.d.ts +2 -2
  12. package/lib/components/float-table/src/float-table.vue.d.ts +2 -2
  13. package/lib/components/form-create/index.js +104 -36
  14. package/lib/components/form-designer/index.js +43 -13
  15. package/lib/components/staffs-selector/index.d.ts +4 -4
  16. package/lib/components/staffs-selector/index.js +2 -2
  17. package/lib/components/staffs-selector/src/departmentCmp.vue.d.ts +2 -2
  18. package/lib/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  19. package/lib/components/staffs-selector/src/staffs-selector.vue.d.ts +4 -4
  20. package/lib/utils/isNull.js +1 -1
  21. package/package.json +1 -1
  22. package/types/components/float-table/index.d.ts +2 -2
  23. package/types/components/float-table/src/float-table.vue.d.ts +2 -2
  24. package/types/components/staffs-selector/index.d.ts +4 -4
  25. package/types/components/staffs-selector/src/departmentCmp.vue.d.ts +2 -2
  26. package/types/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  27. package/types/components/staffs-selector/src/staffs-selector.vue.d.ts +4 -4
@@ -42,9 +42,9 @@ declare const BmFloatTable: import("bm-admin-ui/es/utils/with-install").SFCWithI
42
42
  gridOptions: import("vue").ComputedRef<any>;
43
43
  gridEvents: import("vue").ComputedRef<any>;
44
44
  pager: import("vue").ComputedRef<any>;
45
- simpleImage: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
45
+ simpleImage: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
46
46
  [key: string]: any;
47
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
47
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
48
48
  [key: string]: any;
49
49
  }> | null | undefined)[]>;
50
50
  floatRefsId: import("vue").Ref<{}>;
@@ -42,9 +42,9 @@ declare const _default: {
42
42
  gridOptions: import("vue").ComputedRef<any>;
43
43
  gridEvents: import("vue").ComputedRef<any>;
44
44
  pager: import("vue").ComputedRef<any>;
45
- simpleImage: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
45
+ simpleImage: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
46
46
  [key: string]: any;
47
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
47
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
48
48
  [key: string]: any;
49
49
  }> | null | undefined)[]>;
50
50
  floatRefsId: import("vue").Ref<{}>;
@@ -1,5 +1,5 @@
1
1
  import { withInstall } from 'bm-admin-ui/es/utils/with-install';
2
- import { h, defineComponent, computed, openBlock, createBlock, unref, withCtx, createElementBlock, Fragment, renderList, createTextVNode, toDisplayString, nextTick, ref, createVNode, normalizeStyle, withModifiers, createElementVNode, createCommentVNode, normalizeClass, reactive, watch, createSlots, inject, createStaticVNode, provide, resolveComponent } from 'vue';
2
+ import { h, defineComponent, computed, openBlock, createBlock, unref, withCtx, createElementBlock, Fragment, renderList, createTextVNode, toDisplayString, nextTick as nextTick$1, ref, createVNode, normalizeStyle, withModifiers, createElementVNode, createCommentVNode, normalizeClass, reactive, watch, createSlots, inject, createStaticVNode, provide, resolveComponent } from 'vue';
3
3
  import { Input, InputNumber, RadioGroup, Radio, Select, DatePicker, RangePicker, message, Modal, Layout, LayoutSider, Tree, LayoutContent, Button, Row, Col, Pagination, FormItemRest, Divider, Tabs, TabPane, Cascader } from 'ant-design-vue';
4
4
  import dayjs from 'dayjs';
5
5
  import Picture from 'bm-admin-ui/es/components/upload';
@@ -690,7 +690,7 @@ var picture = {
690
690
  update(inject, list) {
691
691
  const rule = inject.self;
692
692
  inject.api.form[rule.field] = list;
693
- nextTick(() => {
693
+ nextTick$1(() => {
694
694
  inject.api.validateField(rule.field);
695
695
  });
696
696
  },
@@ -738,7 +738,7 @@ var picture = {
738
738
  update(inject, list) {
739
739
  const rule = inject.self;
740
740
  inject.api.form[rule.field] = list;
741
- nextTick(() => {
741
+ nextTick$1(() => {
742
742
  inject.api.validateField(rule.field);
743
743
  });
744
744
  },
@@ -786,7 +786,7 @@ var file = {
786
786
  update(inject, list) {
787
787
  const rule = inject.self;
788
788
  inject.api.form[rule.field] = list;
789
- nextTick(() => {
789
+ nextTick$1(() => {
790
790
  inject.api.validateField(rule.field);
791
791
  });
792
792
  },
@@ -827,7 +827,7 @@ var file = {
827
827
  update(inject, list) {
828
828
  const rule = inject.self;
829
829
  inject.api.form[rule.field] = list;
830
- nextTick(() => {
830
+ nextTick$1(() => {
831
831
  inject.api.validateField(rule.field);
832
832
  });
833
833
  },
@@ -941,14 +941,16 @@ var people = {
941
941
  },
942
942
  inject: true,
943
943
  on: {
944
- change(inject, list) {
945
- const rule = inject.self;
946
- rule.props.defaultSelected = list;
947
- inject.api.form[rule.field] = list;
948
- inject.api.validateField(rule.field, () => {
949
- if (list.length) {
950
- inject.api.clearValidateState(rule.field);
951
- }
944
+ change({ api, self }, list) {
945
+ const rule = self;
946
+ nextTick(() => {
947
+ rule.props.defaultSelected = list;
948
+ api.form[rule.field] = list;
949
+ api.validateField(rule.field, () => {
950
+ if (list.length) {
951
+ api.clearValidateState(rule.field);
952
+ }
953
+ });
952
954
  });
953
955
  },
954
956
  },
@@ -981,14 +983,16 @@ var people = {
981
983
  },
982
984
  inject: true,
983
985
  on: {
984
- change(inject, list) {
985
- const rule = inject.self;
986
- rule.props.defaultSelected = list;
987
- inject.api.form[rule.field] = list;
988
- inject.api.validateField(rule.field, () => {
989
- if (list.length) {
990
- inject.api.clearValidateState(rule.field);
991
- }
986
+ change({ api, self }, list) {
987
+ const rule = self;
988
+ nextTick(() => {
989
+ rule.props.defaultSelected = list;
990
+ api.form[rule.field] = list;
991
+ api.validateField(rule.field, () => {
992
+ if (list.length) {
993
+ api.clearValidateState(rule.field);
994
+ }
995
+ });
992
996
  });
993
997
  },
994
998
  },
@@ -18577,9 +18581,10 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
18577
18581
  "value",
18578
18582
  "disabled",
18579
18583
  "shopValue",
18580
- "doNotClearAfterFilterChange"
18584
+ "doNotClearAfterFilterChange",
18585
+ "fetchMode"
18581
18586
  ],
18582
- emits: ["change"],
18587
+ emits: ["change", "blur", "pressEnter"],
18583
18588
  setup(__props, { emit: emits }) {
18584
18589
  const props = __props;
18585
18590
  const debounceFn = lodash.exports.debounce(emitChange, 500);
@@ -18587,6 +18592,12 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
18587
18592
  function emitChange(val) {
18588
18593
  emits("change", val);
18589
18594
  }
18595
+ function handleBlur(val) {
18596
+ emits("blur", val);
18597
+ }
18598
+ function handlePressEnter(val) {
18599
+ emits("pressEnter", val);
18600
+ }
18590
18601
  watch(
18591
18602
  () => props.value,
18592
18603
  (val) => {
@@ -18605,13 +18616,23 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
18605
18616
  }
18606
18617
  );
18607
18618
  return (_ctx, _cache) => {
18608
- return openBlock(), createBlock(unref(Input), {
18619
+ return props.fetchMode === "blur" ? (openBlock(), createBlock(unref(Input), {
18620
+ key: 0,
18609
18621
  value: inputValue.value,
18610
18622
  "onUpdate:value": _cache[0] || (_cache[0] = ($event) => inputValue.value = $event),
18611
18623
  placeholder: "\u8BF7\u8F93\u5165",
18612
18624
  disabled: __props.disabled,
18613
- onChange: _cache[1] || (_cache[1] = ($event) => unref(debounceFn)($event.target.value))
18614
- }, null, 8, ["value", "disabled"]);
18625
+ onChange: _cache[1] || (_cache[1] = ($event) => emitChange($event.target.value)),
18626
+ onBlur: _cache[2] || (_cache[2] = ($event) => handleBlur($event.target?.value)),
18627
+ onPressEnter: _cache[3] || (_cache[3] = ($event) => handlePressEnter($event.target?.value))
18628
+ }, null, 8, ["value", "disabled"])) : (openBlock(), createBlock(unref(Input), {
18629
+ key: 1,
18630
+ value: inputValue.value,
18631
+ "onUpdate:value": _cache[4] || (_cache[4] = ($event) => inputValue.value = $event),
18632
+ placeholder: "\u8BF7\u8F93\u5165",
18633
+ disabled: __props.disabled,
18634
+ onChange: _cache[5] || (_cache[5] = ($event) => unref(debounceFn)($event.target.value))
18635
+ }, null, 8, ["value", "disabled"]));
18615
18636
  };
18616
18637
  }
18617
18638
  });
@@ -18620,14 +18641,20 @@ var ProductInput = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["__file", "product
18620
18641
  const _sfc_main$9 = /* @__PURE__ */ defineComponent({
18621
18642
  __name: "customer-input-in-table",
18622
18643
  props: ["value", "disabled", "shopValue"],
18623
- emits: ["change"],
18644
+ emits: ["change", "blur", "pressEnter"],
18624
18645
  setup(__props, { emit: emits }) {
18625
18646
  const props = __props;
18626
- const debounceFn = lodash.exports.debounce(emitChange, 500);
18647
+ lodash.exports.debounce(emitChange, 500);
18627
18648
  const inputValue = ref();
18628
18649
  function emitChange(val) {
18629
18650
  emits("change", val);
18630
18651
  }
18652
+ function handleBlur(val) {
18653
+ emits("blur", val);
18654
+ }
18655
+ function handlePressEnter(val) {
18656
+ emits("pressEnter", val);
18657
+ }
18631
18658
  watch(
18632
18659
  () => props.value,
18633
18660
  (val) => {
@@ -18649,7 +18676,9 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
18649
18676
  "onUpdate:value": _cache[0] || (_cache[0] = ($event) => inputValue.value = $event),
18650
18677
  placeholder: "\u8BF7\u8F93\u5165",
18651
18678
  disabled: __props.disabled,
18652
- onChange: _cache[1] || (_cache[1] = ($event) => unref(debounceFn)($event.target.value))
18679
+ onChange: _cache[1] || (_cache[1] = ($event) => emitChange($event.target.value)),
18680
+ onBlur: _cache[2] || (_cache[2] = ($event) => handleBlur($event.target?.value)),
18681
+ onPressEnter: _cache[3] || (_cache[3] = ($event) => handlePressEnter($event.target?.value))
18653
18682
  }, null, 8, ["value", "disabled"]);
18654
18683
  };
18655
18684
  }
@@ -19001,7 +19030,7 @@ const _sfc_main$7 = defineComponent({
19001
19030
  }
19002
19031
  }
19003
19032
  ];
19004
- if (associatedFields.length) {
19033
+ if (associatedFields?.length) {
19005
19034
  associatedFields.forEach((item) => {
19006
19035
  const childField = productPicName(item.value, field);
19007
19036
  columns2.push({
@@ -19037,7 +19066,17 @@ const _sfc_main$7 = defineComponent({
19037
19066
  return columns2;
19038
19067
  }
19039
19068
  function handleAdd(rowData) {
19040
- Array.isArray(rowData) ? data.push(...rowData) : data.push(getRowData());
19069
+ let defaultRowData = getRowData();
19070
+ if (Array.isArray(rowData)) {
19071
+ rowData.forEach((item) => {
19072
+ Object.keys(defaultRowData).forEach((field) => {
19073
+ if (item[field] === void 0) {
19074
+ item[field] = defaultRowData[field];
19075
+ }
19076
+ });
19077
+ });
19078
+ }
19079
+ Array.isArray(rowData) ? data.push(...rowData) : data.push(defaultRowData);
19041
19080
  }
19042
19081
  function handleCopy(row) {
19043
19082
  const newData = cloneDeep(row);
@@ -19407,7 +19446,7 @@ const _sfc_main$7 = defineComponent({
19407
19446
  return false;
19408
19447
  return !formData.value[shopField];
19409
19448
  }
19410
- function handlePressEnter(value, rule, row) {
19449
+ function handleProductChange(value, rule, row) {
19411
19450
  row[rule.field] = value;
19412
19451
  if (isProductCenterSuit.value && rule.field === "productCode") {
19413
19452
  Object.keys(row).forEach((key) => {
@@ -19416,8 +19455,17 @@ const _sfc_main$7 = defineComponent({
19416
19455
  }
19417
19456
  });
19418
19457
  }
19458
+ if (rule.config.fetchMode !== "blur") {
19459
+ queryProductInfo(rule, row);
19460
+ }
19461
+ }
19462
+ function handleProductPressEnter(value, rule, row) {
19463
+ row[rule.field] = value;
19419
19464
  queryProductInfo(rule, row);
19420
19465
  }
19466
+ function handleCustomerChange(value, rule, row) {
19467
+ row[rule.field] = value;
19468
+ }
19421
19469
  function handleCustomerPressEnter(value, rule, row) {
19422
19470
  row[rule.field] = value;
19423
19471
  queryCustomerInfo(rule, row);
@@ -19767,8 +19815,11 @@ const _sfc_main$7 = defineComponent({
19767
19815
  disabled: item.disabled || pruductInputDisabled(item.config?.dataFiltering),
19768
19816
  "shop-value": unref(formData)[item.config.dataFiltering],
19769
19817
  "do-not-clear-after-filter-change": getProductClearSetting(item.field),
19770
- onChange: ($event) => handlePressEnter($event, item, row)
19771
- }, null, 8, ["value", "disabled", "shop-value", "do-not-clear-after-filter-change", "onChange"])
19818
+ "fetch-mode": item.config.fetchMode,
19819
+ onChange: ($event) => handleProductChange($event, item, row),
19820
+ onBlur: ($event) => handleProductPressEnter($event, item, row),
19821
+ onPressEnter: ($event) => handleProductPressEnter($event, item, row)
19822
+ }, null, 8, ["value", "disabled", "shop-value", "do-not-clear-after-filter-change", "fetch-mode", "onChange", "onBlur", "onPressEnter"])
19772
19823
  ])
19773
19824
  };
19774
19825
  }),
@@ -19794,8 +19845,10 @@ const _sfc_main$7 = defineComponent({
19794
19845
  value: row[item.field],
19795
19846
  disabled: item.disabled || pruductInputDisabled(item.config?.dataFiltering),
19796
19847
  "shop-value": unref(formData)[item.config.dataFiltering],
19797
- onChange: ($event) => handleCustomerPressEnter($event, item, row)
19798
- }, null, 8, ["value", "disabled", "shop-value", "onChange"])
19848
+ onChange: ($event) => handleCustomerChange($event, item, row),
19849
+ onBlur: ($event) => handleCustomerPressEnter($event, item, row),
19850
+ onPressEnter: ($event) => handleCustomerPressEnter($event, item, row)
19851
+ }, null, 8, ["value", "disabled", "shop-value", "onChange", "onBlur", "onPressEnter"])
19799
19852
  ])
19800
19853
  };
19801
19854
  })
@@ -20455,7 +20508,8 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
20455
20508
  "extraConfig",
20456
20509
  "defalutValue",
20457
20510
  "disabled",
20458
- "formCreateInject"
20511
+ "formCreateInject",
20512
+ "fetchMode"
20459
20513
  ],
20460
20514
  emits: ["change"],
20461
20515
  setup(__props, { emit: emits }) {
@@ -20554,14 +20608,23 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
20554
20608
  }),
20555
20609
  createVNode(unref(Col), { flex: 1 }, {
20556
20610
  default: withCtx(() => [
20557
- createVNode(unref(Input), {
20611
+ props.fetchMode === "blur" ? (openBlock(), createBlock(unref(Input), {
20612
+ key: 0,
20558
20613
  value: inputValue.value,
20559
20614
  "onUpdate:value": _cache[0] || (_cache[0] = ($event) => inputValue.value = $event),
20560
20615
  placeholder: "\u8BF7\u8F93\u5165",
20561
20616
  disabled: __props.disabled || inputDisbale(__props.dataFiltering),
20617
+ onPressEnter: unref(debounceFn),
20618
+ onBlur: handleBlur
20619
+ }, null, 8, ["value", "disabled", "onPressEnter"])) : (openBlock(), createBlock(unref(Input), {
20620
+ key: 1,
20621
+ value: inputValue.value,
20622
+ "onUpdate:value": _cache[1] || (_cache[1] = ($event) => inputValue.value = $event),
20623
+ placeholder: "\u8BF7\u8F93\u5165",
20624
+ disabled: __props.disabled || inputDisbale(__props.dataFiltering),
20562
20625
  onPressEnter: handleBlur,
20563
20626
  onChange: handleChange
20564
- }, null, 8, ["value", "disabled"])
20627
+ }, null, 8, ["value", "disabled"]))
20565
20628
  ]),
20566
20629
  _: 1
20567
20630
  })
@@ -20638,12 +20701,13 @@ var product = {
20638
20701
  doNotClearAfterFilterChange: data.config.doNotClearAfterFilterChange,
20639
20702
  extraConfig: extraConfig,
20640
20703
  defalutValue: data.value,
20704
+ fetchMode: data.config.fetchMode,
20641
20705
  },
20642
20706
  inject: true,
20643
20707
  on: {
20644
20708
  change(inject, value) {
20645
20709
  inject.self.props.defalutValue = value;
20646
- nextTick(() => {
20710
+ nextTick$1(() => {
20647
20711
  inject.api.form[inject.self.field] = value;
20648
20712
  setTimeout(() => {
20649
20713
  inject.api.validateField(inject.self.field);
@@ -20668,12 +20732,13 @@ var product = {
20668
20732
  doNotClearAfterFilterChange: data.config.doNotClearAfterFilterChange,
20669
20733
  defalutValue: data.value,
20670
20734
  extraConfig: extraConfig,
20735
+ fetchMode: data.config.fetchMode,
20671
20736
  },
20672
20737
  inject: true,
20673
20738
  on: {
20674
20739
  change(inject, value) {
20675
20740
  inject.self.props.defalutValue = value;
20676
- nextTick(() => {
20741
+ nextTick$1(() => {
20677
20742
  inject.api.form[inject.self.field] = value;
20678
20743
  setTimeout(() => {
20679
20744
  inject.api.validateField(inject.self.field);
@@ -20895,7 +20960,7 @@ var shop = {
20895
20960
  change(inject, value) {
20896
20961
  const rule = inject.self;
20897
20962
  inject.api.form[inject.self.field] = value;
20898
- nextTick(() => {
20963
+ nextTick$1(() => {
20899
20964
  setTimeout(() => {
20900
20965
  inject.api.validateField(rule.field);
20901
20966
  });
@@ -20911,7 +20976,6 @@ var shop = {
20911
20976
  return {
20912
20977
  type: 'ShopWidget',
20913
20978
  component: ShopWidget,
20914
- title: data.title.title,
20915
20979
  field: data.field,
20916
20980
  effect: {
20917
20981
  required: data.effect.required && '请选择店铺',
@@ -20919,13 +20983,15 @@ var shop = {
20919
20983
  props: {
20920
20984
  dataFiltering: (_a = data.config) === null || _a === void 0 ? void 0 : _a.dataFiltering,
20921
20985
  extraConfig: shopExtraConfig,
20986
+ associatedFields: data.config.associatedFields,
20987
+ title: `${data.title.title}`,
20922
20988
  },
20923
20989
  inject: true,
20924
20990
  on: {
20925
20991
  change(inject, value) {
20926
20992
  const rule = inject.self;
20927
20993
  inject.api.form[inject.self.field] = value;
20928
- nextTick(() => {
20994
+ nextTick$1(() => {
20929
20995
  setTimeout(() => {
20930
20996
  inject.api.validateField(rule.field);
20931
20997
  });
@@ -20933,7 +20999,7 @@ var shop = {
20933
20999
  },
20934
21000
  },
20935
21001
  col: {
20936
- span: 12,
21002
+ span: 24,
20937
21003
  },
20938
21004
  value: data.value,
20939
21005
  };
@@ -21063,7 +21129,7 @@ var materialType = {
21063
21129
  rule.props.value = list;
21064
21130
  inject.api.form[rule.field] = list;
21065
21131
  inject.api.emit('update:modelValue', inject.api.form);
21066
- nextTick(() => {
21132
+ nextTick$1(() => {
21067
21133
  setTimeout(() => {
21068
21134
  inject.api.validateField(rule.field);
21069
21135
  });
@@ -21101,7 +21167,7 @@ var materialType = {
21101
21167
  rule.value = list;
21102
21168
  rule.props.value = list;
21103
21169
  inject.api.emit('update:modelValue', inject.api.form);
21104
- nextTick(() => {
21170
+ nextTick$1(() => {
21105
21171
  setTimeout(() => {
21106
21172
  inject.api.validateField(rule.field);
21107
21173
  });
@@ -21336,6 +21402,7 @@ var table = {
21336
21402
  message: '请检查必填项',
21337
21403
  },
21338
21404
  ],
21405
+ wrap: data.wrap,
21339
21406
  };
21340
21407
  },
21341
21408
  rowRule(data, extraConfig) {
@@ -21366,6 +21433,7 @@ var table = {
21366
21433
  col: {
21367
21434
  span: 24,
21368
21435
  },
21436
+ wrap: data.wrap,
21369
21437
  };
21370
21438
  },
21371
21439
  };
@@ -3548,10 +3548,6 @@ const formDesignerProps = {
3548
3548
  type: Boolean,
3549
3549
  default: false,
3550
3550
  },
3551
- dragCheckFunc: {
3552
- type: Function,
3553
- default: (underlying_vm) => true,
3554
- },
3555
3551
  formRulePipe: {
3556
3552
  type: Function,
3557
3553
  default: (obj) => obj,
@@ -3560,14 +3556,14 @@ const formDesignerProps = {
3560
3556
  type: Function,
3561
3557
  default: (pushRuleWidget, pushRowWidget, pushTableWidget) => null,
3562
3558
  },
3563
- deleteFormItemCheck: {
3564
- type: Function,
3565
- default: (targetRule, parentRule) => true,
3566
- },
3567
3559
  resetCmpRatio: {
3568
3560
  type: Function,
3569
3561
  default: (ruleName, parentRuleName) => 0,
3570
3562
  },
3563
+ dragingCallback: {
3564
+ type: Object,
3565
+ default: () => ({}),
3566
+ },
3571
3567
  };
3572
3568
 
3573
3569
  const _hoisted_1$3 = {
@@ -3954,6 +3950,19 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
3954
3950
  department: "\u9664\u201C\u5FC5\u586B\u3001\u9009\u9879\u201D\u5185\u5BB9\u8BBE\u7F6E\u4E0D\u53EF\u4FEE\u6539\uFF0C\u5176\u4ED6\u4FE1\u606F\u53EF\u4FEE\u6539"
3955
3951
  };
3956
3952
  const tabData = typeof props.formRulePipe === "function" ? props.formRulePipe(createTab()) : [];
3953
+ (() => {
3954
+ if (!(tabData instanceof Array)) {
3955
+ console.error("formRulePipe\u5C5E\u6027\u8FD4\u56DE\u53C2\u6570\u7C7B\u578B\u5E94\u4E3AArray");
3956
+ }
3957
+ tabData.some((tab) => {
3958
+ if (!tab["key"] || !tab["tab"] || !tab["menuList"] || !(tab["menuList"] instanceof Array)) {
3959
+ console.error(
3960
+ "\u8BF7\u6B63\u786E\u914D\u7F6EformRulePipe\u8FD4\u56DE\u6570\u7EC4\u7C7B\u578B:{key:string, tab:string, menuList: {name:string, title: string, list: any[]}[]}[]"
3961
+ );
3962
+ return true;
3963
+ }
3964
+ });
3965
+ })();
3957
3966
  typeof props.addWidgetFunc === "function" && props.addWidgetFunc(pushRuleWidgets, pushRowWidgets, pushTableWidgets);
3958
3967
  const activeKey = ref("controlLibrary");
3959
3968
  const widgetFormRules = reactive([]);
@@ -3961,6 +3970,18 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
3961
3970
  const cacheProps = reactive({});
3962
3971
  const fApi = ref();
3963
3972
  const activeParentRule = ref();
3973
+ const defaultCallbackfun = {
3974
+ movingCallback: (config) => true,
3975
+ deleteCallback: (targetRule, parentRule) => true,
3976
+ afterAdded: (targetRule, parentRule) => null,
3977
+ rearrangeCallback: (config) => true
3978
+ };
3979
+ function executeCallback(func) {
3980
+ if (!props.dragingCallback[func] || typeof props.dragingCallback[func] !== "function") {
3981
+ return defaultCallbackfun[func];
3982
+ }
3983
+ return props.dragingCallback[func];
3984
+ }
3964
3985
  const menuList = computed(
3965
3986
  () => tabData.find((tab) => tab.key === activeKey.value)?.menuList
3966
3987
  );
@@ -3993,10 +4014,14 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
3993
4014
  }
3994
4015
  }
3995
4016
  function moveMenuItem(evt) {
3996
- return props?.dragCheckFunc(evt?.dragged?._underlying_vm_?.config?.config) && checkDragMove(evt);
4017
+ return executeCallback("movingCallback")(
4018
+ evt?.dragged?._underlying_vm_?.config?.config
4019
+ ) && checkDragMove(evt);
3997
4020
  }
3998
4021
  function moveFormItem(evt) {
3999
- return props?.dragCheckFunc(evt?.dragged?._underlying_vm_) && checkDragMove(evt);
4022
+ return executeCallback("rearrangeCallback")(
4023
+ evt?.dragged?._underlying_vm_?.config?.config
4024
+ ) && checkDragMove(evt);
4000
4025
  }
4001
4026
  function handleMenuItemDragStart(evt) {
4002
4027
  const item = evt.item.children[0];
@@ -4021,7 +4046,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
4021
4046
  const activeParentRuleName = activeParentRule.value?.config?.config?.name;
4022
4047
  if (!widgetNamesRowAccept.includes(config.name) && activeParentRuleName === "row" || !Object.keys(widgetsTableAccept).includes(config.name) && activeParentRuleName === "table") {
4023
4048
  disabledTip(activeParentRule.value?.config?.config?.name);
4024
- } else if (!props?.dragCheckFunc(config)) {
4049
+ } else if (!executeCallback("movingCallback")(config)) {
4025
4050
  return;
4026
4051
  } else {
4027
4052
  const index = activeRuleInList.value.findIndex(
@@ -4058,6 +4083,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
4058
4083
  }
4059
4084
  function handleFormItemAdd({ newIndex }) {
4060
4085
  const rule = widgetFormRules[newIndex];
4086
+ executeCallback("afterAdded")(rule, void 0);
4061
4087
  dragAdd(rule);
4062
4088
  hideShowDragTip();
4063
4089
  }
@@ -4093,7 +4119,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
4093
4119
  return newRule;
4094
4120
  }
4095
4121
  function handleFormItemCopy(rule, parentRule) {
4096
- if (!props?.dragCheckFunc(rule.config.config)) {
4122
+ if (!executeCallback("movingCallback")(rule.config.config)) {
4097
4123
  return;
4098
4124
  }
4099
4125
  const newRule = copyRule(
@@ -4104,7 +4130,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
4104
4130
  setActiveRule(newRule, parentRule);
4105
4131
  }
4106
4132
  function handleFormItemDelete(targetRule, parentRule) {
4107
- const customerCheck = props.deleteFormItemCheck(targetRule, parentRule);
4133
+ const customerCheck = executeCallback("deleteCallback")(
4134
+ targetRule,
4135
+ parentRule
4136
+ );
4108
4137
  if (!customerCheck) {
4109
4138
  return;
4110
4139
  }
@@ -4200,6 +4229,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
4200
4229
  });
4201
4230
  }
4202
4231
  function handleWidgetAdd(rule, parentRule) {
4232
+ executeCallback("afterAdded")(rule, parentRule);
4203
4233
  dragAdd(rule, parentRule);
4204
4234
  }
4205
4235
  function handlePropsSetActive(rule) {
@@ -902,9 +902,9 @@ declare const BmStaffsSelector: import("bm-admin-ui/es/utils/with-install").SFCW
902
902
  searchVal: import("vue").Ref<string>;
903
903
  selectAll: import("vue").Ref<boolean>;
904
904
  indeterminate: import("vue").Ref<boolean>;
905
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
905
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
906
906
  [key: string]: any;
907
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
907
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
908
908
  [key: string]: any;
909
909
  }> | null | undefined)[]>;
910
910
  isFulfill: import("vue").Ref<boolean>;
@@ -977,9 +977,9 @@ declare const BmStaffsSelector: import("bm-admin-ui/es/utils/with-install").SFCW
977
977
  searchVal: import("vue").Ref<string>;
978
978
  selectAll: import("vue").Ref<boolean>;
979
979
  indeterminate: import("vue").Ref<boolean>;
980
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
980
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
981
981
  [key: string]: any;
982
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
982
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
983
983
  [key: string]: any;
984
984
  }> | null | undefined)[]>;
985
985
  isFulfill: import("vue").Ref<boolean>;
@@ -191,13 +191,13 @@ function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
191
191
  value: _ctx.searchVal,
192
192
  "onUpdate:value": _cache[0] || (_cache[0] = ($event) => _ctx.searchVal = $event),
193
193
  placeholder: "\u8BF7\u8F93\u5165\u59D3\u540D",
194
- onBlur: _ctx.search
194
+ onChange: _ctx.search
195
195
  }, {
196
196
  suffix: withCtx(() => [
197
197
  createVNode(_component_search_outlined, { style: { color: "#9393A3" } })
198
198
  ]),
199
199
  _: 1
200
- }, 8, ["value", "onBlur"]),
200
+ }, 8, ["value", "onChange"]),
201
201
  createElementVNode("div", _hoisted_4$3, [
202
202
  createElementVNode("div", _hoisted_5$3, [
203
203
  withDirectives(createVNode(_component_Checkbox, {
@@ -20,9 +20,9 @@ declare const _default: import("vue").DefineComponent<{
20
20
  searchVal: import("vue").Ref<string>;
21
21
  selectAll: import("vue").Ref<boolean>;
22
22
  indeterminate: import("vue").Ref<boolean>;
23
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
23
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
24
24
  [key: string]: any;
25
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
25
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
26
26
  [key: string]: any;
27
27
  }> | null | undefined)[]>;
28
28
  isFulfill: import("vue").Ref<boolean>;
@@ -21,9 +21,9 @@ declare const _default: import("vue").DefineComponent<{
21
21
  searchVal: import("vue").Ref<string>;
22
22
  selectAll: import("vue").Ref<boolean>;
23
23
  indeterminate: import("vue").Ref<boolean>;
24
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
24
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
25
25
  [key: string]: any;
26
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
26
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
27
27
  [key: string]: any;
28
28
  }> | null | undefined)[]>;
29
29
  isFulfill: import("vue").Ref<boolean>;
@@ -902,9 +902,9 @@ declare const _default: import("vue").DefineComponent<{
902
902
  searchVal: import("vue").Ref<string>;
903
903
  selectAll: import("vue").Ref<boolean>;
904
904
  indeterminate: import("vue").Ref<boolean>;
905
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
905
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
906
906
  [key: string]: any;
907
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
907
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
908
908
  [key: string]: any;
909
909
  }> | null | undefined)[]>;
910
910
  isFulfill: import("vue").Ref<boolean>;
@@ -977,9 +977,9 @@ declare const _default: import("vue").DefineComponent<{
977
977
  searchVal: import("vue").Ref<string>;
978
978
  selectAll: import("vue").Ref<boolean>;
979
979
  indeterminate: import("vue").Ref<boolean>;
980
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
980
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
981
981
  [key: string]: any;
982
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
982
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
983
983
  [key: string]: any;
984
984
  }> | null | undefined)[]>;
985
985
  isFulfill: import("vue").Ref<boolean>;
@@ -1,5 +1,5 @@
1
1
  export function isNull(value) {
2
- return (!value ||
2
+ return ([null, undefined, ''].includes(value) ||
3
3
  (Array.isArray(value) && !value.length) ||
4
4
  (value.constructor === Object && !Object.keys(value).length));
5
5
  }