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,291 @@
1
+ <template>
2
+ <template v-if="usesSpanEditor">
3
+ <FormItemSpanEditor
4
+ :model-value="selectedItem.span"
5
+ :default-span="spanEditorDefaultSpan"
6
+ :control-width="selectedItem.style?.width"
7
+ :offset-right="offsetRightValue"
8
+ :show-advanced="activeType === 'grid'"
9
+ @update:modelValue="handleSpanChange"
10
+ @update:controlWidth="handleControlWidthChange"
11
+ @update:offsetRight="handleOffsetRightChange"
12
+ />
13
+ </template>
14
+ <ObjectSectionEditor
15
+ v-else
16
+ :key="activeType"
17
+ :model-value="activeValue"
18
+ :title="title || activeTitle"
19
+ :root-key="rootKey"
20
+ :value-mode="activeValueMode"
21
+ :main-key="activeMainKey"
22
+ :sync-keys="activeSyncKeys"
23
+ section-mode="plain"
24
+ :sections="activeSections"
25
+ v-bind="gridSyncAttrs"
26
+ @update:modelValue="handleChange"
27
+ @update:offsetRight="emit('update:offsetRight', $event)"
28
+ />
29
+ </template>
30
+
31
+ <script setup lang="ts">
32
+ import { computed, inject, type ComputedRef } from 'vue'
33
+ import ObjectSectionEditor from './object-section-editor.vue'
34
+ import FormItemSpanEditor from './form-item-span-editor.vue'
35
+ import {
36
+ descriptionsItemLayoutSections,
37
+ inputArrayItemWidthLayoutSections,
38
+ inputTableMergedColumnLayoutSections,
39
+ inputTableNestedColumnLayoutSections,
40
+ tableItemLayoutSections
41
+ } from '../component-configs/layout-sections'
42
+ import { setFormItemControlWidth } from '../utils/form-item-width'
43
+
44
+ type LayoutType = 'grid' | 'descriptions' | 'table' | 'input-array-grid' | 'input-array-width'
45
+ type EditorNode = Record<string, any>
46
+
47
+ const props = defineProps<{
48
+ modelValue?: any
49
+ title?: string
50
+ offsetRight?: number
51
+ }>()
52
+
53
+ const emit = defineEmits<{
54
+ (event: 'update:modelValue', value: any): void
55
+ (event: 'update:offsetRight', value: any): void
56
+ }>()
57
+
58
+ const editorContext = inject<ComputedRef<{ form?: any; selectedItem?: any }> | null>('x-editor-context', null)
59
+ const EDITOR_ID_FIELD = '__editorId'
60
+
61
+ const selectedItem = computed(() => editorContext?.value?.selectedItem || {})
62
+ const selectedEditorId = computed(() => selectedItem.value?.[EDITOR_ID_FIELD] ?? selectedItem.value?._id)
63
+
64
+ const findParentByEditorId = (items: EditorNode[] = [], editorId: unknown, parent?: EditorNode): EditorNode | undefined => {
65
+ if (editorId === undefined || editorId === null) return undefined
66
+
67
+ for (const item of items) {
68
+ const itemId = item?.[EDITOR_ID_FIELD] ?? item?._id
69
+ if (itemId === editorId) return parent
70
+
71
+ for (const key of ['body', 'items']) {
72
+ if (!Array.isArray(item?.[key])) continue
73
+ const result = findParentByEditorId(item[key], editorId, item)
74
+ if (result) return result
75
+ }
76
+ }
77
+ }
78
+
79
+ const parentNode = computed(() => findParentByEditorId(editorContext?.value?.form?.body || [], selectedEditorId.value))
80
+ const inputArrayItemParent = computed(() => (parentNode.value?.type === 'x-input-array' ? parentNode.value : undefined))
81
+ const isInputArrayItem = computed(() => Boolean(inputArrayItemParent.value))
82
+ const isGridInputArrayItem = computed(() => Boolean(inputArrayItemParent.value?.useLayout))
83
+ const inputArrayDefaultSpan = computed(() => {
84
+ const value = inputArrayItemParent.value?.layout?.col?.span
85
+ return typeof value === 'number' ? value : 12
86
+ })
87
+ const rootDefaultSpan = computed(() => {
88
+ const parentLayoutSpan = parentNode.value?.layout?.col?.span
89
+ if (typeof parentLayoutSpan === 'number') return parentLayoutSpan
90
+ const formLayoutSpan = editorContext?.value?.form?.layout?.col?.span
91
+ return typeof formLayoutSpan === 'number' ? formLayoutSpan : 24
92
+ })
93
+ const spanEditorDefaultSpan = computed(() => (activeType.value === 'input-array-grid' ? inputArrayDefaultSpan.value : rootDefaultSpan.value))
94
+ const usesSpanEditor = computed(() => activeType.value === 'grid' || activeType.value === 'input-array-grid')
95
+ const offsetRightValue = computed(() => clampOffsetRight(props.offsetRight ?? selectedItem.value.offsetRight))
96
+
97
+ const activeType = computed<LayoutType>(() => {
98
+ if (isInputArrayItem.value) return isGridInputArrayItem.value ? 'input-array-grid' : 'input-array-width'
99
+ const type = editorContext?.value?.form?.layout?.type
100
+ if (type === 'descriptions' || type === 'table') return type
101
+ return 'grid'
102
+ })
103
+
104
+ const inputTableColumnParent = computed(() => {
105
+ return parentNode.value?.type === 'x-input-table' ? parentNode.value : undefined
106
+ })
107
+ const isInputTableColumn = computed(() => Boolean(inputTableColumnParent.value))
108
+ const isMergedInputTableColumn = computed(() => inputTableColumnParent.value?.tableComposition === 'merged')
109
+
110
+ const activeValue = computed(() => {
111
+ if (activeType.value === 'input-array-width') {
112
+ return {
113
+ width: selectedItem.value.style?.width
114
+ }
115
+ }
116
+ if (activeType.value === 'table' && isInputTableColumn.value) {
117
+ if (isMergedInputTableColumn.value) {
118
+ return {
119
+ align: selectedItem.value.align,
120
+ headerAlign: selectedItem.value.headerAlign,
121
+ colspan: selectedItem.value.colspan ?? selectedItem.value.layoutCfg?.table?.colspan ?? selectedItem.value.layoutCfg?.table?.valueColspan
122
+ }
123
+ }
124
+ return {
125
+ align: selectedItem.value.align,
126
+ headerAlign: selectedItem.value.headerAlign,
127
+ minWidth: selectedItem.value.minWidth
128
+ }
129
+ }
130
+ if (activeType.value === 'grid') {
131
+ return props.modelValue
132
+ }
133
+ return selectedItem.value.layoutCfg?.[activeType.value] || {}
134
+ })
135
+
136
+ const activeSections = computed(() => {
137
+ if (activeType.value === 'input-array-width') return inputArrayItemWidthLayoutSections
138
+ if (activeType.value === 'table' && isInputTableColumn.value) {
139
+ return isMergedInputTableColumn.value ? inputTableMergedColumnLayoutSections : inputTableNestedColumnLayoutSections
140
+ }
141
+ if (activeType.value === 'descriptions') return descriptionsItemLayoutSections
142
+ if (activeType.value === 'table') return tableItemLayoutSections
143
+ return []
144
+ })
145
+
146
+ const activeTitle = computed(() => {
147
+ if (activeType.value === 'input-array-grid') return '数组子项栅格'
148
+ if (activeType.value === 'input-array-width') return '数组子项宽度'
149
+ if (activeType.value === 'table' && isInputTableColumn.value) return '列布局'
150
+ if (activeType.value === 'descriptions') return '描述表布局'
151
+ if (activeType.value === 'table') return '表格布局'
152
+ return '布局配置'
153
+ })
154
+
155
+ const rootKey = computed(() => {
156
+ if (activeType.value === 'input-array-grid') return 'span'
157
+ if (activeType.value === 'input-array-width') return 'style.width'
158
+ if (activeType.value === 'grid') return 'layout'
159
+ return `layoutCfg.${activeType.value}`
160
+ })
161
+
162
+ const activeValueMode = computed<'flat'>(() => 'flat')
163
+ const activeMainKey = computed(() => undefined)
164
+ const activeSyncKeys = computed(() => undefined)
165
+ const gridSyncAttrs = computed(() => {
166
+ if (activeType.value === 'input-array-grid' || activeType.value === 'input-array-width') return {}
167
+ if (activeType.value !== 'grid') return {}
168
+ return {
169
+ offsetRight: props.offsetRight
170
+ }
171
+ })
172
+
173
+ const cleanRecord = (value: any) => {
174
+ if (!value || typeof value !== 'object') return undefined
175
+ const next = Object.entries(value).reduce<Record<string, any>>((result, [key, itemValue]) => {
176
+ if (itemValue !== undefined && itemValue !== null && itemValue !== '') {
177
+ result[key] = itemValue
178
+ }
179
+ return result
180
+ }, {})
181
+ return Object.keys(next).length > 0 ? next : undefined
182
+ }
183
+
184
+ const handleChange = (value: any) => {
185
+ if (activeType.value === 'input-array-width') {
186
+ if (value?.width === undefined || value?.width === null || value?.width === '') {
187
+ const style = { ...(selectedItem.value.style || {}) }
188
+ delete style.width
189
+ const cleanedStyle = cleanRecord(style)
190
+ selectedItem.value.style = cleanedStyle
191
+ } else {
192
+ const nextStyle = {
193
+ ...(selectedItem.value.style || {}),
194
+ width: value.width
195
+ }
196
+ selectedItem.value.style = nextStyle
197
+ }
198
+ delete selectedItem.value.span
199
+ emit('update:modelValue', selectedItem.value.span)
200
+ return
201
+ }
202
+
203
+ const item = selectedItem.value
204
+ if (activeType.value === 'table' && isInputTableColumn.value) {
205
+ const cleaned = cleanRecord(value) || {}
206
+ if (cleaned.align === undefined) {
207
+ delete item.align
208
+ } else {
209
+ item.align = cleaned.align
210
+ }
211
+ if (cleaned.headerAlign === undefined) {
212
+ delete item.headerAlign
213
+ } else {
214
+ item.headerAlign = cleaned.headerAlign
215
+ }
216
+
217
+ if (isMergedInputTableColumn.value) {
218
+ if (cleaned.colspan === undefined) {
219
+ delete item.colspan
220
+ } else {
221
+ item.colspan = cleaned.colspan
222
+ }
223
+ delete item.minWidth
224
+ } else {
225
+ if (cleaned.minWidth === undefined) {
226
+ delete item.minWidth
227
+ } else {
228
+ item.minWidth = cleaned.minWidth
229
+ }
230
+ delete item.colspan
231
+ }
232
+
233
+ const tableLayout = { ...(item.layoutCfg?.table || {}) }
234
+ delete tableLayout.basic
235
+ delete tableLayout.advanced
236
+ delete tableLayout.colspan
237
+ delete tableLayout.labelColspan
238
+ delete tableLayout.valueColspan
239
+ delete tableLayout.valueMinWidth
240
+ delete tableLayout.rowspan
241
+
242
+ const layoutCfg = { ...(item.layoutCfg || {}), table: cleanRecord(tableLayout) }
243
+ if (!layoutCfg.table) delete layoutCfg.table
244
+ item.layoutCfg = cleanRecord(layoutCfg)
245
+ emit('update:modelValue', props.modelValue)
246
+ return
247
+ }
248
+
249
+ const layoutCfg = {
250
+ ...(item.layoutCfg || {}),
251
+ [activeType.value]: cleanRecord(value)
252
+ }
253
+ if (!layoutCfg[activeType.value]) {
254
+ delete layoutCfg[activeType.value]
255
+ }
256
+ item.layoutCfg = cleanRecord(layoutCfg)
257
+ emit('update:modelValue', props.modelValue)
258
+ }
259
+
260
+ const handleSpanChange = (value: number | undefined) => {
261
+ if (value === undefined || value === null) {
262
+ delete selectedItem.value.span
263
+ } else {
264
+ selectedItem.value.span = value
265
+ }
266
+ emit('update:modelValue', selectedItem.value.span)
267
+ }
268
+
269
+ const handleControlWidthChange = (value: number | string | undefined) => {
270
+ if (activeType.value !== 'grid') return
271
+ setFormItemControlWidth(selectedItem.value, value)
272
+ emit('update:modelValue', selectedItem.value.span)
273
+ }
274
+
275
+ function clampOffsetRight(value: unknown) {
276
+ const numericValue = Number(value)
277
+ if (!Number.isFinite(numericValue)) return 0
278
+ return Math.min(23, Math.max(0, Math.round(numericValue)))
279
+ }
280
+
281
+ const handleOffsetRightChange = (value: number | undefined) => {
282
+ const nextValue = clampOffsetRight(value)
283
+ if (nextValue === 0) {
284
+ delete selectedItem.value.offsetRight
285
+ emit('update:offsetRight', undefined)
286
+ return
287
+ }
288
+ selectedItem.value.offsetRight = nextValue
289
+ emit('update:offsetRight', nextValue)
290
+ }
291
+ </script>
@@ -0,0 +1,328 @@
1
+ <template>
2
+ <div class="form-item-span-editor">
3
+ <div class="form-item-span-editor__panel">
4
+ <span class="form-item-span-editor__corner" />
5
+ <div class="form-item-span-editor__header">
6
+ <div class="form-item-span-editor__path">span</div>
7
+ <button v-if="showAdvanced" class="form-item-span-editor__toggle" type="button" @click="advancedVisible = !advancedVisible">
8
+ {{ advancedVisible ? '折叠' : '展开' }}
9
+ </button>
10
+ </div>
11
+ <div class="form-item-span-editor__row">
12
+ <span class="form-item-span-editor__label">自定义列数</span>
13
+ <el-switch :model-value="enabled" @update:modelValue="handleEnabledChange" />
14
+ </div>
15
+ <div v-if="enabled" class="form-item-span-editor__body">
16
+ <button
17
+ v-for="cell in cells"
18
+ :key="cell"
19
+ class="form-item-span-editor__cell"
20
+ :class="{
21
+ 'is-active': cell <= activeCellCount,
22
+ 'is-selected-marker': cell === selectedMarkerCell,
23
+ }"
24
+ type="button"
25
+ @click="handleCellClick(cell)"
26
+ >
27
+ <span v-if="cellMarkers[cell]" class="form-item-span-editor__cell-fraction" aria-hidden="true">
28
+ <span>{{ cellMarkers[cell].numerator }}</span>
29
+ <span v-if="cellMarkers[cell].denominator">{{ cellMarkers[cell].denominator }}</span>
30
+ </span>
31
+ </button>
32
+ <el-input-number
33
+ class="form-item-span-editor__number"
34
+ :model-value="resolvedSpan"
35
+ :min="1"
36
+ :max="24"
37
+ :step="1"
38
+ :controls="false"
39
+ controls-position="right"
40
+ size="small"
41
+ @update:modelValue="handleSpanChange"
42
+ />
43
+ </div>
44
+ <div v-if="showAdvanced && advancedVisible" class="form-item-span-editor__advanced">
45
+ <div class="form-item-span-editor__row">
46
+ <span class="form-item-span-editor__label">控件宽度占满</span>
47
+ <el-switch :model-value="controlWidthFull" @update:modelValue="handleControlWidthFullChange" />
48
+ </div>
49
+ <div v-if="!controlWidthFull" class="form-item-span-editor__row form-item-span-editor__row--nested">
50
+ <span class="form-item-span-editor__label">控件宽度</span>
51
+ <div class="form-item-span-editor__number-with-unit">
52
+ <el-input-number
53
+ class="form-item-span-editor__width-number"
54
+ :model-value="customControlWidth"
55
+ :min="1"
56
+ :step="10"
57
+ controls-position="right"
58
+ size="small"
59
+ @update:modelValue="handleControlWidthChange"
60
+ />
61
+ <span class="form-item-span-editor__unit">px</span>
62
+ </div>
63
+ </div>
64
+ <div class="form-item-span-editor__row form-item-span-editor__row--nested">
65
+ <span class="form-item-span-editor__label" title="不占满一行时,如需独占一行,可设置右侧排斥。">右侧排斥</span>
66
+ <el-input-number
67
+ class="form-item-span-editor__offset-right-number"
68
+ :model-value="resolvedOffsetRight"
69
+ :min="0"
70
+ :max="23"
71
+ :step="1"
72
+ controls-position="right"
73
+ size="small"
74
+ @update:modelValue="handleOffsetRightChange"
75
+ />
76
+ </div>
77
+ </div>
78
+ </div>
79
+ </div>
80
+ </template>
81
+
82
+ <script setup lang="ts">
83
+ import { computed, ref } from 'vue'
84
+ import { ElInputNumber, ElSwitch } from 'element-plus'
85
+ import {
86
+ DEFAULT_FORM_ITEM_CUSTOM_WIDTH,
87
+ isFullFormItemControlWidth,
88
+ normalizeCustomFormItemControlWidth
89
+ } from '../utils/form-item-width'
90
+
91
+ const props = defineProps<{
92
+ modelValue?: number
93
+ defaultSpan?: number
94
+ controlWidth?: number | string
95
+ offsetRight?: number
96
+ showAdvanced?: boolean
97
+ }>()
98
+
99
+ const emit = defineEmits<{
100
+ (event: 'update:modelValue', value: number | undefined): void
101
+ (event: 'update:controlWidth', value: number | string | undefined): void
102
+ (event: 'update:offsetRight', value: number | undefined): void
103
+ }>()
104
+
105
+ const cells = Array.from({ length: 12 }, (_, index) => index + 1)
106
+ const cellMarkers: Record<number, { numerator: string; denominator?: string }> = {
107
+ 3: { numerator: '1', denominator: '4' },
108
+ 4: { numerator: '1', denominator: '3' },
109
+ 6: { numerator: '1', denominator: '2' },
110
+ 8: { numerator: '2', denominator: '3' },
111
+ 9: { numerator: '3', denominator: '4' },
112
+ 12: { numerator: '1' },
113
+ }
114
+ const advancedVisible = ref(false)
115
+ const enabled = computed(() => props.modelValue !== undefined && props.modelValue !== null)
116
+ const fallbackSpan = computed(() => clampSpan(props.defaultSpan ?? 24))
117
+ const resolvedSpan = computed(() => clampSpan(props.modelValue ?? fallbackSpan.value))
118
+ const controlWidthFull = computed(() => isFullFormItemControlWidth(props.controlWidth))
119
+ const customControlWidth = computed(() => {
120
+ return controlWidthFull.value ? DEFAULT_FORM_ITEM_CUSTOM_WIDTH : normalizeCustomFormItemControlWidth(props.controlWidth, DEFAULT_FORM_ITEM_CUSTOM_WIDTH)
121
+ })
122
+ const resolvedOffsetRight = computed(() => clampOffsetRight(props.offsetRight))
123
+ const activeCellCount = computed(() => Math.ceil(resolvedSpan.value / 2))
124
+ const selectedMarkerCell = computed(() => {
125
+ const cell = resolvedSpan.value / 2
126
+ return Number.isInteger(cell) && cellMarkers[cell] ? cell : null
127
+ })
128
+
129
+ function clampSpan(value: unknown) {
130
+ const numericValue = Number(value)
131
+ if (!Number.isFinite(numericValue)) return 24
132
+ return Math.min(24, Math.max(1, Math.round(numericValue)))
133
+ }
134
+
135
+ function clampOffsetRight(value: unknown) {
136
+ const numericValue = Number(value)
137
+ if (!Number.isFinite(numericValue)) return 0
138
+ return Math.min(23, Math.max(0, Math.round(numericValue)))
139
+ }
140
+
141
+ const handleEnabledChange = (value: boolean | string | number) => {
142
+ emit('update:modelValue', value ? fallbackSpan.value : undefined)
143
+ }
144
+
145
+ const handleCellClick = (cell: number) => {
146
+ emit('update:modelValue', clampSpan(cell * 2))
147
+ }
148
+
149
+ const handleSpanChange = (value: number | undefined) => {
150
+ emit('update:modelValue', value === undefined || value === null ? fallbackSpan.value : clampSpan(value))
151
+ }
152
+
153
+ const handleControlWidthFullChange = (value: boolean | string | number) => {
154
+ emit('update:controlWidth', value ? undefined : customControlWidth.value)
155
+ }
156
+
157
+ const handleControlWidthChange = (value: number | undefined) => {
158
+ emit('update:controlWidth', normalizeCustomFormItemControlWidth(value, DEFAULT_FORM_ITEM_CUSTOM_WIDTH))
159
+ }
160
+
161
+ const handleOffsetRightChange = (value: number | undefined) => {
162
+ const nextValue = clampOffsetRight(value)
163
+ emit('update:offsetRight', nextValue === 0 ? undefined : nextValue)
164
+ }
165
+ </script>
166
+
167
+ <style scoped lang="scss">
168
+ .form-item-span-editor {
169
+ width: 100%;
170
+ }
171
+
172
+ .form-item-span-editor__panel {
173
+ position: relative;
174
+ padding: 8px;
175
+ border: 1px solid var(--el-border-color-lighter);
176
+ border-radius: 4px;
177
+ background: var(--el-fill-color-blank);
178
+ }
179
+
180
+ .form-item-span-editor__corner {
181
+ position: absolute;
182
+ top: -1px;
183
+ left: -1px;
184
+ width: 8px;
185
+ height: 8px;
186
+ border-top: 1px solid var(--el-color-primary);
187
+ border-left: 1px solid var(--el-color-primary);
188
+ }
189
+
190
+ .form-item-span-editor__header {
191
+ display: flex;
192
+ align-items: center;
193
+ justify-content: space-between;
194
+ gap: 8px;
195
+ margin-bottom: 8px;
196
+ }
197
+
198
+ .form-item-span-editor__path {
199
+ color: var(--el-text-color-placeholder);
200
+ font-size: 12px;
201
+ line-height: 1;
202
+ }
203
+
204
+ .form-item-span-editor__toggle {
205
+ height: 18px;
206
+ padding: 0;
207
+ border: 0;
208
+ background: transparent;
209
+ color: var(--el-color-primary);
210
+ font-size: 12px;
211
+ line-height: 18px;
212
+ cursor: pointer;
213
+ }
214
+
215
+ .form-item-span-editor__row {
216
+ display: flex;
217
+ align-items: center;
218
+ justify-content: space-between;
219
+ gap: 8px;
220
+ }
221
+
222
+ .form-item-span-editor__row--nested {
223
+ padding-left: 8px;
224
+ }
225
+
226
+ .form-item-span-editor__label {
227
+ color: var(--el-text-color-regular);
228
+ font-size: 13px;
229
+ }
230
+
231
+ .form-item-span-editor__body {
232
+ display: grid;
233
+ grid-template-columns: repeat(12, minmax(0, 1fr)) 44px;
234
+ gap: 4px;
235
+ align-items: center;
236
+ margin-top: 10px;
237
+ }
238
+
239
+ .form-item-span-editor__cell {
240
+ display: flex;
241
+ align-items: center;
242
+ justify-content: center;
243
+ height: 24px;
244
+ min-width: 0;
245
+ padding: 0;
246
+ border: 1px solid var(--el-border-color);
247
+ border-radius: 2px;
248
+ background: var(--el-fill-color-light);
249
+ cursor: pointer;
250
+
251
+ &.is-active {
252
+ border-color: var(--el-color-primary);
253
+ background: var(--el-color-primary);
254
+ }
255
+ }
256
+
257
+ .form-item-span-editor__cell-fraction {
258
+ display: inline-flex;
259
+ flex-direction: column;
260
+ align-items: center;
261
+ justify-content: center;
262
+ min-width: 10px;
263
+ color: var(--el-text-color-secondary);
264
+ font-size: 10px;
265
+ font-weight: 600;
266
+ line-height: 1;
267
+ opacity: 0;
268
+ transition: opacity var(--el-transition-duration-fast);
269
+
270
+ span + span {
271
+ margin-top: 1px;
272
+ padding-top: 1px;
273
+ border-top: 1px solid currentColor;
274
+ }
275
+ }
276
+
277
+ .form-item-span-editor__body:hover .form-item-span-editor__cell-fraction,
278
+ .form-item-span-editor__body:focus-within .form-item-span-editor__cell-fraction,
279
+ .form-item-span-editor__cell.is-selected-marker .form-item-span-editor__cell-fraction {
280
+ opacity: 1;
281
+ }
282
+
283
+ .form-item-span-editor__cell.is-active .form-item-span-editor__cell-fraction {
284
+ color: var(--el-color-white);
285
+ }
286
+
287
+ .form-item-span-editor__number {
288
+ width: 44px;
289
+ }
290
+
291
+ .form-item-span-editor__number :deep(.el-input__wrapper) {
292
+ padding-left: 4px;
293
+ padding-right: 4px;
294
+ }
295
+
296
+ .form-item-span-editor__advanced {
297
+ display: grid;
298
+ gap: 8px;
299
+ margin-top: 10px;
300
+ padding-top: 10px;
301
+ border-top: 1px solid var(--el-border-color-lighter);
302
+ }
303
+
304
+ .form-item-span-editor__number-with-unit {
305
+ display: inline-flex;
306
+ align-items: center;
307
+ gap: 4px;
308
+ }
309
+
310
+ .form-item-span-editor__width-number {
311
+ width: 86px;
312
+ }
313
+
314
+ .form-item-span-editor__offset-right-number {
315
+ width: 70px;
316
+ }
317
+
318
+ .form-item-span-editor__width-number :deep(.el-input__wrapper),
319
+ .form-item-span-editor__offset-right-number :deep(.el-input__wrapper) {
320
+ padding-left: 4px;
321
+ padding-right: 4px;
322
+ }
323
+
324
+ .form-item-span-editor__unit {
325
+ color: var(--el-text-color-secondary);
326
+ font-size: 12px;
327
+ }
328
+ </style>