@fecp/designer 5.5.39 → 5.5.43

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 (39) hide show
  1. package/es/designer/package.json.mjs +1 -1
  2. package/es/designer/src/components/DocumentParam.vue.mjs +1 -1
  3. package/es/designer/src/components/ParamsConfig.vue2.mjs +1 -1
  4. package/es/designer/src/layout/aside/HiddenFieldDialog.vue.mjs +1 -1
  5. package/es/designer/src/packages/advancedFilter/ValueInput.vue2.mjs +1 -1
  6. package/es/designer/src/packages/dataLinkage/index.vue.mjs +1 -1
  7. package/es/designer/src/packages/dialogGlobal/index.vue.mjs +1 -1
  8. package/es/designer/src/packages/eventFlow/dialog/action/RiskSch.vue.mjs +1 -1
  9. package/es/designer/src/packages/form/property/approvalHistory.vue.mjs +1 -1
  10. package/es/designer/src/packages/form/property/contract.vue.mjs +1 -1
  11. package/es/designer/src/packages/form/property/subForm.vue.mjs +1 -1
  12. package/es/designer/src/packages/prod/index.vue.mjs +1 -1
  13. package/es/designer/src/packages/table/headerBtn.vue.mjs +1 -1
  14. package/es/designer.css +48 -16
  15. package/es/packages/vue/src/components/details/footer/Footer.vue.mjs +16 -5
  16. package/es/packages/vue/src/components/forms/form/Form.vue.mjs +24 -14
  17. package/es/packages/vue/src/components/forms/formItem/FormItem.vue.mjs +1 -1
  18. package/es/packages/vue/src/components/forms/subForm/SubForm.vue.mjs +1 -0
  19. package/lib/designer/package.json.js +1 -1
  20. package/lib/designer/src/components/DocumentParam.vue.js +1 -1
  21. package/lib/designer/src/components/ParamsConfig.vue2.js +1 -1
  22. package/lib/designer/src/layout/aside/HiddenFieldDialog.vue.js +1 -1
  23. package/lib/designer/src/packages/advancedFilter/ValueInput.vue2.js +1 -1
  24. package/lib/designer/src/packages/dataLinkage/index.vue.js +1 -1
  25. package/lib/designer/src/packages/dialog/index.vue2.js +326 -326
  26. package/lib/designer/src/packages/dialogGlobal/index.vue.js +1 -1
  27. package/lib/designer/src/packages/dialogGlobal/index.vue2.js +297 -297
  28. package/lib/designer/src/packages/eventFlow/dialog/action/RiskSch.vue.js +1 -1
  29. package/lib/designer/src/packages/form/property/approvalHistory.vue.js +1 -1
  30. package/lib/designer/src/packages/form/property/contract.vue.js +1 -1
  31. package/lib/designer/src/packages/form/property/subForm.vue.js +1 -1
  32. package/lib/designer/src/packages/prod/index.vue.js +1 -1
  33. package/lib/designer/src/packages/table/headerBtn.vue.js +1 -1
  34. package/lib/designer.css +48 -16
  35. package/lib/packages/vue/src/components/details/footer/Footer.vue.js +15 -4
  36. package/lib/packages/vue/src/components/forms/form/Form.vue.js +24 -14
  37. package/lib/packages/vue/src/components/forms/formItem/FormItem.vue.js +1 -1
  38. package/lib/packages/vue/src/components/forms/subForm/SubForm.vue.js +1 -0
  39. package/package.json +1 -1
@@ -6,7 +6,7 @@ require("../../../../../../node_modules/element-plus/es/index.js");
6
6
  ;/* empty css */
7
7
  const Vue = require("vue");
8
8
  const RiskSchemeSelector = require("../../../../components/RiskSchemeSelector.vue2.js");
9
- const ValueSelector = require("../../../../components/ValueSelector.vue2.js");
9
+ const ValueSelector = require("../../../../components/ValueSelector.vue.js");
10
10
  const ParamsConfig = require("../../../../components/ParamsConfig.vue2.js");
11
11
  const index = require("../../../../../../node_modules/element-plus/es/components/form/index.js");
12
12
  const index$1 = require("../../../../../../node_modules/element-plus/es/components/switch/index.js");
@@ -13,7 +13,7 @@ require("../../../../../node_modules/element-plus/es/index.js");
13
13
  const Vue = require("vue");
14
14
  const common = require("../../utils/common.js");
15
15
  const eventBus = require("../../utils/eventBus.js");
16
- const ValueSelector = require("../../../components/ValueSelector.vue2.js");
16
+ const ValueSelector = require("../../../components/ValueSelector.vue.js");
17
17
  const index = require("../../../../../node_modules/element-plus/es/components/collapse/index.js");
18
18
  const index$1 = require("../../../../../node_modules/element-plus/es/components/form/index.js");
19
19
  const index$2 = require("../../../../../node_modules/element-plus/es/components/input/index.js");
@@ -19,7 +19,7 @@ require("../../../../../node_modules/element-plus/es/index.js");
19
19
  const Vue = require("vue");
20
20
  const common = require("../../utils/common.js");
21
21
  require("../../utils/eventBus.js");
22
- const ValueSelector = require("../../../components/ValueSelector.vue2.js");
22
+ const ValueSelector = require("../../../components/ValueSelector.vue.js");
23
23
  const index = require("../../../api/index.js");
24
24
  const ParamsConfig = require("../../../components/ParamsConfig.vue2.js");
25
25
  ;/* empty css */
@@ -14,7 +14,7 @@ const Vue = require("vue");
14
14
  const common = require("../../utils/common.js");
15
15
  const TemplateSelector = require("../../../components/TemplateSelector.vue2.js");
16
16
  const eventBus = require("../../utils/eventBus.js");
17
- const ValueSelector = require("../../../components/ValueSelector.vue2.js");
17
+ const ValueSelector = require("../../../components/ValueSelector.vue.js");
18
18
  const ParamsConfig = require("../../../components/ParamsConfig.vue2.js");
19
19
  const index = require("../../../../../node_modules/element-plus/es/components/collapse/index.js");
20
20
  const index$1 = require("../../../../../node_modules/element-plus/es/components/form/index.js");
@@ -16,7 +16,7 @@ require("../../../../node_modules/element-plus/es/index.js");
16
16
  const Vue = require("vue");
17
17
  const index$6 = require("../../../../node_modules/@element-plus/icons-vue/dist/index.js");
18
18
  const common = require("../utils/common.js");
19
- const ValueSelector = require("../../components/ValueSelector.vue2.js");
19
+ const ValueSelector = require("../../components/ValueSelector.vue.js");
20
20
  const index = require("../../api/index.js");
21
21
  ;/* empty css */
22
22
  const _pluginVue_exportHelper = require("../../../../_virtual/_plugin-vue_export-helper.js");
@@ -47,7 +47,7 @@ const index$1 = require("../../../../node_modules/@element-plus/icons-vue/dist/i
47
47
  ;/* empty css */
48
48
  require("../../store/index.js");
49
49
  ;/* empty css */
50
- ;/* empty css */
50
+ ;/* empty css */
51
51
  ;/* empty css */
52
52
  ;/* empty css */
53
53
  ;/* empty css */
package/lib/designer.css CHANGED
@@ -5852,23 +5852,20 @@ body,
5852
5852
  outline: none;
5853
5853
  box-shadow: 0 1px 0 0 #c0c4cc inset, 0 -1px 0 0 #c0c4cc inset, -1px 0 0 0 #c0c4cc inset;
5854
5854
  }
5855
- .info-icon[data-v-2860c795] {
5855
+ .info-icon[data-v-44a32b0c] {
5856
5856
  margin-left: 4px;
5857
5857
  color: #f5b041;
5858
5858
  cursor: help;
5859
5859
  font-size: 14px;
5860
5860
  pointer-events: all;
5861
5861
  }
5862
- .credit-icon[data-v-2860c795] {
5862
+ .credit-icon[data-v-44a32b0c] {
5863
5863
  color: #2e8bff;
5864
5864
  margin-right: 2px;
5865
5865
  }
5866
- .regulation-icon[data-v-2860c795] {
5866
+ .regulation-icon[data-v-44a32b0c] {
5867
5867
  color: #f56c6c;
5868
5868
  margin-right: 2px;
5869
- }
5870
- [data-v-2860c795] .el-form-item__label {
5871
- padding: 0 8px 0 0;
5872
5869
  }
5873
5870
  .el-page-header.is-contentful .el-page-header__main{border-top:1px solid var(--el-border-color-light);margin-top:16px}.el-page-header__header{justify-content:space-between;align-items:center;line-height:24px;display:flex}.el-page-header__left{align-items:center;margin-right:40px;display:flex;position:relative}.el-page-header__back{cursor:pointer;align-items:center;display:flex}.el-page-header__left .el-divider--vertical{margin:0 16px}.el-page-header__icon{align-items:center;margin-right:10px;font-size:16px;display:flex}.el-page-header__icon .el-icon{font-size:inherit}.el-page-header__title{font-size:14px;font-weight:500}.el-page-header__content{color:var(--el-text-color-primary);font-size:18px}.el-page-header__breadcrumb{margin-bottom:16px}.fec-header[data-v-a55fc4ab] {
5874
5871
  padding: 0 20px;
@@ -5919,7 +5916,7 @@ body,
5919
5916
  display: flex;
5920
5917
  align-items: flex-end;
5921
5918
  }
5922
- .form-details-footer[data-v-97973006] {
5919
+ .form-details-footer[data-v-69e1a97b] {
5923
5920
  background-color: #fff;
5924
5921
  height: 50px;
5925
5922
  display: flex;
@@ -5930,29 +5927,30 @@ body,
5930
5927
  padding: 0;
5931
5928
  z-index: 1;
5932
5929
  }
5933
- .form-details-footer > .el-button[data-v-97973006] {
5930
+ .form-details-footer > .el-button[data-v-69e1a97b] {
5934
5931
  width: 80px;
5935
5932
  font-size: var(--el-font-size-extra-small);
5936
5933
  }
5937
- .fec-form[data-v-71dda23e] {
5934
+
5935
+ .fec-form[data-v-95d9b970] {
5938
5936
  height: 100%;
5939
5937
  }
5940
- [data-v-71dda23e] .vgl-layout {
5938
+ [data-v-95d9b970] .vgl-layout {
5941
5939
  position: relative;
5942
5940
  }
5943
- [data-v-71dda23e] .vgl-item {
5941
+ [data-v-95d9b970] .vgl-item {
5944
5942
  transition: none;
5945
5943
  }
5946
- [data-v-71dda23e] .vgl-item > .el-form-item {
5944
+ [data-v-95d9b970] .vgl-item > .el-form-item {
5947
5945
  width: 100%;
5948
5946
  padding: 6px 8px 0 8px;
5949
5947
  height: calc(100% - 15px);
5950
5948
  display: flex;
5951
5949
  }
5952
- [data-v-71dda23e] .vgl-item > .el-form-item.el-form-item--label-top {
5950
+ [data-v-95d9b970] .vgl-item > .el-form-item.el-form-item--label-top {
5953
5951
  flex-direction: column;
5954
5952
  }
5955
- [data-v-71dda23e] .vgl-item > .el-form-item .el-form-item__label {
5953
+ [data-v-95d9b970] .vgl-item > .el-form-item .el-form-item__label {
5956
5954
  line-height: 20px;
5957
5955
  display: flex;
5958
5956
  align-items: center;
@@ -5960,14 +5958,48 @@ body,
5960
5958
  pointer-events: none;
5961
5959
  flex-wrap: wrap;
5962
5960
  white-space: normal;
5961
+ padding: 0 8px 0 0;
5962
+ width: 100% !important;
5963
+ max-width: 160px;
5964
+ min-width: 80px;
5965
+ flex-shrink: 0;
5963
5966
  }
5964
- [data-v-71dda23e] .vgl-item > .el-form-item {
5967
+ [data-v-95d9b970] .vgl-item > .el-form-item {
5965
5968
  /* .el-form-item__error {
5966
5969
  padding-top: 10px;
5967
5970
  } */
5968
5971
  }
5969
- [data-v-71dda23e] .vgl-item > .el-container {
5972
+ [data-v-95d9b970] .vgl-item > .el-container {
5970
5973
  height: auto !important;
5974
+ }
5975
+ @media (min-width: 1440px) {
5976
+ [data-v-95d9b970] .vgl-item .el-form-item__label {
5977
+ max-width: 160px !important;
5978
+ }
5979
+ }
5980
+ /* 标准 PC(1200px ~ 1439px)*/
5981
+ @media (min-width: 1200px) and (max-width: 1439px) {
5982
+ [data-v-95d9b970] .vgl-item .el-form-item__label {
5983
+ max-width: 135px !important;
5984
+ }
5985
+ }
5986
+ /* 2. 标准 PC 992px ~ 1199px */
5987
+ @media (min-width: 992px) and (max-width: 1199px) {
5988
+ [data-v-95d9b970] .vgl-item .el-form-item__label {
5989
+ max-width: 120px !important;
5990
+ }
5991
+ }
5992
+ /* 3. 小屏 PC / 窄窗口 <992px(最小到768px)*/
5993
+ @media (max-width: 991px) and (min-width: 768px) {
5994
+ [data-v-95d9b970] .vgl-item .el-form-item__label {
5995
+ max-width: 100px !important;
5996
+ }
5997
+ }
5998
+ /* 超小屏 <768px */
5999
+ @media (max-width: 767px) {
6000
+ [data-v-95d9b970] .vgl-item .el-form-item__label {
6001
+ max-width: 80px !important;
6002
+ }
5971
6003
  }.table-pagination[data-v-142fdd35] {
5972
6004
  display: flex;
5973
6005
  justify-content: flex-end;
@@ -26,18 +26,29 @@ const _sfc_main = {
26
26
  },
27
27
  emits: ["cancel", "submit", "custom-button-click"],
28
28
  setup(__props, { emit: __emit }) {
29
+ const props = __props;
29
30
  const emit = __emit;
31
+ const formDetailsFooterRef = Vue.ref();
30
32
  const handleButtonClick = (button) => {
31
33
  emit("custom-button-click", button);
32
34
  };
35
+ const showFooter = Vue.ref(true);
36
+ Vue.onMounted(() => {
37
+ const layoutDom = formDetailsFooterRef.value.$el.closest(".fec-layout-row");
38
+ if (layoutDom && props.formMode == "query") {
39
+ showFooter.value = false;
40
+ }
41
+ });
33
42
  return (_ctx, _cache) => {
34
43
  var _a;
35
44
  const _component_el_button = index$1.ElButton;
36
45
  const _component_el_footer = index.ElFooter;
37
46
  const _directive_fec_auth = Vue.resolveDirective("fec-auth");
38
- return __props.pageFooterConfig.enabled && ((_a = __props.pageFooterConfig.actions) == null ? void 0 : _a.length) ? (Vue.openBlock(), Vue.createBlock(_component_el_footer, {
47
+ return __props.pageFooterConfig.enabled && ((_a = __props.pageFooterConfig.actions) == null ? void 0 : _a.length) && Vue.unref(showFooter) ? (Vue.openBlock(), Vue.createBlock(_component_el_footer, {
39
48
  key: 0,
40
- class: "form-details-footer"
49
+ class: "form-details-footer",
50
+ ref_key: "formDetailsFooterRef",
51
+ ref: formDetailsFooterRef
41
52
  }, {
42
53
  default: Vue.withCtx(() => [
43
54
  (Vue.openBlock(true), Vue.createElementBlock(Vue.Fragment, null, Vue.renderList(__props.pageFooterConfig.actions, (button) => {
@@ -60,9 +71,9 @@ const _sfc_main = {
60
71
  }), 128))
61
72
  ]),
62
73
  _: 1
63
- })) : Vue.createCommentVNode("", true);
74
+ }, 512)) : Vue.createCommentVNode("", true);
64
75
  };
65
76
  }
66
77
  };
67
- const component = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-97973006"]]);
78
+ const component = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-69e1a97b"]]);
68
79
  exports.default = component;
@@ -119,6 +119,8 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
119
119
  const productData = Vue.ref({});
120
120
  const fieldsData = Vue.ref([]);
121
121
  const hiddenFields = Vue.ref([]);
122
+ const prevFormData = Vue.ref({});
123
+ let linkaged = false;
122
124
  const rowHeight = Vue.ref(1);
123
125
  const pageEvents = props.canPageEvent ? usePageEvents.usePageEvents(() => ({
124
126
  pageEventConfig: localConfig.value.pageEventConfig,
@@ -140,7 +142,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
140
142
  () => props.templateKey,
141
143
  (key) => {
142
144
  if (key) {
143
- loadConfig();
145
+ loadConfig("dynamic");
144
146
  }
145
147
  }
146
148
  );
@@ -148,14 +150,16 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
148
150
  () => props.modelValue,
149
151
  (newVal, oldVal) => {
150
152
  if (JSON.stringify(newVal) !== JSON.stringify(oldVal)) {
151
- loadFormData(true);
153
+ loadFormData("change");
152
154
  }
153
155
  }
154
156
  );
155
- const loadConfig = async () => {
157
+ const loadConfig = async (state) => {
156
158
  if (!props.templateKey && (!props.initOption || Object.keys(props.initOption).length == 0)) {
157
159
  return;
158
160
  }
161
+ prevFormData.value = {};
162
+ linkaged = false;
159
163
  configLoading.value = true;
160
164
  try {
161
165
  let option = await getJsonAsyncUtil.default(
@@ -178,7 +182,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
178
182
  return item.component;
179
183
  });
180
184
  hiddenFields.value = option.hiddenFields || [];
181
- loadFormData();
185
+ loadFormData(state);
182
186
  loadEventFlow();
183
187
  if (pageEvents && localConfig.value.pageEventConfig) {
184
188
  const onCreatedEvent = localConfig.value.pageEventConfig.find(
@@ -209,7 +213,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
209
213
  function layoutUpdated(layoutData) {
210
214
  emit("layoutUpdated", layoutData);
211
215
  }
212
- const loadFormData = (flag) => {
216
+ const loadFormData = (state) => {
213
217
  var _a;
214
218
  const defaultData = {};
215
219
  const rules = {};
@@ -222,7 +226,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
222
226
  }
223
227
  defaultData[component.fieldName] = defaultValue;
224
228
  }
225
- if (!flag) {
229
+ if (state != "change") {
226
230
  if (component.fieldName) {
227
231
  const fieldRules = validation.generateFieldRules(component, formData, [
228
232
  ...fieldsData.value,
@@ -243,15 +247,22 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
243
247
  ...fieldsData.value,
244
248
  ...hiddenFields.value
245
249
  ]);
246
- defaultData[field.fieldName] = value !== void 0 ? value : null;
247
- } else {
248
- defaultData[field.fieldName] = field.value !== void 0 ? field.value : null;
250
+ if (value) {
251
+ defaultData[field.fieldName] = value;
252
+ }
253
+ } else if (field.value) {
254
+ defaultData[field.fieldName] = field.value;
249
255
  }
250
256
  }
251
257
  });
252
258
  }
253
- formData.value = { ...defaultData, ...setFormData(props.modelValue, true) };
254
- if (!flag) {
259
+ if (state == "dynamic") {
260
+ debugger;
261
+ formData.value = { ...setFormData(props.modelValue, true), ...defaultData };
262
+ } else {
263
+ formData.value = { ...defaultData, ...setFormData(props.modelValue, true) };
264
+ }
265
+ if (state != "change") {
255
266
  formRules.value = rules;
256
267
  }
257
268
  };
@@ -765,7 +776,6 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
765
776
  Vue.onBeforeUnmount(() => {
766
777
  formItemRefs.value.clear();
767
778
  });
768
- const prevFormData = Vue.ref({});
769
779
  const findChangedFields = (newData, oldData) => {
770
780
  const changedFields = [];
771
781
  const allKeys = /* @__PURE__ */ new Set([
@@ -951,7 +961,6 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
951
961
  gridLayoutFieldsData.value = updatedLayoutData.filter((item) => !item.hidden);
952
962
  (_a = gridLayout == null ? void 0 : gridLayout.value) == null ? void 0 : _a.resizeEvent();
953
963
  };
954
- let linkaged = false;
955
964
  function initLinkage() {
956
965
  const changedFields = findChangedFields(formData.value, prevFormData.value);
957
966
  console.log("🚀 ~ initLinkage ~ changedFields:", changedFields);
@@ -1005,6 +1014,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
1005
1014
  Vue.provide("setFormItemHeight", setFormItemHeight);
1006
1015
  Vue.provide("formCtx", ctx);
1007
1016
  Vue.provide("handleEvent", handleEvent);
1017
+ Vue.provide("getFormData", getFormData);
1008
1018
  __expose({
1009
1019
  validate,
1010
1020
  resetFields,
@@ -1105,5 +1115,5 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
1105
1115
  };
1106
1116
  }
1107
1117
  });
1108
- const _Form = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-71dda23e"]]);
1118
+ const _Form = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-95d9b970"]]);
1109
1119
  exports.default = _Form;
@@ -207,5 +207,5 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
207
207
  };
208
208
  }
209
209
  });
210
- const _FormItem = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-2860c795"]]);
210
+ const _FormItem = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-44a32b0c"]]);
211
211
  exports.default = _FormItem;
@@ -50,6 +50,7 @@ const _sfc_main = /* @__PURE__ */ Object.assign({
50
50
  setup(__props, { expose: __expose }) {
51
51
  const props = __props;
52
52
  const formData = Vue.inject("formData");
53
+ Vue.inject("getFormData");
53
54
  Vue.inject("rowHeight");
54
55
  Vue.inject("gridLayout");
55
56
  const setFormItemHeight = Vue.inject("setFormItemHeight");
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fecp/designer",
3
- "version": "5.5.39",
3
+ "version": "5.5.43",
4
4
  "main": "lib/designer/index.js",
5
5
  "module": "es/designer/index.mjs",
6
6
  "files": [