@kp-ui/lowcode 2.15.0-beta.8 → 2.16.0-alpha.5

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 (74) hide show
  1. package/install.js +18 -14
  2. package/install.js.map +1 -1
  3. package/package.json +2 -1
  4. package/src/components/FormRender/FormContainer.vue.js +55 -0
  5. package/src/components/FormRender/FormContainer.vue.js.map +1 -0
  6. package/src/components/FormRender/FormContainer.vue2.js +5 -0
  7. package/src/components/FormRender/FormContainer.vue2.js.map +1 -0
  8. package/src/components/FormRender/index.vue.js +2 -2
  9. package/src/components/FormRender/index.vue2.js +35 -40
  10. package/src/components/FormRender/index.vue2.js.map +1 -1
  11. package/src/components/FormRender/useFormContext.js +128 -120
  12. package/src/components/FormRender/useFormContext.js.map +1 -1
  13. package/src/components/form-designer/form-widget/container-widget/useTableWidget.js +116 -114
  14. package/src/components/form-designer/form-widget/container-widget/useTableWidget.js.map +1 -1
  15. package/src/components/form-designer/form-widget/container-widget/vf-dialog-widget.vue.js +2 -2
  16. package/src/components/form-designer/form-widget/container-widget/vf-dialog-widget.vue2.js +22 -16
  17. package/src/components/form-designer/form-widget/container-widget/vf-dialog-widget.vue2.js.map +1 -1
  18. package/src/components/form-designer/form-widget/field-widget/rich-editor-widget.vue2.js.map +1 -1
  19. package/src/components/form-designer/form-widget/field-widget/useField.js +33 -33
  20. package/src/components/form-designer/form-widget/field-widget/useField.js.map +1 -1
  21. package/src/components/form-designer/setting-panel/form-setting.vue.js +2 -2
  22. package/src/components/form-designer/setting-panel/form-setting.vue2.js +100 -126
  23. package/src/components/form-designer/setting-panel/form-setting.vue2.js.map +1 -1
  24. package/src/components/form-designer/setting-panel/property-editor/button-list-editor.vue2.js +45 -39
  25. package/src/components/form-designer/setting-panel/property-editor/button-list-editor.vue2.js.map +1 -1
  26. package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-showButtonsColumn-editor.vue.js +2 -2
  27. package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-showButtonsColumn-editor.vue2.js.map +1 -1
  28. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/cancelButtonLabel-editor.vue2.js.map +1 -1
  29. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/left-editor.vue.js +5 -0
  30. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/left-editor.vue.js.map +1 -0
  31. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/left-editor.vue2.js +38 -0
  32. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/left-editor.vue2.js.map +1 -0
  33. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/top-editor.vue.js +5 -0
  34. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/top-editor.vue.js.map +1 -0
  35. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/top-editor.vue2.js +38 -0
  36. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/top-editor.vue2.js.map +1 -0
  37. package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/width-editor.vue2.js.map +1 -1
  38. package/src/components/form-designer/setting-panel/property-editor/event-handler/onTableChange-editor.vue2.js +4 -4
  39. package/src/components/form-designer/setting-panel/property-editor/event-handler/onTableChange-editor.vue2.js.map +1 -1
  40. package/src/components/form-designer/setting-panel/property-editor/index.js +158 -156
  41. package/src/components/form-designer/setting-panel/property-editor/index.js.map +1 -1
  42. package/src/components/form-designer/setting-panel/propertyRegister.js +2 -0
  43. package/src/components/form-designer/setting-panel/propertyRegister.js.map +1 -1
  44. package/src/components/form-designer/widget-panel/containers/vf-dialog.js +34 -10
  45. package/src/components/form-designer/widget-panel/containers/vf-dialog.js.map +1 -1
  46. package/src/components/form-render/container-items/data-table-widget.vue.js +1 -1
  47. package/src/components/form-render/container-items/data-table-widget.vue2.js +60 -61
  48. package/src/components/form-render/container-items/data-table-widget.vue2.js.map +1 -1
  49. package/src/components/form-render/dynamic-dialog.vue.js +72 -75
  50. package/src/components/form-render/dynamic-dialog.vue.js.map +1 -1
  51. package/src/components/public/ActionButtonListDialog.vue.js +1 -1
  52. package/src/components/public/ActionButtonListDialog.vue2.js +115 -94
  53. package/src/components/public/ActionButtonListDialog.vue2.js.map +1 -1
  54. package/src/components/public/ActionButtonListRender.vue.js +15 -13
  55. package/src/components/public/ActionButtonListRender.vue.js.map +1 -1
  56. package/src/components/public/ActionButtonListRender.vue2.js +35 -25
  57. package/src/components/public/ActionButtonListRender.vue2.js.map +1 -1
  58. package/src/components/public/ConfigView/CustomPageRender.vue.js +58 -0
  59. package/src/components/public/ConfigView/CustomPageRender.vue.js.map +1 -0
  60. package/src/components/public/ConfigView/CustomPageRender.vue2.js +5 -0
  61. package/src/components/public/ConfigView/CustomPageRender.vue2.js.map +1 -0
  62. package/src/constants/EditorTypeEnum.js +1 -1
  63. package/src/constants/EditorTypeEnum.js.map +1 -1
  64. package/src/hooks/useLowcode.js.map +1 -1
  65. package/src/lang/en-US.js +1 -0
  66. package/src/lang/en-US.js.map +1 -1
  67. package/src/lang/zh-CN.js +1 -0
  68. package/src/lang/zh-CN.js.map +1 -1
  69. package/src/utils/util.js +21 -20
  70. package/src/utils/util.js.map +1 -1
  71. package/stats.html +1 -1
  72. package/styles/style.css +1 -1
  73. package/src/components/FormRender/FormContainer.js +0 -52
  74. package/src/components/FormRender/FormContainer.js.map +0 -1
@@ -1,20 +1,19 @@
1
- import { defineComponent as Y, inject as D, ref as m, onMounted as Z, resolveComponent as v, createElementBlock as K, openBlock as F, Fragment as P, createVNode as t, withModifiers as ee, unref as e, withCtx as o, createBlock as te, createCommentVNode as ne, createTextVNode as c, toDisplayString as p, normalizeClass as $, renderList as le } from "vue";
2
- import { useI18n as oe } from "../../../utils/i18n.js";
3
- import { insertCustomCssToHead as j, deepClone as I } from "../../../utils/util.js";
4
- import ae from "../../public/methoad-item.vue.js";
5
- import se from "./property-editor/container-vf-dialog/okButtonHidden-editor.vue2.js";
6
- import ie from "./property-editor/container-vf-dialog/cancelButtonHidden-editor.vue2.js";
7
- import { TpfCodeEditor as re } from "tmgc2-share";
8
- import { useDesigner as ue } from "../form-widget/useFormDesigner.js";
9
- const _e = /* @__PURE__ */ Y({
1
+ import { defineComponent as X, inject as D, ref as u, onMounted as Y, resolveComponent as m, createElementBlock as K, openBlock as H, Fragment as P, createVNode as t, withModifiers as Z, unref as e, withCtx as o, createBlock as ee, createCommentVNode as te, createTextVNode as c, toDisplayString as p, normalizeClass as j, renderList as ne } from "vue";
2
+ import { useI18n as le } from "../../../utils/i18n.js";
3
+ import { insertCustomCssToHead as I, deepClone as T } from "../../../utils/util.js";
4
+ import oe from "../../public/methoad-item.vue.js";
5
+ import { TpfCodeEditor as ae } from "tmgc2-share";
6
+ import { useDesigner as se } from "../form-widget/useFormDesigner.js";
7
+ import ie from "./property-editor/button-list-editor.vue2.js";
8
+ const pe = /* @__PURE__ */ X({
10
9
  name: "form-setting",
11
10
  __name: "form-setting",
12
- setup(de) {
13
- const { formConfig: n } = ue(), { i18nt: a } = oe(), h = D("designer", m({})), H = D("getDesignerConfig"), y = H ? H() : {}, B = m("javascript"), O = m(""), S = m(""), N = m(!1), U = m(""), M = m(["1", "2"]), b = m(""), E = m([]), x = m(""), A = m(null), T = [
11
+ setup(re) {
12
+ const { formConfig: l } = se(), { i18nt: a } = le(), h = D("designer", u({})), k = D("getDesignerConfig"), O = k ? k() : {}, S = u("javascript"), y = u(""), N = u(""), A = u(!1), U = u(""), z = u(["1", "2"]), C = u(""), E = u([]), w = u(""), M = u(null), W = [
14
13
  { label: "default", value: "middle" },
15
14
  { label: "large", value: "large" },
16
15
  { label: "small", value: "small" }
17
- ], z = {
16
+ ], V = {
18
17
  onFormCreated: "onFormCreated() {",
19
18
  onFormMounted: "onFormMounted() {",
20
19
  onOkButtonClick: "onOkButtonClick() {",
@@ -22,91 +21,91 @@ const _e = /* @__PURE__ */ Y({
22
21
  onFormEnterKey: "onFormEnterKey() {",
23
22
  onFormDataChange: "onFormDataChange(fieldName, newValue, oldValue, formModel, subFormName, subFormRowIndex) {"
24
23
  //'onFormValidate': 'onFormValidate() {',
25
- }, W = (r) => {
26
- n.value[O.value] = r;
27
- }, w = (r) => {
28
- O.value = r.eventName, B.value = r.mode, N.value = r.isShowEventHeader, x.value = n.value[r.eventName], S.value = r.title || a("designer.setting.editWidgetEventHandler"), U.value = r.eventHeader || "", A.value.open();
29
- }, R = (r) => !!n.value[r] && n.value[r].length > 0, q = () => y.eventCollapse === void 0 ? !0 : !!y.eventCollapse, k = () => {
30
- const r = /\..*{/g, l = b.value.match(r), f = [];
31
- l && l.length > 0 && l.forEach((d) => {
32
- const g = d.split(",");
33
- g.length > 0 && g.forEach((C) => {
34
- const i = C.trim();
35
- if (i.indexOf(".", 1) !== -1) {
36
- const u = i.substring(
37
- i.indexOf(".") + 1,
38
- i.indexOf(".", 1)
24
+ }, $ = (r) => {
25
+ l.value[y.value] = r;
26
+ }, x = (r) => {
27
+ y.value = r.eventName, S.value = r.mode, A.value = r.isShowEventHeader, w.value = l.value[r.eventName], N.value = r.title || a("designer.setting.editWidgetEventHandler"), U.value = r.eventHeader || "", M.value.open();
28
+ }, R = (r) => !!l.value[r] && l.value[r].length > 0, L = () => O.eventCollapse === void 0 ? !0 : !!O.eventCollapse, F = () => {
29
+ const r = /\..*{/g, n = C.value.match(r), f = [];
30
+ n && n.length > 0 && n.forEach((v) => {
31
+ const g = v.split(",");
32
+ g.length > 0 && g.forEach((_) => {
33
+ const s = _.trim();
34
+ if (s.indexOf(".", 1) !== -1) {
35
+ const d = s.substring(
36
+ s.indexOf(".") + 1,
37
+ s.indexOf(".", 1)
39
38
  );
40
- u && f.push(u.trim());
41
- } else if (i.indexOf(" ") !== -1) {
42
- const u = i.substring(
43
- i.indexOf(".") + 1,
44
- i.indexOf(" ")
39
+ d && f.push(d.trim());
40
+ } else if (s.indexOf(" ") !== -1) {
41
+ const d = s.substring(
42
+ s.indexOf(".") + 1,
43
+ s.indexOf(" ")
45
44
  );
46
- u && f.push(u.trim());
47
- } else if (i.indexOf("{") !== -1) {
48
- const u = i.substring(
49
- i.indexOf(".") + 1,
50
- i.indexOf("{")
45
+ d && f.push(d.trim());
46
+ } else if (s.indexOf("{") !== -1) {
47
+ const d = s.substring(
48
+ s.indexOf(".") + 1,
49
+ s.indexOf("{")
51
50
  );
52
- f.push(u.trim());
51
+ f.push(d.trim());
53
52
  } else {
54
- const u = i.substring(i.indexOf(".") + 1);
55
- f.push(u.trim());
53
+ const d = s.substring(s.indexOf(".") + 1);
54
+ f.push(d.trim());
56
55
  }
57
56
  });
58
57
  });
59
58
  };
60
- return Z(() => {
59
+ return Y(() => {
61
60
  h.value.handleEvent("form-json-imported", () => {
62
- b.value = n.value.cssCode, j(b.value), k(), h.value.emitEvent("form-css-updated", I(E.value));
61
+ C.value = l.value.cssCode, I(C.value), F(), h.value.emitEvent("form-css-updated", T(E.value));
63
62
  }), setTimeout(() => {
64
- b.value = n.value.cssCode, j(b.value), k(), h.value.emitEvent("form-css-updated", I(E.value));
63
+ C.value = l.value.cssCode, I(C.value), F(), h.value.emitEvent("form-css-updated", T(E.value));
65
64
  }, 1200);
66
- }), (r, l) => {
67
- const f = v("a-select"), d = v("a-form-item"), g = v("a-radio-button"), C = v("a-radio-group"), i = v("a-input-number"), u = v("a-button"), L = v("a-input"), V = v("a-collapse-panel"), G = v("a-collapse"), J = v("a-form"), Q = v("a-config-provider");
68
- return F(), K(P, null, [
69
- t(J, {
70
- model: e(n),
65
+ }), (r, n) => {
66
+ const f = m("a-select"), v = m("a-form-item"), g = m("a-radio-button"), _ = m("a-radio-group"), s = m("a-input-number"), d = m("a-button"), B = m("a-collapse-panel"), q = m("a-collapse"), G = m("a-form"), J = m("a-config-provider");
67
+ return H(), K(P, null, [
68
+ t(G, {
69
+ model: e(l),
71
70
  labelAlign: "left",
72
71
  "label-width": "120px",
73
72
  class: "setting-form",
74
- onSubmit: l[10] || (l[10] = ee(() => {
73
+ onSubmit: n[8] || (n[8] = Z(() => {
75
74
  }, ["prevent"]))
76
75
  }, {
77
76
  default: o(() => [
78
- t(G, {
79
- activeKey: M.value,
80
- "onUpdate:activeKey": l[9] || (l[9] = (s) => M.value = s),
77
+ t(q, {
78
+ activeKey: z.value,
79
+ "onUpdate:activeKey": n[7] || (n[7] = (i) => z.value = i),
81
80
  class: "setting-collapse"
82
81
  }, {
83
82
  default: o(() => [
84
- t(V, {
83
+ t(B, {
85
84
  key: "1",
86
85
  header: e(a)("designer.setting.基本属性")
87
86
  }, {
88
87
  default: o(() => [
89
- t(d, {
88
+ t(v, {
90
89
  label: e(a)("designer.setting.formSize")
91
90
  }, {
92
91
  default: o(() => [
93
92
  t(f, {
94
- value: e(n).size,
95
- "onUpdate:value": l[0] || (l[0] = (s) => e(n).size = s),
96
- options: T,
93
+ value: e(l).size,
94
+ "onUpdate:value": n[0] || (n[0] = (i) => e(l).size = i),
95
+ options: W,
97
96
  allowClear: "",
98
97
  style: { width: "120px" }
99
98
  }, null, 8, ["value"])
100
99
  ]),
101
100
  _: 1
102
101
  }, 8, ["label"]),
103
- t(d, {
102
+ t(v, {
104
103
  label: e(a)("designer.setting.labelPosition")
105
104
  }, {
106
105
  default: o(() => [
107
- t(C, {
108
- value: e(n).labelPosition,
109
- "onUpdate:value": l[1] || (l[1] = (s) => e(n).labelPosition = s),
106
+ t(_, {
107
+ value: e(l).labelPosition,
108
+ "onUpdate:value": n[1] || (n[1] = (i) => e(l).labelPosition = i),
110
109
  class: "radio-group-custom"
111
110
  }, {
112
111
  default: o(() => [
@@ -128,13 +127,13 @@ const _e = /* @__PURE__ */ Y({
128
127
  ]),
129
128
  _: 1
130
129
  }, 8, ["label"]),
131
- t(d, {
130
+ t(v, {
132
131
  label: e(a)("designer.setting.labelAlign")
133
132
  }, {
134
133
  default: o(() => [
135
- t(C, {
136
- value: e(n).labelAlign,
137
- "onUpdate:value": l[2] || (l[2] = (s) => e(n).labelAlign = s),
134
+ t(_, {
135
+ value: e(l).labelAlign,
136
+ "onUpdate:value": n[2] || (n[2] = (i) => e(l).labelAlign = i),
138
137
  class: "radio-group-custom"
139
138
  }, {
140
139
  default: o(() => [
@@ -156,13 +155,13 @@ const _e = /* @__PURE__ */ Y({
156
155
  ]),
157
156
  _: 1
158
157
  }, 8, ["label"]),
159
- t(d, {
158
+ t(v, {
160
159
  label: e(a)("designer.setting.labelWidth")
161
160
  }, {
162
161
  default: o(() => [
163
- t(i, {
164
- value: e(n).labelWidth,
165
- "onUpdate:value": l[3] || (l[3] = (s) => e(n).labelWidth = s),
162
+ t(s, {
163
+ value: e(l).labelWidth,
164
+ "onUpdate:value": n[3] || (n[3] = (i) => e(l).labelWidth = i),
166
165
  min: 0,
167
166
  style: { width: "100%" },
168
167
  allowClear: ""
@@ -170,19 +169,19 @@ const _e = /* @__PURE__ */ Y({
170
169
  ]),
171
170
  _: 1
172
171
  }, 8, ["label"]),
173
- t(d, {
172
+ t(v, {
174
173
  label: e(a)("designer.setting.formCss")
175
174
  }, {
176
175
  default: o(() => [
177
- t(u, {
176
+ t(d, {
178
177
  shape: "round",
179
- onClick: l[4] || (l[4] = (s) => w({
178
+ onClick: n[4] || (n[4] = (i) => x({
180
179
  eventName: "cssCode",
181
180
  isShowEventHeader: !1,
182
181
  mode: "css",
183
182
  title: e(a)("designer.setting.formCss")
184
183
  })),
185
- class: $([{ "button-text-highlight": !!e(n).cssCode }])
184
+ class: j([{ "button-text-highlight": !!e(l).cssCode }])
186
185
  }, {
187
186
  default: o(() => [
188
187
  c(p(e(a)("designer.setting.addCss")), 1)
@@ -192,29 +191,29 @@ const _e = /* @__PURE__ */ Y({
192
191
  ]),
193
192
  _: 1
194
193
  }, 8, ["label"]),
195
- t(d, {
194
+ t(v, {
196
195
  label: e(a)("designer.setting.customClass")
197
196
  }, {
198
197
  default: o(() => [
199
198
  t(f, {
200
- value: e(n).customClass,
201
- "onUpdate:value": l[5] || (l[5] = (s) => e(n).customClass = s),
199
+ value: e(l).customClass,
200
+ "onUpdate:value": n[5] || (n[5] = (i) => e(l).customClass = i),
202
201
  allowClear: "",
203
202
  mode: "tags",
204
- onChange: k,
203
+ onChange: F,
205
204
  options: E.value
206
205
  }, null, 8, ["value", "options"])
207
206
  ]),
208
207
  _: 1
209
208
  }, 8, ["label"]),
210
- t(d, {
209
+ t(v, {
211
210
  label: e(a)("designer.setting.globalFunctions")
212
211
  }, {
213
212
  default: o(() => [
214
- t(u, {
215
- class: $([{ "button-text-highlight": !!e(n).functions }]),
213
+ t(d, {
214
+ class: j([{ "button-text-highlight": !!e(l).functions }]),
216
215
  shape: "round",
217
- onClick: l[6] || (l[6] = (s) => w({
216
+ onClick: n[6] || (n[6] = (i) => x({
218
217
  eventName: "functions",
219
218
  isShowEventHeader: !1,
220
219
  mode: "javascript",
@@ -229,73 +228,48 @@ const _e = /* @__PURE__ */ Y({
229
228
  ]),
230
229
  _: 1
231
230
  }, 8, ["label"]),
232
- t(d, {
233
- label: e(a)("designer.setting.cancelButtonLabel")
234
- }, {
235
- default: o(() => [
236
- t(L, {
237
- type: "text",
238
- value: e(n).cancelButtonLabel,
239
- "onUpdate:value": l[7] || (l[7] = (s) => e(n).cancelButtonLabel = s)
240
- }, null, 8, ["value"])
241
- ]),
242
- _: 1
243
- }, 8, ["label"]),
244
- t(ie, { optionModel: e(n) }, null, 8, ["optionModel"]),
245
- t(d, {
246
- label: e(a)("designer.setting.okButtonLabel")
247
- }, {
248
- default: o(() => [
249
- t(L, {
250
- type: "text",
251
- value: e(n).okButtonLabel,
252
- "onUpdate:value": l[8] || (l[8] = (s) => e(n).okButtonLabel = s)
253
- }, null, 8, ["value"])
254
- ]),
255
- _: 1
256
- }, 8, ["label"]),
257
- t(se, { optionModel: e(n) }, null, 8, ["optionModel"])
231
+ t(ie, { optionModel: e(l) }, null, 8, ["optionModel"])
258
232
  ]),
259
233
  _: 1
260
234
  }, 8, ["header"]),
261
- q() ? (F(), te(V, {
235
+ L() ? (H(), ee(B, {
262
236
  key: "2",
263
237
  class: "eventPanel",
264
238
  header: e(a)("designer.setting.事件属性")
265
239
  }, {
266
240
  default: o(() => [
267
- (F(), K(P, null, le(z, (s, _) => t(ae, {
268
- onClickItem: w,
269
- key: _,
270
- "event-name": _,
271
- value: e(n)[_],
272
- "onUpdate:value": (X) => e(n)[_] = X,
241
+ (H(), K(P, null, ne(V, (i, b) => t(oe, {
242
+ onClickItem: x,
243
+ key: b,
244
+ "event-name": b,
245
+ value: e(l)[b],
246
+ "onUpdate:value": (Q) => e(l)[b] = Q,
273
247
  "get-form-event-handled": R,
274
- "event-params-map": z,
275
- "form-config": e(n)
248
+ "event-params-map": V,
249
+ "form-config": e(l)
276
250
  }, null, 8, ["event-name", "value", "onUpdate:value", "form-config"])), 64))
277
251
  ]),
278
252
  _: 1
279
- }, 8, ["header"])) : ne("", !0)
253
+ }, 8, ["header"])) : te("", !0)
280
254
  ]),
281
255
  _: 1
282
256
  }, 8, ["activeKey"])
283
257
  ]),
284
258
  _: 1
285
259
  }, 8, ["model"]),
286
- t(Q, { componentSize: "middle" }, {
260
+ t(J, { componentSize: "middle" }, {
287
261
  default: o(() => [
288
- t(e(re), {
289
- isShowEventHeader: N.value,
262
+ t(e(ae), {
263
+ isShowEventHeader: A.value,
290
264
  ref_key: "codeEditorRef",
291
- ref: A,
265
+ ref: M,
292
266
  "event-header": U.value,
293
- modelValue: x.value,
294
- "onUpdate:modelValue": l[11] || (l[11] = (s) => x.value = s),
295
- mode: B.value,
267
+ modelValue: w.value,
268
+ "onUpdate:modelValue": n[9] || (n[9] = (i) => w.value = i),
269
+ mode: S.value,
296
270
  readonly: !1,
297
- title: S.value,
298
- onSetCode: W
271
+ title: N.value,
272
+ onSetCode: $
299
273
  }, null, 8, ["isShowEventHeader", "event-header", "modelValue", "mode", "title"])
300
274
  ]),
301
275
  _: 1
@@ -305,6 +279,6 @@ const _e = /* @__PURE__ */ Y({
305
279
  }
306
280
  });
307
281
  export {
308
- _e as default
282
+ pe as default
309
283
  };
310
284
  //# sourceMappingURL=form-setting.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-setting.vue2.js","sources":["../../../../../src/components/form-designer/setting-panel/form-setting.vue"],"sourcesContent":["<template>\n <a-form\n :model=\"formConfig\"\n labelAlign=\"left\"\n label-width=\"120px\"\n class=\"setting-form\"\n @submit.prevent\n >\n <a-collapse v-model:activeKey=\"formActiveCollapseNames\" class=\"setting-collapse\">\n <a-collapse-panel key=\"1\" :header=\"i18nt('designer.setting.基本属性')\">\n <a-form-item :label=\"i18nt('designer.setting.formSize')\">\n <a-select\n v-model:value=\"formConfig.size\"\n :options=\"formSizes\"\n allowClear\n style=\"width: 120px\"\n />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelPosition')\">\n <a-radio-group\n v-model:value=\"formConfig.labelPosition\"\n class=\"radio-group-custom\"\n >\n <a-radio-button value=\"horizontal\">\n {{ i18nt('designer.setting.horizontal') }}\n </a-radio-button>\n <a-radio-button value=\"vertical\">\n {{ i18nt('designer.setting.vertical') }}\n </a-radio-button>\n </a-radio-group>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelAlign')\">\n <a-radio-group v-model:value=\"formConfig.labelAlign\" class=\"radio-group-custom\">\n <a-radio-button value=\"left\">\n {{ i18nt('designer.setting.leftAlign') }}\n </a-radio-button>\n <a-radio-button value=\"right\">\n {{ i18nt('designer.setting.rightAlign') }}\n </a-radio-button>\n </a-radio-group>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelWidth')\">\n <a-input-number\n v-model:value=\"formConfig.labelWidth\"\n :min=\"0\"\n style=\"width: 100%\"\n allowClear\n />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.formCss')\">\n <a-button\n shape=\"round\"\n @click=\"\n handleEditEvent({\n eventName: 'cssCode',\n isShowEventHeader: false,\n mode: 'css',\n title: i18nt('designer.setting.formCss')\n })\n \"\n :class=\"[{ 'button-text-highlight': !!formConfig.cssCode }]\"\n >\n {{ i18nt('designer.setting.addCss') }}\n </a-button>\n </a-form-item>\n <!-- -->\n <a-form-item :label=\"i18nt('designer.setting.customClass')\">\n <a-select\n v-model:value=\"formConfig.customClass\"\n allowClear\n mode=\"tags\"\n @change=\"extractCssClass\"\n :options=\"cssClassList\"\n />\n </a-form-item>\n <!-- 表单全局函数 -->\n <a-form-item :label=\"i18nt('designer.setting.globalFunctions')\">\n <a-button\n :class=\"[{ 'button-text-highlight': !!formConfig.functions }]\"\n shape=\"round\"\n @click=\"\n handleEditEvent({\n eventName: 'functions',\n isShowEventHeader: false,\n mode: 'javascript',\n title: i18nt('designer.setting.globalFunctions')\n })\n \"\n >\n {{ i18nt('designer.setting.addEventHandler') }}\n </a-button>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.cancelButtonLabel')\">\n <a-input type=\"text\" v-model:value=\"formConfig.cancelButtonLabel\" />\n </a-form-item>\n <!-- 隐藏取消按钮 -->\n <CancelButtonHidden :optionModel=\"formConfig\" />\n <a-form-item :label=\"i18nt('designer.setting.okButtonLabel')\">\n <a-input type=\"text\" v-model:value=\"formConfig.okButtonLabel\" />\n </a-form-item>\n <OkButtonHiddenEditor :optionModel=\"formConfig\" />\n </a-collapse-panel>\n\n <a-collapse-panel\n v-if=\"showEventCollapse()\"\n key=\"2\"\n class=\"eventPanel\"\n :header=\"i18nt('designer.setting.事件属性')\"\n >\n <MethodItem\n @click-item=\"handleEditEvent\"\n v-for=\"(value, key) in eventParamsMap\"\n :key=\"key\"\n :event-name=\"key\"\n v-model:value=\"formConfig[key]\"\n :get-form-event-handled=\"getFormEventHandled\"\n :event-params-map=\"eventParamsMap\"\n :form-config=\"formConfig\"\n />\n </a-collapse-panel>\n </a-collapse>\n </a-form>\n\n <a-config-provider componentSize=\"middle\">\n <TpfCodeEditor\n :isShowEventHeader=\"isShowEventHeader\"\n ref=\"codeEditorRef\"\n :event-header=\"eventHeader\"\n v-model=\"formEventHandlerCode\"\n :mode=\"mode\"\n :readonly=\"false\"\n :title=\"title\"\n @set-code=\"saveFormEventHandler\"\n /></a-config-provider>\n</template>\n\n<script lang=\"ts\" setup>\n import { ref, reactive, onMounted, inject, Ref } from 'vue';\n import { useI18n } from '@/utils/i18n';\n import { deepClone, insertCustomCssToHead } from '@/utils/util';\n import MethodItem from '@/components/public/methoad-item.vue';\n import OkButtonHiddenEditor from '@/components/form-designer/setting-panel/property-editor/container-vf-dialog/okButtonHidden-editor.vue';\n import CancelButtonHidden from '@/components/form-designer/setting-panel/property-editor/container-vf-dialog/cancelButtonHidden-editor.vue';\n import { ILanguageMode, TpfCodeEditor } from 'tmgc2-share';\n import { FormDesigner } from '@/types/designer';\n import { useDesigner } from '../form-widget/useFormDesigner';\n // 定义类型\n interface FormSize {\n label: string;\n value: string;\n }\n\n interface EventParams {\n [key: string]: string;\n }\n\n const { formConfig } = useDesigner();\n interface EditEventParams {\n eventName: string;\n mode: ILanguageMode;\n isShowEventHeader: boolean;\n title: string;\n eventHeader?: string;\n }\n\n // 使用i18n\n const { i18nt } = useI18n();\n const designer = inject<Ref<FormDesigner>>('designer', ref({} as FormDesigner));\n // 注入依赖\n const getDesignerConfig = inject<() => any>('getDesignerConfig');\n const designerConfig = getDesignerConfig ? getDesignerConfig() : {};\n\n // 响应式状态\n const mode = ref<ILanguageMode>('javascript');\n const eventName = ref('');\n const title = ref('');\n const isShowEventHeader = ref(false);\n const eventHeader = ref('');\n const formActiveCollapseNames = ref(['1', '2']);\n const formCssCode = ref('');\n const cssClassList = ref<string[]>([]);\n const formEventHandlerCode = ref('');\n\n // 引用\n const codeEditorRef = ref<any>(null);\n\n // 常量数据\n const formSizes: FormSize[] = [\n { label: 'default', value: 'middle' },\n { label: 'large', value: 'large' },\n { label: 'small', value: 'small' }\n ];\n\n const eventParamsMap: EventParams = {\n onFormCreated: 'onFormCreated() {',\n onFormMounted: 'onFormMounted() {',\n onOkButtonClick: 'onOkButtonClick() {',\n onCancelButtonClick: 'onCancelButtonClick() {',\n onFormEnterKey: 'onFormEnterKey() {',\n onFormDataChange:\n 'onFormDataChange(fieldName, newValue, oldValue, formModel, subFormName, subFormRowIndex) {'\n //'onFormValidate': 'onFormValidate() {',\n };\n\n // 方法\n const saveFormEventHandler = (value: string) => {\n formConfig.value[eventName.value] = value;\n };\n\n const handleEditEvent = (params: EditEventParams) => {\n eventName.value = params.eventName;\n mode.value = params.mode;\n isShowEventHeader.value = params.isShowEventHeader;\n formEventHandlerCode.value = formConfig.value[params.eventName];\n title.value = params.title || i18nt('designer.setting.editWidgetEventHandler');\n eventHeader.value = params.eventHeader || '';\n codeEditorRef.value.open();\n };\n\n const getFormEventHandled = (eventName: string) => {\n return !!formConfig.value[eventName] && formConfig.value[eventName].length > 0;\n };\n\n const showEventCollapse = () => {\n if (designerConfig['eventCollapse'] === undefined) {\n return true;\n }\n return !!designerConfig['eventCollapse'];\n };\n\n const extractCssClass = () => {\n const regExp = /\\..*{/g;\n const result = formCssCode.value.match(regExp);\n const cssNameArray: string[] = [];\n\n if (!!result && result.length > 0) {\n result.forEach(rItem => {\n const classArray = rItem.split(','); // 切分逗号分割的多个class\n if (classArray.length > 0) {\n classArray.forEach(cItem => {\n const caItem = cItem.trim();\n if (caItem.indexOf('.', 1) !== -1) {\n // 查找第二个.位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf('.', 1)\n ); // 仅截取第一、二个.号之间的class\n if (!!newClass) {\n cssNameArray.push(newClass.trim());\n }\n } else if (caItem.indexOf(' ') !== -1) {\n // 查找第一个空格位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf(' ')\n ); // 仅截取第一、二个.号之间的class\n if (!!newClass) {\n cssNameArray.push(newClass.trim());\n }\n } else {\n if (caItem.indexOf('{') !== -1) {\n // 查找第一个{位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf('{')\n );\n cssNameArray.push(newClass.trim());\n } else {\n const newClass = caItem.substring(caItem.indexOf('.') + 1);\n cssNameArray.push(newClass.trim());\n }\n }\n });\n }\n });\n }\n\n // cssClassList.value = Array.from(new Set(cssNameArray)); // 数组去重\n };\n\n // 生命周期钩子\n onMounted(() => {\n // 导入表单JSON后需要重新加载自定义CSS样式\n designer.value.handleEvent('form-json-imported', () => {\n formCssCode.value = formConfig.value.cssCode;\n insertCustomCssToHead(formCssCode.value);\n extractCssClass();\n designer.value.emitEvent('form-css-updated', deepClone(cssClassList.value));\n });\n\n /* SettingPanel和FormWidget为兄弟组件, 在FormWidget加载formConfig时,\n 此处SettingPanel可能无法获取到formConfig.cssCode, 故加个延时函数! */\n setTimeout(() => {\n formCssCode.value = formConfig.value.cssCode;\n insertCustomCssToHead(formCssCode.value);\n extractCssClass();\n designer.value.emitEvent('form-css-updated', deepClone(cssClassList.value));\n }, 1200);\n });\n\n // 组件名称定义\n defineOptions({\n name: 'form-setting'\n });\n</script>\n\n<style lang=\"less\" scoped>\n .eventPanel {\n :deep(.ant-form-item-row) {\n flex: 1;\n .ant-form-item-control-input-content .ant-btn {\n border: 1px solid #eee;\n }\n .ant-form-item-label {\n flex: 1;\n }\n }\n :deep(.ant-col.ant-form-item-control) {\n flex: 0 0 80px;\n }\n }\n</style>\n"],"names":["formConfig","useDesigner","i18nt","useI18n","designer","inject","ref","getDesignerConfig","designerConfig","mode","eventName","title","isShowEventHeader","eventHeader","formActiveCollapseNames","formCssCode","cssClassList","formEventHandlerCode","codeEditorRef","formSizes","eventParamsMap","saveFormEventHandler","value","handleEditEvent","params","getFormEventHandled","showEventCollapse","extractCssClass","regExp","result","cssNameArray","rItem","classArray","cItem","caItem","newClass","onMounted","insertCustomCssToHead","deepClone","_createVNode","_component_a_form","_unref","_component_a_collapse","$event","_component_a_collapse_panel","_component_a_form_item","_component_a_select","_cache","_component_a_radio_group","_component_a_radio_button","_component_a_input_number","_component_a_button","_normalizeClass","_component_a_input","CancelButtonHidden","OkButtonHiddenEditor","_createBlock","_openBlock","_createElementBlock","_Fragment","_renderList","key","MethodItem","_component_a_config_provider","TpfCodeEditor"],"mappings":";;;;;;;;;;;;AA4JI,UAAM,EAAE,YAAAA,EAAA,IAAeC,GAAA,GAUjB,EAAE,OAAAC,EAAA,IAAUC,GAAA,GACZC,IAAWC,EAA0B,YAAYC,EAAI,CAAA,CAAkB,CAAC,GAExEC,IAAoBF,EAAkB,mBAAmB,GACzDG,IAAiBD,IAAoBA,EAAA,IAAsB,CAAA,GAG3DE,IAAOH,EAAmB,YAAY,GACtCI,IAAYJ,EAAI,EAAE,GAClBK,IAAQL,EAAI,EAAE,GACdM,IAAoBN,EAAI,EAAK,GAC7BO,IAAcP,EAAI,EAAE,GACpBQ,IAA0BR,EAAI,CAAC,KAAK,GAAG,CAAC,GACxCS,IAAcT,EAAI,EAAE,GACpBU,IAAeV,EAAc,EAAE,GAC/BW,IAAuBX,EAAI,EAAE,GAG7BY,IAAgBZ,EAAS,IAAI,GAG7Ba,IAAwB;AAAA,MAC1B,EAAE,OAAO,WAAW,OAAO,SAAA;AAAA,MAC3B,EAAE,OAAO,SAAS,OAAO,QAAA;AAAA,MACzB,EAAE,OAAO,SAAS,OAAO,QAAA;AAAA,IAAQ,GAG/BC,IAA8B;AAAA,MAChC,eAAe;AAAA,MACf,eAAe;AAAA,MACf,iBAAiB;AAAA,MACjB,qBAAqB;AAAA,MACrB,gBAAgB;AAAA,MAChB,kBACI;AAAA;AAAA,IAAA,GAKFC,IAAuB,CAACC,MAAkB;AAC5C,MAAAtB,EAAW,MAAMU,EAAU,KAAK,IAAIY;AAAA,IACxC,GAEMC,IAAkB,CAACC,MAA4B;AACjD,MAAAd,EAAU,QAAQc,EAAO,WACzBf,EAAK,QAAQe,EAAO,MACpBZ,EAAkB,QAAQY,EAAO,mBACjCP,EAAqB,QAAQjB,EAAW,MAAMwB,EAAO,SAAS,GAC9Db,EAAM,QAAQa,EAAO,SAAStB,EAAM,yCAAyC,GAC7EW,EAAY,QAAQW,EAAO,eAAe,IAC1CN,EAAc,MAAM,KAAA;AAAA,IACxB,GAEMO,IAAsB,CAACf,MAClB,CAAC,CAACV,EAAW,MAAMU,CAAS,KAAKV,EAAW,MAAMU,CAAS,EAAE,SAAS,GAG3EgB,IAAoB,MAClBlB,EAAe,kBAAqB,SAC7B,KAEJ,CAAC,CAACA,EAAe,eAGtBmB,IAAkB,MAAM;AAC1B,YAAMC,IAAS,UACTC,IAASd,EAAY,MAAM,MAAMa,CAAM,GACvCE,IAAyB,CAAA;AAE/B,MAAMD,KAAUA,EAAO,SAAS,KAC5BA,EAAO,QAAQ,CAAAE,MAAS;AACpB,cAAMC,IAAaD,EAAM,MAAM,GAAG;AAClC,QAAIC,EAAW,SAAS,KACpBA,EAAW,QAAQ,CAAAC,MAAS;AACxB,gBAAMC,IAASD,EAAM,KAAA;AACrB,cAAIC,EAAO,QAAQ,KAAK,CAAC,MAAM,IAAI;AAE/B,kBAAMC,IAAWD,EAAO;AAAA,cACpBA,EAAO,QAAQ,GAAG,IAAI;AAAA,cACtBA,EAAO,QAAQ,KAAK,CAAC;AAAA,YAAA;AAEzB,YAAMC,KACFL,EAAa,KAAKK,EAAS,MAAM;AAAA,UAEzC,WAAWD,EAAO,QAAQ,GAAG,MAAM,IAAI;AAEnC,kBAAMC,IAAWD,EAAO;AAAA,cACpBA,EAAO,QAAQ,GAAG,IAAI;AAAA,cACtBA,EAAO,QAAQ,GAAG;AAAA,YAAA;AAEtB,YAAMC,KACFL,EAAa,KAAKK,EAAS,MAAM;AAAA,UAEzC,WACQD,EAAO,QAAQ,GAAG,MAAM,IAAI;AAE5B,kBAAMC,IAAWD,EAAO;AAAA,cACpBA,EAAO,QAAQ,GAAG,IAAI;AAAA,cACtBA,EAAO,QAAQ,GAAG;AAAA,YAAA;AAEtB,YAAAJ,EAAa,KAAKK,EAAS,MAAM;AAAA,UACrC,OAAO;AACH,kBAAMA,IAAWD,EAAO,UAAUA,EAAO,QAAQ,GAAG,IAAI,CAAC;AACzD,YAAAJ,EAAa,KAAKK,EAAS,MAAM;AAAA,UACrC;AAAA,QAER,CAAC;AAAA,MAET,CAAC;AAAA,IAIT;AAGA,WAAAC,EAAU,MAAM;AAEZ,MAAAhC,EAAS,MAAM,YAAY,sBAAsB,MAAM;AACnD,QAAAW,EAAY,QAAQf,EAAW,MAAM,SACrCqC,EAAsBtB,EAAY,KAAK,GACvCY,EAAA,GACAvB,EAAS,MAAM,UAAU,oBAAoBkC,EAAUtB,EAAa,KAAK,CAAC;AAAA,MAC9E,CAAC,GAID,WAAW,MAAM;AACb,QAAAD,EAAY,QAAQf,EAAW,MAAM,SACrCqC,EAAsBtB,EAAY,KAAK,GACvCY,EAAA,GACAvB,EAAS,MAAM,UAAU,oBAAoBkC,EAAUtB,EAAa,KAAK,CAAC;AAAA,MAC9E,GAAG,IAAI;AAAA,IACX,CAAC;;;QAzSDuB,EAwHSC,GAAA;AAAA,UAvHJ,OAAOC,EAAAzC,CAAA;AAAA,UACR,YAAW;AAAA,UACX,eAAY;AAAA,UACZ,OAAM;AAAA,UACL,+BAAD,MAAA;AAAA,UAAA,GAAe,CAAA,SAAA,CAAA;AAAA,QAAA;qBAEf,MAgHa;AAAA,YAhHbuC,EAgHaG,GAAA;AAAA,cAhHO,WAAW5B,EAAA;AAAA,2DAAAA,EAAuB,QAAA6B;AAAA,cAAE,OAAM;AAAA,YAAA;yBAC1D,MA4FmB;AAAA,gBA5FnBJ,EA4FmBK,GAAA;AAAA,kBA5FD,KAAI;AAAA,kBAAK,QAAQH,EAAAvC,CAAA,EAAK,uBAAA;AAAA,gBAAA;6BACpC,MAOc;AAAA,oBAPdqC,EAOcM,GAAA;AAAA,sBAPA,OAAOJ,EAAAvC,CAAA,EAAK,2BAAA;AAAA,oBAAA;iCACtB,MAKE;AAAA,wBALFqC,EAKEO,GAAA;AAAA,0BAJU,OAAOL,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,OAAI2C;AAAA,0BAC7B,SAASxB;AAAA,0BACV,YAAA;AAAA,0BACA,OAAA,EAAA,OAAA,QAAA;AAAA,wBAAA;;;;oBAGRoB,EAYcM,GAAA;AAAA,sBAZA,OAAOJ,EAAAvC,CAAA,EAAK,gCAAA;AAAA,oBAAA;iCACtB,MAUgB;AAAA,wBAVhBqC,EAUgBS,GAAA;AAAA,0BATJ,OAAOP,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,gBAAa2C;AAAA,0BACvC,OAAM;AAAA,wBAAA;qCAEN,MAEiB;AAAA,4BAFjBJ,EAEiBU,GAAA,EAFD,OAAM,gBAAY;AAAA,yCAC9B,MAA0C;AAAA,oCAAvCR,EAAAvC,CAAA,EAAK,6BAAA,CAAA,GAAA,CAAA;AAAA,8BAAA;;;4BAEZqC,EAEiBU,GAAA,EAFD,OAAM,cAAU;AAAA,yCAC5B,MAAwC;AAAA,oCAArCR,EAAAvC,CAAA,EAAK,2BAAA,CAAA,GAAA,CAAA;AAAA,8BAAA;;;;;;;;;oBAIpBqC,EAScM,GAAA;AAAA,sBATA,OAAOJ,EAAAvC,CAAA,EAAK,6BAAA;AAAA,oBAAA;iCACtB,MAOgB;AAAA,wBAPhBqC,EAOgBS,GAAA;AAAA,0BAPO,OAAOP,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,aAAU2C;AAAA,0BAAE,OAAM;AAAA,wBAAA;qCACvD,MAEiB;AAAA,4BAFjBJ,EAEiBU,GAAA,EAFD,OAAM,UAAM;AAAA,yCACxB,MAAyC;AAAA,oCAAtCR,EAAAvC,CAAA,EAAK,4BAAA,CAAA,GAAA,CAAA;AAAA,8BAAA;;;4BAEZqC,EAEiBU,GAAA,EAFD,OAAM,WAAO;AAAA,yCACzB,MAA0C;AAAA,oCAAvCR,EAAAvC,CAAA,EAAK,6BAAA,CAAA,GAAA,CAAA;AAAA,8BAAA;;;;;;;;;oBAIpBqC,EAOcM,GAAA;AAAA,sBAPA,OAAOJ,EAAAvC,CAAA,EAAK,6BAAA;AAAA,oBAAA;iCACtB,MAKE;AAAA,wBALFqC,EAKEW,GAAA;AAAA,0BAJU,OAAOT,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,aAAU2C;AAAA,0BACnC,KAAK;AAAA,0BACN,OAAA,EAAA,OAAA,OAAA;AAAA,0BACA,YAAA;AAAA,wBAAA;;;;oBAGRJ,EAecM,GAAA;AAAA,sBAfA,OAAOJ,EAAAvC,CAAA,EAAK,0BAAA;AAAA,oBAAA;iCACtB,MAaW;AAAA,wBAbXqC,EAaWY,GAAA;AAAA,0BAZP,OAAM;AAAA,0BACL,SAAKJ,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAA+BpB,EAAe;AAAA;;;mCAAuMkB,EAAAvC,CAAA,EAAK,0BAAA;AAAA,0BAAA;0BAQ/P,OAAKkD,EAAA,CAAA,EAAA,yBAAA,CAAA,CAAgCX,EAAAzC,CAAA,EAAW,SAAO,CAAA;AAAA,wBAAA;qCAExD,MAAsC;AAAA,gCAAnCyC,EAAAvC,CAAA,EAAK,yBAAA,CAAA,GAAA,CAAA;AAAA,0BAAA;;;;;;oBAIhBqC,EAQcM,GAAA;AAAA,sBARA,OAAOJ,EAAAvC,CAAA,EAAK,8BAAA;AAAA,oBAAA;iCACtB,MAME;AAAA,wBANFqC,EAMEO,GAAA;AAAA,0BALU,OAAOL,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,cAAW2C;AAAA,0BACrC,YAAA;AAAA,0BACA,MAAK;AAAA,0BACJ,UAAQhB;AAAA,0BACR,SAASX,EAAA;AAAA,wBAAA;;;;oBAIlBuB,EAecM,GAAA;AAAA,sBAfA,OAAOJ,EAAAvC,CAAA,EAAK,kCAAA;AAAA,oBAAA;iCACtB,MAaW;AAAA,wBAbXqC,EAaWY,GAAA;AAAA,0BAZN,OAAKC,EAAA,CAAA,EAAA,yBAAA,CAAA,CAAgCX,EAAAzC,CAAA,EAAW,UAAA,CAAS,CAAA;AAAA,0BAC1D,OAAM;AAAA,0BACL,SAAK+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAA+BpB,EAAe;AAAA;;;mCAAgNkB,EAAAvC,CAAA,EAAK,kCAAA;AAAA,0BAAA;;qCASzQ,MAA+C;AAAA,gCAA5CuC,EAAAvC,CAAA,EAAK,kCAAA,CAAA,GAAA,CAAA;AAAA,0BAAA;;;;;;oBAGhBqC,EAEcM,GAAA;AAAA,sBAFA,OAAOJ,EAAAvC,CAAA,EAAK,oCAAA;AAAA,oBAAA;iCACtB,MAAoE;AAAA,wBAApEqC,EAAoEc,GAAA;AAAA,0BAA3D,MAAK;AAAA,0BAAe,OAAOZ,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,oBAAiB2C;AAAA,wBAAA;;;;oBAGpEJ,EAAgDe,IAAA,EAA3B,aAAab,EAAAzC,CAAA,EAAA,GAAU,MAAA,GAAA,CAAA,aAAA,CAAA;AAAA,oBAC5CuC,EAEcM,GAAA;AAAA,sBAFA,OAAOJ,EAAAvC,CAAA,EAAK,gCAAA;AAAA,oBAAA;iCACtB,MAAgE;AAAA,wBAAhEqC,EAAgEc,GAAA;AAAA,0BAAvD,MAAK;AAAA,0BAAe,OAAOZ,EAAAzC,CAAA,EAAW;AAAA,0BAAX,kBAAA+C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAJ,MAAAF,EAAAzC,CAAA,EAAW,gBAAa2C;AAAA,wBAAA;;;;oBAEhEJ,EAAkDgB,IAAA,EAA3B,aAAad,EAAAzC,CAAA,EAAA,GAAU,MAAA,GAAA,CAAA,aAAA,CAAA;AAAA,kBAAA;;;gBAIxC0B,YADV8B,GAgBmBZ,GAAA;AAAA,kBAdf,KAAI;AAAA,kBACJ,OAAM;AAAA,kBACL,QAAQH,EAAAvC,CAAA,EAAK,uBAAA;AAAA,gBAAA;6BAIV,MAAsC;AAAA,qBAF1CuD,EAAA,GAAAC,EASEC,GAAA,MAAAC,GAPyBxC,GAAc,CAA7BE,GAAOuC,MAFnBtB,EASEuB,IAAA;AAAA,sBARG,aAAYvC;AAAA,sBAEZ,KAAAsC;AAAA,sBACA,cAAYA;AAAA,sBACL,OAAOpB,EAAAzC,CAAA,EAAW6D,CAAG;AAAA,sBAAd,kBAAA,CAAAlB,MAAAF,EAAAzC,CAAA,EAAW6D,CAAG,IAAAlB;AAAA,sBAC5B,0BAAwBlB;AAAA,sBACxB,oBAAkBL;AAAA,sBAClB,eAAaqB,EAAAzC,CAAA;AAAA,oBAAA;;;;;;;;;;QAM9BuC,EAUsBwB,GAAA,EAVH,eAAc,YAAQ;AAAA,qBACrC,MASF;AAAA,YATExB,EASFE,EAAAuB,EAAA,GAAA;AAAA,cARO,mBAAmBpD,EAAA;AAAA,uBAChB;AAAA,cAAJ,KAAIM;AAAA,cACH,gBAAcL,EAAA;AAAA,0BACNI,EAAA;AAAA,8DAAAA,EAAoB,QAAA0B;AAAA,cAC5B,MAAMlC,EAAA;AAAA,cACN,UAAU;AAAA,cACV,OAAOE,EAAA;AAAA,cACP,WAAUU;AAAA,YAAA;;;;;;;;"}
1
+ {"version":3,"file":"form-setting.vue2.js","sources":["../../../../../src/components/form-designer/setting-panel/form-setting.vue"],"sourcesContent":["<template>\n <a-form\n :model=\"formConfig\"\n labelAlign=\"left\"\n label-width=\"120px\"\n class=\"setting-form\"\n @submit.prevent\n >\n <a-collapse v-model:activeKey=\"formActiveCollapseNames\" class=\"setting-collapse\">\n <a-collapse-panel key=\"1\" :header=\"i18nt('designer.setting.基本属性')\">\n <a-form-item :label=\"i18nt('designer.setting.formSize')\">\n <a-select\n v-model:value=\"formConfig.size\"\n :options=\"formSizes\"\n allowClear\n style=\"width: 120px\"\n />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelPosition')\">\n <a-radio-group\n v-model:value=\"formConfig.labelPosition\"\n class=\"radio-group-custom\"\n >\n <a-radio-button value=\"horizontal\">\n {{ i18nt('designer.setting.horizontal') }}\n </a-radio-button>\n <a-radio-button value=\"vertical\">\n {{ i18nt('designer.setting.vertical') }}\n </a-radio-button>\n </a-radio-group>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelAlign')\">\n <a-radio-group v-model:value=\"formConfig.labelAlign\" class=\"radio-group-custom\">\n <a-radio-button value=\"left\">\n {{ i18nt('designer.setting.leftAlign') }}\n </a-radio-button>\n <a-radio-button value=\"right\">\n {{ i18nt('designer.setting.rightAlign') }}\n </a-radio-button>\n </a-radio-group>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelWidth')\">\n <a-input-number\n v-model:value=\"formConfig.labelWidth\"\n :min=\"0\"\n style=\"width: 100%\"\n allowClear\n />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.formCss')\">\n <a-button\n shape=\"round\"\n @click=\"\n handleEditEvent({\n eventName: 'cssCode',\n isShowEventHeader: false,\n mode: 'css',\n title: i18nt('designer.setting.formCss')\n })\n \"\n :class=\"[{ 'button-text-highlight': !!formConfig.cssCode }]\"\n >\n {{ i18nt('designer.setting.addCss') }}\n </a-button>\n </a-form-item>\n <!-- -->\n <a-form-item :label=\"i18nt('designer.setting.customClass')\">\n <a-select\n v-model:value=\"formConfig.customClass\"\n allowClear\n mode=\"tags\"\n @change=\"extractCssClass\"\n :options=\"cssClassList\"\n />\n </a-form-item>\n <!-- 表单全局函数 -->\n <a-form-item :label=\"i18nt('designer.setting.globalFunctions')\">\n <a-button\n :class=\"[{ 'button-text-highlight': !!formConfig.functions }]\"\n shape=\"round\"\n @click=\"\n handleEditEvent({\n eventName: 'functions',\n isShowEventHeader: false,\n mode: 'javascript',\n title: i18nt('designer.setting.globalFunctions')\n })\n \"\n >\n {{ i18nt('designer.setting.addEventHandler') }}\n </a-button>\n </a-form-item>\n <!-- <a-form-item :label=\"i18nt('designer.setting.cancelButtonLabel')\">\n <a-input type=\"text\" v-model:value=\"formConfig.cancelButtonLabel\" />\n </a-form-item>\n <CancelButtonHidden :optionModel=\"formConfig\" />\n <a-form-item :label=\"i18nt('designer.setting.okButtonLabel')\">\n <a-input type=\"text\" v-model:value=\"formConfig.okButtonLabel\" />\n </a-form-item>\n <OkButtonHiddenEditor :optionModel=\"formConfig\" /> -->\n <ButtonListEditor :optionModel=\"formConfig\" />\n </a-collapse-panel>\n\n <a-collapse-panel\n v-if=\"showEventCollapse()\"\n key=\"2\"\n class=\"eventPanel\"\n :header=\"i18nt('designer.setting.事件属性')\"\n >\n <MethodItem\n @click-item=\"handleEditEvent\"\n v-for=\"(value, key) in eventParamsMap\"\n :key=\"key\"\n :event-name=\"key\"\n v-model:value=\"formConfig[key]\"\n :get-form-event-handled=\"getFormEventHandled\"\n :event-params-map=\"eventParamsMap\"\n :form-config=\"formConfig\"\n />\n </a-collapse-panel>\n </a-collapse>\n </a-form>\n\n <a-config-provider componentSize=\"middle\">\n <TpfCodeEditor\n :isShowEventHeader=\"isShowEventHeader\"\n ref=\"codeEditorRef\"\n :event-header=\"eventHeader\"\n v-model=\"formEventHandlerCode\"\n :mode=\"mode\"\n :readonly=\"false\"\n :title=\"title\"\n @set-code=\"saveFormEventHandler\"\n /></a-config-provider>\n</template>\n\n<script lang=\"ts\" setup>\n import { ref, reactive, onMounted, inject, Ref } from 'vue';\n import { useI18n } from '@/utils/i18n';\n import { deepClone, insertCustomCssToHead } from '@/utils/util';\n import MethodItem from '@/components/public/methoad-item.vue';\n import OkButtonHiddenEditor from '@/components/form-designer/setting-panel/property-editor/container-vf-dialog/okButtonHidden-editor.vue';\n import CancelButtonHidden from '@/components/form-designer/setting-panel/property-editor/container-vf-dialog/cancelButtonHidden-editor.vue';\n import { ILanguageMode, TpfCodeEditor } from 'tmgc2-share';\n import { FormDesigner } from '@/types/designer';\n import { useDesigner } from '../form-widget/useFormDesigner';\n import ButtonListEditor from '@/components/form-designer/setting-panel/property-editor/button-list-editor.vue';\n // 定义类型\n interface FormSize {\n label: string;\n value: string;\n }\n\n interface EventParams {\n [key: string]: string;\n }\n\n const { formConfig } = useDesigner();\n interface EditEventParams {\n eventName: string;\n mode: ILanguageMode;\n isShowEventHeader: boolean;\n title: string;\n eventHeader?: string;\n }\n\n // 使用i18n\n const { i18nt } = useI18n();\n const designer = inject<Ref<FormDesigner>>('designer', ref({} as FormDesigner));\n // 注入依赖\n const getDesignerConfig = inject<() => any>('getDesignerConfig');\n const designerConfig = getDesignerConfig ? getDesignerConfig() : {};\n\n // 响应式状态\n const mode = ref<ILanguageMode>('javascript');\n const eventName = ref('');\n const title = ref('');\n const isShowEventHeader = ref(false);\n const eventHeader = ref('');\n const formActiveCollapseNames = ref(['1', '2']);\n const formCssCode = ref('');\n const cssClassList = ref<string[]>([]);\n const formEventHandlerCode = ref('');\n\n // 引用\n const codeEditorRef = ref<any>(null);\n\n // 常量数据\n const formSizes: FormSize[] = [\n { label: 'default', value: 'middle' },\n { label: 'large', value: 'large' },\n { label: 'small', value: 'small' }\n ];\n\n const eventParamsMap: EventParams = {\n onFormCreated: 'onFormCreated() {',\n onFormMounted: 'onFormMounted() {',\n onOkButtonClick: 'onOkButtonClick() {',\n onCancelButtonClick: 'onCancelButtonClick() {',\n onFormEnterKey: 'onFormEnterKey() {',\n onFormDataChange:\n 'onFormDataChange(fieldName, newValue, oldValue, formModel, subFormName, subFormRowIndex) {'\n //'onFormValidate': 'onFormValidate() {',\n };\n\n // 方法\n const saveFormEventHandler = (value: string) => {\n formConfig.value[eventName.value] = value;\n };\n\n const handleEditEvent = (params: EditEventParams) => {\n eventName.value = params.eventName;\n mode.value = params.mode;\n isShowEventHeader.value = params.isShowEventHeader;\n formEventHandlerCode.value = formConfig.value[params.eventName];\n title.value = params.title || i18nt('designer.setting.editWidgetEventHandler');\n eventHeader.value = params.eventHeader || '';\n codeEditorRef.value.open();\n };\n\n const getFormEventHandled = (eventName: string) => {\n return !!formConfig.value[eventName] && formConfig.value[eventName].length > 0;\n };\n\n const showEventCollapse = () => {\n if (designerConfig['eventCollapse'] === undefined) {\n return true;\n }\n return !!designerConfig['eventCollapse'];\n };\n\n const extractCssClass = () => {\n const regExp = /\\..*{/g;\n const result = formCssCode.value.match(regExp);\n const cssNameArray: string[] = [];\n\n if (!!result && result.length > 0) {\n result.forEach(rItem => {\n const classArray = rItem.split(','); // 切分逗号分割的多个class\n if (classArray.length > 0) {\n classArray.forEach(cItem => {\n const caItem = cItem.trim();\n if (caItem.indexOf('.', 1) !== -1) {\n // 查找第二个.位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf('.', 1)\n ); // 仅截取第一、二个.号之间的class\n if (!!newClass) {\n cssNameArray.push(newClass.trim());\n }\n } else if (caItem.indexOf(' ') !== -1) {\n // 查找第一个空格位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf(' ')\n ); // 仅截取第一、二个.号之间的class\n if (!!newClass) {\n cssNameArray.push(newClass.trim());\n }\n } else {\n if (caItem.indexOf('{') !== -1) {\n // 查找第一个{位置\n const newClass = caItem.substring(\n caItem.indexOf('.') + 1,\n caItem.indexOf('{')\n );\n cssNameArray.push(newClass.trim());\n } else {\n const newClass = caItem.substring(caItem.indexOf('.') + 1);\n cssNameArray.push(newClass.trim());\n }\n }\n });\n }\n });\n }\n\n // cssClassList.value = Array.from(new Set(cssNameArray)); // 数组去重\n };\n\n // 生命周期钩子\n onMounted(() => {\n // 导入表单JSON后需要重新加载自定义CSS样式\n designer.value.handleEvent('form-json-imported', () => {\n formCssCode.value = formConfig.value.cssCode;\n insertCustomCssToHead(formCssCode.value);\n extractCssClass();\n designer.value.emitEvent('form-css-updated', deepClone(cssClassList.value));\n });\n\n /* SettingPanel和FormWidget为兄弟组件, 在FormWidget加载formConfig时,\n 此处SettingPanel可能无法获取到formConfig.cssCode, 故加个延时函数! */\n setTimeout(() => {\n formCssCode.value = formConfig.value.cssCode;\n insertCustomCssToHead(formCssCode.value);\n extractCssClass();\n designer.value.emitEvent('form-css-updated', deepClone(cssClassList.value));\n }, 1200);\n });\n\n // 组件名称定义\n defineOptions({\n name: 'form-setting'\n });\n</script>\n\n<style lang=\"less\" scoped>\n .eventPanel {\n :deep(.ant-form-item-row) {\n flex: 1;\n .ant-form-item-control-input-content .ant-btn {\n border: 1px solid #eee;\n }\n .ant-form-item-label {\n flex: 1;\n }\n }\n :deep(.ant-col.ant-form-item-control) {\n flex: 0 0 80px;\n }\n }\n</style>\n"],"names":["formConfig","useDesigner","i18nt","useI18n","designer","inject","ref","getDesignerConfig","designerConfig","mode","eventName","title","isShowEventHeader","eventHeader","formActiveCollapseNames","formCssCode","cssClassList","formEventHandlerCode","codeEditorRef","formSizes","eventParamsMap","saveFormEventHandler","value","handleEditEvent","params","getFormEventHandled","showEventCollapse","extractCssClass","regExp","result","cssNameArray","rItem","classArray","cItem","caItem","newClass","onMounted","insertCustomCssToHead","deepClone","_createVNode","_component_a_form","_unref","_component_a_collapse","$event","_component_a_collapse_panel","_component_a_form_item","_component_a_select","_cache","_component_a_radio_group","_component_a_radio_button","_component_a_input_number","_component_a_button","_normalizeClass","ButtonListEditor","_createBlock","_openBlock","_createElementBlock","_Fragment","_renderList","key","MethodItem","_component_a_config_provider","TpfCodeEditor"],"mappings":"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"}
@@ -1,46 +1,52 @@
1
- import { defineComponent as _, ref as d, watch as C, resolveComponent as p, createElementBlock as L, openBlock as h, Fragment as k, createVNode as e, unref as o, withCtx as n, createTextVNode as f, toDisplayString as m } from "vue";
2
- import { useI18n as w } from "../../../../utils/i18n.js";
3
- import { cloneDeep as x } from "lodash-es";
4
- import D from "../../../public/ActionButtonListDialog.vue.js";
5
- import { TpfModal as E } from "tmgc2-share";
6
- import { EditorTypeEnum as B } from "../../../../constants/EditorTypeEnum.js";
7
- const z = /* @__PURE__ */ _({
1
+ import { defineComponent as _, ref as d, watch as h, resolveComponent as p, createElementBlock as L, openBlock as k, Fragment as w, createVNode as o, unref as n, withCtx as i, normalizeClass as x, createTextVNode as f, toDisplayString as m } from "vue";
2
+ import { useI18n as D } from "../../../../utils/i18n.js";
3
+ import { cloneDeep as E } from "lodash-es";
4
+ import M from "../../../public/ActionButtonListDialog.vue.js";
5
+ import { TpfModal as B } from "tmgc2-share";
6
+ import { EditorTypeEnum as y } from "../../../../constants/EditorTypeEnum.js";
7
+ const F = /* @__PURE__ */ _({
8
8
  inheritAttrs: !1,
9
- name: B.buttonListEditor,
9
+ name: y.buttonListEditor,
10
10
  __name: "button-list-editor",
11
11
  props: {
12
12
  optionModel: {}
13
13
  },
14
14
  setup(c) {
15
- const { i18nt: i } = w(), r = c, t = d([]), l = d(!1);
16
- C(t, () => {
17
- r.optionModel.buttonList = t.value;
15
+ const { i18nt: l } = D(), r = c, e = d([]), s = d(!1);
16
+ h(e, () => {
17
+ r.optionModel.buttonList = e.value;
18
18
  });
19
19
  const g = () => {
20
- t.value = x(r.optionModel.buttonList), l.value = !0;
20
+ e.value = E(r.optionModel.buttonList), s.value = !0;
21
21
  }, b = () => {
22
- l.value = !1;
22
+ s.value = !1;
23
23
  };
24
- return (M, s) => {
25
- const u = p("a-button"), v = p("a-form-item");
26
- return h(), L(k, null, [
27
- e(v, {
28
- label: o(i)("designer.setting.buttonList")
24
+ return (v, a) => {
25
+ const u = p("a-button"), C = p("a-form-item");
26
+ return k(), L(w, null, [
27
+ o(C, {
28
+ label: n(l)("designer.setting.buttonListConfig")
29
29
  }, {
30
- default: n(() => [
31
- e(u, { onClick: g }, {
32
- default: n(() => [
33
- f(m(o(i)("designer.setting.buttonConfig")), 1)
34
- ]),
35
- _: 1
36
- })
37
- ]),
30
+ default: i(() => {
31
+ var t;
32
+ return [
33
+ o(u, {
34
+ class: x([(t = v.optionModel.buttonList) != null && t.length ? "button-text-highlight" : ""]),
35
+ onClick: g
36
+ }, {
37
+ default: i(() => [
38
+ f(m(n(l)("designer.setting.buttonConfig")), 1)
39
+ ]),
40
+ _: 1
41
+ }, 8, ["class"])
42
+ ];
43
+ }),
38
44
  _: 1
39
45
  }, 8, ["label"]),
40
- e(o(E), {
41
- title: o(i)("designer.setting.buttonsColumnEdit"),
42
- visible: l.value,
43
- "onUpdate:visible": s[1] || (s[1] = (a) => l.value = a),
46
+ o(n(B), {
47
+ title: n(l)("designer.setting.buttonsColumnEdit"),
48
+ visible: s.value,
49
+ "onUpdate:visible": a[1] || (a[1] = (t) => s.value = t),
44
50
  "show-close": !0,
45
51
  dialogClass: "drag-dialog",
46
52
  "append-to-body": "",
@@ -49,21 +55,21 @@ const z = /* @__PURE__ */ _({
49
55
  width: "1050px",
50
56
  mask: !1
51
57
  }, {
52
- footerRight: n(() => [
53
- e(u, {
58
+ footerRight: i(() => [
59
+ o(u, {
54
60
  size: "default",
55
61
  onClick: b
56
62
  }, {
57
- default: n(() => [
58
- f(m(o(i)("designer.hint.closePreview")), 1)
63
+ default: i(() => [
64
+ f(m(n(l)("designer.hint.closePreview")), 1)
59
65
  ]),
60
66
  _: 1
61
67
  })
62
68
  ]),
63
- default: n(() => [
64
- e(D, {
65
- data: t.value,
66
- "onUpdate:data": s[0] || (s[0] = (a) => t.value = a)
69
+ default: i(() => [
70
+ o(M, {
71
+ data: e.value,
72
+ "onUpdate:data": a[0] || (a[0] = (t) => e.value = t)
67
73
  }, null, 8, ["data"])
68
74
  ]),
69
75
  _: 1
@@ -73,6 +79,6 @@ const z = /* @__PURE__ */ _({
73
79
  }
74
80
  });
75
81
  export {
76
- z as default
82
+ F as default
77
83
  };
78
84
  //# sourceMappingURL=button-list-editor.vue2.js.map