@farris/ui-vue 1.2.6 → 1.2.8

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 (210) hide show
  1. package/components/accordion/index.esm.js +150 -142
  2. package/components/avatar/index.esm.js +393 -457
  3. package/components/border-editor/index.esm.js +4 -4
  4. package/components/button/index.esm.js +1 -1
  5. package/components/button-edit/index.esm.js +353 -444
  6. package/components/button-group/index.esm.js +5 -5
  7. package/components/calendar/index.esm.js +176 -176
  8. package/components/capsule/index.esm.js +93 -93
  9. package/components/checkbox/index.esm.js +491 -554
  10. package/components/color-picker/index.esm.js +1 -1
  11. package/components/combo-list/index.esm.js +479 -513
  12. package/components/combo-tree/index.esm.js +8 -8
  13. package/components/component/index.esm.js +89 -89
  14. package/components/condition/index.esm.js +857 -743
  15. package/components/content-container/index.esm.js +61 -61
  16. package/components/data-grid/index.esm.js +4883 -5182
  17. package/components/data-view/index.esm.js +3072 -2949
  18. package/components/date-picker/index.esm.js +2626 -2689
  19. package/components/dependent-base/style.js +1 -0
  20. package/components/dependent-fluid/style.js +1 -0
  21. package/components/dependent-icon/style.js +1 -0
  22. package/components/dependent-input/style.js +1 -0
  23. package/components/dependent-table/style.js +1 -0
  24. package/components/designer-canvas/index.esm.js +478 -475
  25. package/components/designer-outline/index.esm.js +173 -131
  26. package/components/discussion-editor/index.esm.js +1 -1
  27. package/components/dropdown/index.esm.js +73 -73
  28. package/components/dynamic-form/index.esm.js +940 -998
  29. package/components/dynamic-resolver/index.esm.js +67 -35
  30. package/components/dynamic-view/index.esm.js +307 -293
  31. package/components/enum-editor/index.esm.js +3 -3
  32. package/components/events-editor/index.esm.js +178 -178
  33. package/components/expression-editor/index.esm.js +105 -105
  34. package/components/external-container/index.esm.js +1747 -1627
  35. package/components/field-selector/index.css +1 -1
  36. package/components/field-selector/index.esm.js +5877 -6176
  37. package/components/filter-bar/index.css +1 -1
  38. package/components/filter-bar/index.esm.js +1454 -1524
  39. package/components/flow-canvas/index.esm.js +678 -675
  40. package/components/image-cropper/index.esm.js +266 -266
  41. package/components/input-group/index.esm.js +659 -722
  42. package/components/layout/index.esm.js +148 -148
  43. package/components/list-nav/index.esm.js +109 -109
  44. package/components/list-view/index.esm.js +1643 -1524
  45. package/components/lookup/index.css +1 -1
  46. package/components/lookup/index.esm.js +6502 -6770
  47. package/components/mapping-editor/index.esm.js +5639 -5939
  48. package/components/message-box/index.esm.js +1 -1
  49. package/components/modal/index.esm.js +1 -1
  50. package/components/nav/index.esm.js +86 -86
  51. package/components/number-range/index.esm.js +1120 -0
  52. package/components/number-range/package.json +8 -0
  53. package/components/number-range/style.js +6 -0
  54. package/components/number-spinner/index.esm.js +1146 -0
  55. package/components/number-spinner/package.json +8 -0
  56. package/components/number-spinner/style.js +4 -0
  57. package/components/order/index.esm.js +1098 -1130
  58. package/components/page-footer/index.esm.js +106 -106
  59. package/components/page-header/index.esm.js +1088 -1317
  60. package/components/pagination/index.esm.js +252 -252
  61. package/components/progress/index.esm.js +37 -37
  62. package/components/property-editor/index.esm.js +1479 -1513
  63. package/components/property-panel/index.css +1 -1
  64. package/components/property-panel/index.esm.js +706 -778
  65. package/components/query-solution/index.css +1 -0
  66. package/components/query-solution/index.esm.js +6935 -0
  67. package/components/query-solution/package.json +8 -0
  68. package/components/query-solution/style.js +2 -0
  69. package/components/radio-button/index.esm.js +64 -64
  70. package/components/radio-group/index.esm.js +453 -516
  71. package/components/rate/index.esm.js +92 -92
  72. package/components/response-layout/index.esm.js +33 -33
  73. package/components/response-layout-editor/index.esm.js +555 -526
  74. package/components/response-toolbar/index.esm.js +1009 -1247
  75. package/components/schema-selector/index.esm.js +3261 -3373
  76. package/components/search-box/index.esm.js +143 -143
  77. package/components/section/index.esm.js +209 -209
  78. package/components/smoke-detector/index.esm.js +22 -22
  79. package/components/spacing-editor/index.esm.js +2 -2
  80. package/components/splitter/index.esm.js +1097 -394
  81. package/components/step/index.esm.js +153 -153
  82. package/components/switch/index.esm.js +441 -504
  83. package/components/tabs/index.esm.js +1849 -2039
  84. package/components/tags/index.esm.js +215 -215
  85. package/components/text/index.esm.js +53 -53
  86. package/components/textarea/index.esm.js +445 -493
  87. package/components/time-picker/index.esm.js +1350 -1414
  88. package/components/transfer/index.esm.js +146 -144
  89. package/components/tree-grid/index.css +1 -1
  90. package/components/tree-grid/index.esm.js +5948 -6237
  91. package/components/tree-view/index.esm.js +2381 -2255
  92. package/components/uploader/index.esm.js +1 -1
  93. package/components/verify-detail/index.esm.js +232 -232
  94. package/components/video/index.esm.js +136 -136
  95. package/components/weather/index.esm.js +2 -2
  96. package/farris.all.esm.js +27221 -26804
  97. package/farris.all.umd.cjs +9 -9
  98. package/index.css +1 -1
  99. package/package.json +1 -1
  100. package/types/checkbox/index.d.ts +1 -0
  101. package/types/combo-list/src/components/list-container.component.d.ts +6 -0
  102. package/types/combo-list/src/components/list-container.props.d.ts +9 -1
  103. package/types/data-grid/src/data-grid.props.d.ts +1 -0
  104. package/types/data-grid/src/designer/column-header.design.component.d.ts +1 -1
  105. package/types/data-grid/src/designer/data-grid-column.props.d.ts +1 -0
  106. package/types/data-view/composition/types.d.ts +1 -1
  107. package/types/designer-canvas/src/composition/dg-control.d.ts +16 -350
  108. package/types/designer-canvas/src/types.d.ts +1 -1
  109. package/types/dynamic-form/index.d.ts +1 -0
  110. package/types/dynamic-form/src/types.d.ts +1 -1
  111. package/types/dynamic-resolver/index.d.ts +1 -0
  112. package/types/dynamic-resolver/src/binding-resolver.d.ts +1 -0
  113. package/types/dynamic-view/src/dynamic-view.component.d.ts +1 -1
  114. package/types/lookup/src/property-config/converters/lookup-property.converter.d.ts +0 -4
  115. package/types/lookup/src/property-config/lookup.property-config.d.ts +4 -3
  116. package/types/modal/src/modal.props.d.ts +1 -4
  117. package/types/property-panel/src/composition/entity/base-property.d.ts +0 -28
  118. package/types/property-panel/src/composition/entity/input-base-property.d.ts +11 -5
  119. package/types/property-panel/src/composition/entity/schema-dom-mapping.d.ts +10 -8
  120. package/types/tabs/src/designer/tab-toolbar-item.props.d.ts +19 -0
  121. package/types/tabs/src/property-config/tabs.property-config.d.ts +6 -6
  122. package/types/tree-grid/src/designer/use-designer-rules.d.ts +3 -0
  123. package/types/tree-grid/src/property-config/tree-grid.property-config.d.ts +11 -0
  124. package/types/tree-grid/src/schema/column-resolver.d.ts +1 -1
  125. package/types/tree-grid/src/tree-grid.props.d.ts +8 -0
  126. package/components/accordion/index.umd.cjs +0 -1
  127. package/components/avatar/index.umd.cjs +0 -1
  128. package/components/border-editor/index.umd.cjs +0 -1
  129. package/components/button/index.umd.cjs +0 -1
  130. package/components/button-edit/index.umd.cjs +0 -1
  131. package/components/button-group/index.umd.cjs +0 -1
  132. package/components/calculator/index.umd.cjs +0 -1
  133. package/components/calendar/index.umd.cjs +0 -1
  134. package/components/capsule/index.umd.cjs +0 -1
  135. package/components/checkbox/index.umd.cjs +0 -1
  136. package/components/color-picker/index.umd.cjs +0 -3
  137. package/components/combo-list/index.umd.cjs +0 -1
  138. package/components/combo-tree/index.umd.cjs +0 -1
  139. package/components/common/index.umd.cjs +0 -1
  140. package/components/component/index.umd.cjs +0 -1
  141. package/components/condition/index.umd.cjs +0 -1
  142. package/components/content-container/index.umd.cjs +0 -1
  143. package/components/data-grid/index.umd.cjs +0 -1
  144. package/components/data-view/index.umd.cjs +0 -1
  145. package/components/date-picker/index.umd.cjs +0 -1
  146. package/components/designer-canvas/index.umd.cjs +0 -1
  147. package/components/designer-outline/index.umd.cjs +0 -1
  148. package/components/designer-toolbox/index.umd.cjs +0 -1
  149. package/components/discussion-editor/index.umd.cjs +0 -3
  150. package/components/discussion-list/index.umd.cjs +0 -1
  151. package/components/drawer/index.umd.cjs +0 -1
  152. package/components/dropdown/index.umd.cjs +0 -2
  153. package/components/dynamic-form/index.umd.cjs +0 -1
  154. package/components/dynamic-resolver/index.umd.cjs +0 -1
  155. package/components/dynamic-view/index.umd.cjs +0 -1
  156. package/components/enum-editor/index.umd.cjs +0 -1
  157. package/components/events-editor/index.umd.cjs +0 -1
  158. package/components/expression-editor/index.umd.cjs +0 -1
  159. package/components/external-container/index.umd.cjs +0 -1
  160. package/components/field-selector/index.umd.cjs +0 -1
  161. package/components/filter-bar/index.umd.cjs +0 -1
  162. package/components/flow-canvas/index.umd.cjs +0 -1
  163. package/components/image-cropper/index.umd.cjs +0 -1
  164. package/components/input-group/index.umd.cjs +0 -1
  165. package/components/layout/index.umd.cjs +0 -1
  166. package/components/list-nav/index.umd.cjs +0 -1
  167. package/components/list-view/index.umd.cjs +0 -1
  168. package/components/loading/index.umd.cjs +0 -8
  169. package/components/locale/index.umd.cjs +0 -1
  170. package/components/lookup/index.umd.cjs +0 -1
  171. package/components/mapping-editor/index.umd.cjs +0 -1
  172. package/components/message-box/index.umd.cjs +0 -1
  173. package/components/modal/index.umd.cjs +0 -1
  174. package/components/nav/index.umd.cjs +0 -3
  175. package/components/notify/index.umd.cjs +0 -1
  176. package/components/order/index.umd.cjs +0 -1
  177. package/components/page-footer/index.umd.cjs +0 -1
  178. package/components/page-header/index.umd.cjs +0 -1
  179. package/components/pagination/index.umd.cjs +0 -1
  180. package/components/popover/index.umd.cjs +0 -1
  181. package/components/progress/index.umd.cjs +0 -3
  182. package/components/property-editor/index.umd.cjs +0 -3
  183. package/components/property-panel/index.umd.cjs +0 -1
  184. package/components/radio-button/index.umd.cjs +0 -1
  185. package/components/radio-group/index.umd.cjs +0 -1
  186. package/components/rate/index.umd.cjs +0 -1
  187. package/components/response-layout/index.umd.cjs +0 -1
  188. package/components/response-layout-editor/index.umd.cjs +0 -1
  189. package/components/response-toolbar/index.umd.cjs +0 -1
  190. package/components/schema-selector/index.umd.cjs +0 -8
  191. package/components/search-box/index.umd.cjs +0 -1
  192. package/components/section/index.umd.cjs +0 -1
  193. package/components/smoke-detector/index.umd.cjs +0 -1
  194. package/components/spacing-editor/index.umd.cjs +0 -1
  195. package/components/splitter/index.umd.cjs +0 -1
  196. package/components/step/index.umd.cjs +0 -1
  197. package/components/switch/index.umd.cjs +0 -1
  198. package/components/tabs/index.umd.cjs +0 -1
  199. package/components/tags/index.umd.cjs +0 -1
  200. package/components/text/index.umd.cjs +0 -1
  201. package/components/textarea/index.umd.cjs +0 -1
  202. package/components/time-picker/index.umd.cjs +0 -1
  203. package/components/tooltip/index.umd.cjs +0 -1
  204. package/components/transfer/index.umd.cjs +0 -1
  205. package/components/tree-grid/index.umd.cjs +0 -1
  206. package/components/tree-view/index.umd.cjs +0 -1
  207. package/components/uploader/index.umd.cjs +0 -2
  208. package/components/verify-detail/index.umd.cjs +0 -1
  209. package/components/video/index.umd.cjs +0 -1
  210. package/components/weather/index.umd.cjs +0 -16
@@ -1,106 +1,106 @@
1
- var Q = Object.defineProperty;
2
- var q = (n, e, t) => e in n ? Q(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t;
3
- var v = (n, e, t) => q(n, typeof e != "symbol" ? e + "" : e, t);
4
- import { defineComponent as U, ref as C, computed as M, onMounted as $, createVNode as S, inject as O } from "vue";
5
- import { cloneDeep as _ } from "lodash-es";
6
- const z = {}, I = {};
7
- function x(n) {
8
- const { properties: e, title: t } = n, o = Object.keys(e).reduce((i, p) => (i[p] = e[p].type === "object" && e[p].properties ? x(e[p]) : _(e[p].default), i), {});
1
+ var X = Object.defineProperty;
2
+ var Y = (n, e, t) => e in n ? X(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t;
3
+ var v = (n, e, t) => Y(n, typeof e != "symbol" ? e + "" : e, t);
4
+ import { defineComponent as G, ref as M, computed as P, onMounted as W, createVNode as w, withDirectives as Z, vModelText as H, inject as O } from "vue";
5
+ import { cloneDeep as I } from "lodash-es";
6
+ import { useTextBox as K, useClear as R } from "../common/index.esm.js";
7
+ import { getSchemaByType as q } from "../dynamic-resolver/index.esm.js";
8
+ const z = {}, J = {};
9
+ function $(n) {
10
+ const { properties: e, title: t } = n, o = Object.keys(e).reduce((r, s) => (r[s] = e[s].type === "object" && e[s].properties ? $(e[s]) : I(e[s].default), r), {});
9
11
  return o.id = `${t}-${Date.now()}`, o;
10
12
  }
11
- function P(n, e = {}) {
13
+ function N(n, e = {}) {
12
14
  const t = z[n];
13
15
  if (t) {
14
- let o = x(t);
15
- const i = I[n];
16
- return o = i ? i({ getSchemaByType: P }, o, e) : o, o;
16
+ let o = $(t);
17
+ const r = J[n];
18
+ return o = r ? r({ getSchemaByType: N }, o, e) : o, o;
17
19
  }
18
20
  return null;
19
21
  }
20
- function X(n, e) {
21
- const t = x(e);
22
- return Object.keys(n).reduce((o, i) => (o[i] = n[i], o), t), t;
22
+ function ee(n, e) {
23
+ const t = $(e);
24
+ return Object.keys(n).reduce((o, r) => (o[r] && typeof o[r] == "object" ? Object.assign(o[r], n[r]) : o[r] = n[r], o), t), t;
23
25
  }
24
- function Y(n, e) {
25
- return Object.keys(n).filter((o) => n[o] != null).reduce((o, i) => {
26
- if (e.has(i)) {
27
- const p = e.get(i);
28
- if (typeof p == "string")
29
- o[p] = n[i];
26
+ function te(n, e) {
27
+ return Object.keys(n).filter((o) => n[o] != null).reduce((o, r) => {
28
+ if (e.has(r)) {
29
+ const s = e.get(r);
30
+ if (typeof s == "string")
31
+ o[s] = n[r];
30
32
  else {
31
- const m = p(i, n[i], n);
32
- Object.assign(o, m);
33
+ const d = s(r, n[r], n);
34
+ Object.assign(o, d);
33
35
  }
34
36
  } else
35
- o[i] = n[i];
37
+ o[r] = n[r];
36
38
  return o;
37
39
  }, {});
38
40
  }
39
- function Z(n, e, t = /* @__PURE__ */ new Map()) {
40
- const o = X(n, e);
41
- return Y(o, t);
41
+ function ne(n, e, t = /* @__PURE__ */ new Map()) {
42
+ const o = ee(n, e);
43
+ return te(o, t);
42
44
  }
43
- function R(n = {}) {
44
- function e(r, c, l, s) {
45
- if (typeof l == "number")
46
- return s[r].length === l;
47
- if (typeof l == "object") {
48
- const f = Object.keys(l)[0], h = l[f];
45
+ function oe(n = {}) {
46
+ function e(a, l, c, u) {
47
+ if (typeof c == "number")
48
+ return u[a].length === c;
49
+ if (typeof c == "object") {
50
+ const f = Object.keys(c)[0], h = c[f];
49
51
  if (f === "not")
50
- return Number(s[r].length) !== Number(h);
52
+ return Number(u[a].length) !== Number(h);
51
53
  if (f === "moreThan")
52
- return Number(s[r].length) >= Number(h);
54
+ return Number(u[a].length) >= Number(h);
53
55
  if (f === "lessThan")
54
- return Number(s[r].length) <= Number(h);
56
+ return Number(u[a].length) <= Number(h);
55
57
  }
56
58
  return !1;
57
59
  }
58
- function t(r, c, l, s) {
59
- return s[r] && s[r].propertyValue && String(s[r].propertyValue.value) === String(l);
60
+ function t(a, l, c, u) {
61
+ return u[a] && u[a].propertyValue && String(u[a].propertyValue.value) === String(c);
60
62
  }
61
63
  const o = /* @__PURE__ */ new Map([
62
64
  ["length", e],
63
65
  ["getProperty", t]
64
66
  ]);
65
- Object.keys(n).reduce((r, c) => (r.set(c, n[c]), r), o);
66
- function i(r, c) {
67
- const l = r;
68
- return typeof c == "number" ? [{ target: l, operator: "length", param: null, value: Number(c) }] : typeof c == "boolean" ? [{ target: l, operator: "getProperty", param: r, value: !!c }] : typeof c == "object" ? Object.keys(c).map((s) => {
69
- if (s === "length")
70
- return { target: l, operator: "length", param: null, value: c[s] };
71
- const f = s, h = c[s];
72
- return { target: l, operator: "getProperty", param: f, value: h };
67
+ Object.keys(n).reduce((a, l) => (a.set(l, n[l]), a), o);
68
+ function r(a, l) {
69
+ const c = a;
70
+ return typeof l == "number" ? [{ target: c, operator: "length", param: null, value: Number(l) }] : typeof l == "boolean" ? [{ target: c, operator: "getProperty", param: a, value: !!l }] : typeof l == "object" ? Object.keys(l).map((u) => {
71
+ if (u === "length")
72
+ return { target: c, operator: "length", param: null, value: l[u] };
73
+ const f = u, h = l[u];
74
+ return { target: c, operator: "getProperty", param: f, value: h };
73
75
  }) : [];
74
76
  }
75
- function p(r) {
76
- return Object.keys(r).reduce((l, s) => {
77
- const f = i(s, r[s]);
78
- return l.push(...f), l;
77
+ function s(a) {
78
+ return Object.keys(a).reduce((c, u) => {
79
+ const f = r(u, a[u]);
80
+ return c.push(...f), c;
79
81
  }, []);
80
82
  }
81
- function m(r, c) {
82
- if (o.has(r.operator)) {
83
- const l = o.get(r.operator);
84
- return l && l(r.target, r.param, r.value, c) || !1;
83
+ function d(a, l) {
84
+ if (o.has(a.operator)) {
85
+ const c = o.get(a.operator);
86
+ return c && c(a.target, a.param, a.value, l) || !1;
85
87
  }
86
88
  return !1;
87
89
  }
88
- function d(r, c) {
89
- return p(r).reduce((f, h) => f && m(h, c), !0);
90
+ function p(a, l) {
91
+ return s(a).reduce((f, h) => f && d(h, l), !0);
90
92
  }
91
- function y(r, c) {
92
- const l = Object.keys(r), s = l.includes("allOf"), f = l.includes("anyOf"), h = s || f, w = (h ? r[h ? s ? "allOf" : "anyOf" : "allOf"] : [r]).map((D) => d(D, c));
93
- return s ? !w.includes(!1) : w.includes(!0);
93
+ function m(a, l) {
94
+ const c = Object.keys(a), u = c.includes("allOf"), f = c.includes("anyOf"), h = u || f, T = (h ? a[h ? u ? "allOf" : "anyOf" : "allOf"] : [a]).map((B) => p(B, l));
95
+ return u ? !T.includes(!1) : T.includes(!0);
94
96
  }
95
- return { parseValueSchema: y };
97
+ return { parseValueSchema: m };
96
98
  }
97
- const a = {
98
- Button: { type: "Button", name: "按钮", icon: "Button" },
99
- ButtonGroup: { type: "ButtonGroup", name: "按钮组", icon: "ButtonGroup" },
99
+ const i = {
100
+ button: { type: "button", name: "按钮", icon: "Button" },
100
101
  "response-toolbar": { type: "response-toolbar", name: "工具栏", icon: "ButtonGroup" },
101
- "response-toolbar-item": { type: "response-toolbar-item", name: "工具栏项", icon: "Button" },
102
+ "response-toolbar-item": { type: "response-toolbar-item", name: "按钮", icon: "Button" },
102
103
  "content-container": { type: "content-container", name: "容器", icon: "ContentContainer" },
103
- DisplayField: { type: "DisplayField", name: "标签", icon: "DisplayField" },
104
104
  "input-group": { type: "input-group", name: "文本", icon: "TextBox" },
105
105
  textarea: { type: "textarea", name: "多行文本", icon: "MultiTextBox" },
106
106
  lookup: { type: "lookup", name: "帮助", icon: "LookupEdit" },
@@ -111,114 +111,43 @@ const a = {
111
111
  "check-box": { type: "check-box", name: "复选框", icon: "CheckBox" },
112
112
  "check-group": { type: "check-group", name: "复选框组", icon: "CheckGroup" },
113
113
  "combo-list": { type: "combo-list", name: "下拉列表", icon: "EnumField" },
114
- /** 暂时没用 */
115
- FlexLayout: { type: "FlexLayout", name: "弹性布局" },
116
- /** 暂时没用 */
117
- FlowLayout: { type: "FlowLayout", name: "流布局" },
118
- ResponseLayout: { type: "ResponseLayout", name: "布局容器", icon: "ResponseLayout3" },
119
- ResponseLayoutItem: { type: "ResponseLayoutItem", name: "布局", icon: "ResponseLayout1" },
114
+ "response-form": { type: "response-form", name: "卡片面板", icon: "Form" },
115
+ "response-layout": { type: "response-layout", name: "布局容器", icon: "ResponseLayout3" },
116
+ "response-layout-item": { type: "response-layout-item", name: "布局", icon: "ResponseLayout1" },
120
117
  "tree-grid": { type: "tree-grid", name: "树表格", icon: "TreeGrid" },
121
- TreeGridField: { type: "TreeGridField", name: "树表格列" },
122
- FieldSet: { type: "FieldSet", name: "分组", icon: "FieldSet" },
123
- Form: { type: "Form", name: "卡片面板", icon: "Form" },
124
- QueryForm: { type: "QueryForm", name: "查询面板", icon: "Form" },
118
+ "tree-grid-column": { type: "tree-grid-column", name: "树表格列" },
125
119
  "data-grid": { type: "data-grid", name: "表格", icon: "DataGrid" },
126
120
  "data-grid-column": { type: "data-grid-column", name: "表格列" },
127
- Panel: { type: "Panel", name: "面板", icon: "ContentContainer" },
128
- Module: { type: "Module", name: "模块", icon: "Module" },
121
+ module: { type: "Module", name: "模块", icon: "Module" },
129
122
  component: { type: "component", name: "组件", icon: "Component" },
130
- ExternalContainer: { type: "ExternalContainer", name: "外部容器", icon: "ContentContainer" },
131
- Image: { type: "Image", name: "图像", icon: "Image" },
132
- ImageUpload: { type: "ImageUpload", name: "图片上传", icon: "imageupload" },
133
- HiddenContainer: { type: "HiddenContainer", name: "隐藏区域", icon: "ContentContainer" },
134
- ModalContainer: { type: "ModalContainer", name: "弹窗容器", icon: "ContentContainer" },
135
- RouteContainer: { type: "RouteContainer", name: "路由区域", icon: "ContentContainer" },
136
123
  tabs: { type: "tabs", name: "标签页", icon: "Tab" },
137
124
  "tab-page": { type: "tab-page", name: "标签页项", dependentParentControl: "Tab" },
138
125
  "tab-toolbar-item": { type: "tab-toolbar-item", name: "标签页工具栏按钮", icon: "Button" },
139
- Tag: { type: "Tag", name: "Tag", icon: "Tag" },
140
- Sidebar: { type: "Sidebar", name: "侧边栏", icon: "Sidebar" },
141
- HtmlTemplate: { type: "HtmlTemplate", name: "模版容器", icon: "HtmlTemplate" },
142
- ListView: { type: "ListView", name: "列表", icon: "ListView" },
143
- RichTextBox: { type: "RichTextBox", name: "富文本", icon: "RichTextBox" },
144
- TimeSpinner: { type: "TimeSpinner", name: "时间调节器", icon: "TimePicker" },
145
- TimePicker: { type: "TimePicker", name: "时间选择", icon: "TimePicker" },
126
+ "time-picker": { type: "time-picker", name: "时间选择", icon: "TimePicker" },
146
127
  section: { type: "section", name: "分组面板", icon: "Section" },
147
- SectionToolbar: { type: "SectionToolbar", name: "分组面板工具栏" },
148
- SectionToolbarItem: { type: "SectionToolbarItem", name: "分组面板按钮" },
149
- QueryScheme: { type: "QueryScheme", name: "筛选方案", icon: "QueryScheme" },
150
- FormHeader: { type: "FormHeader", name: "翻页" },
151
- Splitter: { type: "Splitter", name: "分栏面板", icon: "Splitter" },
152
- SplitterPane: { type: "SplitterPane", name: "分栏面板项", dependentParentControl: "Splitter" },
153
- WizardDetail: { type: "WizardDetail", name: "向导详情页" },
154
- WizardDetailContainer: { type: "WizardDetailContainer", name: "向导详情容器" },
155
- Wizard: { type: "Wizard", name: "向导", icon: "Wizard" },
156
- MultiSelect: { type: "MultiSelect", name: "数据分配", icon: "MultiSelect" },
157
- Steps: { type: "Steps", name: "步骤条", icon: "Steps" },
158
- avatar: { type: "avatar", name: "头像", icon: "Avatar" },
159
- ListFilter: { type: "ListFilter", name: "筛选条", icon: "ListFilter" },
160
- ListNav: { type: "ListNav", name: "列表导航", icon: "ListNav" },
161
- NumberRange: { type: "NumberRange", name: "数字区间选择", icon: "NumericBox" },
162
- Scrollspy: { type: "Scrollspy", name: "滚动监听", icon: "Scrollspy" },
163
- LanguageTextBox: { type: "LanguageTextBox", name: "多语言输入框", icon: "LanguageTextBox" },
164
- ComponentRef: { type: "ComponentRef", name: "组件引用节点" },
165
- FileUpload: { type: "FileUpload", name: "附件上传", icon: "FileUpload" },
166
- FilePreview: { type: "FilePreview", name: "附件预览", icon: "FilePreview" },
167
- ViewChange: { type: "ViewChange", name: "多视图切换", icon: "Button" },
168
- MultiViewContainer: { type: "MultiViewContainer", name: "多视图", icon: "MultiViewContainer" },
169
- MultiViewItem: { type: "MultiViewItem", name: "多视图项", dependentParentControl: "MultiViewContainer" },
170
- Footer: { type: "Footer", name: "页脚" },
171
- DiscussionEditor: { type: "DiscussionEditor", name: "评论编辑区", icon: "DiscussionEditor" },
172
- DiscussionList: { type: "DiscussionList", name: "评论列表", icon: "DiscussionList" },
173
- NavTab: { type: "NavTab", name: "标签类导航", icon: "NavTab" },
174
- Tags: { type: "Tags", name: "标记组", icon: "Tags" },
175
- Portlet: { type: "Portlet", name: "小部件", icon: "dingzhi" },
128
+ "section-toolbar": { type: "section-toolbar", name: "分组面板工具栏" },
129
+ "section-toolbar-item": { type: "section-toolbar-item", name: "分组面板按钮" },
130
+ splitter: { type: "splitter", name: "分栏面板", icon: "Splitter" },
131
+ "splitter-pane": { type: "splitter-pane", name: "分栏面板项", dependentParentControl: "Splitter" },
132
+ "component-ref": { type: "component-ref", name: "组件引用节点" },
133
+ uploader: { type: "uploader", name: "附件上传", icon: "FileUpload" },
176
134
  "page-header": { type: "page-header", name: "页头", icon: "Header" },
177
- ModalFooter: { type: "ModalFooter", name: "弹窗页脚", icon: "ModalFooter" },
178
- ScrollCollapsibleArea: { type: "ScrollCollapsibleArea", name: "滚动收折区域", icon: "ScrollCollapsibleArea" },
179
- PersonnelSelector: { type: "PersonnelSelector", name: "人员选择", icon: "PersonnelSelector" },
180
- Table: { type: "Table", name: "表格", icon: "DataGrid" },
181
- LoopContainer: { type: "LoopContainer", name: "循环容器", icon: "ContentContainer" },
182
- FileUploadPreview: { type: "FileUploadPreview", name: "附件上传预览", icon: "FileUpload" },
183
- DynamicArea: { type: "DynamicArea", name: "动态区域", icon: "ContentContainer" },
184
- DynamicAreaItem: { type: "DynamicAreaItem", name: "动态区域项", icon: "ContentContainer" },
185
- TabToolbar: { type: "TabToolbar", name: "标签页工具栏", icon: "TabToolbar" },
186
- HeaderToolBar: { type: "HeaderToolBar", name: "头部组件工具栏", icon: "HeaderToolBar" },
187
- ModalFooterToolBar: { type: "ModalFooterToolBar", name: "底部组件工具栏", icon: "ModalFooterToolBar" },
188
- HeaderToolBarItem: { type: "HeaderToolBarItem", name: "头部组件工具栏按钮", icon: "HeaderToolBarItem" },
189
- ModalFooterToolBarItem: { type: "ModalFooterToolBarItem", name: "底部组件工具栏按钮", icon: "ModalFooterToolBarItem" },
190
- OrganizationSelector: { type: "OrganizationSelector", name: "组织选择", icon: "OrganizationSelector" },
191
- AdminOrganizationSelector: { type: "AdminOrganizationSelector", name: "组织选择", icon: "OrganizationSelector" },
192
- EmployeeSelector: { type: "EmployeeSelector", name: "人员选择", icon: "PersonnelSelector" },
193
- OaRelation: { type: "OaRelation", name: "关联行政审批", icon: "TextBox" },
194
- CitySelector: { type: "CitySelector", name: "城市选择", icon: "CitySelector" },
195
- ExtIntergration: { type: "ExtIntergration", name: "外部服务集成", icon: "ViewModel" },
196
- AppointmentCalendar: { type: "AppointmentCalendar", name: "预约日历", icon: "DateBox" },
197
- /** 查询类 start */
198
- Charts: { type: "Charts", name: "图表", icon: "Charts" },
199
- QdpFramework: { type: "QdpFramework", name: "查询结果工具栏", icon: "QdpFramework" },
200
- SpreadSheet: { type: "SpreadSheet", name: "查询表格控件", icon: "Charts" },
201
- QdpConditionDialog: { type: "QdpConditionDialog", name: "查询筛选对话框", icon: "ContentContainer" },
202
- QdpConditionDialogTab: { type: "QdpConditionDialogTab", name: "查询筛选标签页", icon: "Tab" },
203
- /** 查询类 end */
204
- /** 审批类 start */
205
- ApprovalLogs: { type: "ApprovalLogs", name: "审批记录", icon: "ApprovalLogs" },
206
- ApprovalComments: { type: "ApprovalComments", name: "审批意见", icon: "shenpiyijian" }
207
- /** 审批类 end */
208
- }, J = {}, K = {};
209
- R();
210
- function ee(n, e, t = /* @__PURE__ */ new Map(), o = (m, d, y) => d, i = {}, p = (m) => m) {
211
- return z[e.title] = e, I[e.title] = o, J[e.title] = i, K[e.title] = p, (m = {}) => {
212
- const d = Z(m, e, t), y = Object.keys(n).reduce((r, c) => (r[c] = n[c].default, r), {});
213
- return Object.assign(y, d);
135
+ "page-footer": { type: "page-footer", name: "页脚", icon: "ModalFooter" },
136
+ "tab-toolbar": { type: "tab-toolbar", name: "标签页工具栏", icon: "TabToolbar" }
137
+ }, re = {}, ae = {};
138
+ oe();
139
+ function ie(n, e, t = /* @__PURE__ */ new Map(), o = (d, p, m) => p, r = {}, s = (d) => d) {
140
+ return z[e.title] = e, J[e.title] = o, re[e.title] = r, ae[e.title] = s, (d = {}) => {
141
+ const p = ne(d, e, t), m = Object.keys(n).reduce((a, l) => (a[l] = n[l].default, a), {});
142
+ return Object.assign(m, p);
214
143
  };
215
144
  }
216
- function te(n, e) {
145
+ function le(n, e) {
217
146
  return { customClass: e.class, customStyle: e.style };
218
147
  }
219
- const ne = /* @__PURE__ */ new Map([
220
- ["appearance", te]
221
- ]), oe = "https://json-schema.org/draft/2020-12/schema", ae = "https://farris-design.gitee.io/switch.schema.json", re = "textarea", ie = "A Farris Component", le = "object", ce = {
148
+ const ce = /* @__PURE__ */ new Map([
149
+ ["appearance", le]
150
+ ]), se = "https://json-schema.org/draft/2020-12/schema", pe = "https://farris-design.gitee.io/switch.schema.json", ue = "textarea", de = "A Farris Component", me = "object", ye = {
222
151
  id: {
223
152
  description: "The unique identifier for a textarea",
224
153
  type: "string"
@@ -280,28 +209,30 @@ const ne = /* @__PURE__ */ new Map([
280
209
  type: "boolean",
281
210
  default: !0
282
211
  }
283
- }, pe = [
212
+ }, fe = [
284
213
  "id",
285
214
  "type"
286
- ], se = {
287
- $schema: oe,
288
- $id: ae,
289
- title: re,
290
- description: ie,
291
- type: le,
292
- properties: ce,
293
- required: pe
215
+ ], ge = {
216
+ $schema: se,
217
+ $id: pe,
218
+ title: ue,
219
+ description: de,
220
+ type: me,
221
+ properties: ye,
222
+ required: fe
294
223
  };
295
- function de(n, e, t) {
224
+ function he(n, e, t) {
296
225
  return e;
297
226
  }
298
- const V = {
227
+ const L = {
299
228
  /** 自动聚焦 */
300
229
  autofocus: { type: Boolean, default: !1 },
301
230
  /** 自动完成 */
302
231
  autocomplete: { type: Boolean, default: !1 },
303
232
  /** 禁用 */
304
233
  disabled: { type: Boolean, default: !1 },
234
+ /** 启用清除按钮 */
235
+ enableClear: { type: Boolean, default: !1 },
305
236
  /** 组件标识 */
306
237
  id: { type: String, default: "" },
307
238
  /** 最小字符长度 */
@@ -318,207 +249,156 @@ const V = {
318
249
  rows: { type: Boolean },
319
250
  /** 展示输入文本数量 */
320
251
  showCount: { type: Boolean, default: !1 },
252
+ /** 展示边线 */
253
+ showBorder: { Type: Boolean, default: !0 },
321
254
  /** 键盘按键索引 */
322
255
  tabIndex: { type: Number, default: -1 }
323
- }, j = ee(V, se, ne, de), k = /* @__PURE__ */ U({
256
+ }, _ = ie(L, ge, ce, he), E = /* @__PURE__ */ G({
324
257
  name: "FTextarea",
325
- props: V,
258
+ props: L,
326
259
  emits: ["update:modelValue", "valueChange"],
327
260
  setup(n, e) {
328
- const t = C(), o = M(() => n.maxLength ? n.maxLength : n.modelValue.length), i = (r) => {
329
- var c, l;
330
- e.emit("update:modelValue", (c = r.target) == null ? void 0 : c.value), e.emit("valueChange", (l = r.target) == null ? void 0 : l.value);
331
- }, p = (r) => {
332
- t.value = r;
333
- }, m = M(() => ({
334
- position: "relative"
335
- })), d = M(() => ({
336
- "box-shadow": "0 0 0 1px #dcdfe6 inset",
337
- border: "none",
338
- padding: "5px 10px",
339
- width: "100%"
340
- })), y = {
341
- position: "absolute",
342
- bottom: "5px",
343
- right: "10px"
261
+ const t = M(), o = M(n.modelValue), r = P(() => n.modelValue), s = K(n, e, o, r), {
262
+ inputGroupClass: d,
263
+ onBlur: p,
264
+ onFocus: m
265
+ } = s, a = R(n, e, s), {
266
+ onMouseEnter: l,
267
+ onMouseLeave: c,
268
+ clearButtonClass: u,
269
+ shouldShowClearButton: f,
270
+ clearButtonStyle: h
271
+ } = a, x = P(() => n.maxLength ? n.maxLength : n.modelValue.length), D = (C) => {
272
+ var B, S;
273
+ C.stopPropagation(), e.emit("update:modelValue", (B = C.target) == null ? void 0 : B.value), e.emit("valueChange", (S = C.target) == null ? void 0 : S.value);
274
+ }, T = (C) => {
275
+ C.stopPropagation(), t.value.value = "", e.emit("update:modelValue", ""), e.emit("valueChange", "");
344
276
  };
345
- return $(() => {
346
- p(n.modelValue);
347
- }), () => S("div", {
348
- style: m.value
349
- }, [S("textarea", {
277
+ return W(() => {
278
+ }), () => w("div", {
279
+ class: d.value,
280
+ onMouseenter: l,
281
+ onMouseleave: c,
282
+ style: "position:relative"
283
+ }, [Z(w("textarea", {
350
284
  id: n.id,
285
+ "onUpdate:modelValue": (C) => n.modelValue = C,
351
286
  ref: t,
352
287
  minlength: n.minLength,
353
- maxlength: n.maxLength,
288
+ maxlength: n.maxLength ? n.maxLength : null,
354
289
  tabindex: n.tabIndex,
355
290
  disabled: n.disabled,
356
291
  readonly: n.readonly,
357
292
  autocomplete: n.autocomplete,
358
- style: d.value,
359
293
  placeholder: n.placeholder,
360
294
  autofocus: n.autofocus,
361
295
  rows: n.rows,
362
- onInput: i
363
- }, null), n.showCount && S("span", {
364
- style: y
365
- }, [`${n.modelValue.length}/${o.value}`])]);
296
+ onInput: D,
297
+ onFocus: m,
298
+ onBlur: p,
299
+ style: "box-shadow: 0 0 0 1px #dcdfe6 inset; border: none; border-radius:6px; padding:5px 10px; width:100%"
300
+ }, null), [[H, n.modelValue]]), f.value && w("span", {
301
+ id: "clearIcon",
302
+ class: u.value,
303
+ style: h.value,
304
+ onClick: (C) => T(C)
305
+ }, [w("i", {
306
+ class: "f-icon modal_close"
307
+ }, null)]), n.showCount && w("span", {
308
+ style: "position: absolute;bottom: 5px;right: 10px"
309
+ }, [`${n.modelValue.length}/${x.value}`])]);
366
310
  }
367
311
  });
368
- function ue(n, e, t) {
369
- var L;
312
+ function be(n, e, t) {
313
+ var U;
370
314
  function o() {
371
315
  t != null && t.resolveComponentContext && t.resolveComponentContext();
372
316
  }
373
317
  o();
374
- const i = t && t.getStyles && t.getStyles() || "", p = t && t.getDesignerClass && t.getDesignerClass() || "", m = C();
375
- function d() {
318
+ const r = t && t.getStyles && t.getStyles() || "", s = t && t.getDesignerClass && t.getDesignerClass() || "", d = M();
319
+ function p() {
376
320
  return (e == null ? void 0 : e.schema.componentType) === "frame" ? !1 : t && t.checkCanMoveComponent ? t.checkCanMoveComponent() : !0;
377
321
  }
378
- function y() {
322
+ function m() {
379
323
  return !1;
380
324
  }
381
- function r() {
325
+ function a() {
382
326
  return (e == null ? void 0 : e.schema.componentType) === "frame" ? !1 : t && t.checkCanDeleteComponent ? t.checkCanDeleteComponent() : !0;
383
327
  }
384
- function c() {
328
+ function l() {
385
329
  return (e == null ? void 0 : e.schema.componentType) === "frame" ? !0 : t && t.hideNestedPaddingInDesginerView ? t.hideNestedPaddingInDesginerView() : !1;
386
330
  }
387
- function l(u) {
388
- if (!u || !u.value)
331
+ function c(y) {
332
+ if (!y || !y.value)
389
333
  return null;
390
- if (u.value.schema && u.value.schema.type === "component")
391
- return u.value;
392
- const b = C(u == null ? void 0 : u.value.parent), g = l(b);
334
+ if (y.value.schema && y.value.schema.type === "component")
335
+ return y.value;
336
+ const b = M(y == null ? void 0 : y.value.parent), g = c(b);
393
337
  return g || null;
394
338
  }
395
- function s(u = e) {
396
- const { componentInstance: b, designerItemElementRef: g } = u;
397
- return !b || !b.value ? null : b.value.canMove ? g : s(u.parent);
339
+ function u(y = e) {
340
+ const { componentInstance: b, designerItemElementRef: g } = y;
341
+ return !b || !b.value ? null : b.value.canMove ? g : u(y.parent);
398
342
  }
399
- function f(u) {
400
- return !!t && t.canAccepts(u);
343
+ function f(y) {
344
+ return !!t && t.canAccepts(y);
401
345
  }
402
346
  function h() {
403
347
  return (e == null ? void 0 : e.schema.label) || (e == null ? void 0 : e.schema.title) || (e == null ? void 0 : e.schema.name);
404
348
  }
405
- function B() {
349
+ function x() {
406
350
  }
407
- function A(u, b) {
351
+ function D(y, b) {
408
352
  b && t != null && t.onAcceptMovedChildElement && t.onAcceptMovedChildElement(b);
409
353
  }
410
- function w(u) {
411
- const { componentType: b } = u;
412
- let g = P(b, u);
413
- t && t.onResolveNewComponentSchema && (g = t.onResolveNewComponentSchema(u, g));
354
+ function T(y) {
355
+ const { componentType: b } = y;
356
+ let g = N(b, y);
357
+ t && t.onResolveNewComponentSchema && (g = t.onResolveNewComponentSchema(y, g));
414
358
  const F = b.toLowerCase().replace("-", "_");
415
359
  return g && !g.id && g.type === b && (g.id = `${F}_${Math.random().toString().slice(2, 6)}`), g;
416
360
  }
417
- function E(u, b) {
418
- const g = String(u.getAttribute("data-controltype")), F = u.getAttribute("data-feature"), N = F ? JSON.parse(F) : {};
419
- N.parentComponentInstance = m.value;
420
- let T = P(g, N);
421
- t && t.onAcceptNewChildElement && (T = t.onAcceptNewChildElement(u, b, T));
422
- const G = g.toLowerCase().replace("-", "_");
423
- return T && !T.id && T.type === g && (T.id = `${G}_${Math.random().toString().slice(2, 6)}`), T;
361
+ function C(y, b) {
362
+ const g = String(y.getAttribute("data-controltype")), F = y.getAttribute("data-feature"), j = F ? JSON.parse(F) : {};
363
+ j.parentComponentInstance = d.value;
364
+ let k = N(g, j);
365
+ t && t.onAcceptNewChildElement && (k = t.onAcceptNewChildElement(y, b, k));
366
+ const Q = g.toLowerCase().replace("-", "_");
367
+ return k && !k.id && k.type === g && (k.id = `${Q}_${Math.random().toString().slice(2, 6)}`), k;
424
368
  }
425
- function D(u) {
369
+ function B(y) {
426
370
  }
427
- function H(...u) {
371
+ function S(...y) {
428
372
  if (t && t.getPropsConfig)
429
- return t.getPropsConfig(...u);
373
+ return t.getPropsConfig(...y);
430
374
  }
431
- return m.value = {
432
- canMove: d(),
433
- canSelectParent: y(),
434
- canDelete: r(),
435
- canNested: !c(),
375
+ return d.value = {
376
+ canMove: p(),
377
+ canSelectParent: m(),
378
+ canDelete: a(),
379
+ canNested: !l(),
436
380
  contents: e == null ? void 0 : e.schema.contents,
437
381
  elementRef: n,
438
- parent: (L = e == null ? void 0 : e.parent) == null ? void 0 : L.componentInstance,
382
+ parent: (U = e == null ? void 0 : e.parent) == null ? void 0 : U.componentInstance,
439
383
  schema: e == null ? void 0 : e.schema,
440
- styles: i,
441
- designerClass: p,
384
+ styles: r,
385
+ designerClass: s,
442
386
  canAccepts: f,
443
- getBelongedComponentInstance: l,
444
- getDraggableDesignItemElement: s,
387
+ getBelongedComponentInstance: c,
388
+ getDraggableDesignItemElement: u,
445
389
  getDraggingDisplayText: h,
446
- getPropConfig: H,
447
- getDragScopeElement: B,
448
- onAcceptMovedChildElement: A,
449
- onAcceptNewChildElement: E,
450
- onChildElementMovedOut: D,
451
- addNewChildComponentSchema: w,
390
+ getPropConfig: S,
391
+ getDragScopeElement: x,
392
+ onAcceptMovedChildElement: D,
393
+ onAcceptNewChildElement: C,
394
+ onChildElementMovedOut: B,
395
+ addNewChildComponentSchema: T,
452
396
  updateDragAndDropRules: o,
453
- triggerBelongedComponentToMoveWhenMoved: !!t && t.triggerBelongedComponentToMoveWhenMoved || C(!1),
454
- triggerBelongedComponentToDeleteWhenDeleted: !!t && t.triggerBelongedComponentToDeleteWhenDeleted || C(!1)
455
- }, m;
456
- }
457
- class W {
458
- static getEditorTypesByMDataType(e) {
459
- const t = this.fieldControlTypeMapping[e];
460
- return t || [{ key: "", value: "" }];
461
- }
397
+ triggerBelongedComponentToMoveWhenMoved: !!t && t.triggerBelongedComponentToMoveWhenMoved || M(!1),
398
+ triggerBelongedComponentToDeleteWhenDeleted: !!t && t.triggerBelongedComponentToDeleteWhenDeleted || M(!1)
399
+ }, d;
462
400
  }
463
- /**
464
- * <字段类型,可配置的控件类型列表>的映射
465
- */
466
- v(W, "fieldControlTypeMapping", {
467
- String: [
468
- { key: a["input-group"].type, value: a["input-group"].name },
469
- { key: a.lookup.type, value: a.lookup.name },
470
- { key: a.Image.type, value: a.Image.name },
471
- { key: a["date-picker"].type, value: a["date-picker"].name },
472
- { key: a["check-box"].type, value: a["check-box"].name },
473
- { key: a["radio-group"].type, value: a["radio-group"].name },
474
- { key: a["combo-list"].type, value: a["combo-list"].name },
475
- { key: a.textarea.type, value: a.textarea.name }
476
- // { key: DgControl.Tags.type, value: DgControl.Tags.name },
477
- ],
478
- Text: [
479
- { key: a.textarea.type, value: a.textarea.name },
480
- { key: a.avatar.type, value: a.avatar.name },
481
- { key: a.lookup.type, value: a.lookup.name }
482
- ],
483
- Decimal: [
484
- { key: a["number-spinner"].type, value: a["number-spinner"].name }
485
- ],
486
- Integer: [
487
- { key: a["number-spinner"].type, value: a["number-spinner"].name }
488
- ],
489
- Number: [
490
- { key: a["number-spinner"].type, value: a["number-spinner"].name }
491
- ],
492
- BigNumber: [
493
- { key: a["number-spinner"].type, value: a["number-spinner"].name }
494
- ],
495
- Date: [
496
- { key: a["date-picker"].type, value: a["date-picker"].name }
497
- ],
498
- DateTime: [
499
- { key: a["date-picker"].type, value: a["date-picker"].name }
500
- ],
501
- Boolean: [
502
- { key: a.switch.type, value: a.switch.name },
503
- { key: a["check-box"].type, value: a["check-box"].name }
504
- ],
505
- Enum: [
506
- { key: a["combo-list"].type, value: a["combo-list"].name },
507
- { key: a["radio-group"].type, value: a["radio-group"].name }
508
- ],
509
- Object: [
510
- { key: a.lookup.type, value: a.lookup.name },
511
- { key: a["combo-list"].type, value: a["combo-list"].name },
512
- { key: a["radio-group"].type, value: a["radio-group"].name }
513
- ],
514
- EmployeeSelector: [
515
- { key: a.EmployeeSelector.type, value: a.EmployeeSelector.name }
516
- ],
517
- AdminOrganizationSelector: [
518
- { key: a.AdminOrganizationSelector.type, value: a.AdminOrganizationSelector.name }
519
- ]
520
- });
521
- class me {
401
+ class ve {
522
402
  constructor(e, t) {
523
403
  v(this, "componentId");
524
404
  v(this, "viewModelId");
@@ -547,7 +427,7 @@ class me {
547
427
  if (t) {
548
428
  if (!this.designViewModelField) {
549
429
  const o = this.designViewModelUtils.getDgViewModel(this.viewModelId);
550
- this.designViewModelField = o.fields.find((i) => i.id === t);
430
+ this.designViewModelField = o.fields.find((r) => r.id === t);
551
431
  }
552
432
  e.updateOn = this.designViewModelField.updateOn;
553
433
  }
@@ -555,9 +435,135 @@ class me {
555
435
  changeFieldEditorType(e, t) {
556
436
  }
557
437
  getBasicPropConfig(e) {
558
- var o, i;
559
- var t = this;
560
- return this.setDesignViewModelField(e), {
438
+ return {
439
+ description: "Basic Information",
440
+ title: "基本信息",
441
+ properties: {
442
+ id: {
443
+ description: "组件标识",
444
+ title: "标识",
445
+ type: "string",
446
+ readonly: !0
447
+ },
448
+ type: {
449
+ description: "组件类型",
450
+ title: "控件类型",
451
+ type: "select",
452
+ editor: {
453
+ type: "combo-list",
454
+ textField: "name",
455
+ valueField: "value",
456
+ data: [{ value: e.type, name: i[e.type].name }]
457
+ }
458
+ }
459
+ }
460
+ };
461
+ }
462
+ getAppearanceConfig(e = null) {
463
+ return {
464
+ title: "样式",
465
+ description: "Appearance",
466
+ properties: {
467
+ class: {
468
+ title: "class样式",
469
+ type: "string",
470
+ description: "组件的CSS样式",
471
+ $converter: "/converter/appearance.converter"
472
+ },
473
+ style: {
474
+ title: "style样式",
475
+ type: "string",
476
+ description: "组件的样式",
477
+ $converter: "/converter/appearance.converter"
478
+ }
479
+ }
480
+ };
481
+ }
482
+ }
483
+ const V = class V {
484
+ /**
485
+ * 根据绑定字段类型获取可用的输入类控件
486
+ */
487
+ static getEditorTypesByMDataType(e) {
488
+ const t = V.fieldControlTypeMapping[e];
489
+ return t || [{ key: "", value: "" }];
490
+ }
491
+ /**
492
+ * 获取所有输入类控件
493
+ */
494
+ static getAllInputTypes() {
495
+ const e = [];
496
+ for (let t in V.fieldControlTypeMapping)
497
+ V.fieldControlTypeMapping[t].forEach((o) => {
498
+ e.find((r) => r.key === o.key && r.value === o.value) || e.push({ key: o.key, value: o.value });
499
+ });
500
+ return e;
501
+ }
502
+ };
503
+ /**
504
+ * <字段类型,可配置的控件类型列表>的映射
505
+ */
506
+ v(V, "fieldControlTypeMapping", {
507
+ String: [
508
+ { key: i["input-group"].type, value: i["input-group"].name },
509
+ { key: i.lookup.type, value: i.lookup.name },
510
+ { key: i["date-picker"].type, value: i["date-picker"].name },
511
+ { key: i["check-box"].type, value: i["check-box"].name },
512
+ { key: i["radio-group"].type, value: i["radio-group"].name },
513
+ { key: i["combo-list"].type, value: i["combo-list"].name },
514
+ { key: i.textarea.type, value: i.textarea.name }
515
+ ],
516
+ Text: [
517
+ { key: i.textarea.type, value: i.textarea.name },
518
+ { key: i.lookup.type, value: i.lookup.name }
519
+ ],
520
+ Decimal: [
521
+ { key: i["number-spinner"].type, value: i["number-spinner"].name }
522
+ ],
523
+ Integer: [
524
+ { key: i["number-spinner"].type, value: i["number-spinner"].name }
525
+ ],
526
+ Number: [
527
+ { key: i["number-spinner"].type, value: i["number-spinner"].name }
528
+ ],
529
+ BigNumber: [
530
+ { key: i["number-spinner"].type, value: i["number-spinner"].name }
531
+ ],
532
+ Date: [
533
+ { key: i["date-picker"].type, value: i["date-picker"].name }
534
+ ],
535
+ DateTime: [
536
+ { key: i["date-picker"].type, value: i["date-picker"].name }
537
+ ],
538
+ Boolean: [
539
+ { key: i.switch.type, value: i.switch.name },
540
+ { key: i["check-box"].type, value: i["check-box"].name }
541
+ ],
542
+ Enum: [
543
+ { key: i["combo-list"].type, value: i["combo-list"].name },
544
+ { key: i["radio-group"].type, value: i["radio-group"].name }
545
+ ],
546
+ Object: [
547
+ { key: i.lookup.type, value: i.lookup.name },
548
+ { key: i["combo-list"].type, value: i["combo-list"].name },
549
+ { key: i["radio-group"].type, value: i["radio-group"].name }
550
+ ]
551
+ });
552
+ let A = V;
553
+ const Ce = M(0);
554
+ class Me extends ve {
555
+ constructor(e, t) {
556
+ super(e, t);
557
+ }
558
+ getPropertyConfig(e, t) {
559
+ return this.propertyConfig.categories.basic = this.getBasicProperties(e, t), this.propertyConfig.categories.appearance = this.getAppearanceProperties(e), this.propertyConfig.categories.editor = this.getEditorProperties(e), this.propertyConfig;
560
+ }
561
+ getBasicProperties(e, t) {
562
+ var d;
563
+ var o = this;
564
+ this.setDesignViewModelField(e);
565
+ const r = this.formSchemaUtils.getFormMetadataBasicInfo(), s = this.designViewModelUtils.getAllFields2TreeByVMId(this.viewModelId);
566
+ return {
561
567
  description: "Basic Information",
562
568
  title: "基本信息",
563
569
  properties: {
@@ -577,63 +583,48 @@ class me {
577
583
  type: "combo-list",
578
584
  textField: "value",
579
585
  valueField: "key",
580
- data: W.getEditorTypesByMDataType(((i = (o = t.designViewModelField) == null ? void 0 : o.type) == null ? void 0 : i.name) || ""),
581
- editable: !1
586
+ editable: !1,
587
+ data: o.designViewModelField ? A.getEditorTypesByMDataType((d = o.designViewModelField.type) == null ? void 0 : d.name) : A.getAllInputTypes()
582
588
  }
583
589
  },
584
590
  label: {
585
591
  title: "标签",
586
592
  type: "string",
587
593
  $converter: "/converter/form-group-label.converter"
594
+ },
595
+ binding: {
596
+ description: "绑定的表单字段",
597
+ title: "绑定",
598
+ $converter: "/converter/field-selector.converter",
599
+ editor: {
600
+ type: "field-selector",
601
+ bindingType: { enable: !1 },
602
+ editorParams: {
603
+ propertyData: e,
604
+ formBasicInfo: r
605
+ },
606
+ columns: [
607
+ { field: "name", title: "字段名称" },
608
+ { field: "bindingField", title: "绑定字段" },
609
+ { field: "fieldType", title: "字段类型" }
610
+ ],
611
+ textField: "bindingField",
612
+ data: s
613
+ }
588
614
  }
589
615
  },
590
616
  setPropertyRelates(p, m) {
591
617
  if (p)
592
618
  switch (p && p.propertyID) {
593
619
  case "type": {
594
- t.changeControlType(e, p);
620
+ o.changeControlType(e, p, t);
595
621
  break;
596
622
  }
597
623
  }
598
624
  }
599
625
  };
600
626
  }
601
- /**
602
- * 卡片控件:切换控件类型后事件
603
- * @param propertyData 控件DOM属性
604
- * @param newControlType 新控件类型
605
- */
606
- changeControlType(e, t) {
607
- var r, c, l, s, f;
608
- const o = t.propertyValue, i = this.formSchemaUtils.getComponentById(this.componentId);
609
- let p = this.getControlParentContainer(e.id, i);
610
- if (!p)
611
- return;
612
- const m = p.contents.findIndex((h) => h.id === e.id), d = p.contents[m];
613
- let y;
614
- this.designViewModelField && (this.designViewModelUtils.getDgViewModel(this.viewModelId).changeField(this.designViewModelField.id, {
615
- editor: {
616
- $type: o
617
- },
618
- name: this.designViewModelField.name,
619
- require: this.designViewModelField.require,
620
- readonly: this.designViewModelField.readonly
621
- }, !1), y = this.controlCreatorUtils.setFormFieldProperty("Form", this.designViewModelField, null, o)), Object.assign(y, {
622
- id: d.id,
623
- appearance: d.appearance,
624
- size: d.size,
625
- label: d.label
626
- }), Object.assign(y.editor, {
627
- isTextArea: y.isTextArea && d.isTextArea,
628
- type: o || "",
629
- placeHolder: (r = d.editor) == null ? void 0 : r.placeHolder,
630
- holdPlace: (c = d.editor) == null ? void 0 : c.holdPlace,
631
- readonly: (l = d.editor) == null ? void 0 : l.readonly,
632
- require: (s = d.editor) == null ? void 0 : s.require,
633
- visible: (f = d.editor) == null ? void 0 : f.visible
634
- }), p.contents.splice(m, 1, y);
635
- }
636
- getAppearanceConfig(e = null) {
627
+ getAppearanceProperties(e) {
637
628
  return {
638
629
  title: "样式",
639
630
  description: "Appearance",
@@ -663,90 +654,52 @@ class me {
663
654
  }
664
655
  };
665
656
  }
666
- /**
667
- * 获取控件:以contents为节点进行定位
668
- * @param controlId 控件ID
669
- * @param domJson 容器
670
- */
671
- getControlParentContainer(e, t) {
672
- let o;
673
- if (!t || !t.contents || t.contents.length === 0)
674
- return null;
675
- for (const i of t.contents) {
676
- if (i.id === e)
677
- return o = t, t;
678
- if (o = this.getControlParentContainer(e, i), o)
679
- return o;
680
- }
681
- }
682
- getBindingFieldEditorOptions(e) {
683
- const t = this.formSchemaUtils.getFormMetadataBasicInfo();
684
- return {
685
- type: "field-selector",
686
- bindingType: { enable: !1 },
687
- editorParams: {
688
- propertyData: e,
689
- formBasicInfo: t
690
- },
691
- columns: [
692
- { field: "name", title: "字段名称" },
693
- { field: "bindingField", title: "绑定字段" },
694
- { field: "fieldType", title: "字段类型" }
695
- ],
696
- beforeOpenDialog: (o) => {
697
- const i = this.designViewModelUtils.getAllFields2TreeByVMId(this.viewModelId);
698
- o.instance.loadData(i);
699
- },
700
- textField: "bindingField"
701
- };
702
- }
703
- }
704
- class ye extends me {
705
- constructor(e, t) {
706
- super(e, t);
707
- }
708
- getBasicProperties(e) {
709
- let t = this.getBasicPropConfig(e);
710
- return t.properties.binding = this.getFieldSelectorOptions(e), t;
711
- }
712
- getAppearanceProperties(e) {
713
- return this.getAppearanceConfig(e);
714
- }
715
657
  getEditorProperties(e) {
716
658
  return this.getComponentConfig(e);
717
659
  }
718
- getPropertyConfig(e) {
719
- return this.propertyConfig.categories.basic = this.getBasicProperties(e), this.propertyConfig.categories.appearance = this.getAppearanceProperties(e), this.propertyConfig.categories.editor = this.getEditorProperties(e), this.propertyConfig;
720
- }
721
- getFieldSelectorOptions(e) {
722
- const t = this.formSchemaUtils.getFormMetadataBasicInfo(), o = this.designViewModelUtils.getAllFields2TreeByVMId(this.viewModelId);
723
- return {
724
- description: "绑定的表单字段",
725
- title: "绑定",
726
- $converter: "/converter/field-selector.converter",
660
+ /**
661
+ * 卡片控件:切换控件类型后事件
662
+ * @param propertyData 控件DOM属性
663
+ * @param newControlType 新控件类型
664
+ */
665
+ changeControlType(e, t, o) {
666
+ var a, l, c, u;
667
+ const r = t.propertyValue, s = o && o.parent && o.parent.schema;
668
+ if (!s)
669
+ return;
670
+ const d = s.contents.findIndex((f) => f.id === e.id), p = s.contents[d];
671
+ let m;
672
+ this.designViewModelField && (this.designViewModelUtils.getDgViewModel(this.viewModelId).changeField(this.designViewModelField.id, {
727
673
  editor: {
728
- type: "field-selector",
729
- bindingType: { enable: !1 },
730
- editorParams: {
731
- propertyData: e,
732
- formBasicInfo: t
733
- },
734
- columns: [
735
- { field: "name", title: "字段名称" },
736
- { field: "bindingField", title: "绑定字段" },
737
- { field: "fieldType", title: "字段类型" }
738
- ],
739
- data: o
740
- }
741
- };
674
+ $type: r
675
+ },
676
+ name: this.designViewModelField.name,
677
+ require: this.designViewModelField.require,
678
+ readonly: this.designViewModelField.readonly
679
+ }, !1), m = this.controlCreatorUtils.setFormFieldProperty(this.designViewModelField, r)), m || (m = q("form-group") || {}, m.editor = q(r) || {}, delete m.editor.id, delete m.editor.binding, delete m.editor.appearance), Object.assign(m, {
680
+ id: p.id,
681
+ appearance: p.appearance,
682
+ size: p.size,
683
+ label: p.label,
684
+ binding: p.binding,
685
+ visible: p.visible
686
+ }), Object.assign(m.editor, {
687
+ isTextArea: m.isTextArea && p.isTextArea,
688
+ placeholder: (a = p.editor) == null ? void 0 : a.placeholder,
689
+ holdPlace: (l = p.editor) == null ? void 0 : l.holdPlace,
690
+ readonly: (c = p.editor) == null ? void 0 : c.readonly,
691
+ require: (u = p.editor) == null ? void 0 : u.require
692
+ }), s.contents.splice(d, 1), s.contents.splice(d, 0, m), o.schema = Object.assign(p, m), Array.from(document.getElementsByClassName("dgComponentSelected")).forEach(
693
+ (f) => f.classList.remove("dgComponentSelected")
694
+ ), Ce.value++;
742
695
  }
743
696
  getComponentConfig(e, t = {}, o = {}) {
744
- const i = Object.assign({
697
+ const r = Object.assign({
745
698
  description: "组件信息",
746
699
  title: "组件信息",
747
700
  type: "input-group",
748
701
  $converter: "/converter/property-editor.converter"
749
- }, t), p = Object.assign({
702
+ }, t), s = Object.assign({
750
703
  readonly: {
751
704
  description: "",
752
705
  title: "只读",
@@ -768,82 +721,82 @@ class ye extends me {
768
721
  type: "string"
769
722
  }
770
723
  }, o);
771
- return { ...i, properties: { ...p } };
724
+ return { ...r, properties: { ...s } };
772
725
  }
773
726
  }
774
- class fe extends ye {
727
+ class we extends Me {
775
728
  constructor(e, t) {
776
729
  super(e, t);
777
730
  }
778
731
  }
779
- function ge(n, e) {
732
+ function ke(n, e) {
780
733
  n.schema;
781
- const t = C(!0), o = C(!0);
782
- function i(l) {
734
+ const t = M(!0), o = M(!0);
735
+ function r(c) {
783
736
  return !1;
784
737
  }
785
- function p() {
738
+ function s() {
786
739
  return !1;
787
740
  }
788
- function m() {
741
+ function d() {
789
742
  return !1;
790
743
  }
791
- function d() {
744
+ function p() {
792
745
  return !0;
793
746
  }
794
- function y(l) {
747
+ function m(c) {
795
748
  }
796
- function r() {
749
+ function a() {
797
750
  }
798
- function c(l) {
751
+ function l(c) {
799
752
  return null;
800
753
  }
801
754
  return {
802
- canAccepts: i,
803
- checkCanDeleteComponent: p,
804
- checkCanMoveComponent: m,
805
- hideNestedPaddingInDesginerView: d,
806
- onAcceptMovedChildElement: y,
807
- resolveComponentContext: r,
755
+ canAccepts: r,
756
+ checkCanDeleteComponent: s,
757
+ checkCanMoveComponent: d,
758
+ hideNestedPaddingInDesginerView: p,
759
+ onAcceptMovedChildElement: m,
760
+ resolveComponentContext: a,
808
761
  triggerBelongedComponentToMoveWhenMoved: t,
809
762
  triggerBelongedComponentToDeleteWhenDeleted: o,
810
- getPropsConfig: c
763
+ getPropsConfig: l
811
764
  };
812
765
  }
813
- function he(n, e) {
766
+ function Te(n, e) {
814
767
  const {
815
768
  canAccepts: t,
816
769
  checkCanDeleteComponent: o,
817
- checkCanMoveComponent: i,
818
- hideNestedPaddingInDesginerView: p,
819
- onAcceptMovedChildElement: m,
820
- resolveComponentContext: d,
821
- triggerBelongedComponentToMoveWhenMoved: y,
822
- triggerBelongedComponentToDeleteWhenDeleted: r
823
- } = ge(n), c = n.schema;
824
- function l(s) {
825
- return new fe(s, e).getPropertyConfig(c);
770
+ checkCanMoveComponent: r,
771
+ hideNestedPaddingInDesginerView: s,
772
+ onAcceptMovedChildElement: d,
773
+ resolveComponentContext: p,
774
+ triggerBelongedComponentToMoveWhenMoved: m,
775
+ triggerBelongedComponentToDeleteWhenDeleted: a
776
+ } = ke(n), l = n.schema;
777
+ function c(u, f) {
778
+ return new we(u, e).getPropertyConfig(l, f);
826
779
  }
827
780
  return {
828
781
  canAccepts: t,
829
782
  checkCanDeleteComponent: o,
830
- checkCanMoveComponent: i,
831
- hideNestedPaddingInDesginerView: p,
832
- onAcceptMovedChildElement: m,
833
- resolveComponentContext: d,
834
- triggerBelongedComponentToMoveWhenMoved: y,
835
- triggerBelongedComponentToDeleteWhenDeleted: r,
836
- getPropsConfig: l
783
+ checkCanMoveComponent: r,
784
+ hideNestedPaddingInDesginerView: s,
785
+ onAcceptMovedChildElement: d,
786
+ resolveComponentContext: p,
787
+ triggerBelongedComponentToMoveWhenMoved: m,
788
+ triggerBelongedComponentToDeleteWhenDeleted: a,
789
+ getPropsConfig: c
837
790
  };
838
791
  }
839
- const be = /* @__PURE__ */ U({
792
+ const Be = /* @__PURE__ */ G({
840
793
  name: "FTextareaDesign",
841
- props: V,
794
+ props: L,
842
795
  emits: [""],
843
796
  setup(n, e) {
844
- const t = C(), o = C(), i = O("designer-host-service"), p = O("design-item-context"), m = he(p, i), d = ue(o, p, m), y = M(() => n.maxLength ? n.maxLength : n.modelValue.length), r = M(() => ({
797
+ const t = M(), o = O("designer-host-service"), r = O("design-item-context"), s = Te(r, o), d = be(t, r, s), p = P(() => n.maxLength ? n.maxLength : n.modelValue.length), m = P(() => ({
845
798
  position: "relative"
846
- })), c = M(() => ({
799
+ })), a = P(() => ({
847
800
  "box-shadow": "0 0 0 1px #dcdfe6 inset",
848
801
  border: "none",
849
802
  padding: "5px 10px",
@@ -853,44 +806,43 @@ const be = /* @__PURE__ */ U({
853
806
  bottom: "5px",
854
807
  right: "10px"
855
808
  };
856
- return $(() => {
857
- t.value = n.modelValue, o.value.componentInstance = d;
858
- }), e.expose(d.value), () => S("div", {
859
- style: r.value,
860
- ref: o
861
- }, [S("textarea", {
809
+ return W(() => {
810
+ t.value.componentInstance = d;
811
+ }), e.expose(d.value), () => w("div", {
812
+ style: m.value,
813
+ ref: t
814
+ }, [w("textarea", {
862
815
  id: n.id,
863
- ref: t,
864
816
  minlength: n.minLength,
865
817
  maxlength: n.maxLength,
866
818
  tabindex: n.tabIndex,
867
819
  disabled: n.disabled,
868
820
  readonly: n.readonly,
869
821
  autocomplete: n.autocomplete,
870
- style: c.value,
822
+ style: a.value,
871
823
  placeholder: n.placeholder,
872
824
  autofocus: n.autofocus,
873
825
  rows: n.rows
874
- }, null), n.showCount && S("span", {
826
+ }, null), n.showCount && w("span", {
875
827
  style: l
876
- }, [`${n.modelValue.length}/${y.value}`])]);
828
+ }, [`${n.modelValue.length}/${p.value}`])]);
877
829
  }
878
- }), ve = (n) => {
830
+ }), Ve = (n) => {
879
831
  const e = n;
880
832
  return e.install = function(t) {
881
833
  t.component(e.name, n);
882
834
  }, n;
883
835
  };
884
- k.register = (n, e, t, o) => {
885
- n.textarea = k, e.textarea = j;
836
+ E.register = (n, e, t, o) => {
837
+ n.textarea = E, e.textarea = _;
886
838
  };
887
- k.registerDesigner = (n, e, t) => {
888
- n.textarea = be, e.textarea = j;
839
+ E.registerDesigner = (n, e, t) => {
840
+ n.textarea = Be, e.textarea = _;
889
841
  };
890
- const Se = ve(k);
842
+ const Ee = Ve(E);
891
843
  export {
892
- k as FTextarea,
893
- Se as default,
894
- j as propsResolver,
895
- V as textAreaProps
844
+ E as FTextarea,
845
+ Ee as default,
846
+ _ as propsResolver,
847
+ L as textAreaProps
896
848
  };