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,353 @@
1
+ <template>
2
+ <div class="table-columns-editor">
3
+ <x-input-array
4
+ :model-value="editableColumns"
5
+ id-field="__editorId"
6
+ label-position="top"
7
+ draggable
8
+ addable
9
+ deletable
10
+ show-footer-add-button
11
+ :use-scaffold-value="false"
12
+ use-layout
13
+ :layout="columnLayout"
14
+ :items="columnItems"
15
+ @update:modelValue="handleColumnsChange"
16
+ />
17
+
18
+ <div class="table-columns-editor__operation">
19
+ <div class="table-columns-editor__operation-main">
20
+ <span class="table-columns-editor__operation-title">操作列</span>
21
+ <el-switch v-model="operationVisible" @change="handleOperationChange" />
22
+ </div>
23
+ <el-input-number
24
+ v-if="operationVisible"
25
+ v-model="operationWidth"
26
+ :min="60"
27
+ :step="10"
28
+ controls-position="right"
29
+ size="small"
30
+ @change="handleOperationChange"
31
+ />
32
+ <div v-if="operationVisible" class="table-columns-editor__operation-actions">
33
+ <label class="table-columns-editor__operation-action">
34
+ <span>新增</span>
35
+ <el-switch v-model="operationActions.add" @change="handleOperationChange" />
36
+ </label>
37
+ <label class="table-columns-editor__operation-action">
38
+ <span>删除</span>
39
+ <el-switch v-model="operationActions.delete" @change="handleOperationChange" />
40
+ </label>
41
+ <label class="table-columns-editor__operation-action">
42
+ <span>新增子项</span>
43
+ <el-switch v-model="operationActions.addChild" @change="handleOperationChange" />
44
+ </label>
45
+ </div>
46
+ </div>
47
+ </div>
48
+ </template>
49
+
50
+ <script setup lang="ts">
51
+ import { ref, watch } from 'vue'
52
+ import { ElInputNumber, ElSwitch } from 'element-plus'
53
+ import { XInputArray, genId } from 'xkit-ui'
54
+
55
+ type TableColumn = Record<string, any>
56
+
57
+ const EDITOR_ID_FIELD = '__editorId'
58
+
59
+ const props = defineProps<{
60
+ modelValue?: TableColumn[]
61
+ }>()
62
+
63
+ const emit = defineEmits<{
64
+ (e: 'update:modelValue', value: TableColumn[]): void
65
+ }>()
66
+
67
+ const componentTypeOptions = [
68
+ { label: '输入框', value: 'input' },
69
+ { label: '多行文本', value: 'textarea' },
70
+ { label: '数字输入', value: 'input-number' },
71
+ { label: '下拉框', value: 'select' },
72
+ { label: '单选框', value: 'x-radios' },
73
+ { label: '复选框组', value: 'checkbox' },
74
+ { label: '开关', value: 'switch' },
75
+ { label: '日期选择', value: 'date-picker' },
76
+ { label: '图标选择', value: 'x-icon-select' },
77
+ { label: '文件上传', value: 'x-input-upload' }
78
+ ]
79
+
80
+ const optionComponentTypes = new Set(['select', 'x-radios', 'checkbox'])
81
+ const columnLayout = {
82
+ row: { gutter: 8 },
83
+ col: { span: 8 }
84
+ }
85
+
86
+ const columnItems: any[] = [
87
+ {
88
+ label: false,
89
+ name: 'label',
90
+ type: 'input',
91
+ clearable: false,
92
+ placeholder: '列标题',
93
+ span: 8
94
+ },
95
+ {
96
+ label: false,
97
+ name: 'name',
98
+ type: 'input',
99
+ clearable: false,
100
+ placeholder: '字段名',
101
+ span: 8
102
+ },
103
+ {
104
+ label: false,
105
+ name: 'type',
106
+ type: 'select',
107
+ clearable: false,
108
+ placeholder: '组件',
109
+ options: componentTypeOptions,
110
+ span: 8
111
+ },
112
+ // {
113
+ // label: false,
114
+ // name: 'width',
115
+ // type: 'input-number',
116
+ // min: 60,
117
+ // step: 10,
118
+ // controlsPosition: 'right',
119
+ // placeholder: '宽度',
120
+ // span: 8
121
+ // },
122
+ // {
123
+ // label: false,
124
+ // name: 'placeholder',
125
+ // type: 'input',
126
+ // placeholder: '占位提示',
127
+ // span: 16
128
+ // },
129
+ {
130
+ label: '选项',
131
+ name: 'options',
132
+ type: 'x-input-array',
133
+ labelPosition: 'top',
134
+ useScaffoldValue: false,
135
+ showFooterAddButton: true,
136
+ addable: true,
137
+ deletable: true,
138
+ visible(row: TableColumn) {
139
+ return optionComponentTypes.has(row.type)
140
+ },
141
+ items: [
142
+ {
143
+ label: false,
144
+ name: 'label',
145
+ type: 'input',
146
+ clearable: false,
147
+ placeholder: '选项名称'
148
+ },
149
+ {
150
+ label: false,
151
+ name: 'value',
152
+ type: 'input',
153
+ clearable: false,
154
+ placeholder: '选项值'
155
+ }
156
+ ]
157
+ }
158
+ ]
159
+
160
+ const editableColumns = ref<TableColumn[]>([])
161
+ const operationVisible = ref(true)
162
+ const operationWidth = ref(100)
163
+ const operationActions = ref({
164
+ add: true,
165
+ delete: true,
166
+ addChild: false
167
+ })
168
+ let syncingFromModel = false
169
+ let emitQueued = false
170
+ let queuedColumns: TableColumn[] | undefined
171
+
172
+ const normalizeEditableColumn = (column: TableColumn, index: number, fallbackEditorId?: string): TableColumn => ({
173
+ label: column.label || `列${index + 1}`,
174
+ name: column.name || `field${index + 1}`,
175
+ type: column.type || 'input',
176
+ width: column.width ?? 160,
177
+ ...column,
178
+ [EDITOR_ID_FIELD]: column[EDITOR_ID_FIELD] || fallbackEditorId || genId('editor_table_column')
179
+ })
180
+
181
+ const cleanColumn = (column: TableColumn): TableColumn => {
182
+ const { [EDITOR_ID_FIELD]: _editorId, id: _id, ...rest } = column
183
+ const result: TableColumn = { ...rest }
184
+
185
+ if (!optionComponentTypes.has(result.type)) {
186
+ delete result.options
187
+ }
188
+ if (result.width === '' || result.width == null) {
189
+ delete result.width
190
+ }
191
+ if (result.placeholder === '') {
192
+ delete result.placeholder
193
+ }
194
+
195
+ return result
196
+ }
197
+
198
+ const createActionItem = (action: 'add' | 'delete' | 'add-child') => {
199
+ const labelMap = {
200
+ add: '新增',
201
+ delete: '删除',
202
+ 'add-child': '新增子项'
203
+ }
204
+ return { type: 'link', action, label: labelMap[action] }
205
+ }
206
+
207
+ const normalizeOperationActionState = (actions: unknown) => {
208
+ const actionList = Array.isArray(actions) ? actions : []
209
+ return {
210
+ add: actionList.length === 0 || actionList.some((item) => item?.action === 'add' || item === 'add'),
211
+ delete: actionList.length === 0 || actionList.some((item) => item?.action === 'delete' || item === 'delete'),
212
+ addChild: actionList.some((item) => item?.action === 'add-child' || item === 'add-child')
213
+ }
214
+ }
215
+
216
+ const createOperationActions = () => {
217
+ const result: TableColumn[] = []
218
+ if (operationActions.value.add) result.push(createActionItem('add'))
219
+ if (operationActions.value.delete) result.push(createActionItem('delete'))
220
+ if (operationActions.value.addChild) result.push(createActionItem('add-child'))
221
+ return result
222
+ }
223
+
224
+ const createOperationColumn = (): TableColumn => {
225
+ const actions = createOperationActions()
226
+ return {
227
+ label: '操作',
228
+ type: 'operation',
229
+ width: operationWidth.value,
230
+ actions
231
+ }
232
+ }
233
+
234
+ const normalizeOutputColumns = (value: TableColumn[] | undefined) => {
235
+ const source = Array.isArray(value) ? value : []
236
+ const operationColumn = source.find((item) => item.type === 'operation')
237
+ const columns = source.filter((item) => item.type !== 'operation').map(cleanColumn)
238
+ if (operationColumn) {
239
+ columns.push({
240
+ ...cleanColumn(operationColumn),
241
+ actions: Array.isArray(operationColumn.actions) ? operationColumn.actions : createOperationColumn().actions
242
+ })
243
+ }
244
+ return columns
245
+ }
246
+
247
+ const isSameColumns = (left: TableColumn[] | undefined, right: TableColumn[] | undefined) => {
248
+ return JSON.stringify(normalizeOutputColumns(left)) === JSON.stringify(normalizeOutputColumns(right))
249
+ }
250
+
251
+ const createOutputColumns = (columns: TableColumn[]) => {
252
+ const result = columns.map((column, index) => cleanColumn(normalizeEditableColumn(column, index)))
253
+ if (operationVisible.value) {
254
+ result.push(createOperationColumn())
255
+ }
256
+ return result
257
+ }
258
+
259
+ const syncFromModelValue = (value: TableColumn[] | undefined) => {
260
+ const source = Array.isArray(value) ? value : []
261
+ const previousColumns = editableColumns.value
262
+ const operationColumn = source.find((item) => item.type === 'operation')
263
+ operationVisible.value = source.length === 0 || Boolean(operationColumn)
264
+ operationWidth.value = Number(operationColumn?.width) || 100
265
+ operationActions.value = normalizeOperationActionState(operationColumn?.actions)
266
+ syncingFromModel = true
267
+ editableColumns.value = source
268
+ .filter((item) => item.type !== 'operation')
269
+ .map((column, index) => normalizeEditableColumn(column, index, previousColumns[index]?.[EDITOR_ID_FIELD]))
270
+ syncingFromModel = false
271
+ }
272
+
273
+ watch(
274
+ () => props.modelValue,
275
+ (value) => {
276
+ syncFromModelValue(value)
277
+ },
278
+ { immediate: true }
279
+ )
280
+
281
+ const emitColumns = (sourceColumns = editableColumns.value) => {
282
+ if (syncingFromModel) return
283
+
284
+ const columns = createOutputColumns(sourceColumns)
285
+ if (isSameColumns(props.modelValue, columns)) return
286
+
287
+ queuedColumns = columns
288
+ if (emitQueued) return
289
+
290
+ emitQueued = true
291
+ queueMicrotask(() => {
292
+ emitQueued = false
293
+ const nextColumns = queuedColumns
294
+ queuedColumns = undefined
295
+ if (!nextColumns || isSameColumns(props.modelValue, nextColumns)) return
296
+ emit('update:modelValue', nextColumns)
297
+ })
298
+ }
299
+
300
+ const handleColumnsChange = (value: TableColumn[]) => {
301
+ emitColumns(value)
302
+ }
303
+
304
+ const handleOperationChange = () => {
305
+ emitColumns()
306
+ }
307
+ </script>
308
+
309
+ <style scoped lang="scss">
310
+ .table-columns-editor {
311
+ width: 100%;
312
+ }
313
+
314
+ .table-columns-editor__operation {
315
+ margin-top: 12px;
316
+ padding-top: 12px;
317
+ border-top: 1px solid var(--el-border-color-lighter);
318
+ display: grid;
319
+ grid-template-columns: 1fr auto;
320
+ gap: 8px;
321
+ align-items: center;
322
+ }
323
+
324
+ .table-columns-editor__operation-main {
325
+ display: flex;
326
+ align-items: center;
327
+ gap: 8px;
328
+ min-width: 0;
329
+ }
330
+
331
+ .table-columns-editor__operation-actions {
332
+ grid-column: 1 / -1;
333
+ display: grid;
334
+ grid-template-columns: repeat(3, minmax(0, 1fr));
335
+ gap: 8px;
336
+ }
337
+
338
+ .table-columns-editor__operation-action {
339
+ min-width: 0;
340
+ display: flex;
341
+ align-items: center;
342
+ justify-content: space-between;
343
+ gap: 8px;
344
+ color: var(--el-text-color-regular);
345
+ font-size: 12px;
346
+ }
347
+
348
+ .table-columns-editor__operation-title {
349
+ color: var(--el-text-color-primary);
350
+ font-size: 13px;
351
+ font-weight: 600;
352
+ }
353
+ </style>
@@ -0,0 +1,321 @@
1
+ <template>
2
+ <div class="validation-rules-editor">
3
+ <div class="validation-rules-editor__section">
4
+ <div class="validation-rules-editor__row">
5
+ <span class="validation-rules-editor__label">是否必填</span>
6
+ <el-switch v-model="requiredEnabled" @change="() => emitRules()" />
7
+ </div>
8
+ <el-input
9
+ v-if="requiredEnabled"
10
+ v-model="requiredMessage"
11
+ size="small"
12
+ placeholder="必填提示"
13
+ @change="() => emitRules()"
14
+ />
15
+ </div>
16
+
17
+ <div class="validation-rules-editor__section">
18
+ <span class="validation-rules-editor__title">预置规则</span>
19
+ <el-select
20
+ v-model="selectedPresetTypes"
21
+ multiple
22
+ collapse-tags
23
+ collapse-tags-tooltip
24
+ clearable
25
+ size="small"
26
+ placeholder="请选择预置规则"
27
+ @change="() => emitRules()"
28
+ >
29
+ <el-option v-for="preset in presets" :key="preset.type" :label="preset.label" :value="preset.type" />
30
+ </el-select>
31
+ </div>
32
+
33
+ <div class="validation-rules-editor__section">
34
+ <span class="validation-rules-editor__title">自定义规则</span>
35
+ <x-input-array
36
+ :model-value="editableCustomRules"
37
+ id-field="__editorId"
38
+ label-position="top"
39
+ addable
40
+ deletable
41
+ draggable
42
+ show-footer-add-button
43
+ :use-scaffold-value="false"
44
+ use-layout
45
+ :layout="customRuleLayout"
46
+ :items="customRuleItems"
47
+ @update:modelValue="handleCustomRulesChange"
48
+ />
49
+ </div>
50
+ </div>
51
+ </template>
52
+
53
+ <script setup lang="ts">
54
+ import { computed, ref, watch } from 'vue'
55
+ import { ElInput, ElOption, ElSelect, ElSwitch } from 'element-plus'
56
+ import { XInputArray, genId } from 'xkit-ui'
57
+ import type { FormItemRule } from 'element-plus'
58
+ import { getEditorValidationRulePreset, getEditorValidationRulePresets } from '../validation-rules'
59
+
60
+ type RuleRecord = FormItemRule & Record<string, any>
61
+ type EditableCustomRule = {
62
+ __editorId?: string
63
+ mode?: 'pattern' | 'expression'
64
+ pattern?: string
65
+ validatorExpression?: string
66
+ message?: string
67
+ trigger?: string
68
+ }
69
+
70
+ const EDITOR_ID_FIELD = '__editorId'
71
+ const PRESET_FIELD = 'editorPresetType'
72
+ const customRuleLayout = {
73
+ row: { gutter: 8 },
74
+ col: { span: 8 }
75
+ }
76
+
77
+ const props = defineProps<{
78
+ modelValue?: RuleRecord | RuleRecord[]
79
+ }>()
80
+
81
+ const emit = defineEmits<{
82
+ (e: 'update:modelValue', value: RuleRecord[] | undefined): void
83
+ }>()
84
+
85
+ const requiredEnabled = ref(false)
86
+ const requiredMessage = ref('')
87
+ const selectedPresetTypes = ref<string[]>([])
88
+ const editableCustomRules = ref<EditableCustomRule[]>([])
89
+ let syncingFromModel = false
90
+ let emitQueued = false
91
+ let queuedRules: RuleRecord[] | undefined
92
+
93
+ const presets = computed(() => getEditorValidationRulePresets())
94
+
95
+ const customRuleItems: any[] = [
96
+ {
97
+ label: false,
98
+ name: 'mode',
99
+ type: 'select',
100
+ clearable: false,
101
+ placeholder: '规则类型',
102
+ options: [
103
+ { label: '正则', value: 'pattern' },
104
+ { label: '表达式', value: 'expression' }
105
+ ],
106
+ span: 8
107
+ },
108
+ {
109
+ label: false,
110
+ name: 'trigger',
111
+ type: 'select',
112
+ placeholder: '触发',
113
+ options: [
114
+ { label: '失焦', value: 'blur' },
115
+ { label: '变更', value: 'change' }
116
+ ],
117
+ span: 8
118
+ },
119
+ {
120
+ label: false,
121
+ name: 'message',
122
+ type: 'input',
123
+ placeholder: '错误提示',
124
+ span: 8
125
+ },
126
+ {
127
+ label: false,
128
+ name: 'pattern',
129
+ type: 'input',
130
+ placeholder: '正则,例如 ^[A-Z]+$ 或 /abc/i',
131
+ visible(row: EditableCustomRule) {
132
+ return (row.mode || 'pattern') === 'pattern'
133
+ }
134
+ },
135
+ {
136
+ label: false,
137
+ name: 'validatorExpression',
138
+ type: 'textarea',
139
+ placeholder: '表达式,例如 value > 0 && form.type === "A"',
140
+ visible(row: EditableCustomRule) {
141
+ return row.mode === 'expression'
142
+ }
143
+ }
144
+ ]
145
+
146
+ const normalizeRuleList = (value: RuleRecord | RuleRecord[] | undefined) => {
147
+ if (!value) return []
148
+ return Array.isArray(value) ? value : [value]
149
+ }
150
+
151
+ const isRequiredRule = (rule: RuleRecord) => Boolean(rule.required)
152
+
153
+ const isPresetRule = (rule: RuleRecord) => typeof rule[PRESET_FIELD] === 'string'
154
+
155
+ const isCustomRule = (rule: RuleRecord) => !isRequiredRule(rule) && !isPresetRule(rule)
156
+
157
+ const toStringValue = (value: unknown) => (typeof value === 'string' ? value : '')
158
+
159
+ const toTriggerValue = (value: unknown) => {
160
+ if (typeof value === 'string') return value
161
+ if (Array.isArray(value) && typeof value[0] === 'string') return value[0]
162
+ return 'blur'
163
+ }
164
+
165
+ const toPatternValue = (value: unknown) => {
166
+ if (typeof value === 'string') return value
167
+ if (value instanceof RegExp) return value.toString()
168
+ return ''
169
+ }
170
+
171
+ const normalizeEditableCustomRule = (
172
+ rule: RuleRecord | EditableCustomRule,
173
+ index: number,
174
+ fallbackEditorId?: string
175
+ ): EditableCustomRule => ({
176
+ ...rule,
177
+ mode: rule.validatorExpression ? 'expression' : 'pattern',
178
+ trigger: toTriggerValue(rule.trigger),
179
+ message: toStringValue(rule.message),
180
+ pattern: toPatternValue(rule.pattern),
181
+ validatorExpression: toStringValue(rule.validatorExpression),
182
+ [EDITOR_ID_FIELD]: rule[EDITOR_ID_FIELD] || fallbackEditorId || genId(`editor_validation_rule_${index}`)
183
+ })
184
+
185
+ const cleanCustomRule = (rule: EditableCustomRule): RuleRecord | undefined => {
186
+ const { [EDITOR_ID_FIELD]: _editorId, mode = 'pattern', pattern, validatorExpression, message, trigger } = rule
187
+ const result: RuleRecord = {}
188
+
189
+ if (message) result.message = message
190
+ if (trigger) result.trigger = trigger
191
+
192
+ if (mode === 'expression') {
193
+ const expression = validatorExpression?.trim()
194
+ if (!expression) return undefined
195
+ result.validatorExpression = expression
196
+ result.message ||= '校验未通过'
197
+ return result
198
+ }
199
+
200
+ const patternValue = pattern?.trim()
201
+ if (!patternValue) return undefined
202
+ result.pattern = patternValue
203
+ result.message ||= '格式不正确'
204
+ return result
205
+ }
206
+
207
+ const createRequiredRule = (): RuleRecord | undefined => {
208
+ if (!requiredEnabled.value) return undefined
209
+ return {
210
+ required: true,
211
+ message: requiredMessage.value || '此项为必填项',
212
+ trigger: 'blur'
213
+ }
214
+ }
215
+
216
+ const createPresetRules = () => {
217
+ return selectedPresetTypes.value
218
+ .map((type) => {
219
+ const preset = getEditorValidationRulePreset(type)
220
+ return preset
221
+ ? {
222
+ ...preset.rule,
223
+ [PRESET_FIELD]: preset.type
224
+ }
225
+ : undefined
226
+ })
227
+ .filter(Boolean) as RuleRecord[]
228
+ }
229
+
230
+ const createOutputRules = (customRules = editableCustomRules.value) => {
231
+ const rules = [
232
+ createRequiredRule(),
233
+ ...createPresetRules(),
234
+ ...customRules.map(cleanCustomRule)
235
+ ].filter(Boolean) as RuleRecord[]
236
+ return rules.length > 0 ? rules : undefined
237
+ }
238
+
239
+ const normalizeOutputRules = (value: RuleRecord[] | undefined) => value ?? []
240
+
241
+ const isSameRules = (left: RuleRecord[] | undefined, right: RuleRecord[] | undefined) => {
242
+ return JSON.stringify(normalizeOutputRules(left)) === JSON.stringify(normalizeOutputRules(right))
243
+ }
244
+
245
+ const syncFromModelValue = (value: RuleRecord | RuleRecord[] | undefined) => {
246
+ const rules = normalizeRuleList(value)
247
+ const requiredRule = rules.find(isRequiredRule)
248
+ const previousCustomRules = editableCustomRules.value
249
+
250
+ syncingFromModel = true
251
+ requiredEnabled.value = Boolean(requiredRule)
252
+ requiredMessage.value = typeof requiredRule?.message === 'string' ? requiredRule.message : ''
253
+ selectedPresetTypes.value = rules.map((rule) => rule[PRESET_FIELD]).filter((type): type is string => typeof type === 'string')
254
+ editableCustomRules.value = rules
255
+ .filter(isCustomRule)
256
+ .map((rule, index) => normalizeEditableCustomRule(rule, index, previousCustomRules[index]?.[EDITOR_ID_FIELD]))
257
+ syncingFromModel = false
258
+ }
259
+
260
+ const emitRules = (customRules = editableCustomRules.value) => {
261
+ if (syncingFromModel) return
262
+
263
+ const nextRules = createOutputRules(customRules)
264
+ if (isSameRules(normalizeRuleList(props.modelValue), nextRules)) return
265
+
266
+ queuedRules = nextRules
267
+ if (emitQueued) return
268
+
269
+ emitQueued = true
270
+ queueMicrotask(() => {
271
+ emitQueued = false
272
+ const rules = queuedRules
273
+ queuedRules = undefined
274
+ if (isSameRules(normalizeRuleList(props.modelValue), rules)) return
275
+ emit('update:modelValue', rules)
276
+ })
277
+ }
278
+
279
+ const handleCustomRulesChange = (value: EditableCustomRule[]) => {
280
+ editableCustomRules.value = value.map((rule, index) => normalizeEditableCustomRule(rule, index))
281
+ emitRules(editableCustomRules.value)
282
+ }
283
+
284
+ watch(
285
+ () => props.modelValue,
286
+ (value) => {
287
+ syncFromModelValue(value)
288
+ },
289
+ { immediate: true }
290
+ )
291
+ </script>
292
+
293
+ <style scoped lang="scss">
294
+ .validation-rules-editor {
295
+ width: 100%;
296
+ display: grid;
297
+ gap: 12px;
298
+ }
299
+
300
+ .validation-rules-editor__section {
301
+ display: grid;
302
+ gap: 8px;
303
+ }
304
+
305
+ .validation-rules-editor__row {
306
+ display: flex;
307
+ align-items: center;
308
+ justify-content: space-between;
309
+ gap: 8px;
310
+ }
311
+
312
+ .validation-rules-editor__label,
313
+ .validation-rules-editor__title {
314
+ color: var(--el-text-color-regular);
315
+ font-size: 13px;
316
+ }
317
+
318
+ .validation-rules-editor__title {
319
+ font-weight: 600;
320
+ }
321
+ </style>