bm-admin-ui 1.0.41-alpha → 1.0.43-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 (50) hide show
  1. package/es/components/attachment/index.d.ts +70 -0
  2. package/es/components/attachment/index.js +273 -0
  3. package/es/components/attachment/src/attachment.vue.d.ts +69 -0
  4. package/es/components/editor/index.js +12 -6
  5. package/es/components/float-table/__test__/index.test.d.ts +1 -0
  6. package/es/components/float-table/index.d.ts +2 -2
  7. package/es/components/float-table/src/float-table.vue.d.ts +2 -2
  8. package/es/components/form-create/index.js +211 -100
  9. package/es/components/form-designer/index.js +173 -42
  10. package/es/components/index.d.ts +1 -0
  11. package/es/components/index.js +1 -0
  12. package/es/components/staffs-selector/index.d.ts +2 -2
  13. package/es/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  14. package/es/components/staffs-selector/src/staffs-selector.vue.d.ts +2 -2
  15. package/es/components/upload/index.js +12 -6
  16. package/es/utils/bm-admin-ui-resolver.d.ts +3 -1
  17. package/es/utils/bm-admin-ui-resolver.js +1 -1
  18. package/index.esm.js +1225 -818
  19. package/index.js +1225 -817
  20. package/lib/components/attachment/index.d.ts +70 -0
  21. package/lib/components/attachment/index.js +278 -0
  22. package/lib/components/attachment/src/attachment.vue.d.ts +69 -0
  23. package/lib/components/editor/index.js +12 -6
  24. package/lib/components/float-table/__test__/index.test.d.ts +1 -0
  25. package/lib/components/float-table/index.d.ts +2 -2
  26. package/lib/components/float-table/src/float-table.vue.d.ts +2 -2
  27. package/lib/components/form-create/index.js +210 -99
  28. package/lib/components/form-designer/index.js +172 -41
  29. package/lib/components/index.d.ts +1 -0
  30. package/lib/components/index.js +7 -0
  31. package/lib/components/staffs-selector/index.d.ts +2 -2
  32. package/lib/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  33. package/lib/components/staffs-selector/src/staffs-selector.vue.d.ts +2 -2
  34. package/lib/components/upload/index.js +12 -6
  35. package/lib/utils/bm-admin-ui-resolver.d.ts +3 -1
  36. package/lib/utils/bm-admin-ui-resolver.js +1 -1
  37. package/package.json +2 -2
  38. package/theme-chalk/attachment.css +1 -0
  39. package/theme-chalk/form-create.css +1 -1
  40. package/theme-chalk/index.css +1 -1
  41. package/types/components/attachment/index.d.ts +70 -0
  42. package/types/components/attachment/src/attachment.vue.d.ts +69 -0
  43. package/types/components/float-table/__test__/index.test.d.ts +1 -0
  44. package/types/components/float-table/index.d.ts +2 -2
  45. package/types/components/float-table/src/float-table.vue.d.ts +2 -2
  46. package/types/components/index.d.ts +1 -0
  47. package/types/components/staffs-selector/index.d.ts +2 -2
  48. package/types/components/staffs-selector/src/multipleCmp.vue.d.ts +2 -2
  49. package/types/components/staffs-selector/src/staffs-selector.vue.d.ts +2 -2
  50. package/types/utils/bm-admin-ui-resolver.d.ts +3 -1
@@ -145,8 +145,8 @@ const _sfc_main$h = /* @__PURE__ */ vue.defineComponent({
145
145
  function handleRowWidgetMouseleave() {
146
146
  props.rule.config.isHover = true;
147
147
  }
148
- function handleRowWidgetSetActiveRule(element) {
149
- emits("setActiveRule", element, props.rule);
148
+ function handleNestSetActiveRule(element, parentRule) {
149
+ emits("setActiveRule", element, parentRule || props.rule);
150
150
  }
151
151
  function handleRowWidgetCopy(rule) {
152
152
  emitCopyEvt(rule, props.rule);
@@ -154,7 +154,7 @@ const _sfc_main$h = /* @__PURE__ */ vue.defineComponent({
154
154
  function handleRowWidgetDelete(rule) {
155
155
  emitDeleteEvt(rule, props.rule);
156
156
  }
157
- function handleRowWidgetAdd(rule) {
157
+ function handleNestAdd(rule) {
158
158
  emits("widgetAdd", rule, props.rule);
159
159
  }
160
160
  return (_ctx, _cache) => {
@@ -179,10 +179,10 @@ const _sfc_main$h = /* @__PURE__ */ vue.defineComponent({
179
179
  rule: [__props.rule],
180
180
  onNestMouseenter: handleRowWidgetMouseenter,
181
181
  onNestMouseleave: handleRowWidgetMouseleave,
182
- onNestSetActiveRule: handleRowWidgetSetActiveRule,
182
+ onNestSetActiveRule: handleNestSetActiveRule,
183
183
  onNestCopy: handleRowWidgetCopy,
184
184
  onNestDelete: handleRowWidgetDelete,
185
- onNestAdd: handleRowWidgetAdd
185
+ onNestAdd: handleNestAdd
186
186
  }, null, 8, ["option", "rule"])) : (vue.openBlock(), vue.createBlock(WidgetInstruction, {
187
187
  key: 1,
188
188
  rule: __props.rule
@@ -274,8 +274,8 @@ const _sfc_main$f = /* @__PURE__ */ vue.defineComponent({
274
274
  function handleMouseleave() {
275
275
  emits("mouseleave");
276
276
  }
277
- function emitSetActiveRuleEvt(rule) {
278
- emits("set-active-rule", rule);
277
+ function emitSetActiveRuleEvt(rule, parentRule = void 0) {
278
+ emits("set-active-rule", rule, parentRule);
279
279
  }
280
280
  function handleClick(element) {
281
281
  emitSetActiveRuleEvt(element);
@@ -294,6 +294,9 @@ const _sfc_main$f = /* @__PURE__ */ vue.defineComponent({
294
294
  function handleDelete(rule) {
295
295
  emits("delete", rule);
296
296
  }
297
+ function handleWidgetInTableActive(rule, parentRule) {
298
+ emitSetActiveRuleEvt(rule, parentRule);
299
+ }
297
300
  return (_ctx, _cache) => {
298
301
  const _component_ACol = vue.resolveComponent("ACol");
299
302
  return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$d, [
@@ -332,7 +335,8 @@ const _sfc_main$f = /* @__PURE__ */ vue.defineComponent({
332
335
  onMouseleave: handleMouseleave,
333
336
  onClick: vue.withModifiers(($event) => handleClick(element), ["stop"]),
334
337
  onCopy: handleCopy,
335
- onDelete: handleDelete
338
+ onDelete: handleDelete,
339
+ onSetActiveRule: handleWidgetInTableActive
336
340
  }, null, 8, ["rule", "active-rule", "parent-rule", "onClick"]),
337
341
  vue.createVNode(DragPlaceholder)
338
342
  ]),
@@ -476,7 +480,7 @@ var input = {
476
480
  },
477
481
  },
478
482
  effect: {
479
- required: true,
483
+ required: false,
480
484
  formRule: 'formRule',
481
485
  },
482
486
  props: {
@@ -509,6 +513,7 @@ var input = {
509
513
  field: fieldsMap$g['props.placeholder'],
510
514
  props: {
511
515
  placeholder: '请输入',
516
+ maxlength: 30,
512
517
  },
513
518
  value: rule.props.placeholder,
514
519
  },
@@ -518,6 +523,7 @@ var input = {
518
523
  field: fieldsMap$g['value'],
519
524
  props: {
520
525
  placeholder: '请输入',
526
+ maxlength: 200,
521
527
  },
522
528
  value: rule.value,
523
529
  },
@@ -577,7 +583,7 @@ var textarea = {
577
583
  },
578
584
  },
579
585
  effect: {
580
- required: true,
586
+ required: false,
581
587
  formRule: 'formRule',
582
588
  },
583
589
  props: {
@@ -611,6 +617,7 @@ var textarea = {
611
617
  field: fieldsMap$f['props.placeholder'],
612
618
  props: {
613
619
  placeholder: '请输入',
620
+ maxlength: 30,
614
621
  },
615
622
  value: rule.props.placeholder,
616
623
  },
@@ -620,6 +627,7 @@ var textarea = {
620
627
  field: fieldsMap$f['value'],
621
628
  props: {
622
629
  placeholder: '请输入',
630
+ maxlength: 5000,
623
631
  },
624
632
  value: rule.value,
625
633
  },
@@ -680,7 +688,7 @@ var numInput = {
680
688
  },
681
689
  },
682
690
  effect: {
683
- required: true,
691
+ required: false,
684
692
  formRule: 'formRule',
685
693
  },
686
694
  props: {
@@ -715,6 +723,7 @@ var numInput = {
715
723
  field: fieldsMap$e['props.placeholder'],
716
724
  props: {
717
725
  placeholder: '请输入',
726
+ maxlength: 30,
718
727
  },
719
728
  value: rule.props.placeholder,
720
729
  },
@@ -788,6 +797,7 @@ const _sfc_main$e = /* @__PURE__ */ vue.defineComponent({
788
797
  const visible = vue.ref(false);
789
798
  const text = vue.ref("");
790
799
  const repeatOption = vue.ref([]);
800
+ const maxlength = 500;
791
801
  function edit() {
792
802
  visible.value = true;
793
803
  text.value = makeText(props.options);
@@ -809,6 +819,7 @@ const _sfc_main$e = /* @__PURE__ */ vue.defineComponent({
809
819
  function handleOk() {
810
820
  const options = text.value.split("\n").reduce((pre, cur) => {
811
821
  if (cur) {
822
+ cur = cur.substring(0, maxlength - 1);
812
823
  pre.push({ value: cur, label: cur });
813
824
  }
814
825
  return pre;
@@ -877,6 +888,7 @@ const _sfc_main$e = /* @__PURE__ */ vue.defineComponent({
877
888
  "bm-handle-options__input",
878
889
  repeatOption.value.length && repeatOption.value.includes(element.value) ? "is-error" : ""
879
890
  ]),
891
+ maxlength,
880
892
  onBlur: ($event) => handleBlur(element)
881
893
  }, null, 8, ["value", "onUpdate:value", "class", "onBlur"])
882
894
  ]),
@@ -973,7 +985,7 @@ var radio = {
973
985
  },
974
986
  },
975
987
  effect: {
976
- required: true,
988
+ required: false,
977
989
  formRule: 'formRule',
978
990
  },
979
991
  options: [
@@ -1019,6 +1031,7 @@ var radio = {
1019
1031
  field: fieldsMap$d['props.placeholder'],
1020
1032
  props: {
1021
1033
  placeholder: '请输入',
1034
+ maxlength: 30,
1022
1035
  },
1023
1036
  value: rule.props.placeholder,
1024
1037
  },
@@ -1111,7 +1124,7 @@ var checkbox = {
1111
1124
  },
1112
1125
  },
1113
1126
  effect: {
1114
- required: true,
1127
+ required: false,
1115
1128
  formRule: 'formRule',
1116
1129
  },
1117
1130
  options: [
@@ -1157,6 +1170,7 @@ var checkbox = {
1157
1170
  field: fieldsMap$c['props.placeholder'],
1158
1171
  props: {
1159
1172
  placeholder: '请输入',
1173
+ maxlength: 30,
1160
1174
  },
1161
1175
  value: rule.props.placeholder,
1162
1176
  },
@@ -1318,7 +1332,7 @@ var date = {
1318
1332
  },
1319
1333
  },
1320
1334
  effect: {
1321
- required: true,
1335
+ required: false,
1322
1336
  formRule: 'formRule',
1323
1337
  },
1324
1338
  props: {
@@ -1381,6 +1395,7 @@ var date = {
1381
1395
  field: fieldsMap$b['props.placeholder'],
1382
1396
  props: {
1383
1397
  placeholder: '请输入',
1398
+ maxlength: 30,
1384
1399
  },
1385
1400
  value: rule.props.placeholder,
1386
1401
  },
@@ -1462,7 +1477,7 @@ var dateRange = {
1462
1477
  },
1463
1478
  },
1464
1479
  effect: {
1465
- required: true,
1480
+ required: false,
1466
1481
  formRule: 'formRule',
1467
1482
  },
1468
1483
  props: {
@@ -1527,6 +1542,7 @@ var dateRange = {
1527
1542
  field: fieldsMap$a['props.placeholder.0'],
1528
1543
  props: {
1529
1544
  placeholder: '请输入',
1545
+ maxlength: 30,
1530
1546
  },
1531
1547
  value: rule.props.placeholder[0],
1532
1548
  },
@@ -1536,6 +1552,7 @@ var dateRange = {
1536
1552
  field: fieldsMap$a['props.placeholder.1'],
1537
1553
  props: {
1538
1554
  placeholder: '请输入',
1555
+ maxlength: 30,
1539
1556
  },
1540
1557
  value: rule.props.placeholder[1],
1541
1558
  },
@@ -1606,13 +1623,29 @@ var instruction = {
1606
1623
  minRows: 5,
1607
1624
  },
1608
1625
  },
1626
+ effect: {
1627
+ required: '请输入说明文字',
1628
+ },
1609
1629
  title: label$9,
1610
1630
  field: fieldsMap$9.value,
1611
1631
  value: rule.value,
1632
+ inject: true,
1612
1633
  prefix: {
1613
1634
  type: 'TextColor',
1635
+ on: {
1636
+ change({ api, self }, color) {
1637
+ api.emit('change', 'style.color', color, self, api, true);
1638
+ },
1639
+ },
1614
1640
  props: {
1615
- rule,
1641
+ color: rule.style.color,
1642
+ },
1643
+ },
1644
+ on: {
1645
+ change({ api, self }, list) {
1646
+ vue.nextTick(() => {
1647
+ api.refresh();
1648
+ });
1616
1649
  },
1617
1650
  },
1618
1651
  },
@@ -1655,7 +1688,7 @@ var picture = {
1655
1688
  },
1656
1689
  },
1657
1690
  effect: {
1658
- required: true,
1691
+ required: false,
1659
1692
  formRule: 'formRule',
1660
1693
  },
1661
1694
  props: {
@@ -2004,7 +2037,15 @@ var table = {
2004
2037
  effect: {
2005
2038
  required: true,
2006
2039
  },
2040
+ inject: true,
2007
2041
  value: rule.config.childRules,
2042
+ on: {
2043
+ change({ api, self }, list) {
2044
+ vue.nextTick(() => {
2045
+ api.validate();
2046
+ });
2047
+ },
2048
+ },
2008
2049
  },
2009
2050
  {
2010
2051
  type: 'checkbox',
@@ -2067,7 +2108,7 @@ var file = {
2067
2108
  },
2068
2109
  },
2069
2110
  effect: {
2070
- required: true,
2111
+ required: false,
2071
2112
  formRule: 'formRule',
2072
2113
  },
2073
2114
  config: {
@@ -2138,7 +2179,7 @@ var people = {
2138
2179
  },
2139
2180
  },
2140
2181
  effect: {
2141
- required: true,
2182
+ required: false,
2142
2183
  formRule: 'formRule',
2143
2184
  },
2144
2185
  props: {
@@ -2171,6 +2212,7 @@ var people = {
2171
2212
  field: fieldsMap$5['props.placeholder'],
2172
2213
  props: {
2173
2214
  placeholder: '请输入',
2215
+ maxlength: 30,
2174
2216
  },
2175
2217
  value: rule.props.placeholder,
2176
2218
  },
@@ -2259,7 +2301,7 @@ var department = {
2259
2301
  },
2260
2302
  },
2261
2303
  effect: {
2262
- required: true,
2304
+ required: false,
2263
2305
  formRule: 'formRule',
2264
2306
  },
2265
2307
  props: {
@@ -2292,6 +2334,7 @@ var department = {
2292
2334
  field: fieldsMap$4['props.placeholder'],
2293
2335
  props: {
2294
2336
  placeholder: '请输入',
2337
+ maxlength: 30,
2295
2338
  },
2296
2339
  value: rule.props.placeholder,
2297
2340
  },
@@ -3202,6 +3245,14 @@ var shop = {
3202
3245
  field: fieldsMap$1['config.isMain'],
3203
3246
  value: rule.config.isMain,
3204
3247
  hidden: !!parentRule,
3248
+ inject: true,
3249
+ on: {
3250
+ change({ api, self }, value) {
3251
+ if (value) {
3252
+ api.mergeRule(fieldsMap$1['effect.required'], { value: true });
3253
+ }
3254
+ },
3255
+ },
3205
3256
  },
3206
3257
  {
3207
3258
  type: 'switch',
@@ -3564,7 +3615,8 @@ const _hoisted_2$1 = { class: "bm-table-column-btn-wrap" };
3564
3615
  const _sfc_main$2 = /* @__PURE__ */ vue.defineComponent({
3565
3616
  __name: "table-column",
3566
3617
  props: ["formCreateInject"],
3567
- setup(__props) {
3618
+ emits: ["change"],
3619
+ setup(__props, { emit: emits }) {
3568
3620
  const props = __props;
3569
3621
  const handleClass = "bm-table-column__drag-icon";
3570
3622
  const btnCom = vue.ref();
@@ -3589,6 +3641,15 @@ const _sfc_main$2 = /* @__PURE__ */ vue.defineComponent({
3589
3641
  function getPopupContainer() {
3590
3642
  return document.body;
3591
3643
  }
3644
+ vue.watch(
3645
+ childRules,
3646
+ (val) => {
3647
+ emits("change", val);
3648
+ },
3649
+ {
3650
+ deep: true
3651
+ }
3652
+ );
3592
3653
  return (_ctx, _cache) => {
3593
3654
  const _component_Delete = vue.resolveComponent("Delete");
3594
3655
  const _component_ARow = vue.resolveComponent("ARow");
@@ -3669,12 +3730,17 @@ var TableColumn = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__file", "table-co
3669
3730
 
3670
3731
  const _sfc_main$1 = /* @__PURE__ */ vue.defineComponent({
3671
3732
  __name: "text-color",
3672
- props: ["rule"],
3673
- setup(__props) {
3733
+ props: ["color"],
3734
+ emits: ["change"],
3735
+ setup(__props, { emit: emits }) {
3674
3736
  const props = __props;
3737
+ const color = vue.ref(props.color);
3738
+ function getColor(curColor) {
3739
+ return curColor === Colors.Black ? Colors.Blue : Colors.Black;
3740
+ }
3675
3741
  function handleClick() {
3676
- const rule = props.rule;
3677
- rule.style.color = rule.style.color === Colors.Black ? Colors.Blue : Colors.Black;
3742
+ color.value = getColor(color.value);
3743
+ emits("change", color.value);
3678
3744
  }
3679
3745
  return (_ctx, _cache) => {
3680
3746
  const _component_ColorPanel = vue.resolveComponent("ColorPanel");
@@ -3686,16 +3752,11 @@ const _sfc_main$1 = /* @__PURE__ */ vue.defineComponent({
3686
3752
  width: "1em",
3687
3753
  height: "1em",
3688
3754
  fontSize: "20px",
3689
- color: __props.rule.style.color,
3755
+ color: getColor(color.value),
3690
3756
  cursor: "pointer"
3691
3757
  }),
3692
3758
  onClick: vue.withModifiers(handleClick, ["prevent", "stop"])
3693
- }, {
3694
- default: vue.withCtx(() => [
3695
- vue.createTextVNode("change")
3696
- ]),
3697
- _: 1
3698
- }, 8, ["style", "onClick"]);
3759
+ }, null, 8, ["style", "onClick"]);
3699
3760
  };
3700
3761
  }
3701
3762
  });
@@ -3720,7 +3781,8 @@ const __default__ = {
3720
3781
  const _sfc_main = /* @__PURE__ */ vue.defineComponent({
3721
3782
  ...__default__,
3722
3783
  props: formDesignerProps,
3723
- setup(__props, { expose }) {
3784
+ emits: ["initPresetRule"],
3785
+ setup(__props, { expose, emit: emits }) {
3724
3786
  const props = __props;
3725
3787
  FC__default["default"].component("TableHeadCount", TableHeadCount);
3726
3788
  FC__default["default"].component("TableColumn", TableColumn);
@@ -3883,6 +3945,10 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
3883
3945
  antDesignVue.message.error("\u8BE5\u63A7\u4EF6\u5DF2\u88AB\u8BBE\u4E3A\u6570\u636E\u8FC7\u6EE4\u6761\u4EF6\uFF0C\u4E0D\u53EF\u5220\u9664\u3002");
3884
3946
  return;
3885
3947
  }
3948
+ if (props.flowCondition[targetRule.field]) {
3949
+ antDesignVue.message.error("\u8BE5\u7EC4\u4EF6\u5728\u201C\u6761\u4EF6\u5206\u652F\u540D\u79F0\u201D\u5DF2\u88AB\u8BBE\u4E3A\u5BA1\u6279\u6761\u4EF6\uFF0C\u4E0D\u53EF\u5220\u9664\u3002");
3950
+ return;
3951
+ }
3886
3952
  const parentList = parentRule?.config?.childRules || widgetFormRules;
3887
3953
  const index = parentList.findIndex((rule) => rule.field === targetRule.field);
3888
3954
  parentList.splice(index, 1);
@@ -3919,6 +3985,15 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
3919
3985
  vue.nextTick(() => {
3920
3986
  item.props.activeRule = rule;
3921
3987
  });
3988
+ if (item.type === WidgetType.RowWidget && item?.config?.childRules?.length) {
3989
+ item.config.childRules.forEach((childRule) => {
3990
+ if (childRule.type === WidgetType.TableWidget) {
3991
+ vue.nextTick(() => {
3992
+ childRule.props.activeRule = rule;
3993
+ });
3994
+ }
3995
+ });
3996
+ }
3922
3997
  }
3923
3998
  });
3924
3999
  if (!cacheProps[rule.field]) {
@@ -3993,6 +4068,7 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
3993
4068
  return rule.config.config.parse(rule);
3994
4069
  }
3995
4070
  function edit(formRules) {
4071
+ widgetFormRules.splice(0);
3996
4072
  formRules.forEach((item) => {
3997
4073
  const rule = makeRule(ruleList[item.name]);
3998
4074
  delete item.name;
@@ -4010,22 +4086,77 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
4010
4086
  function getRule(name) {
4011
4087
  return makeRule(ruleList[name]);
4012
4088
  }
4089
+ function validate() {
4090
+ let pass = true;
4091
+ for (const rule of widgetFormRules) {
4092
+ const config = rule.config.config || {};
4093
+ const childRules = rule.config.childRules || [];
4094
+ if (!rule?.title?.title && config.name !== "instruction") {
4095
+ pass = false;
4096
+ }
4097
+ if (!rule?.value && config.name === "instruction") {
4098
+ pass = false;
4099
+ }
4100
+ if (config.name === "table" && !childRules.length) {
4101
+ pass = false;
4102
+ }
4103
+ if (!pass && rule.field !== activeRule.value.field) {
4104
+ setActiveRule(rule);
4105
+ }
4106
+ if (pass && childRules.length) {
4107
+ for (const childRule of childRules) {
4108
+ if (!childRule?.title?.title) {
4109
+ pass = false;
4110
+ if (childRule.field !== activeRule.value.field) {
4111
+ setActiveRule(childRule, rule);
4112
+ }
4113
+ break;
4114
+ }
4115
+ }
4116
+ }
4117
+ if (!pass) {
4118
+ vue.nextTick(() => {
4119
+ fApi.value.validate();
4120
+ });
4121
+ break;
4122
+ }
4123
+ }
4124
+ return pass;
4125
+ }
4126
+ function flowConditionEffect(activeProps2, flowCondition) {
4127
+ const requiredRule = activeProps2?.find(
4128
+ (rule) => rule.field === "effect.required"
4129
+ );
4130
+ if (requiredRule) {
4131
+ if (!requiredRule.props) {
4132
+ requiredRule.props = {};
4133
+ }
4134
+ requiredRule.props.disabled = !!flowCondition[activeRule.value.field];
4135
+ }
4136
+ }
4013
4137
  vue.watch(
4014
4138
  () => props.presetRules,
4015
4139
  (presetRules) => {
4016
4140
  widgetFormRules.push(...presetRules);
4017
- },
4018
- {
4019
- immediate: true
4141
+ emits("initPresetRule", widgetFormRules);
4020
4142
  }
4021
4143
  );
4022
4144
  vue.watch(
4023
4145
  () => props.formRules,
4024
4146
  (formRules) => {
4025
- edit(formRules);
4147
+ formRules && edit(formRules);
4148
+ }
4149
+ );
4150
+ vue.watch(activeProps, (activeProps2) => {
4151
+ flowConditionEffect(activeProps2, props.flowCondition);
4152
+ });
4153
+ vue.watch(
4154
+ () => props.flowCondition,
4155
+ (flowCondition) => {
4156
+ flowConditionEffect(activeProps.value, flowCondition);
4026
4157
  },
4027
4158
  {
4028
- immediate: true
4159
+ deep: true
4029
4160
  }
4030
4161
  );
4031
4162
  vue.onBeforeUnmount(() => {
@@ -4033,7 +4164,8 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
4033
4164
  });
4034
4165
  expose({
4035
4166
  getFormRule,
4036
- getRule
4167
+ getRule,
4168
+ validate
4037
4169
  });
4038
4170
  return (_ctx, _cache) => {
4039
4171
  const _component_ACol = vue.resolveComponent("ACol");
@@ -4076,7 +4208,6 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
4076
4208
  move: moveMenuItem,
4077
4209
  "force-fallback": true,
4078
4210
  "scroll-sensitivity": 100,
4079
- delay: 50,
4080
4211
  onStart: handleMenuItemDragStart,
4081
4212
  onEnd: handleMenuItemDragEnd
4082
4213
  }, {
@@ -4141,7 +4272,7 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
4141
4272
  ]),
4142
4273
  _: 1
4143
4274
  }, 8, ["list"]),
4144
- showDragTip.value && !_ctx.formRules.length ? (vue.openBlock(), vue.createBlock(NoDataTip, {
4275
+ showDragTip.value && !_ctx.formRules?.length ? (vue.openBlock(), vue.createBlock(NoDataTip, {
4145
4276
  key: 0,
4146
4277
  class: "bm-no-data-tip"
4147
4278
  })) : vue.createCommentVNode("v-if", true)
@@ -12,3 +12,4 @@ export * from './input-tags-display';
12
12
  export * from './select-all';
13
13
  export * from './breadcrumb';
14
14
  export * from './editor';
15
+ export * from './attachment';
@@ -18,6 +18,7 @@ var inputTagsDisplay = require('./input-tags-display');
18
18
  var selectAll = require('./select-all');
19
19
  var breadcrumb = require('./breadcrumb');
20
20
  var editor = require('./editor');
21
+ var attachment = require('./attachment');
21
22
 
22
23
 
23
24
 
@@ -117,3 +118,9 @@ Object.keys(editor).forEach(function (k) {
117
118
  get: function () { return editor[k]; }
118
119
  });
119
120
  });
121
+ Object.keys(attachment).forEach(function (k) {
122
+ if (k !== 'default' && !exports.hasOwnProperty(k)) Object.defineProperty(exports, k, {
123
+ enumerable: true,
124
+ get: function () { return attachment[k]; }
125
+ });
126
+ });
@@ -910,9 +910,9 @@ declare const BmStaffsSelector: import("bm-admin-ui/es/utils/with-install").SFCW
910
910
  searchVal: import("vue").Ref<string>;
911
911
  selectAll: import("vue").Ref<boolean>;
912
912
  indeterminate: import("vue").Ref<boolean>;
913
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
913
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
914
914
  [key: string]: any;
915
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
915
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
916
916
  [key: string]: any;
917
917
  }> | null | undefined)[]>;
918
918
  isFulfill: import("vue").Ref<boolean>;
@@ -28,9 +28,9 @@ declare const _default: import("vue").DefineComponent<{
28
28
  searchVal: import("vue").Ref<string>;
29
29
  selectAll: import("vue").Ref<boolean>;
30
30
  indeterminate: import("vue").Ref<boolean>;
31
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
31
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
32
32
  [key: string]: any;
33
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
33
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
34
34
  [key: string]: any;
35
35
  }> | null | undefined)[]>;
36
36
  isFulfill: import("vue").Ref<boolean>;
@@ -910,9 +910,9 @@ declare const _default: import("vue").DefineComponent<{
910
910
  searchVal: import("vue").Ref<string>;
911
911
  selectAll: import("vue").Ref<boolean>;
912
912
  indeterminate: import("vue").Ref<boolean>;
913
- emptyPic: import("vue").Ref<(string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
913
+ emptyPic: import("vue").Ref<JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
914
914
  [key: string]: any;
915
- }> | null | undefined) | JSX.Element | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
915
+ }> | null | undefined) | (string | number | boolean | void | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
916
916
  [key: string]: any;
917
917
  }> | null | undefined)[]>;
918
918
  isFulfill: import("vue").Ref<boolean>;
@@ -322,6 +322,9 @@ const _sfc_main = {
322
322
  status: ""
323
323
  };
324
324
  setTimeout(function() {
325
+ if (methods.fileIsDelete(file)) {
326
+ return;
327
+ }
325
328
  state.fileList[file.uid].isDoneDeloy = true;
326
329
  }, 1e3);
327
330
  methods.customUploadRequest(file);
@@ -600,7 +603,10 @@ const _hoisted_17 = {
600
603
  key: 0,
601
604
  class: "bm-upload__picture__name"
602
605
  };
603
- const _hoisted_18 = { class: "bm-upload__button__wrapper" };
606
+ const _hoisted_18 = {
607
+ key: 1,
608
+ class: "bm-upload__button__wrapper"
609
+ };
604
610
  const _hoisted_19 = { key: 0 };
605
611
  const _hoisted_20 = { class: "ant-upload-text bm-upload__text" };
606
612
  const _hoisted_21 = {
@@ -622,7 +628,7 @@ const _hoisted_26 = {
622
628
  class: "bm-upload__tips"
623
629
  };
624
630
  const _hoisted_27 = {
625
- key: 1,
631
+ key: 2,
626
632
  class: "bm-upload__file-list"
627
633
  };
628
634
  const _hoisted_28 = { class: "bm-upload__file__detail" };
@@ -794,8 +800,8 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
794
800
  }), 128)),
795
801
  vue.createCommentVNode(" </a-image-preview-group> ")
796
802
  ], 64)) : vue.createCommentVNode("v-if", true),
797
- vue.createElementVNode("div", _hoisted_18, [
798
- !($setup.uploadDisabled && _ctx.extraConfigs?.hideDisabledBtn) ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.extraConfigs.drag ? "a-upload-dragger" : "a-upload"), vue.mergeProps({ key: 0 }, _ctx.uploadConfigs, {
803
+ !($setup.uploadDisabled && _ctx.extraConfigs?.hideDisabledBtn) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_18, [
804
+ (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.extraConfigs.drag ? "a-upload-dragger" : "a-upload"), vue.mergeProps(_ctx.uploadConfigs, {
799
805
  disabled: $setup.uploadDisabled,
800
806
  class: { "bm--upload__custom-button": _ctx.extraConfigs.myBtn },
801
807
  onReject: _ctx.handleReject
@@ -826,8 +832,8 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
826
832
  ], 64))
827
833
  ]),
828
834
  _: 3
829
- }, 16, ["disabled", "class", "onReject"])) : vue.createCommentVNode("v-if", true)
830
- ]),
835
+ }, 16, ["disabled", "class", "onReject"]))
836
+ ])) : vue.createCommentVNode("v-if", true),
831
837
  _ctx.uploadConfigs.listType === "text" && !_ctx.uploadConfigs.showSlotList ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_27, [
832
838
  (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(_ctx.fileList, (item) => {
833
839
  return vue.openBlock(), vue.createElementBlock("div", {
@@ -1,4 +1,6 @@
1
- export declare function BmAdminUiResolver(options: any): {
1
+ export declare function BmAdminUiResolver(options?: {
2
+ importStyle: boolean;
3
+ }): {
2
4
  type: string;
3
5
  resolve: (name: string) => {
4
6
  name: string;
@@ -5,7 +5,7 @@ function kebabCase(key) {
5
5
  const result = key.replace(/([A-Z])/g, ' $1').trim();
6
6
  return result.split(' ').join('-').toLowerCase();
7
7
  }
8
- function BmAdminUiResolver(options) {
8
+ function BmAdminUiResolver(options = { importStyle: false }) {
9
9
  return [
10
10
  {
11
11
  type: 'component',