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
package/src/config.ts ADDED
@@ -0,0 +1,51 @@
1
+ import type { ComponentConfig } from './component-configs/types'
2
+ import { inputComponentConfig } from './component-configs/input'
3
+ import { selectComponentConfig } from './component-configs/select'
4
+ import { radioComponentConfig } from './component-configs/radio'
5
+ import { checkboxComponentConfig, checkboxesComponentConfig } from './component-configs/checkbox'
6
+ import { switchComponentConfig } from './component-configs/switch'
7
+ import { cascaderComponentConfig } from './component-configs/cascader'
8
+ import { groupComponentConfig } from './component-configs/group'
9
+ import { inputNumberComponentConfig } from './component-configs/input-number'
10
+ import { inputNumberRangeComponentConfig } from './component-configs/input-number-range'
11
+ import { datePickerComponentConfig } from './component-configs/date-picker'
12
+ import { dateRangePickerComponentConfig, dateRangePickerV2ComponentConfig } from './component-configs/date-range-picker'
13
+ import { textareaComponentConfig } from './component-configs/textarea'
14
+ import { inputUploadComponentConfig } from './component-configs/input-upload'
15
+ import { iconSelectComponentConfig } from './component-configs/icon-select'
16
+ import { inputTableComponentConfig } from './component-configs/input-table'
17
+ import { inputArrayComponentConfig } from './component-configs/input-array'
18
+
19
+ export interface ComponentPaletteGroup {
20
+ label: string
21
+ items: ComponentConfig[]
22
+ }
23
+
24
+ export const componentPaletteGroups: ComponentPaletteGroup[] = [
25
+ {
26
+ label: '组合容器',
27
+ items: [groupComponentConfig, inputTableComponentConfig, inputArrayComponentConfig]
28
+ },
29
+ {
30
+ label: '基础控件',
31
+ items: [
32
+ inputComponentConfig,
33
+ textareaComponentConfig,
34
+ inputNumberComponentConfig,
35
+ inputNumberRangeComponentConfig,
36
+ selectComponentConfig,
37
+ cascaderComponentConfig,
38
+ radioComponentConfig,
39
+ checkboxesComponentConfig,
40
+ datePickerComponentConfig,
41
+ dateRangePickerComponentConfig,
42
+ dateRangePickerV2ComponentConfig,
43
+ checkboxComponentConfig,
44
+ switchComponentConfig,
45
+ inputUploadComponentConfig,
46
+ iconSelectComponentConfig
47
+ ]
48
+ }
49
+ ]
50
+
51
+ export const componentList: ComponentConfig[] = componentPaletteGroups.flatMap((group) => group.items)
@@ -0,0 +1,254 @@
1
+ <template>
2
+ <div
3
+ class="editor-item-wrapper"
4
+ :class="{ 'is-active': isActive, 'is-container': variant === 'container', 'has-visible-mark': showVisibleMark }"
5
+ @click.stop="handleSelect"
6
+ >
7
+ <!-- 拖拽句柄 -->
8
+ <div v-if="showDrag" class="editor-item-drag">
9
+ <i class="ri-drag-move-fill"></i>
10
+ </div>
11
+ <!-- 操作按钮 -->
12
+ <div class="editor-item-actions" v-if="isActive && showActions">
13
+ <div class="action-btn" @click.stop="handleAction('copy')" title="复制">
14
+ <i class="ri-file-copy-line"></i>
15
+ </div>
16
+ <div class="action-btn delete" @click.stop="handleAction('delete')" title="删除">
17
+ <i class="ri-delete-bin-line"></i>
18
+ </div>
19
+ </div>
20
+
21
+ <!-- 标识类型 -->
22
+ <div class="editor-item-tag" v-if="isActive && showTag">
23
+ {{ displayTag }}
24
+ </div>
25
+ <!-- 可见性条件标识 -->
26
+ <div class="editor-item-visible-flag" v-if="showVisibleMark" title="编辑显示条件" @click.stop="handleEditVisibleCondition">条件</div>
27
+
28
+ <!-- 内容插槽 (FormItem) -->
29
+ <div class="editor-item-content">
30
+ <slot></slot>
31
+ </div>
32
+ </div>
33
+ </template>
34
+
35
+ <script setup lang="ts">
36
+ import { computed, inject, type Ref } from 'vue'
37
+
38
+ const props = withDefaults(defineProps<{
39
+ item?: any
40
+ node?: any
41
+ nodeId?: string | number
42
+ editorPath?: Array<string | number>
43
+ parentEditorId?: string | number
44
+ static?: boolean
45
+ tag?: string
46
+ emitCustomEvent: (event: any) => void
47
+ showActions?: boolean
48
+ showDrag?: boolean
49
+ showTag?: boolean
50
+ selectable?: boolean
51
+ variant?: 'item' | 'container'
52
+ }>(), {
53
+ showActions: true,
54
+ showDrag: true,
55
+ showTag: true,
56
+ selectable: true,
57
+ variant: 'item'
58
+ })
59
+
60
+ // 从 XEditor 注入当前选中的 id
61
+ const selectedId = inject<Ref<string | number | undefined>>('selectedId')
62
+ const EDITOR_ID_FIELD = '__editorId'
63
+
64
+ const currentNode = computed(() => props.node ?? props.item)
65
+ const currentNodeId = computed(() => {
66
+ return props.nodeId ?? currentNode.value?.[EDITOR_ID_FIELD] ?? currentNode.value?._id
67
+ })
68
+ const eventMeta = computed(() => ({
69
+ variant: props.variant,
70
+ nodeId: currentNodeId.value,
71
+ editorPath: props.editorPath,
72
+ parentEditorId: props.parentEditorId
73
+ }))
74
+ const displayTag = computed(() => {
75
+ return props.tag ?? currentNode.value?.type ?? currentNode.value?.name ?? 'component'
76
+ })
77
+
78
+ const showVisibleMark = computed(() => {
79
+ const node = currentNode.value
80
+ if (!node || typeof node !== 'object') return false
81
+ const hasVisible = Object.prototype.hasOwnProperty.call(node, 'visible')
82
+ if (!hasVisible) return false
83
+ return node.visible !== true
84
+ })
85
+
86
+ const isActive = computed(() => {
87
+ return selectedId?.value && selectedId.value === currentNodeId.value
88
+ })
89
+
90
+ const handleSelect = () => {
91
+ if (!props.selectable) return
92
+ props.emitCustomEvent({
93
+ name: 'select',
94
+ payload: currentNode.value,
95
+ meta: eventMeta.value
96
+ })
97
+ }
98
+
99
+ const handleAction = (type: string) => {
100
+ props.emitCustomEvent({
101
+ name: type,
102
+ payload: currentNode.value,
103
+ meta: eventMeta.value
104
+ })
105
+ }
106
+
107
+ const handleEditVisibleCondition = () => {
108
+ if (props.selectable) handleSelect()
109
+ props.emitCustomEvent({
110
+ name: 'edit-visible-condition',
111
+ payload: currentNode.value,
112
+ meta: eventMeta.value
113
+ })
114
+ }
115
+ </script>
116
+
117
+ <style lang="scss" scoped>
118
+ .editor-item-wrapper {
119
+ position: relative;
120
+ padding: 2px;
121
+ border: 1px dashed #dcdfe6;
122
+ margin-bottom: 2px;
123
+ background: #fff;
124
+ cursor: pointer;
125
+ transition: all 0.2s;
126
+ min-height: 40px;
127
+
128
+ &.is-container {
129
+ border-style: solid;
130
+ padding: 6px;
131
+ margin-bottom: 0;
132
+ }
133
+
134
+ &.has-visible-mark {
135
+ border-color: #e6a23c;
136
+ background: #fffaf0;
137
+ }
138
+
139
+ &:hover {
140
+ border-color: #409eff;
141
+ background: #f5f7fa;
142
+
143
+ .editor-item-drag {
144
+ opacity: 1;
145
+ }
146
+ }
147
+
148
+ &.is-active {
149
+ outline: 2px solid #409eff;
150
+ border-color: transparent;
151
+ background: #ecf5ff;
152
+ z-index: 10;
153
+ }
154
+
155
+ .editor-item-drag {
156
+ position: absolute;
157
+ top: 0;
158
+ left: 0;
159
+ width: 20px;
160
+ height: 20px;
161
+ background: #409eff;
162
+ color: #fff;
163
+ display: none;
164
+ align-items: center;
165
+ justify-content: center;
166
+ cursor: move;
167
+ font-size: 12px;
168
+ z-index: 11;
169
+ }
170
+
171
+ &:hover > .editor-item-drag,
172
+ &.is-active > .editor-item-drag {
173
+ display: flex;
174
+ }
175
+
176
+ .editor-item-tag {
177
+ position: absolute;
178
+ top: -20px;
179
+ left: 0;
180
+ background: #409eff;
181
+ color: #fff;
182
+ font-size: 11px;
183
+ padding: 0 6px;
184
+ height: 20px;
185
+ line-height: 20px;
186
+ border-radius: 2px 2px 0 0;
187
+ }
188
+
189
+ .editor-item-visible-flag {
190
+ position: absolute;
191
+ top: -10px;
192
+ right: 0;
193
+ height: 18px;
194
+ line-height: 18px;
195
+ padding: 0 6px;
196
+ font-size: 11px;
197
+ color: #b88230;
198
+ background: #fdf6ec;
199
+ border: 1px solid #f3d19e;
200
+ border-radius: 0 0 0 4px;
201
+ cursor: pointer;
202
+ z-index: 12;
203
+
204
+ &:hover {
205
+ color: #ffffff;
206
+ background: #e6a23c;
207
+ border-color: #e6a23c;
208
+ }
209
+ }
210
+
211
+ .editor-item-actions {
212
+ position: absolute;
213
+ bottom: -24px;
214
+ right: -2px;
215
+ display: flex;
216
+ background: #409eff;
217
+ border-radius: 0 0 2px 2px;
218
+ overflow: hidden;
219
+ z-index: 11;
220
+
221
+ .action-btn {
222
+ width: 24px;
223
+ height: 24px;
224
+ display: flex;
225
+ align-items: center;
226
+ justify-content: center;
227
+ color: #fff;
228
+ font-size: 14px;
229
+ cursor: pointer;
230
+
231
+ &:hover {
232
+ background: #66b1ff;
233
+ }
234
+
235
+ &.delete:hover {
236
+ background: #f56c6c;
237
+ }
238
+ }
239
+ }
240
+
241
+ .editor-item-content {
242
+ // 防止内部 FormItem 自身的点击或边距干扰
243
+ :deep(.el-form-item) {
244
+ margin-bottom: 0 !important;
245
+ padding: 10px;
246
+ pointer-events: none; // 编辑状态下不触发内部组件交互
247
+ }
248
+
249
+ :deep(.el-form-item.is-editor-container-item) {
250
+ pointer-events: auto;
251
+ }
252
+ }
253
+ }
254
+ </style>
@@ -0,0 +1,82 @@
1
+ import { ref } from 'vue'
2
+
3
+ export interface EditorGroupTitleStyle {
4
+ key: string
5
+ label: string
6
+ className: string
7
+ description?: string
8
+ }
9
+
10
+ const styleMap = new Map<string, EditorGroupTitleStyle>()
11
+ const groupTitleStyleVersion = ref(0)
12
+
13
+ const trackGroupTitleStyleVersion = () => groupTitleStyleVersion.value
14
+
15
+ export const registerEditorGroupTitleStyle = (style: EditorGroupTitleStyle) => {
16
+ const previous = styleMap.get(style.key)
17
+ styleMap.set(style.key, { ...style })
18
+ groupTitleStyleVersion.value += 1
19
+
20
+ return () => {
21
+ if (previous) {
22
+ styleMap.set(style.key, previous)
23
+ } else {
24
+ styleMap.delete(style.key)
25
+ }
26
+ groupTitleStyleVersion.value += 1
27
+ }
28
+ }
29
+
30
+ export const getEditorGroupTitleStyles = () => {
31
+ trackGroupTitleStyleVersion()
32
+ return Array.from(styleMap.values())
33
+ }
34
+
35
+ registerEditorGroupTitleStyle({
36
+ key: 'default',
37
+ label: '默认标题',
38
+ className: '',
39
+ description: '保持组件默认标题展示'
40
+ })
41
+
42
+ registerEditorGroupTitleStyle({
43
+ key: 'section',
44
+ label: '章节标题',
45
+ className: 'x-group-title--section',
46
+ description: '适合常规表单分区'
47
+ })
48
+
49
+ registerEditorGroupTitleStyle({
50
+ key: 'bar',
51
+ label: '左边线标题',
52
+ className: 'x-group-title--bar',
53
+ description: '强调当前区域层级'
54
+ })
55
+
56
+ registerEditorGroupTitleStyle({
57
+ key: 'gradient-bar',
58
+ label: '渐变条标题',
59
+ className: 'x-group-title--gradient-bar',
60
+ description: '主题色淡出背景,适合醒目的分区标题'
61
+ })
62
+
63
+ registerEditorGroupTitleStyle({
64
+ key: 'solid',
65
+ label: '背景条标题',
66
+ className: 'x-group-title--solid',
67
+ description: '适合较强的分组分隔'
68
+ })
69
+
70
+ registerEditorGroupTitleStyle({
71
+ key: 'underline',
72
+ label: '分割线标题',
73
+ className: 'x-group-title--underline',
74
+ description: '适合信息密度较高的表单'
75
+ })
76
+
77
+ registerEditorGroupTitleStyle({
78
+ key: 'quiet',
79
+ label: '紧凑标题',
80
+ className: 'x-group-title--quiet',
81
+ description: '适合弱化标题存在感'
82
+ })
package/src/index.ts ADDED
@@ -0,0 +1,6 @@
1
+ export { default as XEditor } from './x-editor.vue'
2
+ export { default as DefaultDictOptionsPanel } from './components/options/default-dict-options-panel.vue'
3
+ export * from './option-sources'
4
+ export * from './group-title-styles'
5
+ export * from './validation-rules'
6
+ export * from './utils/local-dict-center'
@@ -0,0 +1,45 @@
1
+ import { markRaw, ref, type Component } from 'vue'
2
+
3
+ export interface EditorOptionSource {
4
+ type: string
5
+ label: string
6
+ component?: Component
7
+ }
8
+
9
+ const sourceMap = new Map<string, EditorOptionSource>()
10
+ const optionSourceVersion = ref(0)
11
+
12
+ const trackOptionSourceVersion = () => optionSourceVersion.value
13
+
14
+ export const registerEditorOptionSource = (source: EditorOptionSource) => {
15
+ const previous = sourceMap.get(source.type)
16
+ sourceMap.set(source.type, {
17
+ ...source,
18
+ component: source.component ? markRaw(source.component) : undefined
19
+ })
20
+ optionSourceVersion.value += 1
21
+
22
+ return () => {
23
+ if (previous) {
24
+ sourceMap.set(source.type, previous)
25
+ } else {
26
+ sourceMap.delete(source.type)
27
+ }
28
+ optionSourceVersion.value += 1
29
+ }
30
+ }
31
+
32
+ export const getEditorOptionSources = () => {
33
+ trackOptionSourceVersion()
34
+ return Array.from(sourceMap.values())
35
+ }
36
+
37
+ export const getEditorOptionSource = (type: string) => {
38
+ trackOptionSourceVersion()
39
+ return sourceMap.get(type)
40
+ }
41
+
42
+ registerEditorOptionSource({
43
+ type: 'static',
44
+ label: '直接配置'
45
+ })
@@ -0,0 +1,278 @@
1
+ import { markRaw } from 'vue'
2
+ import type { XFormItem } from 'xkit-ui'
3
+ import FormLayoutEditor from './components/form-layout-editor.vue'
4
+ import type { EditorConfigTab } from './component-configs/types'
5
+ import { fieldRowsToRecord, recordToFieldRows } from './utils/record-field'
6
+
7
+ export interface RootComponentConfig {
8
+ label: string
9
+ value: string
10
+ configTabs?: EditorConfigTab[]
11
+ configSchema: {
12
+ body: XFormItem[]
13
+ }
14
+ }
15
+
16
+ const rootBasicConfig: XFormItem[] = [
17
+ {
18
+ title: '表单属性',
19
+ type: 'group',
20
+ titleClass: 'config-group-title',
21
+ label: false
22
+ },
23
+ {
24
+ label: '表单标题',
25
+ name: 'title',
26
+ type: 'textarea',
27
+ rows: 3,
28
+ placeholder: '可选,支持换行'
29
+ },
30
+ {
31
+ label: '标题对齐',
32
+ name: 'titleAlign',
33
+ type: 'x-radios',
34
+ mode: 'button',
35
+ size: 'small',
36
+ options: [
37
+ { label: '左', value: 'left' },
38
+ { label: '中', value: 'center' },
39
+ { label: '右', value: 'right' }
40
+ ],
41
+ visible(row) {
42
+ return Boolean(row.title)
43
+ },
44
+ pipeIn(value: string | undefined) {
45
+ return value ?? 'left'
46
+ },
47
+ pipeOut(value: string) {
48
+ return value === 'left' ? undefined : value
49
+ }
50
+ },
51
+ {
52
+ label: '标签宽度',
53
+ name: 'labelWidth',
54
+ type: 'input',
55
+ placeholder: '例如 100'
56
+ },
57
+ {
58
+ label: '标签位置',
59
+ name: 'labelPosition',
60
+ type: 'x-radios',
61
+ mode: 'button',
62
+ size: 'small',
63
+ options: [
64
+ { label: '左', value: 'left' },
65
+ { label: '上', value: 'top' },
66
+ { label: '右', value: 'right' }
67
+ ],
68
+ defaultValue: 'right'
69
+ },
70
+ {
71
+ label: '表单尺寸',
72
+ name: 'size',
73
+ type: 'x-radios',
74
+ mode: 'button',
75
+ size: 'small',
76
+ options: [
77
+ { label: '默认', value: '' },
78
+ { label: '小', value: 'small' },
79
+ { label: '大', value: 'large' }
80
+ ]
81
+ },
82
+ {
83
+ label: '全局可清空',
84
+ name: 'clearable',
85
+ type: 'switch'
86
+ },
87
+ {
88
+ label: '显示边框',
89
+ name: 'border',
90
+ type: 'switch'
91
+ },
92
+ {
93
+ title: '按钮与提交',
94
+ type: 'group',
95
+ titleClass: 'config-group-title',
96
+ label: false
97
+ },
98
+ {
99
+ label: '显示按钮组',
100
+ name: 'showButtonGroup',
101
+ type: 'switch',
102
+ defaultValue: true
103
+ },
104
+ {
105
+ label: '显示提交按钮',
106
+ name: 'submitButtonVisible',
107
+ type: 'switch',
108
+ defaultValue: true
109
+ },
110
+ {
111
+ label: '提交按钮文本',
112
+ name: 'submitButtonText',
113
+ type: 'input'
114
+ },
115
+ {
116
+ label: '显示重置按钮',
117
+ name: 'resetButtonVisible',
118
+ type: 'switch',
119
+ defaultValue: true
120
+ },
121
+ {
122
+ label: '按钮对齐方式',
123
+ name: 'buttonAlign',
124
+ type: 'x-radios',
125
+ mode: 'button',
126
+ size: 'small',
127
+ options: [
128
+ { label: '左', value: 'left' },
129
+ { label: '中', value: 'center' },
130
+ { label: '右', value: 'right' }
131
+ ],
132
+ defaultValue: 'center'
133
+ }
134
+ ]
135
+
136
+ const rootLayoutConfig: XFormItem[] = [
137
+ {
138
+ title: '表单布局',
139
+ name: 'layout',
140
+ type: 'custom',
141
+ component: markRaw(FormLayoutEditor),
142
+ titleClass: 'config-group-title',
143
+ label: false,
144
+ rootKey: 'layout',
145
+ attrs(row) {
146
+ return {
147
+ formSchema: row
148
+ }
149
+ }
150
+ }
151
+ ]
152
+
153
+ const rootDataConfig: XFormItem[] = [
154
+ {
155
+ title: '数据与行为',
156
+ type: 'group',
157
+ titleClass: 'config-group-title',
158
+ label: false
159
+ },
160
+ {
161
+ label: '默认值',
162
+ name: 'defaultValues',
163
+ type: 'x-input-array',
164
+ labelPosition: 'top',
165
+ useScaffoldValue: false,
166
+ showFooterAddButton: true,
167
+ addable: true,
168
+ deletable: true,
169
+ useLayout: true,
170
+ layout: {
171
+ row: { gutter: 8 },
172
+ col: { span: 12 }
173
+ },
174
+ items: [
175
+ {
176
+ label: false,
177
+ name: 'key',
178
+ type: 'input',
179
+ clearable: false,
180
+ placeholder: '字段名',
181
+ span: 12
182
+ },
183
+ {
184
+ label: false,
185
+ name: 'value',
186
+ type: 'input',
187
+ clearable: true,
188
+ placeholder: '默认值',
189
+ span: 12
190
+ }
191
+ ],
192
+ pipeIn: recordToFieldRows,
193
+ pipeOut: fieldRowsToRecord
194
+ },
195
+ {
196
+ label: '提交后清空',
197
+ name: 'clearOnSubmit',
198
+ type: 'switch'
199
+ },
200
+ {
201
+ label: '提交完成后清空',
202
+ name: 'clearOnSubmitDone',
203
+ type: 'switch'
204
+ },
205
+ {
206
+ label: '显示提交加载',
207
+ name: 'showLoading',
208
+ type: 'switch'
209
+ },
210
+ {
211
+ label: '值实时同步',
212
+ name: 'valueReactive',
213
+ type: 'switch'
214
+ },
215
+ {
216
+ label: '自动提交',
217
+ name: 'autoSubmit',
218
+ type: 'switch'
219
+ }
220
+ ]
221
+
222
+ const rootAdvancedConfig: XFormItem[] = [
223
+ {
224
+ title: '高级',
225
+ type: 'group',
226
+ titleClass: 'config-group-title',
227
+ label: false
228
+ },
229
+ {
230
+ label: '动作配置',
231
+ name: 'actions',
232
+ type: 'input',
233
+ placeholder: 'JSON'
234
+ },
235
+ {
236
+ label: '表单类型',
237
+ name: 'formType',
238
+ type: 'input'
239
+ },
240
+ {
241
+ label: '静态表单',
242
+ name: 'static',
243
+ type: 'switch'
244
+ },
245
+ {
246
+ label: '隐藏必填星号',
247
+ name: 'hideRequiredAsterisk',
248
+ type: 'switch'
249
+ },
250
+ {
251
+ label: '显示动静切换',
252
+ name: 'showToggleButton',
253
+ type: 'switch'
254
+ },
255
+ {
256
+ label: '调试模式',
257
+ name: 'debug',
258
+ type: 'switch'
259
+ }
260
+ ]
261
+
262
+ const rootConfigTabs: EditorConfigTab[] = [
263
+ { key: 'basic', body: rootBasicConfig },
264
+ { key: 'layout', body: rootLayoutConfig },
265
+ { key: 'data', body: rootDataConfig },
266
+ { key: 'advanced', body: rootAdvancedConfig }
267
+ ]
268
+
269
+ export const rootComponentConfigMap: Record<string, RootComponentConfig> = {
270
+ 'x-form': {
271
+ label: '表单',
272
+ value: 'x-form',
273
+ configTabs: rootConfigTabs,
274
+ configSchema: {
275
+ body: [...rootBasicConfig, ...rootLayoutConfig, ...rootDataConfig, ...rootAdvancedConfig]
276
+ }
277
+ }
278
+ }