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,342 @@
1
+ <template>
2
+ <div class="object-section-editor">
3
+ <div v-if="resolvedSectionMode !== 'plain'" class="object-section-editor__header">
4
+ <div class="object-section-editor__title">{{ title }}</div>
5
+ <div v-if="resolvedSectionMode === 'tabs'" class="object-section-editor__tabs">
6
+ <button
7
+ v-for="section in sections"
8
+ :key="section.key"
9
+ class="object-section-editor__tab"
10
+ :class="{ 'is-active': section.key === activeKey }"
11
+ type="button"
12
+ @click="activeKey = section.key"
13
+ >
14
+ {{ section.label }}
15
+ </button>
16
+ </div>
17
+ </div>
18
+
19
+ <div class="object-section-editor__panel" :class="{ 'is-plain': resolvedSectionMode === 'plain' }">
20
+ <span class="object-section-editor__corner" />
21
+ <div v-if="resolvedSectionMode !== 'plain'" class="object-section-editor__path">{{ pathLabel }}</div>
22
+ <x-form
23
+ :key="formKey"
24
+ :model-value="editorValue"
25
+ :body="editorBody"
26
+ value-reactive
27
+ auto-submit
28
+ label-position="left"
29
+ :size="editorFormSize"
30
+ :show-button-group="false"
31
+ @update:modelValue="handleSectionChange"
32
+ />
33
+ </div>
34
+ </div>
35
+ </template>
36
+
37
+ <script setup lang="ts">
38
+ import { computed, ref, useAttrs, watch } from 'vue'
39
+ import { XForm, type XFormItem } from 'xkit-ui'
40
+
41
+ export interface ObjectSection {
42
+ label: string
43
+ key: string
44
+ body: XFormItem[]
45
+ }
46
+
47
+ const props = defineProps<{
48
+ modelValue?: any
49
+ title?: string
50
+ rootKey?: string
51
+ valueMode?: 'nested' | 'flat'
52
+ sectionMode?: 'tabs' | 'flat' | 'plain'
53
+ mainKey?: string
54
+ syncKeys?: string[]
55
+ sections?: ObjectSection[]
56
+ }>()
57
+
58
+ const emit = defineEmits<(event: string, value: any) => void>()
59
+ const attrs = useAttrs()
60
+
61
+ const isEmptyValue = (value: unknown) => value === undefined || value === null || value === ''
62
+
63
+ const cleanRecord = (value: Record<string, any> | undefined) => {
64
+ if (!value || typeof value !== 'object') return undefined
65
+ const next = Object.entries(value).reduce<Record<string, any>>((result, [key, itemValue]) => {
66
+ if (!isEmptyValue(itemValue)) {
67
+ result[key] = itemValue
68
+ }
69
+ return result
70
+ }, {})
71
+ return Object.keys(next).length > 0 ? next : undefined
72
+ }
73
+
74
+ const cleanSections = (value: Record<string, any> | undefined) => {
75
+ if (!value || typeof value !== 'object') return undefined
76
+ const next = Object.entries(value).reduce<Record<string, any>>((result, [key, sectionValue]) => {
77
+ const cleaned = cleanRecord(sectionValue)
78
+ if (cleaned) {
79
+ result[key] = cleaned
80
+ }
81
+ return result
82
+ }, {})
83
+ return Object.keys(next).length > 0 ? next : undefined
84
+ }
85
+
86
+ const activeKey = ref(props.sections?.[0]?.key || '')
87
+
88
+ watch(
89
+ () => props.sections,
90
+ (sections) => {
91
+ if (!sections?.length) {
92
+ activeKey.value = ''
93
+ return
94
+ }
95
+ if (!sections.some((section) => section.key === activeKey.value)) {
96
+ activeKey.value = sections[0].key
97
+ }
98
+ },
99
+ { immediate: true }
100
+ )
101
+
102
+ const activeSection = computed(() => props.sections?.find((section) => section.key === activeKey.value))
103
+ const flatKeys = computed(() => {
104
+ const names = props.sections?.flatMap((section) => section.body.map((item) => item.name).filter(Boolean) as string[]) || []
105
+ return Array.from(new Set(names))
106
+ })
107
+ const resolvedSectionMode = computed(() => props.sectionMode || 'tabs')
108
+ const sectionFieldName = (sectionKey: string, name: string) => `__section_${sectionKey}_${name}`
109
+ const isPlainNestedMode = computed(() => resolvedSectionMode.value === 'plain' && props.valueMode !== 'flat')
110
+ const plainFieldMap = computed(() => {
111
+ const entries =
112
+ props.sections?.flatMap((section) => {
113
+ return section.body
114
+ .map((item) => item.name)
115
+ .filter(Boolean)
116
+ .map((name) => {
117
+ const fieldName = sectionFieldName(section.key, String(name))
118
+ return [fieldName, { sectionKey: section.key, name: String(name) }] as const
119
+ })
120
+ }) || []
121
+ return new Map(entries)
122
+ })
123
+ const flatSectionBody = computed<XFormItem[]>(() => {
124
+ return (
125
+ props.sections?.flatMap((section) => [
126
+ {
127
+ title: section.label,
128
+ type: 'group',
129
+ titleClass: 'config-group-title',
130
+ label: false
131
+ } as XFormItem,
132
+ ...section.body
133
+ ]) || []
134
+ )
135
+ })
136
+ const plainSectionBody = computed<XFormItem[]>(() => {
137
+ return (
138
+ props.sections?.flatMap((section) =>
139
+ section.body.map((item) => {
140
+ if (props.valueMode === 'flat') return item
141
+ if (!item.name) return item
142
+ return {
143
+ ...item,
144
+ name: sectionFieldName(section.key, String(item.name))
145
+ }
146
+ })
147
+ ) || []
148
+ )
149
+ })
150
+ const editorBody = computed(() => {
151
+ if (resolvedSectionMode.value === 'plain') return plainSectionBody.value
152
+ if (resolvedSectionMode.value === 'flat') return flatSectionBody.value
153
+ return activeSection.value?.body || []
154
+ })
155
+ const editorValue = computed(() => {
156
+ if (props.valueMode === 'flat') {
157
+ return flatKeys.value.reduce<Record<string, any>>((result, key) => {
158
+ if (props.mainKey === key) {
159
+ result[key] = props.modelValue
160
+ } else if (!props.mainKey) {
161
+ result[key] = props.modelValue?.[key]
162
+ } else {
163
+ result[key] = attrs[key]
164
+ }
165
+ return result
166
+ }, {})
167
+ }
168
+
169
+ if (isPlainNestedMode.value) {
170
+ return Array.from(plainFieldMap.value.entries()).reduce<Record<string, any>>((result, [fieldName, meta]) => {
171
+ result[fieldName] = props.modelValue?.[meta.sectionKey]?.[meta.name]
172
+ return result
173
+ }, {})
174
+ }
175
+
176
+ if (resolvedSectionMode.value === 'flat') {
177
+ return props.sections?.reduce<Record<string, any>>((result, section) => {
178
+ result[section.key] = props.modelValue?.[section.key] || {}
179
+ return result
180
+ }, {})
181
+ }
182
+
183
+ const key = activeSection.value?.key
184
+ if (!key) return {}
185
+ return { ...(props.modelValue?.[key] || {}) }
186
+ })
187
+ const pathLabel = computed(() => {
188
+ if (props.valueMode === 'flat') return props.rootKey || ''
189
+ if (resolvedSectionMode.value !== 'tabs') return props.rootKey || ''
190
+ if (!activeSection.value) return props.rootKey || ''
191
+ return [props.rootKey, activeSection.value.key].filter(Boolean).join('.')
192
+ })
193
+ const formKey = computed(() => (resolvedSectionMode.value === 'tabs' ? activeSection.value?.key : resolvedSectionMode.value))
194
+ const editorFormSize = computed(() => (resolvedSectionMode.value === 'plain' ? undefined : 'small'))
195
+
196
+ const handleSectionChange = (formValue: Record<string, any>) => {
197
+ if (props.valueMode === 'flat') {
198
+ if (props.mainKey) {
199
+ emit('update:modelValue', isEmptyValue(formValue[props.mainKey]) ? undefined : formValue[props.mainKey])
200
+ props.syncKeys?.forEach((key) => {
201
+ emit(`update:${key}`, isEmptyValue(formValue[key]) ? undefined : formValue[key])
202
+ })
203
+ return
204
+ }
205
+
206
+ const sectionKeys =
207
+ resolvedSectionMode.value === 'plain' ? flatKeys.value : ((activeSection.value?.body.map((item) => item.name).filter(Boolean) as string[] | undefined) ?? [])
208
+ const next = { ...(props.modelValue || {}) }
209
+ sectionKeys.forEach((key) => {
210
+ if (isEmptyValue(formValue[key])) {
211
+ delete next[key]
212
+ } else {
213
+ next[key] = formValue[key]
214
+ }
215
+ })
216
+ emit('update:modelValue', cleanRecord(next))
217
+ return
218
+ }
219
+
220
+ if (isPlainNestedMode.value) {
221
+ const next = { ...(props.modelValue || {}) }
222
+ props.sections?.forEach((section) => {
223
+ const nextSectionValue = { ...(next[section.key] || {}) }
224
+ section.body
225
+ .map((item) => item.name)
226
+ .filter(Boolean)
227
+ .forEach((name) => {
228
+ const fieldName = sectionFieldName(section.key, String(name))
229
+ if (isEmptyValue(formValue[fieldName])) {
230
+ delete nextSectionValue[String(name)]
231
+ } else {
232
+ nextSectionValue[String(name)] = formValue[fieldName]
233
+ }
234
+ })
235
+ next[section.key] = nextSectionValue
236
+ })
237
+ emit('update:modelValue', cleanSections(next))
238
+ return
239
+ }
240
+
241
+ if (resolvedSectionMode.value === 'flat') {
242
+ emit('update:modelValue', cleanSections(formValue))
243
+ return
244
+ }
245
+
246
+ const key = activeSection.value?.key
247
+ if (!key) return
248
+ const next = {
249
+ ...(props.modelValue || {}),
250
+ [key]: formValue
251
+ }
252
+ emit('update:modelValue', cleanSections(next))
253
+ }
254
+ </script>
255
+
256
+ <style scoped lang="scss">
257
+ .object-section-editor {
258
+ width: 100%;
259
+ }
260
+
261
+ .object-section-editor__header {
262
+ display: flex;
263
+ align-items: center;
264
+ justify-content: flex-end;
265
+ gap: 8px;
266
+ margin-bottom: 8px;
267
+ }
268
+
269
+ .object-section-editor__title {
270
+ flex: 1;
271
+ min-width: 0;
272
+ color: var(--el-text-color-primary);
273
+ font-size: 13px;
274
+ font-weight: 600;
275
+ }
276
+
277
+ .object-section-editor__tabs {
278
+ display: flex;
279
+ flex: none;
280
+ gap: 4px;
281
+ }
282
+
283
+ .object-section-editor__tab {
284
+ height: 24px;
285
+ padding: 0 10px;
286
+ border: 1px solid var(--el-border-color);
287
+ border-radius: 4px;
288
+ background: var(--el-fill-color-blank);
289
+ color: var(--el-text-color-regular);
290
+ font-size: 12px;
291
+ line-height: 22px;
292
+ cursor: pointer;
293
+ }
294
+
295
+ .object-section-editor__tab.is-active {
296
+ border-color: var(--el-color-primary);
297
+ background: var(--el-color-primary-light-9);
298
+ color: var(--el-color-primary);
299
+ }
300
+
301
+ .object-section-editor__panel {
302
+ position: relative;
303
+ padding: 28px 10px 2px;
304
+ border: 1px solid var(--el-border-color-lighter);
305
+ border-radius: 6px;
306
+ background: var(--el-fill-color-light);
307
+ }
308
+
309
+ .object-section-editor__panel.is-plain {
310
+ padding: 0;
311
+ border: 0;
312
+ border-radius: 0;
313
+ background: transparent;
314
+ }
315
+
316
+ .object-section-editor__panel.is-plain .object-section-editor__corner {
317
+ display: none;
318
+ }
319
+
320
+ .object-section-editor__corner {
321
+ position: absolute;
322
+ top: 0;
323
+ right: 0;
324
+ width: 0;
325
+ height: 0;
326
+ border-top: 18px solid var(--el-color-primary-light-5);
327
+ border-left: 18px solid transparent;
328
+ }
329
+
330
+ .object-section-editor__path {
331
+ position: absolute;
332
+ top: 7px;
333
+ right: 22px;
334
+ color: var(--el-text-color-secondary);
335
+ font-size: 11px;
336
+ line-height: 1;
337
+ }
338
+
339
+ .object-section-editor__panel :deep(.el-form-item) {
340
+ margin-bottom: 12px;
341
+ }
342
+ </style>
@@ -0,0 +1,197 @@
1
+ <template>
2
+ <div class="default-dict-options-panel">
3
+ <el-select
4
+ :model-value="selectedCode"
5
+ filterable
6
+ clearable
7
+ placeholder="请选择字典"
8
+ class="default-dict-options-panel__select"
9
+ @update:modelValue="handleCodeChange"
10
+ >
11
+ <el-option
12
+ v-for="dict in filteredDicts"
13
+ :key="dict.code"
14
+ :label="`${dict.label}(${dict.code})`"
15
+ :value="dict.code"
16
+ />
17
+ </el-select>
18
+ <el-button size="small" @click="dialogVisible = true">管理</el-button>
19
+
20
+ <el-dialog v-model="dialogVisible" title="字典中心" width="760px" append-to-body>
21
+ <div class="default-dict-options-panel__dialog">
22
+ <div class="default-dict-options-panel__toolbar">
23
+ <el-input v-model="keyword" clearable placeholder="搜索字典编码或名称" />
24
+ <el-button type="primary" @click="handleAddDict">新增字典</el-button>
25
+ </div>
26
+
27
+ <el-table :data="filteredDicts" border height="260" highlight-current-row @row-click="handleSelectDict">
28
+ <el-table-column prop="code" label="编码" width="150" />
29
+ <el-table-column prop="label" label="名称" />
30
+ <el-table-column label="选项数" width="90">
31
+ <template #default="{ row }">{{ row.options.length }}</template>
32
+ </el-table-column>
33
+ <el-table-column label="操作" width="110">
34
+ <template #default="{ row }">
35
+ <el-button link type="primary" @click.stop="handleSelectDict(row)">选择</el-button>
36
+ </template>
37
+ </el-table-column>
38
+ </el-table>
39
+
40
+ <div v-if="editingDict" class="default-dict-options-panel__editor">
41
+ <div class="default-dict-options-panel__row">
42
+ <el-input v-model="editingDict.code" placeholder="字典编码" />
43
+ <el-input v-model="editingDict.label" placeholder="字典名称" />
44
+ </div>
45
+ <x-input-array
46
+ v-model="editingDict.options"
47
+ label-position="top"
48
+ draggable
49
+ addable
50
+ deletable
51
+ use-layout
52
+ show-footer-add-button
53
+ :layout="optionLayout"
54
+ :items="optionItems"
55
+ />
56
+ </div>
57
+ </div>
58
+ <template #footer>
59
+ <el-button @click="dialogVisible = false">取消</el-button>
60
+ <el-button type="primary" @click="handleSave">保存</el-button>
61
+ </template>
62
+ </el-dialog>
63
+ </div>
64
+ </template>
65
+
66
+ <script setup lang="ts">
67
+ import { computed, ref, watch } from 'vue'
68
+ import { ElButton, ElDialog, ElInput, ElOption, ElSelect, ElTable, ElTableColumn } from 'element-plus'
69
+ import { XInputArray, type XInputArrayItem } from 'xkit-ui'
70
+ import {
71
+ ensureEditorLocalDicts,
72
+ saveEditorLocalDicts,
73
+ type EditorDictRecord
74
+ } from '../../utils/local-dict-center'
75
+
76
+ const props = defineProps<{
77
+ modelValue?: any
78
+ }>()
79
+
80
+ const emit = defineEmits<{
81
+ (e: 'update:modelValue', value: any): void
82
+ }>()
83
+
84
+ const cloneDicts = (items: EditorDictRecord[]) => JSON.parse(JSON.stringify(items)) as EditorDictRecord[]
85
+
86
+ const dialogVisible = ref(false)
87
+ const keyword = ref('')
88
+ const dicts = ref<EditorDictRecord[]>(cloneDicts(ensureEditorLocalDicts()))
89
+ const editingDict = ref<EditorDictRecord>()
90
+
91
+ const selectedCode = computed(() => {
92
+ if (typeof props.modelValue === 'string') return props.modelValue
93
+ if (props.modelValue?.type === 'dict') return props.modelValue.code
94
+ return ''
95
+ })
96
+
97
+ const filteredDicts = computed(() => {
98
+ const value = keyword.value.trim().toLowerCase()
99
+ if (!value) return dicts.value
100
+ return dicts.value.filter((item) => `${item.code} ${item.label}`.toLowerCase().includes(value))
101
+ })
102
+
103
+ const optionItems: XInputArrayItem[] = [
104
+ {
105
+ label: false,
106
+ name: 'label',
107
+ type: 'input',
108
+ clearable: false,
109
+ placeholder: '选项名称',
110
+ span: 12
111
+ },
112
+ {
113
+ label: false,
114
+ name: 'value',
115
+ type: 'input',
116
+ clearable: false,
117
+ placeholder: '选项值',
118
+ span: 12
119
+ }
120
+ ]
121
+
122
+ const optionLayout = {
123
+ row: { gutter: 8 },
124
+ col: { span: 12 }
125
+ }
126
+
127
+ watch(dialogVisible, (visible) => {
128
+ if (visible) {
129
+ dicts.value = cloneDicts(ensureEditorLocalDicts())
130
+ editingDict.value = dicts.value.find((item) => item.code === selectedCode.value) || dicts.value[0]
131
+ }
132
+ })
133
+
134
+ const handleCodeChange = (code?: string) => {
135
+ emit('update:modelValue', code ? { type: 'dict', code } : undefined)
136
+ }
137
+
138
+ const handleSelectDict = (dict: EditorDictRecord) => {
139
+ editingDict.value = dict
140
+ handleCodeChange(dict.code)
141
+ }
142
+
143
+ const handleAddDict = () => {
144
+ const next: EditorDictRecord = {
145
+ code: `DICT_${dicts.value.length + 1}`,
146
+ label: '新字典',
147
+ options: []
148
+ }
149
+ dicts.value.push(next)
150
+ editingDict.value = next
151
+ }
152
+
153
+ const handleSave = () => {
154
+ dicts.value = saveEditorLocalDicts(dicts.value)
155
+ if (editingDict.value?.code) {
156
+ handleCodeChange(editingDict.value.code)
157
+ }
158
+ dialogVisible.value = false
159
+ }
160
+ </script>
161
+
162
+ <style scoped lang="scss">
163
+ .default-dict-options-panel {
164
+ display: flex;
165
+ width: 100%;
166
+ gap: 8px;
167
+ }
168
+
169
+ .default-dict-options-panel__select {
170
+ flex: 1;
171
+ }
172
+
173
+ .default-dict-options-panel__dialog {
174
+ display: grid;
175
+ gap: 12px;
176
+ }
177
+
178
+ .default-dict-options-panel__toolbar,
179
+ .default-dict-options-panel__row {
180
+ display: grid;
181
+ grid-template-columns: 1fr auto;
182
+ gap: 8px;
183
+ }
184
+
185
+ .default-dict-options-panel__row {
186
+ grid-template-columns: 1fr 1fr;
187
+ }
188
+
189
+ .default-dict-options-panel__editor {
190
+ display: grid;
191
+ gap: 8px;
192
+ padding: 12px;
193
+ border: 1px solid var(--el-border-color-lighter);
194
+ border-radius: 6px;
195
+ background: var(--el-fill-color-lighter);
196
+ }
197
+ </style>
@@ -0,0 +1,161 @@
1
+ <template>
2
+ <div class="options-editor">
3
+ <div class="options-editor__header">
4
+ <span class="options-editor__title">{{ title }}</span>
5
+ <div class="options-editor__tabs">
6
+ <button
7
+ v-for="source in sources"
8
+ :key="source.type"
9
+ class="options-editor__tab"
10
+ :class="{ 'is-active': source.type === activeType }"
11
+ type="button"
12
+ @click="handleTypeChange(source.type)"
13
+ >
14
+ {{ source.label }}
15
+ </button>
16
+ </div>
17
+ </div>
18
+
19
+ <x-input-array
20
+ v-if="activeType === 'static'"
21
+ :model-value="staticOptions"
22
+ label-position="top"
23
+ draggable
24
+ addable
25
+ deletable
26
+ use-layout
27
+ show-footer-add-button
28
+ :layout="optionLayout"
29
+ :items="optionItems"
30
+ @update:modelValue="handleStaticChange"
31
+ />
32
+ <component
33
+ v-else-if="activeSource?.component"
34
+ :is="activeSource.component"
35
+ :model-value="modelValue"
36
+ @update:modelValue="handleSourceChange"
37
+ />
38
+ </div>
39
+ </template>
40
+
41
+ <script setup lang="ts">
42
+ import { computed, ref, watch } from 'vue'
43
+ import { XInputArray, type FormItemOptions, type OptionItem, type XInputArrayItem } from 'xkit-ui'
44
+ import { getEditorOptionSource, getEditorOptionSources } from '../../option-sources'
45
+
46
+ const props = defineProps<{
47
+ modelValue?: FormItemOptions
48
+ title?: string
49
+ }>()
50
+
51
+ const emit = defineEmits<{
52
+ (e: 'update:modelValue', value: FormItemOptions | undefined): void
53
+ }>()
54
+
55
+ const optionItems: XInputArrayItem[] = [
56
+ {
57
+ label: false,
58
+ name: 'label',
59
+ type: 'input',
60
+ clearable: false,
61
+ placeholder: '选项名称',
62
+ span: 12
63
+ },
64
+ {
65
+ label: false,
66
+ name: 'value',
67
+ type: 'input',
68
+ clearable: false,
69
+ placeholder: '选项值',
70
+ span: 12
71
+ }
72
+ ]
73
+
74
+ const optionLayout = {
75
+ row: { gutter: 8 },
76
+ col: { span: 12 }
77
+ }
78
+
79
+ const resolveType = (value: FormItemOptions | undefined, fallback = 'static') => {
80
+ if (!value) return fallback
81
+ if (Array.isArray(value)) return 'static'
82
+ if (typeof value === 'string') return 'dict'
83
+ if (typeof value === 'object' && 'type' in value && typeof value.type === 'string') {
84
+ return value.type
85
+ }
86
+ return fallback
87
+ }
88
+
89
+ const activeType = ref(resolveType(props.modelValue))
90
+
91
+ watch(
92
+ () => props.modelValue,
93
+ (value) => {
94
+ activeType.value = resolveType(value, activeType.value)
95
+ }
96
+ )
97
+
98
+ const sources = computed(() => getEditorOptionSources())
99
+ const activeSource = computed(() => getEditorOptionSource(activeType.value))
100
+ const staticOptions = computed(() => (Array.isArray(props.modelValue) ? props.modelValue : []))
101
+
102
+ const handleTypeChange = (type: string) => {
103
+ activeType.value = type
104
+ if (type === 'static') {
105
+ emit('update:modelValue', Array.isArray(props.modelValue) ? props.modelValue : [])
106
+ }
107
+ }
108
+
109
+ const handleStaticChange = (value: OptionItem[]) => {
110
+ emit('update:modelValue', value)
111
+ }
112
+
113
+ const handleSourceChange = (value: FormItemOptions | undefined) => {
114
+ emit('update:modelValue', value)
115
+ }
116
+ </script>
117
+
118
+ <style scoped lang="scss">
119
+ .options-editor {
120
+ width: 100%;
121
+ }
122
+
123
+ .options-editor__header {
124
+ display: flex;
125
+ align-items: center;
126
+ gap: 8px;
127
+ margin-bottom: 8px;
128
+ }
129
+
130
+ .options-editor__title {
131
+ flex: 1;
132
+ min-width: 0;
133
+ color: var(--el-text-color-primary);
134
+ font-size: 13px;
135
+ font-weight: 600;
136
+ }
137
+
138
+ .options-editor__tabs {
139
+ display: flex;
140
+ flex: none;
141
+ gap: 4px;
142
+ }
143
+
144
+ .options-editor__tab {
145
+ height: 24px;
146
+ padding: 0 10px;
147
+ border: 1px solid var(--el-border-color);
148
+ border-radius: 4px;
149
+ background: var(--el-fill-color-blank);
150
+ color: var(--el-text-color-regular);
151
+ font-size: 12px;
152
+ line-height: 22px;
153
+ cursor: pointer;
154
+ }
155
+
156
+ .options-editor__tab.is-active {
157
+ border-color: var(--el-color-primary);
158
+ background: var(--el-color-primary-light-9);
159
+ color: var(--el-color-primary);
160
+ }
161
+ </style>