xkit-editor 2.0.0-alpha.0

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 (479) hide show
  1. package/lib/index.d.ts +2 -0
  2. package/lib/packages/editor/env.d.ts +7 -0
  3. package/lib/packages/editor/src/component-configs/__tests__/config.test.d.ts +2 -0
  4. package/lib/packages/editor/src/component-configs/__tests__/config.test.d.ts.map +1 -0
  5. package/lib/packages/editor/src/component-configs/__tests__/group.test.d.ts +2 -0
  6. package/lib/packages/editor/src/component-configs/__tests__/group.test.d.ts.map +1 -0
  7. package/lib/packages/editor/src/component-configs/cascader.d.ts +3 -0
  8. package/lib/packages/editor/src/component-configs/cascader.d.ts.map +1 -0
  9. package/lib/packages/editor/src/component-configs/checkbox.d.ts +4 -0
  10. package/lib/packages/editor/src/component-configs/checkbox.d.ts.map +1 -0
  11. package/lib/packages/editor/src/component-configs/common-props.d.ts +16 -0
  12. package/lib/packages/editor/src/component-configs/common-props.d.ts.map +1 -0
  13. package/lib/packages/editor/src/component-configs/date-picker.d.ts +3 -0
  14. package/lib/packages/editor/src/component-configs/date-picker.d.ts.map +1 -0
  15. package/lib/packages/editor/src/component-configs/date-range-picker.d.ts +4 -0
  16. package/lib/packages/editor/src/component-configs/date-range-picker.d.ts.map +1 -0
  17. package/lib/packages/editor/src/component-configs/group.d.ts +3 -0
  18. package/lib/packages/editor/src/component-configs/group.d.ts.map +1 -0
  19. package/lib/packages/editor/src/component-configs/icon-select.d.ts +3 -0
  20. package/lib/packages/editor/src/component-configs/icon-select.d.ts.map +1 -0
  21. package/lib/packages/editor/src/component-configs/input-array.d.ts +4 -0
  22. package/lib/packages/editor/src/component-configs/input-array.d.ts.map +1 -0
  23. package/lib/packages/editor/src/component-configs/input-number-range.d.ts +3 -0
  24. package/lib/packages/editor/src/component-configs/input-number-range.d.ts.map +1 -0
  25. package/lib/packages/editor/src/component-configs/input-number.d.ts +3 -0
  26. package/lib/packages/editor/src/component-configs/input-number.d.ts.map +1 -0
  27. package/lib/packages/editor/src/component-configs/input-table.d.ts +3 -0
  28. package/lib/packages/editor/src/component-configs/input-table.d.ts.map +1 -0
  29. package/lib/packages/editor/src/component-configs/input-upload.d.ts +3 -0
  30. package/lib/packages/editor/src/component-configs/input-upload.d.ts.map +1 -0
  31. package/lib/packages/editor/src/component-configs/input.d.ts +3 -0
  32. package/lib/packages/editor/src/component-configs/input.d.ts.map +1 -0
  33. package/lib/packages/editor/src/component-configs/layout-sections.d.ts +11 -0
  34. package/lib/packages/editor/src/component-configs/layout-sections.d.ts.map +1 -0
  35. package/lib/packages/editor/src/component-configs/options-config.d.ts +3 -0
  36. package/lib/packages/editor/src/component-configs/options-config.d.ts.map +1 -0
  37. package/lib/packages/editor/src/component-configs/radio.d.ts +3 -0
  38. package/lib/packages/editor/src/component-configs/radio.d.ts.map +1 -0
  39. package/lib/packages/editor/src/component-configs/select.d.ts +3 -0
  40. package/lib/packages/editor/src/component-configs/select.d.ts.map +1 -0
  41. package/lib/packages/editor/src/component-configs/switch.d.ts +3 -0
  42. package/lib/packages/editor/src/component-configs/switch.d.ts.map +1 -0
  43. package/lib/packages/editor/src/component-configs/textarea.d.ts +3 -0
  44. package/lib/packages/editor/src/component-configs/textarea.d.ts.map +1 -0
  45. package/lib/packages/editor/src/component-configs/types.d.ts +33 -0
  46. package/lib/packages/editor/src/component-configs/types.d.ts.map +1 -0
  47. package/lib/packages/editor/src/components/condition-editor.vue.d.ts +19 -0
  48. package/lib/packages/editor/src/components/condition-editor.vue.d.ts.map +1 -0
  49. package/lib/packages/editor/src/components/design-renderers/input-array-design.vue.d.ts +17 -0
  50. package/lib/packages/editor/src/components/design-renderers/input-array-design.vue.d.ts.map +1 -0
  51. package/lib/packages/editor/src/components/design-renderers/input-table-design.vue.d.ts +15 -0
  52. package/lib/packages/editor/src/components/design-renderers/input-table-design.vue.d.ts.map +1 -0
  53. package/lib/packages/editor/src/components/form-item-layout-editor.vue.d.ts +14 -0
  54. package/lib/packages/editor/src/components/form-item-layout-editor.vue.d.ts.map +1 -0
  55. package/lib/packages/editor/src/components/form-item-span-editor.vue.d.ts +18 -0
  56. package/lib/packages/editor/src/components/form-item-span-editor.vue.d.ts.map +1 -0
  57. package/lib/packages/editor/src/components/form-layout-editor.vue.d.ts +21 -0
  58. package/lib/packages/editor/src/components/form-layout-editor.vue.d.ts.map +1 -0
  59. package/lib/packages/editor/src/components/group-title-color-select.vue.d.ts +10 -0
  60. package/lib/packages/editor/src/components/group-title-color-select.vue.d.ts.map +1 -0
  61. package/lib/packages/editor/src/components/group-title-style-picker.vue.d.ts +10 -0
  62. package/lib/packages/editor/src/components/group-title-style-picker.vue.d.ts.map +1 -0
  63. package/lib/packages/editor/src/components/input-number-range-binding-editor.vue.d.ts +25 -0
  64. package/lib/packages/editor/src/components/input-number-range-binding-editor.vue.d.ts.map +1 -0
  65. package/lib/packages/editor/src/components/input-table-default-rows-editor.vue.d.ts +11 -0
  66. package/lib/packages/editor/src/components/input-table-default-rows-editor.vue.d.ts.map +1 -0
  67. package/lib/packages/editor/src/components/input-table-operation-editor.vue.d.ts +11 -0
  68. package/lib/packages/editor/src/components/input-table-operation-editor.vue.d.ts.map +1 -0
  69. package/lib/packages/editor/src/components/json-code-editor.vue.d.ts +18 -0
  70. package/lib/packages/editor/src/components/json-code-editor.vue.d.ts.map +1 -0
  71. package/lib/packages/editor/src/components/object-section-editor.vue.d.ts +23 -0
  72. package/lib/packages/editor/src/components/object-section-editor.vue.d.ts.map +1 -0
  73. package/lib/packages/editor/src/components/options/default-dict-options-panel.vue.d.ts +10 -0
  74. package/lib/packages/editor/src/components/options/default-dict-options-panel.vue.d.ts.map +1 -0
  75. package/lib/packages/editor/src/components/options/options-editor.vue.d.ts +12 -0
  76. package/lib/packages/editor/src/components/options/options-editor.vue.d.ts.map +1 -0
  77. package/lib/packages/editor/src/components/validation-rules-editor.vue.d.ts +12 -0
  78. package/lib/packages/editor/src/components/validation-rules-editor.vue.d.ts.map +1 -0
  79. package/lib/packages/editor/src/config.d.ts +8 -0
  80. package/lib/packages/editor/src/config.d.ts.map +1 -0
  81. package/lib/packages/editor/src/editor-item-wrapper.vue.d.ts +39 -0
  82. package/lib/packages/editor/src/editor-item-wrapper.vue.d.ts.map +1 -0
  83. package/lib/packages/editor/src/group-title-styles.d.ts +9 -0
  84. package/lib/packages/editor/src/group-title-styles.d.ts.map +1 -0
  85. package/lib/packages/editor/src/index.d.ts +7 -0
  86. package/lib/packages/editor/src/index.d.ts.map +1 -0
  87. package/lib/packages/editor/src/option-sources.d.ts +10 -0
  88. package/lib/packages/editor/src/option-sources.d.ts.map +1 -0
  89. package/lib/packages/editor/src/root-configs.d.ts +12 -0
  90. package/lib/packages/editor/src/root-configs.d.ts.map +1 -0
  91. package/lib/packages/editor/src/shims-vue.d.ts +5 -0
  92. package/lib/packages/editor/src/utils/__tests__/component-replace.test.d.ts +2 -0
  93. package/lib/packages/editor/src/utils/__tests__/component-replace.test.d.ts.map +1 -0
  94. package/lib/packages/editor/src/utils/__tests__/editor-schema.test.d.ts +2 -0
  95. package/lib/packages/editor/src/utils/__tests__/editor-schema.test.d.ts.map +1 -0
  96. package/lib/packages/editor/src/utils/__tests__/form-item-width.test.d.ts +2 -0
  97. package/lib/packages/editor/src/utils/__tests__/form-item-width.test.d.ts.map +1 -0
  98. package/lib/packages/editor/src/utils/__tests__/group-drag-path.test.d.ts +2 -0
  99. package/lib/packages/editor/src/utils/__tests__/group-drag-path.test.d.ts.map +1 -0
  100. package/lib/packages/editor/src/utils/__tests__/record-field.test.d.ts +2 -0
  101. package/lib/packages/editor/src/utils/__tests__/record-field.test.d.ts.map +1 -0
  102. package/lib/packages/editor/src/utils/component-replace.d.ts +8 -0
  103. package/lib/packages/editor/src/utils/component-replace.d.ts.map +1 -0
  104. package/lib/packages/editor/src/utils/editor-schema.d.ts +28 -0
  105. package/lib/packages/editor/src/utils/editor-schema.d.ts.map +1 -0
  106. package/lib/packages/editor/src/utils/form-item-width.d.ts +6 -0
  107. package/lib/packages/editor/src/utils/form-item-width.d.ts.map +1 -0
  108. package/lib/packages/editor/src/utils/local-dict-center.d.ts +11 -0
  109. package/lib/packages/editor/src/utils/local-dict-center.d.ts.map +1 -0
  110. package/lib/packages/editor/src/utils/record-field.d.ts +7 -0
  111. package/lib/packages/editor/src/utils/record-field.d.ts.map +1 -0
  112. package/lib/packages/editor/src/validation-rules.d.ts +10 -0
  113. package/lib/packages/editor/src/validation-rules.d.ts.map +1 -0
  114. package/lib/packages/editor/src/x-editor.vue.d.ts +107 -0
  115. package/lib/packages/editor/src/x-editor.vue.d.ts.map +1 -0
  116. package/lib/packages/ui/src/assets/icon-add-circle-fill.vue.d.ts +3 -0
  117. package/lib/packages/ui/src/assets/icon-add-circle-fill.vue.d.ts.map +1 -0
  118. package/lib/packages/ui/src/assets/icon-close-line.vue.d.ts +3 -0
  119. package/lib/packages/ui/src/assets/icon-close-line.vue.d.ts.map +1 -0
  120. package/lib/packages/ui/src/assets/icon-drag.vue.d.ts +3 -0
  121. package/lib/packages/ui/src/assets/icon-drag.vue.d.ts.map +1 -0
  122. package/lib/packages/ui/src/assets/icon-minus-circle.vue.d.ts +3 -0
  123. package/lib/packages/ui/src/assets/icon-minus-circle.vue.d.ts.map +1 -0
  124. package/lib/packages/ui/src/components/_public/form-item-cols.vue.d.ts +17 -0
  125. package/lib/packages/ui/src/components/_public/form-item-cols.vue.d.ts.map +1 -0
  126. package/lib/packages/ui/src/components/button/type.d.ts +85 -0
  127. package/lib/packages/ui/src/components/button/type.d.ts.map +1 -0
  128. package/lib/packages/ui/src/components/cascader/index.vue.d.ts +66 -0
  129. package/lib/packages/ui/src/components/cascader/index.vue.d.ts.map +1 -0
  130. package/lib/packages/ui/src/components/cascader/type.d.ts +125 -0
  131. package/lib/packages/ui/src/components/cascader/type.d.ts.map +1 -0
  132. package/lib/packages/ui/src/components/checkbox/index.vue.d.ts +30 -0
  133. package/lib/packages/ui/src/components/checkbox/index.vue.d.ts.map +1 -0
  134. package/lib/packages/ui/src/components/checkbox/type.d.ts +36 -0
  135. package/lib/packages/ui/src/components/checkbox/type.d.ts.map +1 -0
  136. package/lib/packages/ui/src/components/checkboxes/index.vue.d.ts +42 -0
  137. package/lib/packages/ui/src/components/checkboxes/index.vue.d.ts.map +1 -0
  138. package/lib/packages/ui/src/components/checkboxes/type.d.ts +56 -0
  139. package/lib/packages/ui/src/components/checkboxes/type.d.ts.map +1 -0
  140. package/lib/packages/ui/src/components/component/index.d.ts +7 -0
  141. package/lib/packages/ui/src/components/component/index.d.ts.map +1 -0
  142. package/lib/packages/ui/src/components/condition-builder/condition-node.vue.d.ts +32 -0
  143. package/lib/packages/ui/src/components/condition-builder/condition-node.vue.d.ts.map +1 -0
  144. package/lib/packages/ui/src/components/condition-builder/group-bracket.vue.d.ts +19 -0
  145. package/lib/packages/ui/src/components/condition-builder/group-bracket.vue.d.ts.map +1 -0
  146. package/lib/packages/ui/src/components/condition-builder/group-indent.vue.d.ts +19 -0
  147. package/lib/packages/ui/src/components/condition-builder/group-indent.vue.d.ts.map +1 -0
  148. package/lib/packages/ui/src/components/condition-builder/index.vue.d.ts +160 -0
  149. package/lib/packages/ui/src/components/condition-builder/index.vue.d.ts.map +1 -0
  150. package/lib/packages/ui/src/components/condition-builder/type.d.ts +88 -0
  151. package/lib/packages/ui/src/components/condition-builder/type.d.ts.map +1 -0
  152. package/lib/packages/ui/src/components/crud/action-type.d.ts +80 -0
  153. package/lib/packages/ui/src/components/crud/action-type.d.ts.map +1 -0
  154. package/lib/packages/ui/src/components/crud/index.vue.d.ts +78 -0
  155. package/lib/packages/ui/src/components/crud/index.vue.d.ts.map +1 -0
  156. package/lib/packages/ui/src/components/crud/multi-action.vue.d.ts +8 -0
  157. package/lib/packages/ui/src/components/crud/multi-action.vue.d.ts.map +1 -0
  158. package/lib/packages/ui/src/components/crud/single-action.vue.d.ts +7 -0
  159. package/lib/packages/ui/src/components/crud/single-action.vue.d.ts.map +1 -0
  160. package/lib/packages/ui/src/components/crud/type.d.ts +171 -0
  161. package/lib/packages/ui/src/components/crud/type.d.ts.map +1 -0
  162. package/lib/packages/ui/src/components/crud-form/index.vue.d.ts +22 -0
  163. package/lib/packages/ui/src/components/crud-form/index.vue.d.ts.map +1 -0
  164. package/lib/packages/ui/src/components/crud-form/type.d.ts +65 -0
  165. package/lib/packages/ui/src/components/crud-form/type.d.ts.map +1 -0
  166. package/lib/packages/ui/src/components/date-picker/index.vue.d.ts +35 -0
  167. package/lib/packages/ui/src/components/date-picker/index.vue.d.ts.map +1 -0
  168. package/lib/packages/ui/src/components/date-picker/type.d.ts +139 -0
  169. package/lib/packages/ui/src/components/date-picker/type.d.ts.map +1 -0
  170. package/lib/packages/ui/src/components/date-range-picker/index.vue.d.ts +15 -0
  171. package/lib/packages/ui/src/components/date-range-picker/index.vue.d.ts.map +1 -0
  172. package/lib/packages/ui/src/components/date-range-picker/type.d.ts +137 -0
  173. package/lib/packages/ui/src/components/date-range-picker/type.d.ts.map +1 -0
  174. package/lib/packages/ui/src/components/date-range-picker-v2/index.vue.d.ts +22 -0
  175. package/lib/packages/ui/src/components/date-range-picker-v2/index.vue.d.ts.map +1 -0
  176. package/lib/packages/ui/src/components/date-range-picker-v2/type.d.ts +37 -0
  177. package/lib/packages/ui/src/components/date-range-picker-v2/type.d.ts.map +1 -0
  178. package/lib/packages/ui/src/components/description/index.vue.d.ts +28 -0
  179. package/lib/packages/ui/src/components/description/index.vue.d.ts.map +1 -0
  180. package/lib/packages/ui/src/components/description/type.d.ts +120 -0
  181. package/lib/packages/ui/src/components/description/type.d.ts.map +1 -0
  182. package/lib/packages/ui/src/components/dialog/type.d.ts +100 -0
  183. package/lib/packages/ui/src/components/dialog/type.d.ts.map +1 -0
  184. package/lib/packages/ui/src/components/dropdown/type.d.ts +62 -0
  185. package/lib/packages/ui/src/components/dropdown/type.d.ts.map +1 -0
  186. package/lib/packages/ui/src/components/ellipsis/index.vue.d.ts +34 -0
  187. package/lib/packages/ui/src/components/ellipsis/index.vue.d.ts.map +1 -0
  188. package/lib/packages/ui/src/components/ellipsis/type.d.ts +26 -0
  189. package/lib/packages/ui/src/components/ellipsis/type.d.ts.map +1 -0
  190. package/lib/packages/ui/src/components/event-menu/index.vue.d.ts +25 -0
  191. package/lib/packages/ui/src/components/event-menu/index.vue.d.ts.map +1 -0
  192. package/lib/packages/ui/src/components/form/form-item.type.d.ts +304 -0
  193. package/lib/packages/ui/src/components/form/form-item.type.d.ts.map +1 -0
  194. package/lib/packages/ui/src/components/form/form-item.vue.d.ts +50 -0
  195. package/lib/packages/ui/src/components/form/form-item.vue.d.ts.map +1 -0
  196. package/lib/packages/ui/src/components/form/form-layout-renderer.vue.d.ts +71 -0
  197. package/lib/packages/ui/src/components/form/form-layout-renderer.vue.d.ts.map +1 -0
  198. package/lib/packages/ui/src/components/form/index.vue.d.ts +220 -0
  199. package/lib/packages/ui/src/components/form/index.vue.d.ts.map +1 -0
  200. package/lib/packages/ui/src/components/form/query-form.d.ts +4 -0
  201. package/lib/packages/ui/src/components/form/query-form.d.ts.map +1 -0
  202. package/lib/packages/ui/src/components/form/type.d.ts +312 -0
  203. package/lib/packages/ui/src/components/form/type.d.ts.map +1 -0
  204. package/lib/packages/ui/src/components/group/group-item.vue.d.ts +9 -0
  205. package/lib/packages/ui/src/components/group/group-item.vue.d.ts.map +1 -0
  206. package/lib/packages/ui/src/components/group/index.vue.d.ts +24 -0
  207. package/lib/packages/ui/src/components/group/index.vue.d.ts.map +1 -0
  208. package/lib/packages/ui/src/components/group/type.d.ts +119 -0
  209. package/lib/packages/ui/src/components/group/type.d.ts.map +1 -0
  210. package/lib/packages/ui/src/components/icon-select/__tests__/icon-sources.test.d.ts +2 -0
  211. package/lib/packages/ui/src/components/icon-select/__tests__/icon-sources.test.d.ts.map +1 -0
  212. package/lib/packages/ui/src/components/icon-select/icon-parser.vue.d.ts +41 -0
  213. package/lib/packages/ui/src/components/icon-select/icon-parser.vue.d.ts.map +1 -0
  214. package/lib/packages/ui/src/components/icon-select/icon-sources.d.ts +22 -0
  215. package/lib/packages/ui/src/components/icon-select/icon-sources.d.ts.map +1 -0
  216. package/lib/packages/ui/src/components/icon-select/index.vue.d.ts +15 -0
  217. package/lib/packages/ui/src/components/icon-select/index.vue.d.ts.map +1 -0
  218. package/lib/packages/ui/src/components/icon-select/type.d.ts +24 -0
  219. package/lib/packages/ui/src/components/icon-select/type.d.ts.map +1 -0
  220. package/lib/packages/ui/src/components/index.d.ts +107 -0
  221. package/lib/packages/ui/src/components/index.d.ts.map +1 -0
  222. package/lib/packages/ui/src/components/input/index.vue.d.ts +20 -0
  223. package/lib/packages/ui/src/components/input/index.vue.d.ts.map +1 -0
  224. package/lib/packages/ui/src/components/input/type.d.ts +121 -0
  225. package/lib/packages/ui/src/components/input/type.d.ts.map +1 -0
  226. package/lib/packages/ui/src/components/input-array/__tests__/layout.test.d.ts +2 -0
  227. package/lib/packages/ui/src/components/input-array/__tests__/layout.test.d.ts.map +1 -0
  228. package/lib/packages/ui/src/components/input-array/index.vue.d.ts +28 -0
  229. package/lib/packages/ui/src/components/input-array/index.vue.d.ts.map +1 -0
  230. package/lib/packages/ui/src/components/input-array/layout.d.ts +11 -0
  231. package/lib/packages/ui/src/components/input-array/layout.d.ts.map +1 -0
  232. package/lib/packages/ui/src/components/input-array/type.d.ts +89 -0
  233. package/lib/packages/ui/src/components/input-array/type.d.ts.map +1 -0
  234. package/lib/packages/ui/src/components/input-collapse/index.vue.d.ts +7 -0
  235. package/lib/packages/ui/src/components/input-collapse/index.vue.d.ts.map +1 -0
  236. package/lib/packages/ui/src/components/input-collapse/type.d.ts +50 -0
  237. package/lib/packages/ui/src/components/input-collapse/type.d.ts.map +1 -0
  238. package/lib/packages/ui/src/components/input-linked/index.vue.d.ts +13 -0
  239. package/lib/packages/ui/src/components/input-linked/index.vue.d.ts.map +1 -0
  240. package/lib/packages/ui/src/components/input-linked/type.d.ts +32 -0
  241. package/lib/packages/ui/src/components/input-linked/type.d.ts.map +1 -0
  242. package/lib/packages/ui/src/components/input-number/index.vue.d.ts +29 -0
  243. package/lib/packages/ui/src/components/input-number/index.vue.d.ts.map +1 -0
  244. package/lib/packages/ui/src/components/input-number/type.d.ts +57 -0
  245. package/lib/packages/ui/src/components/input-number/type.d.ts.map +1 -0
  246. package/lib/packages/ui/src/components/input-number-range/index.vue.d.ts +28 -0
  247. package/lib/packages/ui/src/components/input-number-range/index.vue.d.ts.map +1 -0
  248. package/lib/packages/ui/src/components/input-number-range/type.d.ts +49 -0
  249. package/lib/packages/ui/src/components/input-number-range/type.d.ts.map +1 -0
  250. package/lib/packages/ui/src/components/input-table/index.vue.d.ts +25 -0
  251. package/lib/packages/ui/src/components/input-table/index.vue.d.ts.map +1 -0
  252. package/lib/packages/ui/src/components/input-table/type.d.ts +37 -0
  253. package/lib/packages/ui/src/components/input-table/type.d.ts.map +1 -0
  254. package/lib/packages/ui/src/components/input-upload/index.vue.d.ts +11 -0
  255. package/lib/packages/ui/src/components/input-upload/index.vue.d.ts.map +1 -0
  256. package/lib/packages/ui/src/components/input-upload/type.d.ts +59 -0
  257. package/lib/packages/ui/src/components/input-upload/type.d.ts.map +1 -0
  258. package/lib/packages/ui/src/components/json/index.vue.d.ts +10 -0
  259. package/lib/packages/ui/src/components/json/index.vue.d.ts.map +1 -0
  260. package/lib/packages/ui/src/components/link/index.vue.d.ts +21 -0
  261. package/lib/packages/ui/src/components/link/index.vue.d.ts.map +1 -0
  262. package/lib/packages/ui/src/components/link/type.d.ts +28 -0
  263. package/lib/packages/ui/src/components/link/type.d.ts.map +1 -0
  264. package/lib/packages/ui/src/components/radios/index.vue.d.ts +42 -0
  265. package/lib/packages/ui/src/components/radios/index.vue.d.ts.map +1 -0
  266. package/lib/packages/ui/src/components/radios/type.d.ts +36 -0
  267. package/lib/packages/ui/src/components/radios/type.d.ts.map +1 -0
  268. package/lib/packages/ui/src/components/search-bar/index.vue.d.ts +37 -0
  269. package/lib/packages/ui/src/components/search-bar/index.vue.d.ts.map +1 -0
  270. package/lib/packages/ui/src/components/select/index.vue.d.ts +48 -0
  271. package/lib/packages/ui/src/components/select/index.vue.d.ts.map +1 -0
  272. package/lib/packages/ui/src/components/select/type.d.ts +222 -0
  273. package/lib/packages/ui/src/components/select/type.d.ts.map +1 -0
  274. package/lib/packages/ui/src/components/static/options-viewer.vue.d.ts +16 -0
  275. package/lib/packages/ui/src/components/static/options-viewer.vue.d.ts.map +1 -0
  276. package/lib/packages/ui/src/components/static/rich-text-viewer.vue.d.ts +8 -0
  277. package/lib/packages/ui/src/components/static/rich-text-viewer.vue.d.ts.map +1 -0
  278. package/lib/packages/ui/src/components/static/textarea-viewer.vue.d.ts +6 -0
  279. package/lib/packages/ui/src/components/static/textarea-viewer.vue.d.ts.map +1 -0
  280. package/lib/packages/ui/src/components/switch/index.vue.d.ts +38 -0
  281. package/lib/packages/ui/src/components/switch/index.vue.d.ts.map +1 -0
  282. package/lib/packages/ui/src/components/switch/type.d.ts +72 -0
  283. package/lib/packages/ui/src/components/switch/type.d.ts.map +1 -0
  284. package/lib/packages/ui/src/components/table/index.vue.d.ts +1317 -0
  285. package/lib/packages/ui/src/components/table/index.vue.d.ts.map +1 -0
  286. package/lib/packages/ui/src/components/table/table-column.vue.d.ts +44 -0
  287. package/lib/packages/ui/src/components/table/table-column.vue.d.ts.map +1 -0
  288. package/lib/packages/ui/src/components/table/type.d.ts +306 -0
  289. package/lib/packages/ui/src/components/table/type.d.ts.map +1 -0
  290. package/lib/packages/ui/src/components/table-select/const.d.ts +14 -0
  291. package/lib/packages/ui/src/components/table-select/const.d.ts.map +1 -0
  292. package/lib/packages/ui/src/components/table-select/index.vue.d.ts +21871 -0
  293. package/lib/packages/ui/src/components/table-select/index.vue.d.ts.map +1 -0
  294. package/lib/packages/ui/src/components/table-select/table-selector-main.vue.d.ts +4795 -0
  295. package/lib/packages/ui/src/components/table-select/table-selector-main.vue.d.ts.map +1 -0
  296. package/lib/packages/ui/src/components/table-select/type.d.ts +71 -0
  297. package/lib/packages/ui/src/components/table-select/type.d.ts.map +1 -0
  298. package/lib/packages/ui/src/components/tabs/index.vue.d.ts +6 -0
  299. package/lib/packages/ui/src/components/tabs/index.vue.d.ts.map +1 -0
  300. package/lib/packages/ui/src/components/tabs/type.d.ts +23 -0
  301. package/lib/packages/ui/src/components/tabs/type.d.ts.map +1 -0
  302. package/lib/packages/ui/src/components/text/index.vue.d.ts +7 -0
  303. package/lib/packages/ui/src/components/text/index.vue.d.ts.map +1 -0
  304. package/lib/packages/ui/src/components/text/type.d.ts +7 -0
  305. package/lib/packages/ui/src/components/text/type.d.ts.map +1 -0
  306. package/lib/packages/ui/src/components/textarea/type.d.ts +79 -0
  307. package/lib/packages/ui/src/components/textarea/type.d.ts.map +1 -0
  308. package/lib/packages/ui/src/components/toolbar/index.vue.d.ts +15 -0
  309. package/lib/packages/ui/src/components/toolbar/index.vue.d.ts.map +1 -0
  310. package/lib/packages/ui/src/components/transitions/TransitionHeight.vue.d.ts +30 -0
  311. package/lib/packages/ui/src/components/transitions/TransitionHeight.vue.d.ts.map +1 -0
  312. package/lib/packages/ui/src/components/tree/index.vue.d.ts +17 -0
  313. package/lib/packages/ui/src/components/tree/index.vue.d.ts.map +1 -0
  314. package/lib/packages/ui/src/components/tree/tree-node.vue.d.ts +8 -0
  315. package/lib/packages/ui/src/components/tree/tree-node.vue.d.ts.map +1 -0
  316. package/lib/packages/ui/src/components/tree/tree-state.d.ts +35 -0
  317. package/lib/packages/ui/src/components/tree/tree-state.d.ts.map +1 -0
  318. package/lib/packages/ui/src/components/tree/type.d.ts +50 -0
  319. package/lib/packages/ui/src/components/tree/type.d.ts.map +1 -0
  320. package/lib/packages/ui/src/components/tree-select/index.vue.d.ts +94 -0
  321. package/lib/packages/ui/src/components/tree-select/index.vue.d.ts.map +1 -0
  322. package/lib/packages/ui/src/components/tree-select/type.d.ts +156 -0
  323. package/lib/packages/ui/src/components/tree-select/type.d.ts.map +1 -0
  324. package/lib/packages/ui/src/components/tree-select-crud/index.vue.d.ts +3102 -0
  325. package/lib/packages/ui/src/components/tree-select-crud/index.vue.d.ts.map +1 -0
  326. package/lib/packages/ui/src/components/tree-select-crud/type.d.ts +88 -0
  327. package/lib/packages/ui/src/components/tree-select-crud/type.d.ts.map +1 -0
  328. package/lib/packages/ui/src/components/upload/index.vue.d.ts +54 -0
  329. package/lib/packages/ui/src/components/upload/index.vue.d.ts.map +1 -0
  330. package/lib/packages/ui/src/composables/__tests__/use-option-static.test.d.ts +2 -0
  331. package/lib/packages/ui/src/composables/__tests__/use-option-static.test.d.ts.map +1 -0
  332. package/lib/packages/ui/src/composables/index.d.ts +3 -0
  333. package/lib/packages/ui/src/composables/index.d.ts.map +1 -0
  334. package/lib/packages/ui/src/composables/use-action.d.ts +21 -0
  335. package/lib/packages/ui/src/composables/use-action.d.ts.map +1 -0
  336. package/lib/packages/ui/src/composables/use-component.d.ts +74 -0
  337. package/lib/packages/ui/src/composables/use-component.d.ts.map +1 -0
  338. package/lib/packages/ui/src/composables/use-config.d.ts +76 -0
  339. package/lib/packages/ui/src/composables/use-config.d.ts.map +1 -0
  340. package/lib/packages/ui/src/composables/use-draggable.d.ts +22 -0
  341. package/lib/packages/ui/src/composables/use-draggable.d.ts.map +1 -0
  342. package/lib/packages/ui/src/composables/use-input-array.d.ts +45 -0
  343. package/lib/packages/ui/src/composables/use-input-array.d.ts.map +1 -0
  344. package/lib/packages/ui/src/composables/use-label.d.ts +2 -0
  345. package/lib/packages/ui/src/composables/use-label.d.ts.map +1 -0
  346. package/lib/packages/ui/src/composables/use-loading.d.ts +6 -0
  347. package/lib/packages/ui/src/composables/use-loading.d.ts.map +1 -0
  348. package/lib/packages/ui/src/composables/use-option-static.d.ts +51 -0
  349. package/lib/packages/ui/src/composables/use-option-static.d.ts.map +1 -0
  350. package/lib/packages/ui/src/composables/use-options.d.ts +66 -0
  351. package/lib/packages/ui/src/composables/use-options.d.ts.map +1 -0
  352. package/lib/packages/ui/src/composables/use-paging.d.ts +134 -0
  353. package/lib/packages/ui/src/composables/use-paging.d.ts.map +1 -0
  354. package/lib/packages/ui/src/composables/use-scaffold.d.ts +54 -0
  355. package/lib/packages/ui/src/composables/use-scaffold.d.ts.map +1 -0
  356. package/lib/packages/ui/src/composables/use-toggle.d.ts +11 -0
  357. package/lib/packages/ui/src/composables/use-toggle.d.ts.map +1 -0
  358. package/lib/packages/ui/src/composables/use-tree-static-path.d.ts +45 -0
  359. package/lib/packages/ui/src/composables/use-tree-static-path.d.ts.map +1 -0
  360. package/lib/packages/ui/src/composables/use-visible.d.ts +11 -0
  361. package/lib/packages/ui/src/composables/use-visible.d.ts.map +1 -0
  362. package/lib/packages/ui/src/config/layout.d.ts +9 -0
  363. package/lib/packages/ui/src/config/layout.d.ts.map +1 -0
  364. package/lib/packages/ui/src/constants/injection.d.ts +11 -0
  365. package/lib/packages/ui/src/constants/injection.d.ts.map +1 -0
  366. package/lib/packages/ui/src/directives/highlight.d.ts +7 -0
  367. package/lib/packages/ui/src/directives/highlight.d.ts.map +1 -0
  368. package/lib/packages/ui/src/directives/index.d.ts +2 -0
  369. package/lib/packages/ui/src/directives/index.d.ts.map +1 -0
  370. package/lib/packages/ui/src/index.d.ts +59 -0
  371. package/lib/packages/ui/src/index.d.ts.map +1 -0
  372. package/lib/packages/ui/src/types/api.d.ts +8 -0
  373. package/lib/packages/ui/src/types/api.d.ts.map +1 -0
  374. package/lib/packages/ui/src/types/base.d.ts +306 -0
  375. package/lib/packages/ui/src/types/base.d.ts.map +1 -0
  376. package/lib/packages/ui/src/types/form.d.ts +82 -0
  377. package/lib/packages/ui/src/types/form.d.ts.map +1 -0
  378. package/lib/packages/ui/src/types/index.d.ts +6 -0
  379. package/lib/packages/ui/src/types/index.d.ts.map +1 -0
  380. package/lib/packages/ui/src/types/option.d.ts +115 -0
  381. package/lib/packages/ui/src/types/option.d.ts.map +1 -0
  382. package/lib/packages/ui/src/types/pagination.d.ts +35 -0
  383. package/lib/packages/ui/src/types/pagination.d.ts.map +1 -0
  384. package/lib/packages/ui/src/types/table.d.ts +34 -0
  385. package/lib/packages/ui/src/types/table.d.ts.map +1 -0
  386. package/lib/packages/ui/src/types/util.d.ts +6 -0
  387. package/lib/packages/ui/src/types/util.d.ts.map +1 -0
  388. package/lib/packages/ui/src/utils/__tests__/condition.test.d.ts +2 -0
  389. package/lib/packages/ui/src/utils/__tests__/condition.test.d.ts.map +1 -0
  390. package/lib/packages/ui/src/utils/__tests__/editor-container.test.d.ts +2 -0
  391. package/lib/packages/ui/src/utils/__tests__/editor-container.test.d.ts.map +1 -0
  392. package/lib/packages/ui/src/utils/__tests__/form.test.d.ts +2 -0
  393. package/lib/packages/ui/src/utils/__tests__/form.test.d.ts.map +1 -0
  394. package/lib/packages/ui/src/utils/__tests__/tree.test.d.ts +2 -0
  395. package/lib/packages/ui/src/utils/__tests__/tree.test.d.ts.map +1 -0
  396. package/lib/packages/ui/src/utils/common.d.ts +13 -0
  397. package/lib/packages/ui/src/utils/common.d.ts.map +1 -0
  398. package/lib/packages/ui/src/utils/computed-state-manager.d.ts +3 -0
  399. package/lib/packages/ui/src/utils/computed-state-manager.d.ts.map +1 -0
  400. package/lib/packages/ui/src/utils/condition.d.ts +4 -0
  401. package/lib/packages/ui/src/utils/condition.d.ts.map +1 -0
  402. package/lib/packages/ui/src/utils/editor-container.d.ts +25 -0
  403. package/lib/packages/ui/src/utils/editor-container.d.ts.map +1 -0
  404. package/lib/packages/ui/src/utils/form-item.d.ts +23 -0
  405. package/lib/packages/ui/src/utils/form-item.d.ts.map +1 -0
  406. package/lib/packages/ui/src/utils/form.d.ts +75 -0
  407. package/lib/packages/ui/src/utils/form.d.ts.map +1 -0
  408. package/lib/packages/ui/src/utils/id.d.ts +24 -0
  409. package/lib/packages/ui/src/utils/id.d.ts.map +1 -0
  410. package/lib/packages/ui/src/utils/options.d.ts +14 -0
  411. package/lib/packages/ui/src/utils/options.d.ts.map +1 -0
  412. package/lib/packages/ui/src/utils/reactive.d.ts +13 -0
  413. package/lib/packages/ui/src/utils/reactive.d.ts.map +1 -0
  414. package/lib/packages/ui/src/utils/style.d.ts +5 -0
  415. package/lib/packages/ui/src/utils/style.d.ts.map +1 -0
  416. package/lib/packages/ui/src/utils/tree.d.ts +51 -0
  417. package/lib/packages/ui/src/utils/tree.d.ts.map +1 -0
  418. package/lib/xkit-editor.css +2 -0
  419. package/lib/xkit-editor.js +78741 -0
  420. package/lib/xkit-editor.umd.cjs +99 -0
  421. package/package.json +50 -0
  422. package/src/component-configs/__tests__/config.test.ts +288 -0
  423. package/src/component-configs/__tests__/group.test.ts +104 -0
  424. package/src/component-configs/cascader.ts +20 -0
  425. package/src/component-configs/checkbox.ts +43 -0
  426. package/src/component-configs/common-props.ts +130 -0
  427. package/src/component-configs/date-picker.ts +153 -0
  428. package/src/component-configs/date-range-picker.ts +185 -0
  429. package/src/component-configs/group.ts +196 -0
  430. package/src/component-configs/icon-select.ts +56 -0
  431. package/src/component-configs/input-array.ts +184 -0
  432. package/src/component-configs/input-number-range.ts +143 -0
  433. package/src/component-configs/input-number.ts +111 -0
  434. package/src/component-configs/input-table.ts +191 -0
  435. package/src/component-configs/input-upload.ts +123 -0
  436. package/src/component-configs/input.ts +48 -0
  437. package/src/component-configs/layout-sections.ts +546 -0
  438. package/src/component-configs/options-config.ts +12 -0
  439. package/src/component-configs/radio.ts +26 -0
  440. package/src/component-configs/select.ts +42 -0
  441. package/src/component-configs/switch.ts +19 -0
  442. package/src/component-configs/textarea.ts +84 -0
  443. package/src/component-configs/types.ts +37 -0
  444. package/src/components/condition-editor.vue +641 -0
  445. package/src/components/design-renderers/input-array-design.vue +283 -0
  446. package/src/components/design-renderers/input-table-design.vue +311 -0
  447. package/src/components/form-item-layout-editor.vue +291 -0
  448. package/src/components/form-item-span-editor.vue +328 -0
  449. package/src/components/form-layout-editor.vue +263 -0
  450. package/src/components/group-title-color-select.vue +75 -0
  451. package/src/components/group-title-style-picker.vue +125 -0
  452. package/src/components/input-number-range-binding-editor.vue +226 -0
  453. package/src/components/input-table-default-rows-editor.vue +147 -0
  454. package/src/components/input-table-operation-editor.vue +168 -0
  455. package/src/components/json-code-editor.vue +219 -0
  456. package/src/components/object-section-editor.vue +342 -0
  457. package/src/components/options/default-dict-options-panel.vue +197 -0
  458. package/src/components/options/options-editor.vue +161 -0
  459. package/src/components/table-columns-editor.vue +353 -0
  460. package/src/components/validation-rules-editor.vue +321 -0
  461. package/src/config.ts +51 -0
  462. package/src/editor-item-wrapper.vue +254 -0
  463. package/src/group-title-styles.ts +82 -0
  464. package/src/index.ts +6 -0
  465. package/src/option-sources.ts +45 -0
  466. package/src/root-configs.ts +278 -0
  467. package/src/shims-vue.d.ts +5 -0
  468. package/src/utils/__tests__/component-replace.test.ts +129 -0
  469. package/src/utils/__tests__/editor-schema.test.ts +429 -0
  470. package/src/utils/__tests__/form-item-width.test.ts +53 -0
  471. package/src/utils/__tests__/group-drag-path.test.ts +84 -0
  472. package/src/utils/__tests__/record-field.test.ts +34 -0
  473. package/src/utils/component-replace.ts +67 -0
  474. package/src/utils/editor-schema.ts +374 -0
  475. package/src/utils/form-item-width.ts +40 -0
  476. package/src/utils/local-dict-center.ts +81 -0
  477. package/src/utils/record-field.ts +30 -0
  478. package/src/validation-rules.ts +104 -0
  479. package/src/x-editor.vue +1300 -0
@@ -0,0 +1,263 @@
1
+ <template>
2
+ <div class="form-layout-editor">
3
+ <div class="form-layout-editor__header">
4
+ <span class="form-layout-editor__title">{{ title || '表单布局' }}</span>
5
+ <el-radio-group :model-value="activeType" size="small" @update:modelValue="handleTypeChange">
6
+ <el-radio-button label="grid">栅格</el-radio-button>
7
+ <el-radio-button label="descriptions">描述表</el-radio-button>
8
+ <el-radio-button label="table">表格</el-radio-button>
9
+ </el-radio-group>
10
+ </div>
11
+
12
+ <ObjectSectionEditor
13
+ :key="activeType"
14
+ :model-value="activeProfile"
15
+ :title="activeProfileTitle"
16
+ :root-key="`layout.${activeType}`"
17
+ :value-mode="activeValueMode"
18
+ section-mode="plain"
19
+ :sections="activeSections"
20
+ @update:modelValue="handleProfileChange"
21
+ />
22
+ </div>
23
+ </template>
24
+
25
+ <script setup lang="ts">
26
+ import { computed } from 'vue'
27
+ import { ElMessageBox, ElRadioButton, ElRadioGroup } from 'element-plus'
28
+ import ObjectSectionEditor from './object-section-editor.vue'
29
+ import { containerLayoutSections, descriptionsLayoutSections, tableLayoutSections } from '../component-configs/layout-sections'
30
+
31
+ type LayoutType = 'grid' | 'descriptions' | 'table'
32
+
33
+ interface LayoutValue {
34
+ type?: LayoutType
35
+ row?: Record<string, any>
36
+ col?: Record<string, any>
37
+ grid?: Record<string, any>
38
+ descriptions?: Record<string, any>
39
+ table?: Record<string, any>
40
+ }
41
+
42
+ const props = defineProps<{
43
+ modelValue?: LayoutValue
44
+ title?: string
45
+ formSchema?: Record<string, any>
46
+ }>()
47
+
48
+ const emit = defineEmits<(event: 'update:modelValue', value: LayoutValue | undefined) => void>()
49
+
50
+ const layoutTypes: LayoutType[] = ['grid', 'descriptions', 'table']
51
+
52
+ const cleanRecord = (value: any) => {
53
+ if (!value || typeof value !== 'object') return undefined
54
+ const next = Object.entries(value).reduce<Record<string, any>>((result, [key, itemValue]) => {
55
+ if (itemValue !== undefined && itemValue !== null && itemValue !== '') {
56
+ result[key] = itemValue
57
+ }
58
+ return result
59
+ }, {})
60
+ return Object.keys(next).length > 0 ? next : undefined
61
+ }
62
+
63
+ const normalizeLegacyLayout = (layout?: LayoutValue): LayoutValue => {
64
+ const current = layout || {}
65
+ const grid = current.grid || cleanRecord({ row: current.row, col: current.col })
66
+ return {
67
+ ...current,
68
+ type: current.type || 'grid',
69
+ ...(grid ? { grid } : {})
70
+ }
71
+ }
72
+
73
+ const activeType = computed<LayoutType>(() => {
74
+ const type = props.modelValue?.type
75
+ return layoutTypes.includes(type as LayoutType) ? (type as LayoutType) : 'grid'
76
+ })
77
+
78
+ const normalizedLayout = computed(() => normalizeLegacyLayout(props.modelValue))
79
+ const activeProfile = computed(() => {
80
+ if (activeType.value === 'grid') {
81
+ return normalizedLayout.value.grid || cleanRecord({ row: normalizedLayout.value.row, col: normalizedLayout.value.col }) || {}
82
+ }
83
+ return normalizedLayout.value[activeType.value] || {}
84
+ })
85
+ const activeSections = computed(() => {
86
+ if (activeType.value === 'descriptions') return descriptionsLayoutSections
87
+ if (activeType.value === 'table') return tableLayoutSections
88
+ return containerLayoutSections
89
+ })
90
+ const activeProfileTitle = computed(() => {
91
+ if (activeType.value === 'descriptions') return '描述表配置'
92
+ if (activeType.value === 'table') return '表格配置'
93
+ return '栅格配置'
94
+ })
95
+ const activeValueMode = computed(() => (activeType.value === 'grid' ? 'nested' : 'flat'))
96
+ const getTableColumns = (layout: LayoutValue) => Math.max(2, Math.floor(Number(layout.table?.columns || 4)))
97
+ const getDefaultFieldColumns = (layout: LayoutValue) => Math.min(2, getTableColumns(layout))
98
+
99
+ const defaultProfile = (type: LayoutType, sourceLayout: LayoutValue) => {
100
+ if (type === 'grid') {
101
+ const sourceItemsPerRow = sourceLayout.table?.columns
102
+ ? Math.max(1, Math.floor(getTableColumns(sourceLayout) / getDefaultFieldColumns(sourceLayout)))
103
+ : sourceLayout.descriptions?.column || 3
104
+ return {
105
+ row: sourceLayout.grid?.row,
106
+ col: {
107
+ span: Math.max(1, Math.round(24 / sourceItemsPerRow))
108
+ }
109
+ }
110
+ }
111
+ if (type === 'descriptions') {
112
+ return {
113
+ column: sourceLayout.table?.columns
114
+ ? Math.max(1, Math.floor(getTableColumns(sourceLayout) / getDefaultFieldColumns(sourceLayout)))
115
+ : Math.round(24 / (sourceLayout.grid?.col?.span || 8)) || 3,
116
+ labelWidth: props.formSchema?.labelWidth
117
+ }
118
+ }
119
+ return {
120
+ columns: 4,
121
+ labelWidth: props.formSchema?.labelWidth,
122
+ valueMinWidth: 220
123
+ }
124
+ }
125
+
126
+ const clamp = (value: number, min: number, max: number) => Math.min(Math.max(value, min), max)
127
+
128
+ const getGridSpan = (item: any, layout: LayoutValue) => {
129
+ return item.layoutCfg?.grid?.span ?? item.span ?? layout.grid?.col?.span ?? layout.col?.span ?? 24
130
+ }
131
+
132
+ const getSourceUnits = (item: any, sourceType: LayoutType, layout: LayoutValue) => {
133
+ if (sourceType === 'table') {
134
+ const itemProfile = item.layoutCfg?.table || {}
135
+ const labelColspan = Math.max(1, Math.floor(Number(itemProfile.labelColspan || 1)))
136
+ const valueColspan = Math.max(1, Math.floor(Number(itemProfile.valueColspan || 1)))
137
+ return {
138
+ value: labelColspan + valueColspan,
139
+ total: getTableColumns(layout)
140
+ }
141
+ }
142
+ if (sourceType === 'descriptions') {
143
+ return {
144
+ value: item.layoutCfg?.descriptions?.span ?? 1,
145
+ total: layout.descriptions?.column ?? 3
146
+ }
147
+ }
148
+ return {
149
+ value: getGridSpan(item, layout),
150
+ total: 24
151
+ }
152
+ }
153
+
154
+ const ensureLayoutCfg = (item: any) => {
155
+ if (!item.layoutCfg || typeof item.layoutCfg !== 'object') {
156
+ item.layoutCfg = {}
157
+ }
158
+ return item.layoutCfg
159
+ }
160
+
161
+ const migrateItemToLayout = (item: any, sourceType: LayoutType, targetType: LayoutType, layout: LayoutValue) => {
162
+ const cfg = ensureLayoutCfg(item)
163
+ const source = getSourceUnits(item, sourceType, layout)
164
+ if (targetType === 'table') {
165
+ const columns = getTableColumns(layout)
166
+ const fieldColumns = clamp(Math.round((source.value / source.total) * columns), 2, columns)
167
+ cfg.table = {
168
+ ...(cfg.table || {}),
169
+ labelColspan: 1,
170
+ valueColspan: fieldColumns - 1
171
+ }
172
+ } else if (targetType === 'descriptions') {
173
+ const column = layout.descriptions?.column ?? defaultProfile('descriptions', layout).column ?? 3
174
+ cfg.descriptions = {
175
+ ...(cfg.descriptions || {}),
176
+ span: clamp(Math.round((source.value / source.total) * column), 1, column)
177
+ }
178
+ } else {
179
+ cfg.grid = {
180
+ ...(cfg.grid || {}),
181
+ span: clamp(Math.round((source.value / source.total) * 24), 1, 24)
182
+ }
183
+ }
184
+
185
+ if (Array.isArray(item.body)) {
186
+ item.body.forEach((child: any) => migrateItemToLayout(child, sourceType, targetType, layout))
187
+ }
188
+ }
189
+
190
+ const migrateBodyToLayout = (sourceType: LayoutType, targetType: LayoutType, layout: LayoutValue) => {
191
+ const body = props.formSchema?.body
192
+ if (!Array.isArray(body)) return
193
+ body.forEach((item) => migrateItemToLayout(item, sourceType, targetType, layout))
194
+ }
195
+
196
+ const emitLayout = (layout: LayoutValue) => {
197
+ const next = cleanRecord(layout) as LayoutValue | undefined
198
+ emit('update:modelValue', next)
199
+ }
200
+
201
+ const handleProfileChange = (profile: Record<string, any>) => {
202
+ const next = normalizeLegacyLayout(props.modelValue)
203
+ next[activeType.value] = profile
204
+ if (activeType.value === 'grid') {
205
+ delete next.row
206
+ delete next.col
207
+ }
208
+ emitLayout(next)
209
+ }
210
+
211
+ const handleTypeChange = async (nextTypeValue: string | number | boolean) => {
212
+ const nextType = nextTypeValue as LayoutType
213
+ if (nextType === activeType.value || !layoutTypes.includes(nextType)) return
214
+
215
+ const sourceType = activeType.value
216
+ const next = normalizeLegacyLayout(props.modelValue)
217
+ next.type = nextType
218
+
219
+ if (next[nextType]) {
220
+ emitLayout(next)
221
+ return
222
+ }
223
+
224
+ const targetProfile = defaultProfile(nextType, next)
225
+ try {
226
+ await ElMessageBox.confirm('目标布局还没有配置。是否保留当前布局方案,并根据当前字段比例近似生成目标布局配置?', '切换布局', {
227
+ confirmButtonText: '保留并迁移',
228
+ cancelButtonText: '仅切换',
229
+ distinguishCancelAndClose: true,
230
+ type: 'warning'
231
+ })
232
+ next[nextType] = targetProfile
233
+ migrateBodyToLayout(sourceType, nextType, next)
234
+ emitLayout(next)
235
+ } catch (action) {
236
+ if (action === 'cancel') {
237
+ next[nextType] = targetProfile
238
+ emitLayout(next)
239
+ }
240
+ }
241
+ }
242
+ </script>
243
+
244
+ <style scoped lang="scss">
245
+ .form-layout-editor {
246
+ width: 100%;
247
+ }
248
+
249
+ .form-layout-editor__header {
250
+ display: flex;
251
+ align-items: center;
252
+ justify-content: space-between;
253
+ gap: 8px;
254
+ margin-bottom: 8px;
255
+ }
256
+
257
+ .form-layout-editor__title {
258
+ min-width: 0;
259
+ color: var(--el-text-color-primary);
260
+ font-size: 13px;
261
+ font-weight: 600;
262
+ }
263
+ </style>
@@ -0,0 +1,75 @@
1
+ <template>
2
+ <ElSelect :model-value="currentValue" class="group-title-color-select" @change="handleChange">
3
+ <ElOption v-for="option in colorOptions" :key="option.value" :label="option.label" :value="option.value">
4
+ <span class="group-title-color-select__option">
5
+ <span class="group-title-color-select__swatch" :class="option.swatchClass" />
6
+ <span>{{ option.label }}</span>
7
+ </span>
8
+ </ElOption>
9
+ <template #label="{ label, value }">
10
+ <span class="group-title-color-select__selected">
11
+ <span class="group-title-color-select__swatch" :class="getSwatchClass(value)" />
12
+ <span>{{ label }}</span>
13
+ </span>
14
+ </template>
15
+ </ElSelect>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ import { computed } from 'vue'
20
+ import { ElOption, ElSelect } from 'element-plus'
21
+
22
+ const props = defineProps<{
23
+ modelValue?: string
24
+ }>()
25
+
26
+ const emit = defineEmits<{
27
+ (event: 'update:modelValue', value: string | undefined): void
28
+ }>()
29
+
30
+ const colorOptions = [
31
+ { label: '主题色', value: 'primary', swatchClass: 'is-primary' },
32
+ { label: '主文字', value: 'main', swatchClass: 'is-main' },
33
+ { label: '次文字', value: 'secondary', swatchClass: 'is-secondary' }
34
+ ]
35
+
36
+ const currentValue = computed(() => props.modelValue || 'main')
37
+ const getSwatchClass = (value: string) => colorOptions.find((option) => option.value === value)?.swatchClass
38
+
39
+ const handleChange = (value: string) => {
40
+ emit('update:modelValue', value === 'main' ? undefined : value)
41
+ }
42
+ </script>
43
+
44
+ <style scoped>
45
+ .group-title-color-select {
46
+ width: 100%;
47
+ }
48
+
49
+ .group-title-color-select__option,
50
+ .group-title-color-select__selected {
51
+ display: inline-flex;
52
+ align-items: center;
53
+ gap: 8px;
54
+ }
55
+
56
+ .group-title-color-select__swatch {
57
+ width: 14px;
58
+ height: 14px;
59
+ border: 1px solid var(--el-border-color);
60
+ border-radius: 3px;
61
+ flex: 0 0 auto;
62
+ }
63
+
64
+ .group-title-color-select__swatch.is-primary {
65
+ background: var(--el-color-primary);
66
+ }
67
+
68
+ .group-title-color-select__swatch.is-main {
69
+ background: var(--x-group-title-color-main, #333333);
70
+ }
71
+
72
+ .group-title-color-select__swatch.is-secondary {
73
+ background: var(--x-group-title-color-secondary, #666666);
74
+ }
75
+ </style>
@@ -0,0 +1,125 @@
1
+ <template>
2
+ <div class="group-title-style-picker">
3
+ <button class="group-title-style-picker__trigger" type="button" @click="dialogVisible = true">
4
+ <span class="group-title-style-picker__trigger-text">{{ currentStyle?.label || '选择标题样式' }}</span>
5
+ <span class="group-title-style-picker__trigger-sample" :class="modelValue">{{ previewTitle }}</span>
6
+ </button>
7
+
8
+ <ElDialog v-model="dialogVisible" title="选择标题样式" width="760px" append-to-body>
9
+ <div class="group-title-style-picker__grid">
10
+ <button
11
+ v-for="style in styles"
12
+ :key="style.key"
13
+ class="group-title-style-picker__card"
14
+ :class="{ 'is-active': style.className === normalizedValue }"
15
+ type="button"
16
+ @click="handleSelect(style.className)"
17
+ >
18
+ <span class="group-title-style-picker__preview" :class="style.className">{{ previewTitle }}</span>
19
+ <span class="group-title-style-picker__name">{{ style.label }}</span>
20
+ <span v-if="style.description" class="group-title-style-picker__description">{{ style.description }}</span>
21
+ </button>
22
+ </div>
23
+ </ElDialog>
24
+ </div>
25
+ </template>
26
+
27
+ <script setup lang="ts">
28
+ import { computed, inject, ref, type ComputedRef } from 'vue'
29
+ import { ElDialog } from 'element-plus'
30
+ import { getEditorGroupTitleStyles } from '../group-title-styles'
31
+
32
+ const props = defineProps<{
33
+ modelValue?: string
34
+ }>()
35
+
36
+ const emit = defineEmits<{
37
+ (event: 'update:modelValue', value: string | undefined): void
38
+ }>()
39
+
40
+ const editorContext = inject<ComputedRef<{ selectedItem?: any }> | null>('x-editor-context', null)
41
+ const dialogVisible = ref(false)
42
+
43
+ const styles = computed(() => getEditorGroupTitleStyles())
44
+ const normalizedValue = computed(() => props.modelValue || '')
45
+ const currentStyle = computed(() => styles.value.find((style) => style.className === normalizedValue.value))
46
+ const previewTitle = computed(() => editorContext?.value?.selectedItem?.title || '分组标题')
47
+
48
+ const handleSelect = (className: string) => {
49
+ emit('update:modelValue', className || undefined)
50
+ dialogVisible.value = false
51
+ }
52
+ </script>
53
+
54
+ <style scoped>
55
+ .group-title-style-picker {
56
+ width: 100%;
57
+ }
58
+
59
+ .group-title-style-picker__trigger {
60
+ display: grid;
61
+ width: 100%;
62
+ min-height: 40px;
63
+ padding: 8px 10px;
64
+ color: var(--el-text-color-primary);
65
+ text-align: left;
66
+ cursor: pointer;
67
+ background: var(--el-fill-color-blank);
68
+ border: 1px solid var(--el-border-color);
69
+ border-radius: 4px;
70
+ gap: 8px;
71
+ }
72
+
73
+ .group-title-style-picker__trigger:hover {
74
+ border-color: var(--el-color-primary);
75
+ }
76
+
77
+ .group-title-style-picker__trigger-text {
78
+ font-size: 12px;
79
+ color: var(--el-text-color-secondary);
80
+ }
81
+
82
+ .group-title-style-picker__trigger-sample {
83
+ display: block;
84
+ }
85
+
86
+ .group-title-style-picker__grid {
87
+ display: grid;
88
+ grid-template-columns: repeat(2, minmax(0, 1fr));
89
+ gap: 12px;
90
+ }
91
+
92
+ .group-title-style-picker__card {
93
+ display: grid;
94
+ min-height: 112px;
95
+ padding: 14px;
96
+ text-align: left;
97
+ cursor: pointer;
98
+ background: var(--el-fill-color-blank);
99
+ border: 1px solid var(--el-border-color);
100
+ border-radius: 6px;
101
+ gap: 8px;
102
+ }
103
+
104
+ .group-title-style-picker__card:hover,
105
+ .group-title-style-picker__card.is-active {
106
+ border-color: var(--el-color-primary);
107
+ box-shadow: 0 0 0 1px var(--el-color-primary-light-7);
108
+ }
109
+
110
+ .group-title-style-picker__preview {
111
+ display: block;
112
+ }
113
+
114
+ .group-title-style-picker__name {
115
+ font-size: 13px;
116
+ font-weight: 600;
117
+ color: var(--el-text-color-primary);
118
+ }
119
+
120
+ .group-title-style-picker__description {
121
+ font-size: 12px;
122
+ line-height: 1.4;
123
+ color: var(--el-text-color-secondary);
124
+ }
125
+ </style>
@@ -0,0 +1,226 @@
1
+ <template>
2
+ <div class="input-number-range-binding-editor">
3
+ <div class="input-number-range-binding-editor__header">
4
+ <div class="input-number-range-binding-editor__title">字段名</div>
5
+ <div v-if="allowTuple" class="input-number-range-binding-editor__tabs">
6
+ <button
7
+ v-for="option in modeOptions"
8
+ :key="option.value"
9
+ class="input-number-range-binding-editor__tab"
10
+ :class="{ 'is-active': option.value === bindingMode }"
11
+ type="button"
12
+ @click="handleModeChange(option.value)"
13
+ >
14
+ {{ option.label }}
15
+ </button>
16
+ </div>
17
+ </div>
18
+
19
+ <div class="input-number-range-binding-editor__panel">
20
+ <span class="input-number-range-binding-editor__corner" />
21
+ <div class="input-number-range-binding-editor__path">{{ bindingMode === 'tuple' ? 'name' : 'sync' }}</div>
22
+ <div v-if="bindingMode === 'tuple'" class="input-number-range-binding-editor__fields">
23
+ <label class="input-number-range-binding-editor__field">
24
+ <span class="input-number-range-binding-editor__field-label">字段名</span>
25
+ <ElInput :model-value="tupleField" placeholder="字段名" clearable @update:modelValue="handleTupleFieldChange" />
26
+ </label>
27
+ </div>
28
+ <div v-else class="input-number-range-binding-editor__fields">
29
+ <label class="input-number-range-binding-editor__field">
30
+ <span class="input-number-range-binding-editor__field-label">{{ startFieldLabel }}</span>
31
+ <ElInput :model-value="startField" :placeholder="startFieldPlaceholder" clearable @update:modelValue="handleStartFieldChange" />
32
+ </label>
33
+ <label class="input-number-range-binding-editor__field">
34
+ <span class="input-number-range-binding-editor__field-label">{{ endFieldLabel }}</span>
35
+ <ElInput :model-value="endField" :placeholder="endFieldPlaceholder" clearable @update:modelValue="handleEndFieldChange" />
36
+ </label>
37
+ </div>
38
+ </div>
39
+ </div>
40
+ </template>
41
+
42
+ <script setup lang="ts">
43
+ import { computed } from 'vue'
44
+ import { ElInput } from 'element-plus'
45
+
46
+ type BindingMode = 'tuple' | 'separate'
47
+
48
+ interface SyncItem {
49
+ name: string
50
+ syncName: string
51
+ }
52
+
53
+ const props = defineProps<{
54
+ modelValue?: SyncItem[]
55
+ name?: string
56
+ allowTuple?: boolean
57
+ defaultBaseName?: string
58
+ startFieldLabel?: string
59
+ endFieldLabel?: string
60
+ startPlaceholder?: string
61
+ endPlaceholder?: string
62
+ startSyncName?: string
63
+ endSyncName?: string
64
+ }>()
65
+
66
+ const emit = defineEmits<{
67
+ (event: 'update:modelValue', value: SyncItem[] | undefined): void
68
+ (event: 'update:name', value: string | undefined): void
69
+ }>()
70
+
71
+ const modeOptions: { label: string; value: BindingMode }[] = [
72
+ { label: '单字段', value: 'tuple' },
73
+ { label: '分别字段', value: 'separate' }
74
+ ]
75
+
76
+ const allowTuple = computed(() => props.allowTuple !== false)
77
+ const startSyncName = computed(() => props.startSyncName || 'startValue')
78
+ const endSyncName = computed(() => props.endSyncName || 'endValue')
79
+ const startFieldLabel = computed(() => props.startFieldLabel || '开始字段')
80
+ const endFieldLabel = computed(() => props.endFieldLabel || '结束字段')
81
+ const startFieldPlaceholder = computed(() => props.startPlaceholder || startFieldLabel.value)
82
+ const endFieldPlaceholder = computed(() => props.endPlaceholder || endFieldLabel.value)
83
+ const startSync = computed(() => props.modelValue?.find((item) => item.syncName === startSyncName.value))
84
+ const endSync = computed(() => props.modelValue?.find((item) => item.syncName === endSyncName.value))
85
+ const bindingMode = computed<BindingMode>(() => (!allowTuple.value || startSync.value || endSync.value ? 'separate' : 'tuple'))
86
+ const tupleField = computed(() => props.name || '')
87
+ const startField = computed(() => startSync.value?.name || '')
88
+ const endField = computed(() => endSync.value?.name || '')
89
+
90
+ const cleanField = (value: string) => value.trim()
91
+
92
+ const createSeparateSync = (startName: string, endName: string): SyncItem[] | undefined => {
93
+ const start = cleanField(startName)
94
+ const end = cleanField(endName)
95
+ const items: SyncItem[] = []
96
+ if (start) items.push({ name: start, syncName: startSyncName.value })
97
+ if (end) items.push({ name: end, syncName: endSyncName.value })
98
+ return items.length ? items : undefined
99
+ }
100
+
101
+ const createFieldName = (suffix: string) => {
102
+ const baseName = cleanField(props.name || props.defaultBaseName || 'range')
103
+ return baseName ? `${baseName}${suffix}` : ''
104
+ }
105
+
106
+ const handleModeChange = (mode: string | number | boolean | undefined) => {
107
+ if (mode === 'separate') {
108
+ emit('update:name', undefined)
109
+ emit('update:modelValue', createSeparateSync(startField.value || createFieldName('Start'), endField.value || createFieldName('End')))
110
+ return
111
+ }
112
+
113
+ if (allowTuple.value) {
114
+ emit('update:modelValue', undefined)
115
+ emit('update:name', cleanField(props.name || startField.value.replace(/Start$/, '') || props.defaultBaseName || 'range') || undefined)
116
+ }
117
+ }
118
+
119
+ const handleTupleFieldChange = (value: string) => {
120
+ emit('update:modelValue', undefined)
121
+ emit('update:name', cleanField(value) || undefined)
122
+ }
123
+
124
+ const handleStartFieldChange = (value: string) => {
125
+ emit('update:name', undefined)
126
+ emit('update:modelValue', createSeparateSync(value, endField.value))
127
+ }
128
+
129
+ const handleEndFieldChange = (value: string) => {
130
+ emit('update:name', undefined)
131
+ emit('update:modelValue', createSeparateSync(startField.value, value))
132
+ }
133
+ </script>
134
+
135
+ <style scoped lang="scss">
136
+ .input-number-range-binding-editor {
137
+ width: 100%;
138
+ }
139
+
140
+ .input-number-range-binding-editor__header {
141
+ display: flex;
142
+ align-items: center;
143
+ justify-content: flex-end;
144
+ gap: 8px;
145
+ margin-bottom: 8px;
146
+ }
147
+
148
+ .input-number-range-binding-editor__title {
149
+ flex: 1;
150
+ min-width: 0;
151
+ color: var(--el-text-color-primary);
152
+ font-size: 13px;
153
+ font-weight: 600;
154
+ }
155
+
156
+ .input-number-range-binding-editor__tabs {
157
+ display: flex;
158
+ flex: none;
159
+ gap: 4px;
160
+ }
161
+
162
+ .input-number-range-binding-editor__tab {
163
+ height: 24px;
164
+ padding: 0 10px;
165
+ color: var(--el-text-color-regular);
166
+ font-size: 12px;
167
+ line-height: 22px;
168
+ background: var(--el-fill-color-blank);
169
+ border: 1px solid var(--el-border-color);
170
+ border-radius: 4px;
171
+ cursor: pointer;
172
+ }
173
+
174
+ .input-number-range-binding-editor__tab.is-active {
175
+ color: var(--el-color-primary);
176
+ background: var(--el-color-primary-light-9);
177
+ border-color: var(--el-color-primary);
178
+ }
179
+
180
+ .input-number-range-binding-editor__panel {
181
+ position: relative;
182
+ padding: 28px 10px 10px;
183
+ background: var(--el-fill-color-light);
184
+ border: 1px solid var(--el-border-color-lighter);
185
+ border-radius: 6px;
186
+ }
187
+
188
+ .input-number-range-binding-editor__corner {
189
+ position: absolute;
190
+ top: 0;
191
+ right: 0;
192
+ width: 0;
193
+ height: 0;
194
+ border-top: 18px solid var(--el-color-primary-light-5);
195
+ border-left: 18px solid transparent;
196
+ }
197
+
198
+ .input-number-range-binding-editor__path {
199
+ position: absolute;
200
+ top: 7px;
201
+ right: 22px;
202
+ color: var(--el-text-color-secondary);
203
+ font-size: 11px;
204
+ line-height: 1;
205
+ }
206
+
207
+ .input-number-range-binding-editor__fields {
208
+ display: grid;
209
+ grid-template-columns: minmax(0, 1fr);
210
+ gap: 8px;
211
+ }
212
+
213
+ .input-number-range-binding-editor__field {
214
+ display: grid;
215
+ grid-template-columns: 64px minmax(0, 1fr);
216
+ align-items: center;
217
+ gap: 8px;
218
+ }
219
+
220
+ .input-number-range-binding-editor__field-label {
221
+ color: var(--el-text-color-regular);
222
+ font-size: 12px;
223
+ line-height: 24px;
224
+ text-align: right;
225
+ }
226
+ </style>