@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
@@ -0,0 +1,274 @@
1
+ <script setup>
2
+ import { UButton, UCollapsible, UForm } from "#components";
3
+ import { computed, onMounted, ref, toRaw, unref, useAttrs, useTemplateRef, watch } from "vue";
4
+ import { deepClone, isFunction } from "@movk/core";
5
+ import { useAutoFormProvider } from "../domains/auto-form/provider";
6
+ import { extractPureSchema, introspectSchema } from "../domains/auto-form/schema";
7
+ import { applyFieldDefaults } from "../domains/auto-form/fields";
8
+ import { DEFAULT_CONTROLS } from "../domains/auto-form/controls";
9
+ import { DEFAULT_SEARCH_ACTIONS } from "../domains/auto-form/actions";
10
+ import AutoFormRendererField from "../domains/auto-form/components/Field.vue";
11
+ import { useAppConfig } from "#imports";
12
+ import theme from "#build/movk-ui/search-form";
13
+ import { useExtendedTv } from "../utils/extend-theme";
14
+ const props = defineProps({
15
+ cols: { type: [Number, Object], required: false, default: 3 },
16
+ visibleRows: { type: Number, required: false, default: 1 },
17
+ actions: { type: Array, required: false },
18
+ loading: { type: Boolean, required: false },
19
+ collapseButtonProps: { type: Object, required: false },
20
+ icon: { type: null, required: false, default: "i-lucide-chevron-down" },
21
+ expandText: { type: String, required: false, default: "\u5C55\u5F00" },
22
+ collapseText: { type: String, required: false, default: "\u6536\u8D77" },
23
+ expanded: { type: Boolean, required: false },
24
+ defaultExpanded: { type: Boolean, required: false, default: false },
25
+ schema: { type: null, required: true },
26
+ controls: { type: Object, required: false },
27
+ globalMeta: { type: Object, required: false },
28
+ loadingAuto: { type: Boolean, required: false, default: true },
29
+ validateOn: { type: Array, required: false, default: () => [] },
30
+ class: { type: null, required: false },
31
+ ui: { type: Object, required: false }
32
+ });
33
+ const modelValue = defineModel({ type: Object, ...{ default: () => ({}) } });
34
+ const expandedModel = defineModel("expanded", { type: Boolean });
35
+ const emits = defineEmits(["reset", "clear", "expand", "update:expanded", "error"]);
36
+ const slots = defineSlots();
37
+ defineOptions({ inheritAttrs: false });
38
+ const attrs = useAttrs();
39
+ let baseline = deepClone(toRaw(modelValue.value));
40
+ const appConfig = useAppConfig();
41
+ const formRef = useTemplateRef("formRef");
42
+ const internalExpanded = ref(props.defaultExpanded ?? false);
43
+ const expanded = computed({
44
+ get: () => expandedModel.value ?? internalExpanded.value,
45
+ set: (val) => {
46
+ internalExpanded.value = val;
47
+ if (expandedModel.value !== void 0) {
48
+ expandedModel.value = val;
49
+ }
50
+ }
51
+ });
52
+ const { baseUi, extraUi } = useExtendedTv(
53
+ { slots: { base: "" } },
54
+ theme,
55
+ () => appConfig.movk?.searchForm,
56
+ () => ({
57
+ ui: {
58
+ ...props.ui,
59
+ root: [props.ui?.root, props.class]
60
+ }
61
+ })
62
+ );
63
+ function maxCols(cols) {
64
+ if (typeof cols === "number") return cols;
65
+ if (!cols) return 1;
66
+ return Math.max(cols.sm ?? 1, cols.md ?? 1, cols.lg ?? 1, cols.xl ?? 1);
67
+ }
68
+ const gridStyle = computed(() => {
69
+ const c = props.cols;
70
+ const vars = {};
71
+ if (typeof c === "number") {
72
+ vars["--m-search-cols"] = String(c);
73
+ } else if (c) {
74
+ const base = c.sm ?? c.md ?? c.lg ?? c.xl ?? 1;
75
+ vars["--m-search-cols"] = String(base);
76
+ if (c.sm !== void 0) vars["--m-search-cols-sm"] = String(c.sm);
77
+ if (c.md !== void 0) vars["--m-search-cols-md"] = String(c.md);
78
+ if (c.lg !== void 0) vars["--m-search-cols-lg"] = String(c.lg);
79
+ if (c.xl !== void 0) vars["--m-search-cols-xl"] = String(c.xl);
80
+ }
81
+ return vars;
82
+ });
83
+ useAutoFormProvider(modelValue, slots);
84
+ const resolvedButtonSize = computed(() => {
85
+ const size = props.globalMeta?.size;
86
+ if (size === void 0 || isFunction(size)) return void 0;
87
+ return unref(size);
88
+ });
89
+ const pureSchema = computed(() => extractPureSchema(props.schema));
90
+ const controlsMapping = computed(() => ({ ...DEFAULT_CONTROLS, ...props.controls }));
91
+ const fields = computed(() => introspectSchema(props.schema, controlsMapping.value, "", props.globalMeta));
92
+ const actionsBag = { toggle, search: submit, reset, clear };
93
+ function buildSlotProps(errors, loading) {
94
+ return {
95
+ ...actionsBag,
96
+ expanded: expanded.value,
97
+ loading: props.loading || loading,
98
+ state: modelValue.value,
99
+ errors
100
+ };
101
+ }
102
+ function resolveActions(slotCtx) {
103
+ const list = props.actions ?? DEFAULT_SEARCH_ACTIONS;
104
+ return list.filter((action) => {
105
+ if (action.visible === void 0) return true;
106
+ if (typeof action.visible === "function") {
107
+ return action.visible(slotCtx);
108
+ }
109
+ return action.visible;
110
+ });
111
+ }
112
+ const showActionsCell = computed(() => {
113
+ const list = props.actions ?? DEFAULT_SEARCH_ACTIONS;
114
+ return list.length > 0 || !!slots.actions || !!slots.extraActions;
115
+ });
116
+ const visibleCount = computed(() => {
117
+ const total = maxCols(props.cols) * props.visibleRows;
118
+ if (!showActionsCell.value) return total;
119
+ if (maxCols(props.cols) <= 1) return total;
120
+ return Math.max(0, total - 1);
121
+ });
122
+ const visibleFields = computed(() => fields.value.slice(0, visibleCount.value));
123
+ const collapsedFields = computed(() => fields.value.slice(visibleCount.value));
124
+ const needsCollapse = computed(() => collapsedFields.value.length > 0);
125
+ function toggle() {
126
+ const next = !expanded.value;
127
+ expanded.value = next;
128
+ emits("expand", next);
129
+ emits("update:expanded", next);
130
+ }
131
+ function submit() {
132
+ formRef.value?.submit();
133
+ }
134
+ function clear() {
135
+ modelValue.value = {};
136
+ formRef.value?.clear();
137
+ emits("clear");
138
+ }
139
+ function reset() {
140
+ modelValue.value = deepClone(baseline);
141
+ applyFieldDefaults(fields.value, modelValue.value);
142
+ formRef.value?.clear();
143
+ emits("reset");
144
+ }
145
+ function setBaseline(value) {
146
+ baseline = deepClone(toRaw(value ?? modelValue.value));
147
+ }
148
+ function handleAction(action, ctx) {
149
+ if (action.onClick) {
150
+ action.onClick(ctx);
151
+ return;
152
+ }
153
+ if (action.type === "submit") return;
154
+ if (action.key === "reset") reset();
155
+ else if (action.key === "search") submit();
156
+ }
157
+ function actionLoading(action, ctx) {
158
+ if (action.key === "search" || action.type === "submit") return ctx.loading;
159
+ return false;
160
+ }
161
+ watch(() => fields.value, () => {
162
+ applyFieldDefaults(fields.value, modelValue.value);
163
+ }, { flush: "post" });
164
+ watch(() => props.schema, () => {
165
+ formRef.value?.clear();
166
+ });
167
+ onMounted(() => {
168
+ applyFieldDefaults(fields.value, modelValue.value);
169
+ setBaseline();
170
+ });
171
+ defineExpose({
172
+ formRef,
173
+ submit,
174
+ reset,
175
+ clear,
176
+ setBaseline,
177
+ expanded,
178
+ toggle
179
+ });
180
+ </script>
181
+
182
+ <template>
183
+ <div :class="extraUi.root" data-slot="root">
184
+ <UForm
185
+ ref="formRef"
186
+ :state="modelValue"
187
+ :schema="pureSchema"
188
+ :loading-auto="props.loadingAuto"
189
+ :validate-on="props.validateOn"
190
+ :ui="baseUi"
191
+ data-slot="form"
192
+ v-bind="attrs"
193
+ @error="emits('error', $event)"
194
+ >
195
+ <template #default="{ errors, loading }">
196
+ <div v-if="$slots.header" :class="extraUi.header" data-slot="header">
197
+ <slot name="header" v-bind="buildSlotProps(errors, loading)" />
198
+ </div>
199
+
200
+ <div :class="extraUi.visible" data-slot="visible">
201
+ <div :class="extraUi.grid" :style="gridStyle" data-slot="grid">
202
+ <AutoFormRendererField
203
+ v-for="field in visibleFields"
204
+ :key="field.path"
205
+ :field="field"
206
+ :schema="props.schema"
207
+ :extra-props="{ errors, loading, state: modelValue }"
208
+ />
209
+
210
+ <slot
211
+ v-if="showActionsCell"
212
+ name="actions"
213
+ v-bind="buildSlotProps(errors, loading)"
214
+ >
215
+ <div :class="extraUi.actions" data-slot="actions">
216
+ <template v-for="action in resolveActions(buildSlotProps(errors, loading))" :key="action.key">
217
+ <UButton
218
+ :label="action.label"
219
+ :type="action.type"
220
+ :icon="action.icon"
221
+ :color="action.color"
222
+ :variant="action.variant"
223
+ :loading="actionLoading(action, buildSlotProps(errors, loading))"
224
+ :size="resolvedButtonSize"
225
+ v-bind="action"
226
+ @click="handleAction(action, buildSlotProps(errors, loading))"
227
+ />
228
+ </template>
229
+ <slot name="extraActions" v-bind="buildSlotProps(errors, loading)" />
230
+ </div>
231
+ </slot>
232
+ </div>
233
+ </div>
234
+
235
+ <UCollapsible v-if="needsCollapse" v-model:open="expanded">
236
+ <template #content>
237
+ <div :class="[extraUi.grid, extraUi.collapsed]" :style="gridStyle" data-slot="collapsed">
238
+ <AutoFormRendererField
239
+ v-for="field in collapsedFields"
240
+ :key="field.path"
241
+ :field="field"
242
+ :schema="props.schema"
243
+ :extra-props="{ errors, loading, state: modelValue }"
244
+ />
245
+ </div>
246
+ </template>
247
+ </UCollapsible>
248
+
249
+ <div v-if="needsCollapse" :class="extraUi.toggleWrapper" data-slot="toggle-wrapper">
250
+ <UButton
251
+ :icon="icon"
252
+ color="neutral"
253
+ :size="resolvedButtonSize"
254
+ variant="ghost"
255
+ :data-state="expanded ? 'open' : 'closed'"
256
+ :label="expanded ? collapseText : expandText"
257
+ tabindex="-1"
258
+ :class="extraUi.toggle"
259
+ v-bind="collapseButtonProps"
260
+ :ui="{
261
+ ...collapseButtonProps?.ui ?? {},
262
+ leadingIcon: [collapseButtonProps?.ui?.leadingIcon, extraUi.toggleIcon].filter(Boolean).join(' ')
263
+ }"
264
+ @click="toggle"
265
+ />
266
+ </div>
267
+
268
+ <div v-if="$slots.footer" :class="extraUi.footer" data-slot="footer">
269
+ <slot name="footer" v-bind="buildSlotProps(errors, loading)" />
270
+ </div>
271
+ </template>
272
+ </UForm>
273
+ </div>
274
+ </template>
@@ -0,0 +1,43 @@
1
+ import type { ComponentConfig, InferInput } from '@nuxt/ui';
2
+ import type { z } from 'zod';
3
+ import type { AppConfig } from 'nuxt/schema';
4
+ import theme from '#build/movk-ui/search-form';
5
+ import type { SearchFormProps, SearchFormSlots } from '../types/auto-form/search-form';
6
+ declare const __VLS_export: <S extends z.ZodObject>(__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<(SearchFormProps<S> & {
8
+ ui?: ComponentConfig<typeof theme, AppConfig, "searchForm">["slots"];
9
+ } & {
10
+ modelValue?: Partial<InferInput<S>>;
11
+ expanded?: boolean;
12
+ }) & {
13
+ onError?: ((event: import("@nuxt/ui").FormErrorEvent) => any) | undefined;
14
+ onClear?: (() => any) | undefined;
15
+ onReset?: (() => any) | undefined;
16
+ "onUpdate:modelValue"?: ((value: Partial<InferInput<S>>) => any) | undefined;
17
+ onExpand?: ((expanded: boolean) => any) | undefined;
18
+ "onUpdate:expanded"?: ((value: boolean | undefined) => any) | undefined;
19
+ }> & (typeof globalThis extends {
20
+ __VLS_PROPS_FALLBACK: infer P;
21
+ } ? P : {});
22
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
23
+ formRef: Readonly<import("vue").ShallowRef<any, any>>;
24
+ submit: () => void;
25
+ reset: () => void;
26
+ clear: () => void;
27
+ setBaseline: (value?: Partial<InferInput<S>>) => void;
28
+ expanded: import("vue").WritableComputedRef<boolean, boolean>;
29
+ toggle: () => void;
30
+ }>) => void;
31
+ attrs: any;
32
+ slots: SearchFormSlots<S>;
33
+ emit: (((evt: "error", event: import("@nuxt/ui").FormErrorEvent) => void) & ((evt: "clear") => void) & ((evt: "reset") => void) & ((evt: "expand", expanded: boolean) => void) & ((evt: "update:expanded", expanded: boolean) => void)) & (((event: "update:modelValue", value: Partial<InferInput<S>>) => void) & ((event: "update:expanded", value: boolean | undefined) => void));
34
+ }>) => import("vue").VNode & {
35
+ __ctx?: Awaited<typeof __VLS_setup>;
36
+ };
37
+ declare const _default: typeof __VLS_export;
38
+ export default _default;
39
+ type __VLS_PrettifyLocal<T> = (T extends any ? {
40
+ [K in keyof T]: T[K];
41
+ } : {
42
+ [K in keyof T as K]: T[K];
43
+ }) & {};
@@ -1,100 +1,34 @@
1
- import type { ClassNameValue } from 'tailwind-merge';
2
- export interface SlideVerifyProps {
3
- /**
4
- * 滑块宽度
5
- * @defaultValue 50
6
- */
7
- sliderWidth?: number;
8
- /**
9
- * 滑块高度
10
- * @defaultValue 44
11
- */
12
- height?: number;
13
- /**
14
- * 是否禁用
15
- * @defaultValue false
16
- */
17
- disabled?: boolean;
18
- /**
19
- * 待滑动时的提示文本
20
- * @defaultValue '请向右滑动验证'
21
- */
22
- text?: string;
23
- /**
24
- * 验证成功时的提示文本
25
- * @defaultValue '验证成功'
26
- */
27
- successText?: string;
28
- /**
29
- * 滑块图标
30
- * @defaultValue 'i-lucide-chevrons-right'
31
- */
32
- icon?: string;
33
- /**
34
- * 验证成功时的图标
35
- * @defaultValue 'i-lucide-check'
36
- */
37
- successIcon?: string;
38
- /**
39
- * 完成验证所需的阈值百分比(0-1)
40
- * @defaultValue 0.9
41
- */
42
- threshold?: number;
43
- /**
44
- * 自定义轨道样式
45
- */
46
- trackClass?: ClassNameValue;
47
- /**
48
- * 自定义滑块样式
49
- */
50
- sliderClass?: ClassNameValue;
51
- /**
52
- * 自定义文本样式
53
- */
54
- textClass?: ClassNameValue;
55
- /**
56
- * 自定义根元素样式
57
- */
58
- class?: ClassNameValue;
59
- }
60
- export interface SlideVerifyEmits {
61
- success: [];
62
- dragStart: [];
63
- dragEnd: [success: boolean];
64
- }
65
- type __VLS_Props = SlideVerifyProps;
1
+ import theme from '#build/movk-ui/slide-verify';
2
+ import type { ComponentConfig } from '@nuxt/ui';
3
+ import type { AppConfig } from 'nuxt/schema';
4
+ import type { SlideVerifyProps, SlideVerifySlots } from '../types/components/slide-verify';
5
+ type __VLS_Props = SlideVerifyProps & {
6
+ size?: ComponentConfig<typeof theme, AppConfig, 'slideVerify'>['variants']['size'];
7
+ ui?: ComponentConfig<typeof theme, AppConfig, 'slideVerify'>['slots'];
8
+ };
9
+ type __VLS_Slots = SlideVerifySlots;
66
10
  declare function reset(): void;
67
11
  type __VLS_ModelProps = {
68
12
  modelValue?: boolean;
69
13
  };
70
14
  type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
71
- declare var __VLS_22: {
72
- verified: boolean;
73
- progress: number;
74
- };
75
- type __VLS_Slots = {} & {
76
- slider?: (props: typeof __VLS_22) => any;
77
- };
78
15
  declare const __VLS_base: import("vue").DefineComponent<__VLS_PublicProps, {
79
16
  reset: typeof reset;
80
17
  }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
81
- "update:modelValue": (value: boolean) => any;
82
18
  success: () => any;
19
+ "update:modelValue": (value: boolean) => any;
83
20
  dragStart: () => any;
84
21
  dragEnd: (success: boolean) => any;
85
22
  }, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
86
- "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
87
23
  onSuccess?: (() => any) | undefined;
24
+ "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
88
25
  onDragStart?: (() => any) | undefined;
89
26
  onDragEnd?: ((success: boolean) => any) | undefined;
90
27
  }>, {
91
- disabled: boolean;
92
- icon: string;
28
+ icon: import("@nuxt/ui").IconProps["name"];
93
29
  text: string;
94
- height: number;
95
- sliderWidth: number;
96
30
  successText: string;
97
- successIcon: string;
31
+ successIcon: import("@nuxt/ui").IconProps["name"];
98
32
  threshold: number;
99
33
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
100
34
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;