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,5 @@
1
+ declare module '*.vue' {
2
+ import type { DefineComponent } from 'vue'
3
+ const component: DefineComponent<{}, {}, any>
4
+ export default component
5
+ }
@@ -0,0 +1,129 @@
1
+ import { describe, expect, it } from 'vitest'
2
+ import type { ComponentConfig } from '../../component-configs/types'
3
+ import { EDITOR_ID_FIELD } from '../editor-schema'
4
+ import { createReplacementNode, isReplaceableComponentConfig } from '../component-replace'
5
+
6
+ const inputConfig: ComponentConfig = {
7
+ label: '输入框',
8
+ value: 'input',
9
+ icon: 'input',
10
+ scaffold: {
11
+ type: 'input',
12
+ label: '输入框',
13
+ placeholder: '请输入内容'
14
+ },
15
+ replace: {
16
+ groups: ['placeholder', 'lengthLimit']
17
+ },
18
+ configSchema: {
19
+ body: []
20
+ }
21
+ }
22
+
23
+ const selectConfig: ComponentConfig = {
24
+ label: '下拉框',
25
+ value: 'select',
26
+ icon: 'select',
27
+ scaffold: {
28
+ type: 'select',
29
+ label: '下拉框',
30
+ options: []
31
+ },
32
+ replace: {
33
+ groups: ['options', 'placeholder']
34
+ },
35
+ configSchema: {
36
+ body: []
37
+ }
38
+ }
39
+
40
+ const radioConfig: ComponentConfig = {
41
+ label: '单选框',
42
+ value: 'x-radios',
43
+ icon: 'radio',
44
+ scaffold: {
45
+ type: 'x-radios',
46
+ label: '单选框',
47
+ options: []
48
+ },
49
+ replace: {
50
+ groups: ['options']
51
+ },
52
+ configSchema: {
53
+ body: []
54
+ }
55
+ }
56
+
57
+ describe('component replacement', () => {
58
+ it('preserves common form item fields and editor id', () => {
59
+ const result = createReplacementNode({
60
+ source: {
61
+ type: 'input',
62
+ name: 'username',
63
+ label: '用户名',
64
+ span: 12,
65
+ visible: { type: 'expression', expression: 'showName' },
66
+ _id: 'runtime',
67
+ [EDITOR_ID_FIELD]: 'field'
68
+ },
69
+ sourceConfig: inputConfig,
70
+ targetConfig: selectConfig
71
+ })
72
+
73
+ expect(result).toMatchObject({
74
+ type: 'select',
75
+ name: 'username',
76
+ label: '用户名',
77
+ span: 12,
78
+ visible: { type: 'expression', expression: 'showName' },
79
+ [EDITOR_ID_FIELD]: 'field'
80
+ })
81
+ expect(result._id).toBeUndefined()
82
+ expect(result.id).toBeUndefined()
83
+ })
84
+
85
+ it('keeps option fields only between option-compatible components', () => {
86
+ const source = {
87
+ type: 'select',
88
+ name: 'status',
89
+ options: [{ label: '启用', value: 'enabled' }],
90
+ placeholder: '请选择'
91
+ }
92
+
93
+ expect(
94
+ createReplacementNode({
95
+ source,
96
+ sourceConfig: selectConfig,
97
+ targetConfig: radioConfig
98
+ }).options
99
+ ).toEqual([{ label: '启用', value: 'enabled' }])
100
+
101
+ const inputResult = createReplacementNode({
102
+ source,
103
+ sourceConfig: selectConfig,
104
+ targetConfig: inputConfig
105
+ })
106
+ expect(inputResult.options).toBeUndefined()
107
+ expect(inputResult.placeholder).toBe('请选择')
108
+ })
109
+
110
+ it('starts from target scaffold for target-only defaults', () => {
111
+ const result = createReplacementNode({
112
+ source: {
113
+ type: 'select',
114
+ label: '状态'
115
+ },
116
+ sourceConfig: selectConfig,
117
+ targetConfig: inputConfig
118
+ })
119
+
120
+ expect(result.type).toBe('input')
121
+ expect(result.label).toBe('状态')
122
+ expect(result.placeholder).toBe('请输入内容')
123
+ })
124
+
125
+ it('does not allow container configs as replaceable targets', () => {
126
+ expect(isReplaceableComponentConfig({ ...inputConfig, editorKind: 'container' })).toBe(false)
127
+ expect(isReplaceableComponentConfig(inputConfig)).toBe(true)
128
+ })
129
+ })
@@ -0,0 +1,429 @@
1
+ import { describe, expect, it } from 'vitest'
2
+ import {
3
+ EDITOR_ID_FIELD,
4
+ assignNewEditorIdsDeep,
5
+ findByEditorId,
6
+ getArrayByEditorPath,
7
+ getByEditorPath,
8
+ insertAtEditorPath,
9
+ insertAfterEditorId,
10
+ moveAcrossEditorPaths,
11
+ moveWithinEditorPath,
12
+ normalizeEditorIds,
13
+ preserveUneditedChildCollections,
14
+ removeByEditorId,
15
+ stripEditorMetaDeep,
16
+ stripRuntimeMetaDeep,
17
+ updateByEditorId
18
+ } from '../editor-schema'
19
+
20
+ const createId = () => {
21
+ let index = 0
22
+ return () => `editor_${++index}`
23
+ }
24
+
25
+ describe('editor schema tree utilities', () => {
26
+ it('normalizes editor ids recursively without mutating existing ids', () => {
27
+ const nextId = createId()
28
+ const source = [
29
+ {
30
+ type: 'group',
31
+ body: [
32
+ { type: 'input' },
33
+ { type: 'select', [EDITOR_ID_FIELD]: 'kept' }
34
+ ]
35
+ }
36
+ ]
37
+
38
+ const result = normalizeEditorIds(source, nextId)
39
+
40
+ expect(result.changed).toBe(true)
41
+ expect(result.items[0][EDITOR_ID_FIELD]).toBe('editor_1')
42
+ expect(result.items[0].body[0][EDITOR_ID_FIELD]).toBe('editor_2')
43
+ expect(result.items[0].body[1][EDITOR_ID_FIELD]).toBe('kept')
44
+ expect(source[0][EDITOR_ID_FIELD]).toBeUndefined()
45
+ })
46
+
47
+ it('normalizes editor ids inside input table items', () => {
48
+ const nextId = createId()
49
+ const source = [
50
+ {
51
+ type: 'x-input-table',
52
+ items: [
53
+ { type: 'input', name: 'name' },
54
+ { type: 'operation' }
55
+ ]
56
+ }
57
+ ]
58
+
59
+ const result = normalizeEditorIds(source, nextId)
60
+
61
+ expect(result.changed).toBe(true)
62
+ expect(result.items[0][EDITOR_ID_FIELD]).toBe('editor_1')
63
+ expect(result.items[0].items[0][EDITOR_ID_FIELD]).toBe('editor_2')
64
+ expect(result.items[0].items[1][EDITOR_ID_FIELD]).toBe('editor_3')
65
+ })
66
+
67
+ it('updates nested nodes by editor id', () => {
68
+ const source = [
69
+ {
70
+ type: 'group',
71
+ [EDITOR_ID_FIELD]: 'group',
72
+ body: [{ type: 'input', name: 'old', [EDITOR_ID_FIELD]: 'field' }]
73
+ }
74
+ ]
75
+
76
+ const result = updateByEditorId(source, 'field', { type: 'input', name: 'next', [EDITOR_ID_FIELD]: 'field' })
77
+
78
+ expect(result.changed).toBe(true)
79
+ expect(result.items[0].body[0].name).toBe('next')
80
+ expect(source[0].body[0].name).toBe('old')
81
+ })
82
+
83
+ it('updates input table columns by editor id', () => {
84
+ const source = [
85
+ {
86
+ type: 'x-input-table',
87
+ [EDITOR_ID_FIELD]: 'table',
88
+ items: [{ type: 'input', name: 'old', [EDITOR_ID_FIELD]: 'column' }]
89
+ }
90
+ ]
91
+
92
+ const result = updateByEditorId(source, 'column', { type: 'select', name: 'next', [EDITOR_ID_FIELD]: 'column' })
93
+
94
+ expect(result.changed).toBe(true)
95
+ expect(result.items[0].items[0]).toMatchObject({ type: 'select', name: 'next' })
96
+ expect(source[0].items[0].name).toBe('old')
97
+ })
98
+
99
+ it('finds nodes and preserves child collections that the active config does not edit', () => {
100
+ const source = [
101
+ {
102
+ type: 'group',
103
+ title: '基础信息',
104
+ [EDITOR_ID_FIELD]: 'group',
105
+ body: [{ type: 'input', name: 'name', [EDITOR_ID_FIELD]: 'field' }]
106
+ }
107
+ ]
108
+ const previousNode = findByEditorId(source, 'group')
109
+ const nextNode = preserveUneditedChildCollections(
110
+ previousNode,
111
+ {
112
+ type: 'group',
113
+ title: '基础信息',
114
+ titleClass: 'x-group-title--gradient-bar',
115
+ [EDITOR_ID_FIELD]: 'group'
116
+ },
117
+ new Set(['titleClass'])
118
+ )
119
+
120
+ expect(nextNode.body).toEqual(source[0].body)
121
+ expect(nextNode.titleClass).toBe('x-group-title--gradient-bar')
122
+ })
123
+
124
+ it('allows edited child collections to be replaced', () => {
125
+ const previousNode = {
126
+ type: 'x-input-table',
127
+ [EDITOR_ID_FIELD]: 'table',
128
+ items: [{ type: 'input', name: 'old' }]
129
+ }
130
+ const nextNode = preserveUneditedChildCollections(
131
+ previousNode,
132
+ {
133
+ type: 'x-input-table',
134
+ [EDITOR_ID_FIELD]: 'table',
135
+ items: [{ type: 'select', name: 'next' }]
136
+ },
137
+ new Set(['items'])
138
+ )
139
+
140
+ expect(nextNode.items).toEqual([{ type: 'select', name: 'next' }])
141
+ })
142
+
143
+ it('removes nested nodes by editor id', () => {
144
+ const source = [
145
+ {
146
+ type: 'group',
147
+ [EDITOR_ID_FIELD]: 'group',
148
+ body: [
149
+ { type: 'input', [EDITOR_ID_FIELD]: 'a' },
150
+ { type: 'select', [EDITOR_ID_FIELD]: 'b' }
151
+ ]
152
+ }
153
+ ]
154
+
155
+ const result = removeByEditorId(source, 'a')
156
+
157
+ expect(result.changed).toBe(true)
158
+ expect(result.items[0].body).toHaveLength(1)
159
+ expect(result.items[0].body[0][EDITOR_ID_FIELD]).toBe('b')
160
+ })
161
+
162
+ it('removes input table columns by editor id', () => {
163
+ const source = [
164
+ {
165
+ type: 'x-input-table',
166
+ [EDITOR_ID_FIELD]: 'table',
167
+ items: [
168
+ { type: 'input', name: 'name', [EDITOR_ID_FIELD]: 'name_column' },
169
+ { type: 'select', name: 'status', [EDITOR_ID_FIELD]: 'status_column' },
170
+ { type: 'operation', [EDITOR_ID_FIELD]: 'operation_column' }
171
+ ]
172
+ }
173
+ ]
174
+
175
+ const result = removeByEditorId(source, 'status_column')
176
+
177
+ expect(result.changed).toBe(true)
178
+ expect(result.items[0].items.map((item: any) => item[EDITOR_ID_FIELD])).toEqual(['name_column', 'operation_column'])
179
+ expect(source[0].items.map((item: any) => item[EDITOR_ID_FIELD])).toEqual(['name_column', 'status_column', 'operation_column'])
180
+ })
181
+
182
+ it('inserts nested nodes after a matching editor id', () => {
183
+ const source = [
184
+ {
185
+ type: 'group',
186
+ [EDITOR_ID_FIELD]: 'group',
187
+ body: [{ type: 'input', [EDITOR_ID_FIELD]: 'field' }]
188
+ }
189
+ ]
190
+
191
+ const result = insertAfterEditorId(source, 'field', { type: 'select', [EDITOR_ID_FIELD]: 'copy' })
192
+
193
+ expect(result.changed).toBe(true)
194
+ expect(result.items[0].body.map((item: any) => item[EDITOR_ID_FIELD])).toEqual(['field', 'copy'])
195
+ })
196
+
197
+ it('assigns fresh editor ids to copied nodes recursively', () => {
198
+ const nextId = createId()
199
+ const result = assignNewEditorIdsDeep(
200
+ {
201
+ type: 'group',
202
+ _id: 'runtime_group',
203
+ [EDITOR_ID_FIELD]: 'old_group',
204
+ body: [{ type: 'input', _id: 'runtime_child', [EDITOR_ID_FIELD]: 'old_child' }]
205
+ },
206
+ nextId
207
+ )
208
+
209
+ expect(result[EDITOR_ID_FIELD]).toBe('editor_1')
210
+ expect(result.body[0][EDITOR_ID_FIELD]).toBe('editor_2')
211
+ expect(result._id).toBeUndefined()
212
+ expect(result.body[0]._id).toBeUndefined()
213
+ })
214
+
215
+ it('strips runtime and editor metadata deeply', () => {
216
+ const source = {
217
+ type: 'group',
218
+ _id: 'runtime_group',
219
+ [EDITOR_ID_FIELD]: 'group',
220
+ body: [{ type: 'input', _id: 'runtime_field', [EDITOR_ID_FIELD]: 'field' }]
221
+ }
222
+
223
+ expect(stripRuntimeMetaDeep(source)).toEqual({
224
+ type: 'group',
225
+ [EDITOR_ID_FIELD]: 'group',
226
+ body: [{ type: 'input', [EDITOR_ID_FIELD]: 'field' }]
227
+ })
228
+ expect(stripEditorMetaDeep(source)).toEqual({
229
+ type: 'group',
230
+ body: [{ type: 'input' }]
231
+ })
232
+ })
233
+
234
+ it('gets nested nodes by editor path', () => {
235
+ const source = [
236
+ {
237
+ type: 'group',
238
+ body: [{ type: 'input', name: 'nested' }]
239
+ }
240
+ ]
241
+
242
+ expect(getByEditorPath(source, [0, 'body', 0])?.name).toBe('nested')
243
+ expect(getByEditorPath(source, [0, 'body', 3])).toBeUndefined()
244
+ })
245
+
246
+ it('gets arrays by editor path', () => {
247
+ const source = [
248
+ {
249
+ type: 'group',
250
+ body: [{ type: 'input', name: 'nested' }]
251
+ }
252
+ ]
253
+
254
+ expect(getArrayByEditorPath(source, [])).toBe(source)
255
+ expect(getArrayByEditorPath(source, [0, 'body'])?.[0].name).toBe('nested')
256
+ expect(getArrayByEditorPath(source, [0, 'missing'])).toBeUndefined()
257
+ })
258
+
259
+ it('inserts nodes into nested containers by editor path', () => {
260
+ const source = [
261
+ {
262
+ type: 'group',
263
+ body: [{ type: 'input', name: 'a' }]
264
+ }
265
+ ]
266
+
267
+ const result = insertAtEditorPath(source, [0, 'body'], 1, { type: 'select', name: 'b' })
268
+
269
+ expect(result.changed).toBe(true)
270
+ expect(result.items[0].body.map((item: any) => item.name)).toEqual(['a', 'b'])
271
+ expect(source[0].body).toHaveLength(1)
272
+ })
273
+
274
+ it('inserts nodes into input table items by editor path', () => {
275
+ const source = [
276
+ {
277
+ type: 'x-input-table',
278
+ items: [{ type: 'input', name: 'name' }, { type: 'operation' }]
279
+ }
280
+ ]
281
+
282
+ const result = insertAtEditorPath(source, [0, 'items'], 1, { type: 'select', name: 'status' })
283
+
284
+ expect(result.changed).toBe(true)
285
+ expect(result.items[0].items.map((item: any) => item.type)).toEqual(['input', 'select', 'operation'])
286
+ expect(source[0].items.map((item: any) => item.type)).toEqual(['input', 'operation'])
287
+ })
288
+
289
+ it('moves nodes within nested containers by editor path', () => {
290
+ const source = [
291
+ {
292
+ type: 'group',
293
+ body: [
294
+ { type: 'input', name: 'a' },
295
+ { type: 'select', name: 'b' }
296
+ ]
297
+ }
298
+ ]
299
+
300
+ const result = moveWithinEditorPath(source, [0, 'body'], 0, 1)
301
+
302
+ expect(result.changed).toBe(true)
303
+ expect(result.items[0].body.map((item: any) => item.name)).toEqual(['b', 'a'])
304
+ })
305
+
306
+ it('moves nodes across containers by editor path', () => {
307
+ const source = [
308
+ { type: 'input', name: 'top' },
309
+ {
310
+ type: 'group',
311
+ body: [{ type: 'select', name: 'nested' }]
312
+ }
313
+ ]
314
+
315
+ const result = moveAcrossEditorPaths(source, [], 0, [1, 'body'], 1)
316
+
317
+ expect(result.changed).toBe(true)
318
+ expect(result.items.map((item: any) => item.name)).toEqual([undefined])
319
+ expect(result.items[0].body.map((item: any) => item.name)).toEqual(['nested', 'top'])
320
+ })
321
+
322
+ it('moves nodes from nested containers to the root by editor path', () => {
323
+ const source = [
324
+ { type: 'input', name: 'top' },
325
+ {
326
+ type: 'group',
327
+ body: [
328
+ { type: 'select', name: 'nested' },
329
+ { type: 'input', name: 'kept' }
330
+ ]
331
+ }
332
+ ]
333
+
334
+ const result = moveAcrossEditorPaths(source, [1, 'body'], 0, [], 1)
335
+
336
+ expect(result.changed).toBe(true)
337
+ expect(result.items.map((item: any) => item.name)).toEqual(['top', 'nested', undefined])
338
+ expect(result.items[2].body.map((item: any) => item.name)).toEqual(['kept'])
339
+ })
340
+
341
+ it('moves nodes between sibling nested containers by editor path', () => {
342
+ const source = [
343
+ {
344
+ type: 'group',
345
+ body: [{ type: 'input', name: 'a' }]
346
+ },
347
+ {
348
+ type: 'group',
349
+ body: [{ type: 'select', name: 'b' }]
350
+ }
351
+ ]
352
+
353
+ const result = moveAcrossEditorPaths(source, [0, 'body'], 0, [1, 'body'], 1)
354
+
355
+ expect(result.changed).toBe(true)
356
+ expect(result.items[0].body).toEqual([])
357
+ expect(result.items[1].body.map((item: any) => item.name)).toEqual(['b', 'a'])
358
+ })
359
+
360
+ it('adjusts nested target paths when source removal shifts an ancestor index', () => {
361
+ const source = [
362
+ {
363
+ type: 'group',
364
+ body: [{ type: 'input', name: 'moving' }]
365
+ },
366
+ {
367
+ type: 'group',
368
+ body: [
369
+ {
370
+ type: 'group',
371
+ body: [{ type: 'select', name: 'nested' }]
372
+ }
373
+ ]
374
+ }
375
+ ]
376
+
377
+ const result = moveAcrossEditorPaths(source, [], 0, [1, 'body', 0, 'body'], 1)
378
+
379
+ expect(result.changed).toBe(true)
380
+ expect(result.items).toHaveLength(1)
381
+ expect(result.items[0].body[0].body.map((item: any) => item.name)).toEqual(['nested', undefined])
382
+ expect(result.items[0].body[0].body[1].body.map((item: any) => item.name)).toEqual(['moving'])
383
+ })
384
+
385
+ it('adjusts nested target paths when nested source removal shifts a sibling ancestor index', () => {
386
+ const source = [
387
+ {
388
+ type: 'group',
389
+ body: [
390
+ {
391
+ type: 'group',
392
+ body: [{ type: 'input', name: 'moving' }]
393
+ },
394
+ {
395
+ type: 'group',
396
+ body: [
397
+ {
398
+ type: 'group',
399
+ body: [{ type: 'select', name: 'nested' }]
400
+ }
401
+ ]
402
+ }
403
+ ]
404
+ }
405
+ ]
406
+
407
+ const result = moveAcrossEditorPaths(source, [0, 'body'], 0, [0, 'body', 1, 'body', 0, 'body'], 1)
408
+
409
+ expect(result.changed).toBe(true)
410
+ expect(result.items[0].body).toHaveLength(1)
411
+ expect(result.items[0].body[0].body[0].body.map((item: any) => item.name)).toEqual(['nested', undefined])
412
+ expect(result.items[0].body[0].body[0].body[1].body.map((item: any) => item.name)).toEqual(['moving'])
413
+ })
414
+
415
+ it('does not move a node into its own descendant container', () => {
416
+ const source = [
417
+ {
418
+ type: 'group',
419
+ name: 'parent',
420
+ body: [{ type: 'input', name: 'child' }]
421
+ }
422
+ ]
423
+
424
+ const result = moveAcrossEditorPaths(source, [], 0, [0, 'body'], 1)
425
+
426
+ expect(result.changed).toBe(false)
427
+ expect(result.items).toBe(source)
428
+ })
429
+ })
@@ -0,0 +1,53 @@
1
+ import { describe, expect, it } from 'vitest'
2
+ import {
3
+ DEFAULT_FORM_ITEM_CUSTOM_WIDTH,
4
+ formatCustomFormItemControlWidth,
5
+ isFullFormItemControlWidth,
6
+ normalizeCustomFormItemControlWidth,
7
+ setFormItemControlWidth
8
+ } from '../form-item-width'
9
+
10
+ describe('form item control width utilities', () => {
11
+ it('treats missing and 100% widths as full width', () => {
12
+ expect(isFullFormItemControlWidth(undefined)).toBe(true)
13
+ expect(isFullFormItemControlWidth(null)).toBe(true)
14
+ expect(isFullFormItemControlWidth('')).toBe(true)
15
+ expect(isFullFormItemControlWidth('100%')).toBe(true)
16
+ expect(isFullFormItemControlWidth(240)).toBe(false)
17
+ })
18
+
19
+ it('normalizes custom widths to positive pixel numbers', () => {
20
+ expect(normalizeCustomFormItemControlWidth(320)).toBe(320)
21
+ expect(normalizeCustomFormItemControlWidth('320px')).toBe(320)
22
+ expect(normalizeCustomFormItemControlWidth('12.4px')).toBe(12)
23
+ expect(normalizeCustomFormItemControlWidth('calc(100% - 20px)')).toBe(DEFAULT_FORM_ITEM_CUSTOM_WIDTH)
24
+ expect(normalizeCustomFormItemControlWidth(0)).toBe(DEFAULT_FORM_ITEM_CUSTOM_WIDTH)
25
+ })
26
+
27
+ it('formats custom widths as pixel strings for schema output', () => {
28
+ expect(formatCustomFormItemControlWidth(320)).toBe('320px')
29
+ expect(formatCustomFormItemControlWidth('320px')).toBe('320px')
30
+ expect(formatCustomFormItemControlWidth('calc(100% - 20px)')).toBe('240px')
31
+ })
32
+
33
+ it('writes custom width and removes full width from schema style', () => {
34
+ const item: Record<string, any> = { style: { color: 'red' } }
35
+
36
+ setFormItemControlWidth(item, 260)
37
+ expect(item.style).toEqual({ color: 'red', width: '260px' })
38
+
39
+ setFormItemControlWidth(item, undefined)
40
+ expect(item.style).toEqual({ color: 'red' })
41
+
42
+ setFormItemControlWidth(item, '100%')
43
+ expect(item.style).toEqual({ color: 'red' })
44
+ })
45
+
46
+ it('removes empty style objects when switching back to full width', () => {
47
+ const item: Record<string, any> = { style: { width: '260px' } }
48
+
49
+ setFormItemControlWidth(item, undefined)
50
+
51
+ expect(item.style).toBeUndefined()
52
+ })
53
+ })
@@ -0,0 +1,84 @@
1
+ import { describe, expect, it } from 'vitest'
2
+ import { getEditorChildContainerPath, getEditorChildItemPath } from 'xkit-ui'
3
+ import { insertAtEditorPath, moveAcrossEditorPaths, moveWithinEditorPath } from '../editor-schema'
4
+
5
+ describe('group drag path integration', () => {
6
+ it('inserts dragged palette scaffolds into an empty group body', () => {
7
+ const groupPath = [0]
8
+ const groupBodyPath = getEditorChildContainerPath(groupPath, 'body')
9
+ const source = [
10
+ {
11
+ type: 'group',
12
+ title: '分组',
13
+ body: []
14
+ }
15
+ ]
16
+ const inputScaffold = {
17
+ type: 'input',
18
+ label: '输入框'
19
+ }
20
+
21
+ const result = insertAtEditorPath(source, groupBodyPath, 0, inputScaffold)
22
+
23
+ expect(result.changed).toBe(true)
24
+ expect(result.items[0].body).toEqual([inputScaffold])
25
+ expect(source[0].body).toEqual([])
26
+ })
27
+
28
+ it('sorts items within group body using the group drop path', () => {
29
+ const groupBodyPath = getEditorChildContainerPath([0], 'body')
30
+ const source = [
31
+ {
32
+ type: 'group',
33
+ body: [
34
+ { type: 'input', name: 'a' },
35
+ { type: 'select', name: 'b' }
36
+ ]
37
+ }
38
+ ]
39
+
40
+ const result = moveWithinEditorPath(source, groupBodyPath, 0, 1)
41
+
42
+ expect(result.changed).toBe(true)
43
+ expect(result.items[0].body.map((item: any) => item.name)).toEqual(['b', 'a'])
44
+ })
45
+
46
+ it('moves root items into group body using root and group drop paths', () => {
47
+ const groupBodyPath = getEditorChildContainerPath([1], 'body')
48
+ const source = [
49
+ { type: 'input', name: 'top' },
50
+ {
51
+ type: 'group',
52
+ body: [{ type: 'select', name: 'nested' }]
53
+ }
54
+ ]
55
+
56
+ const result = moveAcrossEditorPaths(source, [], 0, groupBodyPath, 1)
57
+
58
+ expect(result.changed).toBe(true)
59
+ expect(result.items).toHaveLength(1)
60
+ expect(result.items[0].body.map((item: any) => item.name)).toEqual(['nested', 'top'])
61
+ })
62
+
63
+ it('moves group body items back to root using child item paths', () => {
64
+ const groupPath = [1]
65
+ const groupBodyPath = getEditorChildContainerPath(groupPath, 'body')
66
+ const nestedItemPath = getEditorChildItemPath(groupBodyPath, 0)
67
+ const source = [
68
+ { type: 'input', name: 'top' },
69
+ {
70
+ type: 'group',
71
+ body: [
72
+ { type: 'select', name: 'nested' },
73
+ { type: 'input', name: 'kept' }
74
+ ]
75
+ }
76
+ ]
77
+
78
+ const result = moveAcrossEditorPaths(source, groupBodyPath, Number(nestedItemPath.at(-1)), [], 1)
79
+
80
+ expect(result.changed).toBe(true)
81
+ expect(result.items.map((item: any) => item.name)).toEqual(['top', 'nested', undefined])
82
+ expect(result.items[2].body.map((item: any) => item.name)).toEqual(['kept'])
83
+ })
84
+ })