@movk/nuxt 1.1.2 → 1.3.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 (301) hide show
  1. package/.nuxt/movk-ui.css +3 -0
  2. package/README.md +75 -104
  3. package/dist/module.d.mts +59 -1
  4. package/dist/module.json +2 -2
  5. package/dist/module.mjs +136 -56
  6. package/dist/runtime/components/AutoForm.d.vue.ts +10 -31
  7. package/dist/runtime/components/AutoForm.vue +114 -148
  8. package/dist/runtime/components/AutoForm.vue.d.ts +10 -31
  9. package/dist/runtime/components/ColorChooser.d.vue.ts +20 -17
  10. package/dist/runtime/components/ColorChooser.vue +305 -31
  11. package/dist/runtime/components/ColorChooser.vue.d.ts +20 -17
  12. package/dist/runtime/components/DataTable.d.vue.ts +57 -0
  13. package/dist/runtime/components/DataTable.vue +584 -0
  14. package/dist/runtime/components/DataTable.vue.d.ts +57 -0
  15. package/dist/runtime/components/DatePicker.d.vue.ts +15 -22
  16. package/dist/runtime/components/DatePicker.vue +173 -65
  17. package/dist/runtime/components/DatePicker.vue.d.ts +15 -22
  18. package/dist/runtime/components/MessageBox.d.vue.ts +36 -0
  19. package/dist/runtime/components/MessageBox.vue +113 -0
  20. package/dist/runtime/components/MessageBox.vue.d.ts +36 -0
  21. package/dist/runtime/components/PillGroup.d.vue.ts +33 -0
  22. package/dist/runtime/components/PillGroup.vue +291 -0
  23. package/dist/runtime/components/PillGroup.vue.d.ts +33 -0
  24. package/dist/runtime/components/Popconfirm.d.vue.ts +30 -0
  25. package/dist/runtime/components/Popconfirm.vue +143 -0
  26. package/dist/runtime/components/Popconfirm.vue.d.ts +30 -0
  27. package/dist/runtime/components/SearchForm.d.vue.ts +43 -0
  28. package/dist/runtime/components/SearchForm.vue +274 -0
  29. package/dist/runtime/components/SearchForm.vue.d.ts +43 -0
  30. package/dist/runtime/components/SlideVerify.d.vue.ts +13 -79
  31. package/dist/runtime/components/SlideVerify.vue +117 -90
  32. package/dist/runtime/components/SlideVerify.vue.d.ts +13 -79
  33. package/dist/runtime/components/StarRating.d.vue.ts +25 -82
  34. package/dist/runtime/components/StarRating.vue +128 -99
  35. package/dist/runtime/components/StarRating.vue.d.ts +25 -82
  36. package/dist/runtime/components/input/AsPhoneNumberInput.d.vue.ts +32 -0
  37. package/dist/runtime/components/input/AsPhoneNumberInput.vue +48 -0
  38. package/dist/runtime/components/input/AsPhoneNumberInput.vue.d.ts +32 -0
  39. package/dist/runtime/components/input/WithCharacterLimit.d.vue.ts +13 -7
  40. package/dist/runtime/components/input/WithCharacterLimit.vue +27 -15
  41. package/dist/runtime/components/input/WithCharacterLimit.vue.d.ts +13 -7
  42. package/dist/runtime/components/input/WithClear.d.vue.ts +11 -5
  43. package/dist/runtime/components/input/WithClear.vue +29 -10
  44. package/dist/runtime/components/input/WithClear.vue.d.ts +11 -5
  45. package/dist/runtime/components/input/WithCopy.d.vue.ts +13 -7
  46. package/dist/runtime/components/input/WithCopy.vue +28 -11
  47. package/dist/runtime/components/input/WithCopy.vue.d.ts +13 -7
  48. package/dist/runtime/components/input/WithFloatingLabel.d.vue.ts +33 -0
  49. package/dist/runtime/components/input/WithFloatingLabel.vue +75 -0
  50. package/dist/runtime/components/input/WithFloatingLabel.vue.d.ts +33 -0
  51. package/dist/runtime/components/input/WithPasswordToggle.d.vue.ts +13 -7
  52. package/dist/runtime/components/input/WithPasswordToggle.vue +27 -10
  53. package/dist/runtime/components/input/WithPasswordToggle.vue.d.ts +13 -7
  54. package/dist/runtime/components/theme-picker/ThemePicker.d.vue.ts +8 -1
  55. package/dist/runtime/components/theme-picker/ThemePicker.vue +37 -28
  56. package/dist/runtime/components/theme-picker/ThemePicker.vue.d.ts +8 -1
  57. package/dist/runtime/components/theme-picker/ThemePickerButton.d.vue.ts +5 -6
  58. package/dist/runtime/components/theme-picker/ThemePickerButton.vue +4 -0
  59. package/dist/runtime/components/theme-picker/ThemePickerButton.vue.d.ts +5 -6
  60. package/dist/runtime/composables/index.d.ts +9 -8
  61. package/dist/runtime/composables/index.js +2 -1
  62. package/dist/runtime/composables/useApiFetch.d.ts +23 -15
  63. package/dist/runtime/composables/useApiFetch.js +21 -28
  64. package/dist/runtime/composables/useAutoForm.d.ts +14 -98
  65. package/dist/runtime/composables/useAutoForm.js +55 -161
  66. package/dist/runtime/composables/useClientApiFetch.d.ts +7 -7
  67. package/dist/runtime/composables/useDateFormatter.d.ts +16 -3
  68. package/dist/runtime/composables/useDateFormatter.js +89 -30
  69. package/dist/runtime/composables/useDownloadWithProgress.d.ts +26 -27
  70. package/dist/runtime/composables/useDownloadWithProgress.js +143 -42
  71. package/dist/runtime/composables/useLazyApiFetch.d.ts +19 -0
  72. package/dist/runtime/composables/useLazyApiFetch.js +4 -0
  73. package/dist/runtime/composables/useMessageBox.d.ts +6 -0
  74. package/dist/runtime/composables/useMessageBox.js +16 -0
  75. package/dist/runtime/composables/useTheme.d.ts +21 -8
  76. package/dist/runtime/composables/useTheme.js +109 -86
  77. package/dist/runtime/composables/useUploadWithProgress.d.ts +22 -28
  78. package/dist/runtime/composables/useUploadWithProgress.js +79 -68
  79. package/dist/runtime/domains/api/auth.d.ts +2 -0
  80. package/dist/runtime/domains/api/auth.js +31 -0
  81. package/dist/runtime/domains/api/endpoint-config.d.ts +11 -0
  82. package/dist/runtime/domains/api/endpoint-config.js +17 -0
  83. package/dist/runtime/domains/api/errors.d.ts +2 -0
  84. package/dist/runtime/domains/api/errors.js +10 -0
  85. package/dist/runtime/domains/api/fetch-key.d.ts +20 -0
  86. package/dist/runtime/domains/api/fetch-key.js +23 -0
  87. package/dist/runtime/domains/api/interceptors/error.d.ts +13 -0
  88. package/dist/runtime/domains/api/interceptors/error.js +49 -0
  89. package/dist/runtime/domains/api/interceptors/request.d.ts +12 -0
  90. package/dist/runtime/domains/api/interceptors/request.js +46 -0
  91. package/dist/runtime/domains/api/interceptors/response.d.ts +17 -0
  92. package/dist/runtime/domains/api/interceptors/response.js +27 -0
  93. package/dist/runtime/domains/api/response.d.ts +4 -0
  94. package/dist/runtime/domains/api/response.js +14 -0
  95. package/dist/runtime/domains/api/toast.d.ts +15 -0
  96. package/dist/runtime/domains/api/toast.js +46 -0
  97. package/dist/runtime/domains/api/transfer.d.ts +69 -0
  98. package/dist/runtime/domains/api/transfer.js +81 -0
  99. package/dist/runtime/domains/auto-form/actions.d.ts +2 -0
  100. package/dist/runtime/domains/auto-form/actions.js +4 -0
  101. package/dist/runtime/domains/auto-form/components/Array.d.vue.ts +13 -0
  102. package/dist/runtime/{components/auto-form-renderer/AutoFormRendererArray.vue → domains/auto-form/components/Array.vue} +37 -48
  103. package/dist/runtime/domains/auto-form/components/Array.vue.d.ts +13 -0
  104. package/dist/runtime/domains/auto-form/components/Children.d.vue.ts +11 -0
  105. package/dist/runtime/domains/auto-form/components/Children.vue +50 -0
  106. package/dist/runtime/domains/auto-form/components/Children.vue.d.ts +11 -0
  107. package/dist/runtime/domains/auto-form/components/Field.d.vue.ts +11 -0
  108. package/dist/runtime/domains/auto-form/components/Field.vue +56 -0
  109. package/dist/runtime/domains/auto-form/components/Field.vue.d.ts +11 -0
  110. package/dist/runtime/domains/auto-form/components/Layout.d.vue.ts +11 -0
  111. package/dist/runtime/domains/auto-form/components/Layout.vue +89 -0
  112. package/dist/runtime/domains/auto-form/components/Layout.vue.d.ts +11 -0
  113. package/dist/runtime/domains/auto-form/components/Nested.d.vue.ts +11 -0
  114. package/dist/runtime/domains/auto-form/components/Nested.vue +47 -0
  115. package/dist/runtime/domains/auto-form/components/Nested.vue.d.ts +11 -0
  116. package/dist/runtime/{constants/auto-form.d.ts → domains/auto-form/constants.d.ts} +0 -2
  117. package/dist/runtime/{constants/auto-form.js → domains/auto-form/constants.js} +0 -25
  118. package/dist/runtime/domains/auto-form/controls.d.ts +41 -0
  119. package/dist/runtime/domains/auto-form/controls.js +73 -0
  120. package/dist/runtime/{utils/field-utils.d.ts → domains/auto-form/fields.d.ts} +7 -21
  121. package/dist/runtime/{utils/field-utils.js → domains/auto-form/fields.js} +19 -4
  122. package/dist/runtime/domains/auto-form/metadata.d.ts +22 -0
  123. package/dist/runtime/domains/auto-form/metadata.js +53 -0
  124. package/dist/runtime/domains/auto-form/provider.d.ts +62 -0
  125. package/dist/runtime/{internal/useAutoFormProvider.js → domains/auto-form/provider.js} +6 -3
  126. package/dist/runtime/domains/auto-form/reactive.d.ts +12 -0
  127. package/dist/runtime/{utils/reactive-utils.js → domains/auto-form/reactive.js} +1 -1
  128. package/dist/runtime/domains/auto-form/schema.d.ts +7 -0
  129. package/dist/runtime/{utils/schema-introspector.js → domains/auto-form/schema.js} +12 -10
  130. package/dist/runtime/domains/data-table/columns/constants.d.ts +50 -0
  131. package/dist/runtime/domains/data-table/columns/constants.js +19 -0
  132. package/dist/runtime/domains/data-table/columns/resolve-columns.d.ts +4 -0
  133. package/dist/runtime/domains/data-table/columns/resolve-columns.js +59 -0
  134. package/dist/runtime/domains/data-table/columns/resolve-data-column.d.ts +9 -0
  135. package/dist/runtime/domains/data-table/columns/resolve-data-column.js +164 -0
  136. package/dist/runtime/domains/data-table/columns/resolve-group-column.d.ts +4 -0
  137. package/dist/runtime/domains/data-table/columns/resolve-group-column.js +19 -0
  138. package/dist/runtime/domains/data-table/columns/resolve-special-columns.d.ts +8 -0
  139. package/dist/runtime/domains/data-table/columns/resolve-special-columns.js +232 -0
  140. package/dist/runtime/domains/data-table/columns/style.d.ts +11 -0
  141. package/dist/runtime/domains/data-table/columns/style.js +67 -0
  142. package/dist/runtime/domains/data-table/columns/utils.d.ts +6 -0
  143. package/dist/runtime/domains/data-table/columns/utils.js +16 -0
  144. package/dist/runtime/domains/data-table/components/ActionConfirm.d.vue.ts +10 -0
  145. package/dist/runtime/domains/data-table/components/ActionConfirm.vue +39 -0
  146. package/dist/runtime/domains/data-table/components/ActionConfirm.vue.d.ts +10 -0
  147. package/dist/runtime/domains/data-table/components/ActionsCell.d.vue.ts +11 -0
  148. package/dist/runtime/domains/data-table/components/ActionsCell.vue +91 -0
  149. package/dist/runtime/domains/data-table/components/ActionsCell.vue.d.ts +11 -0
  150. package/dist/runtime/domains/data-table/components/CellTooltip.d.vue.ts +9 -0
  151. package/dist/runtime/domains/data-table/components/CellTooltip.vue +40 -0
  152. package/dist/runtime/domains/data-table/components/CellTooltip.vue.d.ts +9 -0
  153. package/dist/runtime/domains/data-table/components/Pagination.d.vue.ts +26 -0
  154. package/dist/runtime/domains/data-table/components/Pagination.vue +132 -0
  155. package/dist/runtime/domains/data-table/components/Pagination.vue.d.ts +26 -0
  156. package/dist/runtime/domains/data-table/indent.d.ts +8 -0
  157. package/dist/runtime/domains/data-table/indent.js +19 -0
  158. package/dist/runtime/domains/data-table/tree-selection.d.ts +9 -0
  159. package/dist/runtime/domains/data-table/tree-selection.js +76 -0
  160. package/dist/runtime/{utils/theme.d.ts → domains/theme/theme-icons.d.ts} +0 -1
  161. package/dist/runtime/index.css +1 -0
  162. package/dist/runtime/plugins/api.factory.js +28 -171
  163. package/dist/runtime/plugins/theme.js +72 -70
  164. package/dist/runtime/types/api/config.d.ts +127 -0
  165. package/dist/runtime/types/api/fetch.d.ts +50 -0
  166. package/dist/runtime/types/api/index.d.ts +5 -0
  167. package/dist/runtime/types/api/module.d.ts +94 -0
  168. package/dist/runtime/types/api/response.d.ts +62 -0
  169. package/dist/runtime/types/api/transfer.d.ts +32 -0
  170. package/dist/runtime/types/api/transfer.js +0 -0
  171. package/dist/runtime/types/app.config.d.ts +6 -0
  172. package/dist/runtime/types/auto-form/base.d.ts +26 -0
  173. package/dist/runtime/types/auto-form/base.js +0 -0
  174. package/dist/runtime/types/auto-form/component.d.ts +28 -0
  175. package/dist/runtime/types/auto-form/component.js +0 -0
  176. package/dist/runtime/types/auto-form/controls.d.ts +45 -0
  177. package/dist/runtime/types/auto-form/controls.js +0 -0
  178. package/dist/runtime/types/auto-form/fields.d.ts +68 -0
  179. package/dist/runtime/types/auto-form/fields.js +0 -0
  180. package/dist/runtime/types/auto-form/index.d.ts +7 -0
  181. package/dist/runtime/types/auto-form/index.js +0 -0
  182. package/dist/runtime/types/auto-form/search-form.d.ts +84 -0
  183. package/dist/runtime/types/auto-form/search-form.js +0 -0
  184. package/dist/runtime/types/auto-form/slots.d.ts +85 -0
  185. package/dist/runtime/types/auto-form/slots.js +0 -0
  186. package/dist/runtime/types/auto-form/zod-factory.d.ts +127 -0
  187. package/dist/runtime/types/auto-form/zod-factory.js +0 -0
  188. package/dist/runtime/types/components/color-chooser.d.ts +109 -0
  189. package/dist/runtime/types/components/color-chooser.js +0 -0
  190. package/dist/runtime/types/components/date-picker.d.ts +41 -0
  191. package/dist/runtime/types/components/date-picker.js +0 -0
  192. package/dist/runtime/types/components/index.d.ts +8 -0
  193. package/dist/runtime/types/components/index.js +0 -0
  194. package/dist/runtime/types/components/input/as-phone-number-input.d.ts +17 -0
  195. package/dist/runtime/types/components/input/as-phone-number-input.js +0 -0
  196. package/dist/runtime/types/components/input/index.d.ts +6 -0
  197. package/dist/runtime/types/components/input/index.js +0 -0
  198. package/dist/runtime/types/components/input/with-character-limit.d.ts +11 -0
  199. package/dist/runtime/types/components/input/with-character-limit.js +0 -0
  200. package/dist/runtime/types/components/input/with-clear.d.ts +10 -0
  201. package/dist/runtime/types/components/input/with-clear.js +0 -0
  202. package/dist/runtime/types/components/input/with-copy.d.ts +11 -0
  203. package/dist/runtime/types/components/input/with-copy.js +0 -0
  204. package/dist/runtime/types/components/input/with-floating-label.d.ts +12 -0
  205. package/dist/runtime/types/components/input/with-floating-label.js +0 -0
  206. package/dist/runtime/types/components/input/with-password-toggle.d.ts +7 -0
  207. package/dist/runtime/types/components/input/with-password-toggle.js +0 -0
  208. package/dist/runtime/types/components/message-box.d.ts +69 -0
  209. package/dist/runtime/types/components/message-box.js +0 -0
  210. package/dist/runtime/types/components/pill-group.d.ts +103 -0
  211. package/dist/runtime/types/components/pill-group.js +0 -0
  212. package/dist/runtime/types/components/popconfirm.d.ts +74 -0
  213. package/dist/runtime/types/components/popconfirm.js +0 -0
  214. package/dist/runtime/types/components/slide-verify.d.ts +54 -0
  215. package/dist/runtime/types/components/slide-verify.js +0 -0
  216. package/dist/runtime/types/components/star-rating.d.ts +55 -0
  217. package/dist/runtime/types/components/star-rating.js +0 -0
  218. package/dist/runtime/types/data-table/columns.d.ts +236 -0
  219. package/dist/runtime/types/data-table/columns.js +6 -0
  220. package/dist/runtime/types/data-table/component.d.ts +190 -0
  221. package/dist/runtime/types/data-table/component.js +0 -0
  222. package/dist/runtime/types/data-table/contexts.d.ts +44 -0
  223. package/dist/runtime/types/data-table/contexts.js +0 -0
  224. package/dist/runtime/types/data-table/index.d.ts +6 -0
  225. package/dist/runtime/types/data-table/index.js +1 -0
  226. package/dist/runtime/types/data-table/pagination.d.ts +87 -0
  227. package/dist/runtime/types/data-table/pagination.js +0 -0
  228. package/dist/runtime/types/index.d.ts +6 -5
  229. package/dist/runtime/types/index.js +5 -5
  230. package/dist/runtime/types/shared.d.ts +5 -0
  231. package/dist/runtime/types/shared.js +0 -0
  232. package/dist/runtime/types/zod.d.ts +19 -17
  233. package/dist/runtime/utils/extend-theme.d.ts +19 -0
  234. package/dist/runtime/utils/extend-theme.js +44 -0
  235. package/dist/runtime/utils/form-control.d.ts +33 -0
  236. package/dist/runtime/utils/form-control.js +54 -0
  237. package/dist/runtime/utils/meta.d.ts +4 -0
  238. package/dist/runtime/utils/meta.js +14 -0
  239. package/dist/runtime/utils/theme-defaults.d.ts +27 -0
  240. package/dist/runtime/utils/theme-defaults.js +28 -0
  241. package/dist/runtime/utils/tv.d.ts +1 -0
  242. package/dist/runtime/utils/tv.js +4 -0
  243. package/dist/runtime/vue/composables/useSiteConfig.d.ts +13 -0
  244. package/dist/runtime/vue/composables/useSiteConfig.js +11 -0
  245. package/dist/runtime/vue/plugins/theme.d.ts +6 -0
  246. package/dist/runtime/vue/plugins/theme.js +14 -0
  247. package/dist/runtime/vue/stubs/base.d.ts +2 -0
  248. package/dist/runtime/vue/stubs/base.js +2 -0
  249. package/dist/runtime/vue/stubs/inertia.d.ts +2 -0
  250. package/dist/runtime/vue/stubs/inertia.js +2 -0
  251. package/dist/runtime/vue/stubs/movk-extra.d.ts +2 -0
  252. package/dist/runtime/vue/stubs/movk-extra.js +2 -0
  253. package/dist/runtime/vue/stubs/none.d.ts +2 -0
  254. package/dist/runtime/vue/stubs/none.js +2 -0
  255. package/dist/runtime/vue/stubs/vue-router.d.ts +2 -0
  256. package/dist/runtime/vue/stubs/vue-router.js +2 -0
  257. package/dist/shared/nuxt.DfBEyjld.mjs +667 -0
  258. package/dist/types.d.mts +2 -6
  259. package/dist/unplugin.d.mts +28 -0
  260. package/dist/unplugin.mjs +292 -0
  261. package/dist/vite.d.mts +12 -0
  262. package/dist/vite.mjs +20 -0
  263. package/package.json +82 -42
  264. package/vue-plugin.d.ts +5 -0
  265. package/dist/runtime/components/auto-form-renderer/AutoFormRendererArray.d.vue.ts +0 -20
  266. package/dist/runtime/components/auto-form-renderer/AutoFormRendererArray.vue.d.ts +0 -20
  267. package/dist/runtime/components/auto-form-renderer/AutoFormRendererField.d.vue.ts +0 -20
  268. package/dist/runtime/components/auto-form-renderer/AutoFormRendererField.vue +0 -55
  269. package/dist/runtime/components/auto-form-renderer/AutoFormRendererField.vue.d.ts +0 -20
  270. package/dist/runtime/components/auto-form-renderer/AutoFormRendererLayout.d.vue.ts +0 -20
  271. package/dist/runtime/components/auto-form-renderer/AutoFormRendererLayout.vue +0 -125
  272. package/dist/runtime/components/auto-form-renderer/AutoFormRendererLayout.vue.d.ts +0 -20
  273. package/dist/runtime/components/auto-form-renderer/AutoFormRendererNested.d.vue.ts +0 -20
  274. package/dist/runtime/components/auto-form-renderer/AutoFormRendererNested.vue +0 -105
  275. package/dist/runtime/components/auto-form-renderer/AutoFormRendererNested.vue.d.ts +0 -20
  276. package/dist/runtime/composables/useApiAuth.d.ts +0 -47
  277. package/dist/runtime/composables/useApiAuth.js +0 -66
  278. package/dist/runtime/internal/useAutoFormProvider.d.ts +0 -50
  279. package/dist/runtime/schemas/api.d.ts +0 -590
  280. package/dist/runtime/schemas/api.js +0 -228
  281. package/dist/runtime/server/api/_movk/session.post.d.ts +0 -10
  282. package/dist/runtime/server/api/_movk/session.post.js +0 -18
  283. package/dist/runtime/style.css +0 -1
  284. package/dist/runtime/types/api.d.ts +0 -218
  285. package/dist/runtime/types/auth.d.ts +0 -34
  286. package/dist/runtime/types/auto-form-renderer.d.ts +0 -22
  287. package/dist/runtime/types/auto-form.d.ts +0 -548
  288. package/dist/runtime/types/components.d.ts +0 -43
  289. package/dist/runtime/types/module.d.ts +0 -39
  290. package/dist/runtime/utils/api-utils.d.ts +0 -79
  291. package/dist/runtime/utils/api-utils.js +0 -127
  292. package/dist/runtime/utils/auto-form.d.ts +0 -3
  293. package/dist/runtime/utils/auto-form.js +0 -18
  294. package/dist/runtime/utils/reactive-utils.d.ts +0 -30
  295. package/dist/runtime/utils/schema-introspector.d.ts +0 -13
  296. /package/dist/runtime/{utils/theme.js → domains/theme/theme-icons.js} +0 -0
  297. /package/dist/runtime/types/{api.js → api/config.js} +0 -0
  298. /package/dist/runtime/types/{auto-form-renderer.js → api/fetch.js} +0 -0
  299. /package/dist/runtime/types/{auto-form.js → api/index.js} +0 -0
  300. /package/dist/runtime/types/{module.js → api/module.js} +0 -0
  301. /package/dist/runtime/types/{components.js → api/response.js} +0 -0
@@ -1,86 +1,46 @@
1
1
  <script setup>
2
2
  import { UForm } from "#components";
3
- import { computed, onMounted, ref, useTemplateRef } from "vue";
4
- import { useAutoFormProvider } from "../internal/useAutoFormProvider";
5
- import { getPath, setPath } from "@movk/core";
6
- import { classifyFields, extractPureSchema, introspectSchema } from "../utils/auto-form";
7
- import AutoFormRendererArray from "./auto-form-renderer/AutoFormRendererArray.vue";
8
- import AutoFormRendererField from "./auto-form-renderer/AutoFormRendererField.vue";
9
- import AutoFormRendererLayout from "./auto-form-renderer/AutoFormRendererLayout.vue";
10
- import AutoFormRendererNested from "./auto-form-renderer/AutoFormRendererNested.vue";
11
- import { useAutoForm } from "../composables/useAutoForm";
12
- const {
13
- schema,
14
- controls,
15
- globalMeta,
16
- submitButton = true,
17
- submitButtonProps,
18
- addButtonProps,
19
- state: _state,
20
- loadingAuto = true,
21
- ...restProps
22
- } = defineProps({
23
- submitButton: { type: Boolean, required: false },
3
+ import { computed, onMounted, ref, toRaw, unref, useAttrs, useTemplateRef } from "vue";
4
+ import { deepClone, isFunction } from "@movk/core";
5
+ import { useAutoFormProvider } from "../domains/auto-form/provider";
6
+ import { applyFieldDefaults, classifyFields } from "../domains/auto-form/fields";
7
+ import { extractPureSchema, introspectSchema } from "../domains/auto-form/schema";
8
+ import { DEFAULT_CONTROLS } from "../domains/auto-form/controls";
9
+ import AutoFormRendererChildren from "../domains/auto-form/components/Children.vue";
10
+ import AutoFormRendererField from "../domains/auto-form/components/Field.vue";
11
+ import { useExtendedTv } from "../utils/extend-theme";
12
+ import theme from "#build/movk-ui/auto-form";
13
+ import { useAppConfig } from "#imports";
14
+ const props = defineProps({
15
+ state: { type: null, required: false },
16
+ submit: { type: Boolean, required: false, default: true },
24
17
  submitButtonProps: { type: Object, required: false },
18
+ addButtonProps: { type: Object, required: false },
19
+ schema: { type: null, required: true },
25
20
  controls: { type: Object, required: false },
26
21
  globalMeta: { type: Object, required: false },
27
- addButtonProps: { type: Object, required: false },
28
- loadingAuto: { type: Boolean, required: false },
29
- id: { type: [String, Number], required: false },
30
- schema: { type: null, required: false },
31
- state: { type: null, required: false },
32
- validate: { type: Function, required: false },
33
- validateOn: { type: Array, required: false },
34
- disabled: { type: Boolean, required: false },
35
- name: { type: null, required: false },
36
- validateOnInputDelay: { type: Number, required: false },
37
- transform: { type: null, required: false },
38
- nested: { type: Boolean, required: false },
22
+ loadingAuto: { type: Boolean, required: false, default: true },
23
+ validateOn: { type: Array, required: false, default: () => [] },
39
24
  class: { type: null, required: false },
40
- onSubmit: { type: Function, required: false }
25
+ ui: { type: Object, required: false }
41
26
  });
42
- defineEmits(["submit", "error"]);
43
- const _slots = defineSlots();
27
+ const emits = defineEmits(["error"]);
28
+ const slots = defineSlots();
44
29
  defineOptions({ inheritAttrs: false });
45
- const state = ref(_state || {});
30
+ const attrs = useAttrs();
31
+ const appConfig = useAppConfig();
32
+ const initialState = deepClone(toRaw(props.state ?? {}));
33
+ const stateModel = ref(props.state ?? {});
46
34
  const formRef = useTemplateRef("formRef");
47
- const { DEFAULT_CONTROLS } = useAutoForm();
48
- const { resolveFieldProp } = useAutoFormProvider(state, _slots);
49
- const pureSchema = computed(() => schema ? extractPureSchema(schema) : schema);
50
- const controlsMapping = computed(() => ({
51
- ...DEFAULT_CONTROLS,
52
- ...controls
53
- }));
54
- const fields = computed(() => {
55
- if (!schema)
56
- return [];
57
- const items = introspectSchema(schema, controlsMapping.value, "", globalMeta);
58
- return items;
35
+ const { resolveFieldProp } = useAutoFormProvider(stateModel, slots);
36
+ const resolvedButtonSize = computed(() => {
37
+ const size = props.globalMeta?.size;
38
+ if (size === void 0 || isFunction(size)) return void 0;
39
+ return unref(size);
59
40
  });
60
- function resolveDefaultValue(fields2, stateValue) {
61
- if (!fields2.length)
62
- return;
63
- const updates = [];
64
- function collectDefaultValues(fieldList) {
65
- for (const field of fieldList) {
66
- if (field?.decorators?.defaultValue !== void 0 && getPath(stateValue, field.path) === void 0) {
67
- updates.push({
68
- path: field.path,
69
- value: field.decorators.defaultValue
70
- });
71
- }
72
- if (field?.children && Array.isArray(field.children) && field.children.length > 0) {
73
- collectDefaultValues(field.children);
74
- }
75
- }
76
- }
77
- collectDefaultValues(fields2);
78
- if (updates.length > 0) {
79
- for (const { path, value } of updates) {
80
- setPath(stateValue, path, value);
81
- }
82
- }
83
- }
41
+ const pureSchema = computed(() => props.schema ? extractPureSchema(props.schema) : props.schema);
42
+ const controlsMapping = computed(() => ({ ...DEFAULT_CONTROLS, ...props.controls }));
43
+ const fields = computed(() => props.schema ? introspectSchema(props.schema, controlsMapping.value, "", props.globalMeta) : []);
84
44
  const visibleFields = computed(
85
45
  () => fields.value.filter(
86
46
  (field) => field && (field.meta?.if === void 0 || resolveFieldProp(field, "if") === true)
@@ -95,25 +55,32 @@ const renderData = computed(() => {
95
55
  allFields: visibleFields.value
96
56
  };
97
57
  });
98
- onMounted(() => {
99
- resolveDefaultValue(fields.value, state.value);
100
- });
58
+ const { extendUi } = useExtendedTv(
59
+ { slots: {} },
60
+ theme,
61
+ () => appConfig.movk?.autoForm,
62
+ () => ({
63
+ ui: {
64
+ ...props.ui,
65
+ root: [props.ui?.root, props.class]
66
+ }
67
+ })
68
+ );
101
69
  function reset() {
102
- Object.keys(state.value).forEach((key) => {
103
- delete state.value[key];
104
- });
105
- if (_state) {
106
- Object.assign(state.value, _state);
107
- }
108
- resolveDefaultValue(fields.value, state.value);
70
+ const target = stateModel.value;
71
+ for (const key of Object.keys(target)) Reflect.deleteProperty(target, key);
72
+ Object.assign(target, deepClone(initialState));
73
+ applyFieldDefaults(fields.value, target);
109
74
  formRef.value?.clear();
110
75
  }
111
76
  function clear() {
112
- Object.keys(state.value).forEach((key) => {
113
- delete state.value[key];
114
- });
77
+ const target = stateModel.value;
78
+ for (const key of Object.keys(target)) Reflect.deleteProperty(target, key);
115
79
  formRef.value?.clear();
116
80
  }
81
+ onMounted(() => {
82
+ applyFieldDefaults(fields.value, stateModel.value);
83
+ });
117
84
  defineExpose({
118
85
  formRef,
119
86
  reset,
@@ -122,70 +89,69 @@ defineExpose({
122
89
  </script>
123
90
 
124
91
  <template>
125
- <UForm
126
- v-if="renderData"
127
- ref="formRef"
128
- :state="state"
129
- :schema="pureSchema"
130
- :loading-auto="loadingAuto"
131
- v-bind="restProps"
132
- >
133
- <template #default="{ errors, loading }">
134
- <slot name="header" v-bind="{ errors, loading, fields: visibleFields, state }" />
92
+ <div :class="extendUi.root" data-slot="root">
93
+ <UTheme
94
+ :ui="{
95
+ collapsible: { content: extendUi.collapsible }
96
+ }"
97
+ >
98
+ <UForm
99
+ v-if="renderData"
100
+ ref="formRef"
101
+ :state="stateModel"
102
+ :schema="pureSchema"
103
+ :loading-auto="props.loadingAuto"
104
+ :validate-on="props.validateOn"
105
+ data-slot="form"
106
+ v-bind="attrs"
107
+ :ui="{
108
+ base: extendUi.base
109
+ }"
110
+ @error="emits('error', $event)"
111
+ >
112
+ <template #default="{ errors, loading }">
113
+ <div v-if="$slots.header" :class="extendUi.header" data-slot="header">
114
+ <slot name="header" v-bind="{ errors, loading, fields: visibleFields, state: stateModel }" />
115
+ </div>
135
116
 
136
- <template v-if="renderData.hasComplexFields">
137
- <template v-for="field in renderData.allFields" :key="field.path">
138
- <AutoFormRendererField
139
- v-if="renderData.leafFields.includes(field)"
140
- :field="field"
141
- :schema="schema"
142
- :extra-props="{ errors, loading }"
143
- />
144
- <AutoFormRendererArray
145
- v-else-if="renderData.arrayFields.includes(field)"
146
- :field="field"
147
- :schema="schema"
148
- :extra-props="{ errors, loading }"
149
- :add-button-props="addButtonProps"
150
- />
151
- <AutoFormRendererLayout
152
- v-else-if="renderData.layoutFields.includes(field)"
153
- :field="field"
154
- :schema="schema"
155
- :extra-props="{ errors, loading }"
156
- />
157
- <AutoFormRendererNested
158
- v-else
159
- :field="field"
160
- :schema="schema"
161
- :extra-props="{ errors, loading }"
162
- />
163
- </template>
164
- </template>
117
+ <template v-if="renderData.hasComplexFields">
118
+ <AutoFormRendererChildren
119
+ :fields="renderData.allFields"
120
+ :schema="schema"
121
+ :extra-props="{ errors, loading }"
122
+ />
123
+ </template>
165
124
 
166
- <template v-else>
167
- <AutoFormRendererField
168
- v-for="field in renderData.flatFields"
169
- :key="field.path"
170
- :field="field"
171
- :schema="schema"
172
- :extra-props="{ errors, loading }"
173
- />
174
- </template>
125
+ <template v-else>
126
+ <AutoFormRendererField
127
+ v-for="field in renderData.flatFields"
128
+ :key="field.path"
129
+ :field="field"
130
+ :schema="schema"
131
+ :extra-props="{ errors, loading }"
132
+ />
133
+ </template>
175
134
 
176
- <slot name="footer" v-bind="{ errors, loading, fields: visibleFields, state }" />
135
+ <div v-if="$slots.footer" :class="extendUi.footer" data-slot="footer">
136
+ <slot name="footer" v-bind="{ errors, loading, fields: visibleFields, state: stateModel }" />
137
+ </div>
177
138
 
178
- <slot name="submit" v-bind="{ errors, loading, fields: visibleFields, state }">
179
- <UButton
180
- v-if="submitButton"
181
- type="submit"
182
- :loading="loading"
183
- label="提交"
184
- loading-auto
185
- block
186
- v-bind="submitButtonProps"
187
- />
188
- </slot>
189
- </template>
190
- </UForm>
139
+ <div v-if="props.submit" :class="extendUi.actions" data-slot="submit">
140
+ <slot name="submit" v-bind="{ errors, loading, fields: visibleFields, state: stateModel }">
141
+ <UButton
142
+ type="submit"
143
+ label="提交"
144
+ block
145
+ :loading="loading"
146
+ :loading-auto="props.loadingAuto"
147
+ :size="resolvedButtonSize"
148
+ :disabled="attrs.disabled"
149
+ v-bind="props.submitButtonProps"
150
+ />
151
+ </slot>
152
+ </div>
153
+ </template>
154
+ </UForm>
155
+ </UTheme>
156
+ </div>
191
157
  </template>
@@ -1,34 +1,13 @@
1
- import type { ButtonProps, FormEmits, FormProps, InferInput } from '@nuxt/ui';
2
- import type { z } from 'zod/v4';
3
- import type { ZodAutoFormFieldMeta } from '../types/zod.js';
4
- import type { AutoFormControls, AutoFormSlotProps, DynamicFormSlots } from '../types/auto-form.js';
5
- export interface AutoFormProps<S extends z.ZodObject, T extends boolean = true, N extends boolean = false> extends FormProps<S, T, N> {
6
- /**
7
- * 是否显示默认提交按钮
8
- * @defaultValue true
9
- */
10
- submitButton?: boolean;
11
- /** 提交按钮属性 */
12
- submitButtonProps?: ButtonProps;
13
- /** 自定义控件映射 */
14
- controls?: AutoFormControls;
15
- /** 全局字段元数据配置 */
16
- globalMeta?: ZodAutoFormFieldMeta;
17
- /** 数组字段添加按钮属性 */
18
- addButtonProps?: ButtonProps;
19
- loadingAuto?: boolean;
20
- }
21
- export interface AutoFormEmits<S extends z.ZodObject, T extends boolean = true> extends FormEmits<S, T> {
22
- }
23
- export type AutoFormSlots<T extends object> = {
24
- header: (props: AutoFormSlotProps<T>) => any;
25
- footer: (props: AutoFormSlotProps<T>) => any;
26
- submit: (props: AutoFormSlotProps<T>) => any;
27
- } & DynamicFormSlots<T>;
1
+ import type { ComponentConfig, InferInput } from '@nuxt/ui';
2
+ import type { z } from 'zod';
3
+ import type { AutoFormProps, AutoFormSlots } from '../types/auto-form/component';
4
+ import theme from '#build/movk-ui/auto-form';
5
+ import type { AppConfig } from 'nuxt/schema';
28
6
  declare const __VLS_export: <S extends z.ZodObject, T extends boolean = true, N extends boolean = false>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
29
- props: import("vue").PublicProps & __VLS_PrettifyLocal<AutoFormProps<S, T, N> & {
30
- onError?: ((event: import("@nuxt/ui/.").FormErrorEvent) => any) | undefined;
31
- onSubmit?: ((event: import("@nuxt/ui/.").FormSubmitEvent<import("@nuxt/ui/.").FormData<S, T>>) => any) | undefined;
7
+ props: import("vue").PublicProps & __VLS_PrettifyLocal<(AutoFormProps<S, T, N> & {
8
+ ui?: ComponentConfig<typeof theme, AppConfig, "autoForm">["slots"];
9
+ }) & {
10
+ onError?: ((args_0: import("@nuxt/ui").FormErrorEvent) => any) | undefined;
32
11
  }> & (typeof globalThis extends {
33
12
  __VLS_PROPS_FALLBACK: infer P;
34
13
  } ? P : {});
@@ -39,7 +18,7 @@ declare const __VLS_export: <S extends z.ZodObject, T extends boolean = true, N
39
18
  }>) => void;
40
19
  attrs: any;
41
20
  slots: AutoFormSlots<N extends false ? Partial<InferInput<S>> : never>;
42
- emit: ((evt: "error", event: import("@nuxt/ui/.").FormErrorEvent) => void) & ((evt: "submit", event: import("@nuxt/ui/.").FormSubmitEvent<import("@nuxt/ui/.").FormData<S, T>>) => void);
21
+ emit: (evt: "error", args_0: import("@nuxt/ui").FormErrorEvent) => void;
43
22
  }>) => import("vue").VNode & {
44
23
  __ctx?: Awaited<typeof __VLS_setup>;
45
24
  };
@@ -1,26 +1,29 @@
1
- import type { ColorChooserProps } from '../types/components.js';
2
- declare const __VLS_export: <P extends "click" | "hover" = "click">(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
3
- props: import("vue").PublicProps & __VLS_PrettifyLocal<(ColorChooserProps<"click"> & {
1
+ import type { ComponentConfig } from '@nuxt/ui';
2
+ import type { AppConfig } from 'nuxt/schema';
3
+ import theme from '#build/movk-ui/color-chooser';
4
+ import popoverTheme from '#build/ui/popover';
5
+ import type { ColorChooserProps, ColorChooserSlots, ColorFormat } from '../types/components/color-chooser';
6
+ declare const __VLS_export: <M extends "click" | "hover">(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
7
+ props: import("vue").PublicProps & __VLS_PrettifyLocal<(ColorChooserProps<M> & {
8
+ size?: ComponentConfig<typeof popoverTheme & typeof theme, AppConfig, "colorChooser">["variants"]["size"];
9
+ trigger?: ComponentConfig<typeof popoverTheme & typeof theme, AppConfig, "colorChooser">["variants"]["trigger"];
10
+ ui?: ComponentConfig<typeof popoverTheme & typeof theme, AppConfig, "colorChooser">["slots"];
11
+ } & {
4
12
  modelValue?: string;
5
13
  }) & {
14
+ onClear?: (() => any) | undefined;
15
+ onChange?: ((value: string | undefined) => any) | undefined;
16
+ onCopy?: ((value: string) => any) | undefined;
17
+ "onUpdate:open"?: ((open: boolean) => any) | undefined;
6
18
  "onUpdate:modelValue"?: ((value: string | undefined) => any) | undefined;
7
- "onClose:prevent"?: (() => any) | undefined;
8
- "onUpdate:open"?: ((value: boolean) => any) | undefined;
19
+ "onFormat-change"?: ((format: ColorFormat) => any) | undefined;
9
20
  }> & (typeof globalThis extends {
10
- __VLS_PROPS_FALLBACK: infer P_1;
11
- } ? P_1 : {});
21
+ __VLS_PROPS_FALLBACK: infer P;
22
+ } ? P : {});
12
23
  expose: (exposed: {}) => void;
13
24
  attrs: any;
14
- slots: {
15
- default?: (props: any) => any;
16
- } & {
17
- leading?: (props: any) => any;
18
- } & {
19
- trailing?: (props: any) => any;
20
- } & {
21
- anchor?: (props: any) => any;
22
- };
23
- emit: (((evt: "close:prevent") => void) & ((evt: "update:open", value: boolean) => void)) & ((evt: "update:modelValue", value: string | undefined) => void);
25
+ slots: ColorChooserSlots;
26
+ emit: (((evt: "clear") => void) & ((evt: "change", value: string | undefined) => void) & ((evt: "copy", value: string) => void) & ((evt: "update:open", open: boolean) => void) & ((evt: "update:modelValue", value: string | undefined) => void) & ((evt: "format-change", format: ColorFormat) => void)) & ((event: "update:modelValue", value: string | undefined) => void);
24
27
  }>) => import("vue").VNode & {
25
28
  __ctx?: Awaited<typeof __VLS_setup>;
26
29
  };