@vc-shell/framework 1.0.52 → 1.0.54

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 (390) hide show
  1. package/core/composables/index.ts +0 -1
  2. package/core/composables/useApiClient/index.ts +9 -4
  3. package/core/composables/useAsync/index.ts +2 -6
  4. package/core/composables/useAutosave/index.ts +1 -3
  5. package/core/composables/useFunctions/debounce.ts +1 -4
  6. package/core/composables/useFunctions/delay.ts +1 -4
  7. package/core/composables/useFunctions/once.ts +1 -3
  8. package/core/composables/useFunctions/throttle.ts +1 -4
  9. package/core/composables/useI18n/index.ts +3 -24
  10. package/core/composables/useLoading/index.ts +1 -3
  11. package/core/composables/useNotifications/index.ts +6 -13
  12. package/core/composables/usePermissions/index.ts +1 -1
  13. package/core/composables/useSettings/index.ts +3 -4
  14. package/core/composables/useUser/index.ts +27 -66
  15. package/core/directives/permissions/index.ts +1 -1
  16. package/core/plugins/i18n/index.ts +8 -0
  17. package/core/plugins/index.ts +3 -1
  18. package/core/plugins/modularity/index.ts +32 -0
  19. package/core/plugins/moment/humanize.ts +1 -4
  20. package/core/plugins/validation/index.ts +11 -1
  21. package/core/plugins/validation/rules.ts +48 -170
  22. package/core/types/index.ts +7 -9
  23. package/dist/core/composables/index.d.ts +0 -1
  24. package/dist/core/composables/index.d.ts.map +1 -1
  25. package/dist/core/composables/useApiClient/index.d.ts +9 -3
  26. package/dist/core/composables/useApiClient/index.d.ts.map +1 -1
  27. package/dist/core/composables/useAsync/index.d.ts.map +1 -1
  28. package/dist/core/composables/useAutosave/index.d.ts.map +1 -1
  29. package/dist/core/composables/useFunctions/debounce.d.ts.map +1 -1
  30. package/dist/core/composables/useFunctions/delay.d.ts.map +1 -1
  31. package/dist/core/composables/useFunctions/once.d.ts.map +1 -1
  32. package/dist/core/composables/useFunctions/throttle.d.ts.map +1 -1
  33. package/dist/core/composables/useI18n/index.d.ts +2 -4
  34. package/dist/core/composables/useI18n/index.d.ts.map +1 -1
  35. package/dist/core/composables/useLoading/index.d.ts.map +1 -1
  36. package/dist/core/composables/useNotifications/index.d.ts +1 -1
  37. package/dist/core/composables/useNotifications/index.d.ts.map +1 -1
  38. package/dist/core/composables/useSettings/index.d.ts.map +1 -1
  39. package/dist/core/composables/useUser/index.d.ts +2 -2
  40. package/dist/core/composables/useUser/index.d.ts.map +1 -1
  41. package/dist/core/plugins/i18n/index.d.ts +3 -0
  42. package/dist/core/plugins/i18n/index.d.ts.map +1 -0
  43. package/dist/core/plugins/index.d.ts +3 -1
  44. package/dist/core/plugins/index.d.ts.map +1 -1
  45. package/dist/core/plugins/modularity/index.d.ts +8 -0
  46. package/dist/core/plugins/modularity/index.d.ts.map +1 -0
  47. package/dist/core/plugins/moment/humanize.d.ts.map +1 -1
  48. package/dist/core/plugins/validation/index.d.ts +3 -1
  49. package/dist/core/plugins/validation/index.d.ts.map +1 -1
  50. package/dist/core/plugins/validation/rules.d.ts +32 -11
  51. package/dist/core/plugins/validation/rules.d.ts.map +1 -1
  52. package/dist/core/types/index.d.ts +5 -6
  53. package/dist/core/types/index.d.ts.map +1 -1
  54. package/dist/framework.esm.js +42553 -0
  55. package/dist/framework.js +74 -72
  56. package/dist/index.d.ts.map +1 -1
  57. package/dist/shared/app-switcher/composables/useAppSwitcher/index.d.ts +1 -1
  58. package/dist/shared/app-switcher/composables/useAppSwitcher/index.d.ts.map +1 -1
  59. package/dist/shared/app-switcher/index.d.ts +2 -3
  60. package/dist/shared/app-switcher/index.d.ts.map +1 -1
  61. package/dist/shared/assets/components/index.d.ts +1 -1
  62. package/dist/shared/assets/components/index.d.ts.map +1 -1
  63. package/dist/shared/assets/index.d.ts +2 -3
  64. package/dist/shared/assets/index.d.ts.map +1 -1
  65. package/dist/shared/blade-navigation/composables/index.d.ts +1 -1
  66. package/dist/shared/blade-navigation/composables/index.d.ts.map +1 -1
  67. package/dist/shared/blade-navigation/composables/useBladeNavigation/index.d.ts +2 -2
  68. package/dist/shared/blade-navigation/composables/useBladeNavigation/index.d.ts.map +1 -1
  69. package/dist/shared/blade-navigation/index.d.ts +2 -3
  70. package/dist/shared/blade-navigation/index.d.ts.map +1 -1
  71. package/dist/shared/blade-navigation/types/index.d.ts +1 -1
  72. package/dist/shared/blade-navigation/types/index.d.ts.map +1 -1
  73. package/dist/shared/index.d.ts +4 -1
  74. package/dist/shared/index.d.ts.map +1 -1
  75. package/dist/style.css +1 -1
  76. package/dist/tsconfig.tsbuildinfo +1 -1
  77. package/dist/ui/components/atoms/vc-badge/index.d.ts +3 -3
  78. package/dist/ui/components/atoms/vc-badge/index.d.ts.map +1 -1
  79. package/dist/ui/components/atoms/vc-badge/vc-badge-model.d.ts +20 -20
  80. package/dist/ui/components/atoms/vc-badge/vc-badge-model.d.ts.map +1 -1
  81. package/dist/ui/components/atoms/vc-button/index.d.ts +3 -3
  82. package/dist/ui/components/atoms/vc-button/index.d.ts.map +1 -1
  83. package/dist/ui/components/atoms/vc-button/vc-button-model.d.ts +30 -24
  84. package/dist/ui/components/atoms/vc-button/vc-button-model.d.ts.map +1 -1
  85. package/dist/ui/components/atoms/vc-card/index.d.ts +5 -0
  86. package/dist/ui/components/atoms/vc-card/index.d.ts.map +1 -0
  87. package/dist/ui/components/atoms/vc-card/vc-card-model.d.ts +33 -0
  88. package/dist/ui/components/atoms/vc-card/vc-card-model.d.ts.map +1 -0
  89. package/dist/ui/components/atoms/vc-checkbox/index.d.ts +5 -0
  90. package/dist/ui/components/atoms/vc-checkbox/index.d.ts.map +1 -0
  91. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox-model.d.ts +31 -0
  92. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox-model.d.ts.map +1 -0
  93. package/dist/ui/components/atoms/vc-col/index.d.ts +5 -0
  94. package/dist/ui/components/atoms/vc-col/index.d.ts.map +1 -0
  95. package/dist/ui/components/atoms/vc-col/vc-col-model.d.ts +13 -0
  96. package/dist/ui/components/atoms/vc-col/vc-col-model.d.ts.map +1 -0
  97. package/dist/ui/components/atoms/vc-container/index.d.ts +5 -0
  98. package/dist/ui/components/atoms/vc-container/index.d.ts.map +1 -0
  99. package/dist/ui/components/atoms/vc-container/vc-container-model.d.ts +25 -0
  100. package/dist/ui/components/atoms/vc-container/vc-container-model.d.ts.map +1 -0
  101. package/dist/ui/components/atoms/vc-hint/index.d.ts +2 -0
  102. package/dist/ui/components/atoms/vc-hint/index.d.ts.map +1 -0
  103. package/dist/ui/components/atoms/vc-hint/vc-hint-model.d.ts +5 -0
  104. package/dist/ui/components/atoms/vc-hint/vc-hint-model.d.ts.map +1 -0
  105. package/dist/ui/components/atoms/vc-icon/index.d.ts +5 -0
  106. package/dist/ui/components/atoms/vc-icon/index.d.ts.map +1 -0
  107. package/dist/ui/components/atoms/vc-icon/vc-icon-model.d.ts +17 -0
  108. package/dist/ui/components/atoms/vc-icon/vc-icon-model.d.ts.map +1 -0
  109. package/dist/ui/components/atoms/vc-image/index.d.ts +5 -0
  110. package/dist/ui/components/atoms/vc-image/index.d.ts.map +1 -0
  111. package/dist/ui/components/atoms/vc-image/vc-image-model.d.ts +38 -0
  112. package/dist/ui/components/atoms/vc-image/vc-image-model.d.ts.map +1 -0
  113. package/dist/ui/components/atoms/vc-image/vc-image.stories.d.ts.map +1 -1
  114. package/dist/ui/components/atoms/vc-info-row/index.d.ts +5 -0
  115. package/dist/ui/components/atoms/vc-info-row/index.d.ts.map +1 -0
  116. package/dist/ui/components/atoms/vc-info-row/vc-info-row-model.d.ts +25 -0
  117. package/dist/ui/components/atoms/vc-info-row/vc-info-row-model.d.ts.map +1 -0
  118. package/dist/ui/components/atoms/vc-label/index.d.ts +5 -0
  119. package/dist/ui/components/atoms/vc-label/index.d.ts.map +1 -0
  120. package/dist/ui/components/atoms/vc-label/vc-label-model.d.ts +18 -0
  121. package/dist/ui/components/atoms/vc-label/vc-label-model.d.ts.map +1 -0
  122. package/dist/ui/components/atoms/vc-link/index.d.ts +5 -0
  123. package/dist/ui/components/atoms/vc-link/index.d.ts.map +1 -0
  124. package/dist/ui/components/atoms/vc-link/vc-link-model.d.ts +21 -0
  125. package/dist/ui/components/atoms/vc-link/vc-link-model.d.ts.map +1 -0
  126. package/dist/ui/components/atoms/vc-loading/index.d.ts +5 -0
  127. package/dist/ui/components/atoms/vc-loading/index.d.ts.map +1 -0
  128. package/dist/ui/components/atoms/vc-loading/vc-loading-model.d.ts +13 -0
  129. package/dist/ui/components/atoms/vc-loading/vc-loading-model.d.ts.map +1 -0
  130. package/dist/ui/components/atoms/vc-progress/index.d.ts +5 -0
  131. package/dist/ui/components/atoms/vc-progress/index.d.ts.map +1 -0
  132. package/dist/ui/components/atoms/vc-progress/vc-progress-model.d.ts +17 -0
  133. package/dist/ui/components/atoms/vc-progress/vc-progress-model.d.ts.map +1 -0
  134. package/dist/ui/components/atoms/vc-row/index.d.ts +2 -0
  135. package/dist/ui/components/atoms/vc-row/index.d.ts.map +1 -0
  136. package/dist/ui/components/atoms/vc-row/vc-row-model.d.ts +5 -0
  137. package/dist/ui/components/atoms/vc-row/vc-row-model.d.ts.map +1 -0
  138. package/dist/ui/components/atoms/vc-status/index.d.ts +5 -0
  139. package/dist/ui/components/atoms/vc-status/index.d.ts.map +1 -0
  140. package/dist/ui/components/atoms/vc-status/vc-status-model.d.ts +21 -0
  141. package/dist/ui/components/atoms/vc-status/vc-status-model.d.ts.map +1 -0
  142. package/dist/ui/components/atoms/vc-status-icon/index.d.ts +5 -0
  143. package/dist/ui/components/atoms/vc-status-icon/index.d.ts.map +1 -0
  144. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon-model.d.ts +13 -0
  145. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon-model.d.ts.map +1 -0
  146. package/dist/ui/components/atoms/vc-switch/index.d.ts +5 -0
  147. package/dist/ui/components/atoms/vc-switch/index.d.ts.map +1 -0
  148. package/dist/ui/components/atoms/vc-switch/vc-switch-model.d.ts +30 -0
  149. package/dist/ui/components/atoms/vc-switch/vc-switch-model.d.ts.map +1 -0
  150. package/dist/ui/components/atoms/vc-widget/index.d.ts +5 -0
  151. package/dist/ui/components/atoms/vc-widget/index.d.ts.map +1 -0
  152. package/dist/ui/components/atoms/vc-widget/vc-widget-model.d.ts +20 -0
  153. package/dist/ui/components/atoms/vc-widget/vc-widget-model.d.ts.map +1 -0
  154. package/dist/ui/components/index.d.ts +34 -34
  155. package/dist/ui/components/index.d.ts.map +1 -1
  156. package/dist/ui/components/molecules/vc-breadcrumbs/index.d.ts +5 -0
  157. package/dist/ui/components/molecules/vc-breadcrumbs/index.d.ts.map +1 -0
  158. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.d.ts +19 -0
  159. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.d.ts.map +1 -0
  160. package/dist/ui/components/molecules/vc-editor/index.d.ts +5 -0
  161. package/dist/ui/components/molecules/vc-editor/index.d.ts.map +1 -0
  162. package/dist/ui/components/molecules/vc-editor/vc-editor-model.d.ts +33 -0
  163. package/dist/ui/components/molecules/vc-editor/vc-editor-model.d.ts.map +1 -0
  164. package/dist/ui/components/molecules/vc-file-upload/index.d.ts +5 -0
  165. package/dist/ui/components/molecules/vc-file-upload/index.d.ts.map +1 -0
  166. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload-model.d.ts +34 -0
  167. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload-model.d.ts.map +1 -0
  168. package/dist/ui/components/molecules/vc-form/index.d.ts +2 -0
  169. package/dist/ui/components/molecules/vc-form/index.d.ts.map +1 -0
  170. package/dist/ui/components/molecules/vc-form/vc-form-model.d.ts +5 -0
  171. package/dist/ui/components/molecules/vc-form/vc-form-model.d.ts.map +1 -0
  172. package/dist/ui/components/molecules/vc-input/index.d.ts +3 -3
  173. package/dist/ui/components/molecules/vc-input/index.d.ts.map +1 -1
  174. package/dist/ui/components/molecules/vc-input/vc-input-model.d.ts +48 -25
  175. package/dist/ui/components/molecules/vc-input/vc-input-model.d.ts.map +1 -1
  176. package/dist/ui/components/molecules/vc-input-currency/index.d.ts +3 -3
  177. package/dist/ui/components/molecules/vc-input-currency/index.d.ts.map +1 -1
  178. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency-model.d.ts +36 -28
  179. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency-model.d.ts.map +1 -1
  180. package/dist/ui/components/molecules/vc-notification/index.d.ts +5 -0
  181. package/dist/ui/components/molecules/vc-notification/index.d.ts.map +1 -0
  182. package/dist/ui/components/molecules/vc-notification/vc-notification-model.d.ts +18 -0
  183. package/dist/ui/components/molecules/vc-notification/vc-notification-model.d.ts.map +1 -0
  184. package/dist/ui/components/molecules/vc-pagination/index.d.ts +5 -0
  185. package/dist/ui/components/molecules/vc-pagination/index.d.ts.map +1 -0
  186. package/dist/ui/components/molecules/vc-pagination/vc-pagination-model.d.ts +25 -0
  187. package/dist/ui/components/molecules/vc-pagination/vc-pagination-model.d.ts.map +1 -0
  188. package/dist/ui/components/molecules/vc-rating/index.d.ts +5 -0
  189. package/dist/ui/components/molecules/vc-rating/index.d.ts.map +1 -0
  190. package/dist/ui/components/molecules/vc-rating/vc-rating-model.d.ts +21 -0
  191. package/dist/ui/components/molecules/vc-rating/vc-rating-model.d.ts.map +1 -0
  192. package/dist/ui/components/molecules/vc-select/index.d.ts +3 -3
  193. package/dist/ui/components/molecules/vc-select/index.d.ts.map +1 -1
  194. package/dist/ui/components/molecules/vc-select/vc-select-model.d.ts +67 -32
  195. package/dist/ui/components/molecules/vc-select/vc-select-model.d.ts.map +1 -1
  196. package/dist/ui/components/molecules/vc-slider/index.d.ts +5 -0
  197. package/dist/ui/components/molecules/vc-slider/index.d.ts.map +1 -0
  198. package/dist/ui/components/molecules/vc-slider/vc-slider-model.d.ts +33 -0
  199. package/dist/ui/components/molecules/vc-slider/vc-slider-model.d.ts.map +1 -0
  200. package/dist/ui/components/molecules/vc-textarea/index.d.ts +5 -0
  201. package/dist/ui/components/molecules/vc-textarea/index.d.ts.map +1 -0
  202. package/dist/ui/components/molecules/vc-textarea/vc-textarea-model.d.ts +37 -0
  203. package/dist/ui/components/molecules/vc-textarea/vc-textarea-model.d.ts.map +1 -0
  204. package/dist/ui/components/organisms/vc-app/index.d.ts +5 -0
  205. package/dist/ui/components/organisms/vc-app/index.d.ts.map +1 -0
  206. package/dist/ui/components/organisms/vc-app/vc-app-model.d.ts +61 -0
  207. package/dist/ui/components/organisms/vc-app/vc-app-model.d.ts.map +1 -0
  208. package/dist/ui/components/organisms/vc-blade/index.d.ts +5 -0
  209. package/dist/ui/components/organisms/vc-blade/index.d.ts.map +1 -0
  210. package/dist/ui/components/organisms/vc-blade/vc-blade-model.d.ts +34 -0
  211. package/dist/ui/components/organisms/vc-blade/vc-blade-model.d.ts.map +1 -0
  212. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts.map +1 -1
  213. package/dist/ui/components/organisms/vc-dynamic-property/index.d.ts +5 -0
  214. package/dist/ui/components/organisms/vc-dynamic-property/index.d.ts.map +1 -0
  215. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.d.ts +43 -0
  216. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.d.ts.map +1 -0
  217. package/dist/ui/components/organisms/vc-gallery/index.d.ts +5 -0
  218. package/dist/ui/components/organisms/vc-gallery/index.d.ts.map +1 -0
  219. package/dist/ui/components/organisms/vc-gallery/vc-gallery-model.d.ts +74 -0
  220. package/dist/ui/components/organisms/vc-gallery/vc-gallery-model.d.ts.map +1 -0
  221. package/dist/ui/components/organisms/vc-login-form/index.d.ts +5 -0
  222. package/dist/ui/components/organisms/vc-login-form/index.d.ts.map +1 -0
  223. package/dist/ui/components/organisms/vc-login-form/vc-login-form-model.d.ts +15 -0
  224. package/dist/ui/components/organisms/vc-login-form/vc-login-form-model.d.ts.map +1 -0
  225. package/dist/ui/components/organisms/vc-popup/index.d.ts +5 -0
  226. package/dist/ui/components/organisms/vc-popup/index.d.ts.map +1 -0
  227. package/dist/ui/components/organisms/vc-popup/vc-popup-model.d.ts +22 -0
  228. package/dist/ui/components/organisms/vc-popup/vc-popup-model.d.ts.map +1 -0
  229. package/dist/ui/components/organisms/vc-table/index.d.ts +5 -0
  230. package/dist/ui/components/organisms/vc-table/index.d.ts.map +1 -0
  231. package/dist/ui/components/organisms/vc-table/vc-table-model.d.ts +135 -0
  232. package/dist/ui/components/organisms/vc-table/vc-table-model.d.ts.map +1 -0
  233. package/dist/ui/types/index.d.ts +76 -6
  234. package/dist/ui/types/index.d.ts.map +1 -1
  235. package/dist/ui/types/ts-helpers.d.ts +14 -4
  236. package/dist/ui/types/ts-helpers.d.ts.map +1 -1
  237. package/dist/ui/utils/index.d.ts +2 -0
  238. package/dist/ui/utils/index.d.ts.map +1 -0
  239. package/dist/ui/utils/types.d.ts +3 -0
  240. package/dist/ui/utils/types.d.ts.map +1 -0
  241. package/dist/vite.config.d.ts +1 -1
  242. package/dist/vite.config.d.ts.map +1 -1
  243. package/package.json +9 -11
  244. package/shared/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +3 -6
  245. package/shared/app-switcher/composables/useAppSwitcher/index.ts +3 -8
  246. package/shared/app-switcher/index.ts +3 -10
  247. package/shared/assets/components/assets-details/assets-details.vue +10 -31
  248. package/shared/assets/components/index.ts +1 -1
  249. package/shared/assets/index.ts +3 -15
  250. package/shared/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue +2 -7
  251. package/shared/blade-navigation/composables/index.ts +1 -1
  252. package/shared/blade-navigation/composables/useBladeNavigation/index.ts +8 -37
  253. package/shared/blade-navigation/index.ts +3 -10
  254. package/shared/blade-navigation/types/index.ts +1 -1
  255. package/shared/index.ts +9 -11
  256. package/ui/components/atoms/vc-badge/index.ts +5 -5
  257. package/ui/components/atoms/vc-badge/vc-badge-model.ts +21 -20
  258. package/ui/components/atoms/vc-badge/vc-badge.vue +5 -11
  259. package/ui/components/atoms/vc-button/index.ts +5 -5
  260. package/ui/components/atoms/vc-button/vc-button-model.ts +31 -24
  261. package/ui/components/atoms/vc-button/vc-button.vue +9 -38
  262. package/ui/components/atoms/vc-card/index.ts +6 -0
  263. package/ui/components/atoms/vc-card/vc-card-model.ts +37 -0
  264. package/ui/components/atoms/vc-card/vc-card.vue +20 -36
  265. package/ui/components/atoms/vc-checkbox/index.ts +8 -0
  266. package/ui/components/atoms/vc-checkbox/vc-checkbox-model.ts +35 -0
  267. package/ui/components/atoms/vc-checkbox/vc-checkbox.vue +15 -30
  268. package/ui/components/atoms/vc-col/index.ts +5 -0
  269. package/ui/components/atoms/vc-col/vc-col-model.ts +15 -0
  270. package/ui/components/atoms/vc-col/vc-col.vue +2 -6
  271. package/ui/components/atoms/vc-container/index.ts +8 -0
  272. package/ui/components/atoms/vc-container/vc-container-model.ts +28 -0
  273. package/ui/components/atoms/vc-container/vc-container.vue +11 -26
  274. package/ui/components/atoms/vc-hint/index.ts +2 -0
  275. package/ui/components/atoms/vc-hint/vc-hint-model.ts +5 -0
  276. package/ui/components/atoms/vc-icon/index.ts +5 -0
  277. package/ui/components/atoms/vc-icon/vc-icon-model.ts +19 -0
  278. package/ui/components/atoms/vc-icon/vc-icon.vue +2 -8
  279. package/ui/components/atoms/vc-image/index.ts +7 -0
  280. package/ui/components/atoms/vc-image/vc-image-model.ts +41 -0
  281. package/ui/components/atoms/vc-image/vc-image.stories.ts +1 -2
  282. package/ui/components/atoms/vc-image/vc-image.vue +12 -42
  283. package/ui/components/atoms/vc-info-row/index.ts +5 -0
  284. package/ui/components/atoms/vc-info-row/vc-info-row-model.ts +27 -0
  285. package/ui/components/atoms/vc-info-row/vc-info-row.vue +14 -24
  286. package/ui/components/atoms/vc-label/index.ts +5 -0
  287. package/ui/components/atoms/vc-label/vc-label-model.ts +20 -0
  288. package/ui/components/atoms/vc-label/vc-label.vue +11 -15
  289. package/ui/components/atoms/vc-link/index.ts +6 -0
  290. package/ui/components/atoms/vc-link/vc-link-model.ts +24 -0
  291. package/ui/components/atoms/vc-link/vc-link.vue +4 -11
  292. package/ui/components/atoms/vc-loading/index.ts +5 -0
  293. package/ui/components/atoms/vc-loading/vc-loading-model.ts +15 -0
  294. package/ui/components/atoms/vc-loading/vc-loading.vue +5 -11
  295. package/ui/components/atoms/vc-progress/index.ts +5 -0
  296. package/ui/components/atoms/vc-progress/vc-progress-model.ts +19 -0
  297. package/ui/components/atoms/vc-progress/vc-progress.vue +5 -20
  298. package/ui/components/atoms/vc-row/index.ts +2 -0
  299. package/ui/components/atoms/vc-row/vc-row-model.ts +5 -0
  300. package/ui/components/atoms/vc-status/index.ts +5 -0
  301. package/ui/components/atoms/vc-status/vc-status-model.ts +23 -0
  302. package/ui/components/atoms/vc-status/vc-status.vue +3 -21
  303. package/ui/components/atoms/vc-status-icon/index.ts +5 -0
  304. package/ui/components/atoms/vc-status-icon/vc-status-icon-model.ts +15 -0
  305. package/ui/components/atoms/vc-status-icon/vc-status-icon.vue +11 -9
  306. package/ui/components/atoms/vc-switch/index.ts +7 -0
  307. package/ui/components/atoms/vc-switch/vc-switch-model.ts +34 -0
  308. package/ui/components/atoms/vc-switch/vc-switch.vue +12 -28
  309. package/ui/components/atoms/vc-widget/index.ts +7 -0
  310. package/ui/components/atoms/vc-widget/vc-widget-model.ts +23 -0
  311. package/ui/components/atoms/vc-widget/vc-widget.vue +15 -22
  312. package/ui/components/index.ts +34 -34
  313. package/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue +1 -1
  314. package/ui/components/molecules/vc-breadcrumbs/index.ts +5 -0
  315. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.ts +23 -0
  316. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue +6 -14
  317. package/ui/components/molecules/vc-editor/index.ts +7 -0
  318. package/ui/components/molecules/vc-editor/vc-editor-model.ts +37 -0
  319. package/ui/components/molecules/vc-editor/vc-editor.vue +25 -56
  320. package/ui/components/molecules/vc-file-upload/index.ts +8 -0
  321. package/ui/components/molecules/vc-file-upload/vc-file-upload-model.ts +37 -0
  322. package/ui/components/molecules/vc-file-upload/vc-file-upload.vue +11 -36
  323. package/ui/components/molecules/vc-form/index.ts +2 -0
  324. package/ui/components/molecules/vc-form/vc-form-model.ts +5 -0
  325. package/ui/components/molecules/vc-input/index.ts +5 -6
  326. package/ui/components/molecules/vc-input/vc-input-model.ts +53 -35
  327. package/ui/components/molecules/vc-input/vc-input.vue +41 -29
  328. package/ui/components/molecules/vc-input-currency/index.ts +4 -3
  329. package/ui/components/molecules/vc-input-currency/vc-input-currency-model.ts +42 -32
  330. package/ui/components/molecules/vc-input-currency/vc-input-currency.vue +12 -7
  331. package/ui/components/molecules/vc-notification/index.ts +8 -0
  332. package/ui/components/molecules/vc-notification/vc-notification-model.ts +21 -0
  333. package/ui/components/molecules/vc-notification/vc-notification.vue +4 -13
  334. package/ui/components/molecules/vc-pagination/index.ts +8 -0
  335. package/ui/components/molecules/vc-pagination/vc-pagination-model.ts +29 -0
  336. package/ui/components/molecules/vc-pagination/vc-pagination.vue +21 -23
  337. package/ui/components/molecules/vc-rating/index.ts +5 -0
  338. package/ui/components/molecules/vc-rating/vc-rating-model.ts +23 -0
  339. package/ui/components/molecules/vc-rating/vc-rating.vue +11 -13
  340. package/ui/components/molecules/vc-select/index.ts +5 -5
  341. package/ui/components/molecules/vc-select/vc-select-model.ts +74 -44
  342. package/ui/components/molecules/vc-select/vc-select.vue +128 -173
  343. package/ui/components/molecules/vc-slider/index.ts +5 -0
  344. package/ui/components/molecules/vc-slider/vc-slider-model.ts +34 -0
  345. package/ui/components/molecules/vc-slider/vc-slider.vue +2 -26
  346. package/ui/components/molecules/vc-textarea/index.ts +8 -0
  347. package/ui/components/molecules/vc-textarea/vc-textarea-model.ts +41 -0
  348. package/ui/components/molecules/vc-textarea/vc-textarea.vue +19 -53
  349. package/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue +16 -12
  350. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue +13 -4
  351. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue +18 -15
  352. package/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue +11 -5
  353. package/ui/components/organisms/vc-app/index.ts +6 -0
  354. package/ui/components/organisms/vc-app/vc-app-model.ts +65 -0
  355. package/ui/components/organisms/vc-app/vc-app.vue +10 -52
  356. package/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue +40 -40
  357. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue +20 -14
  358. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue +14 -12
  359. package/ui/components/organisms/vc-blade/index.ts +7 -0
  360. package/ui/components/organisms/vc-blade/vc-blade-model.ts +37 -0
  361. package/ui/components/organisms/vc-blade/vc-blade.stories.ts +1 -2
  362. package/ui/components/organisms/vc-blade/vc-blade.vue +13 -40
  363. package/ui/components/organisms/vc-dynamic-property/index.ts +5 -0
  364. package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.ts +58 -0
  365. package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue +101 -125
  366. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue +41 -24
  367. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue +16 -11
  368. package/ui/components/organisms/vc-gallery/index.ts +8 -0
  369. package/ui/components/organisms/vc-gallery/vc-gallery-model.ts +78 -0
  370. package/ui/components/organisms/vc-gallery/vc-gallery.vue +11 -88
  371. package/ui/components/organisms/vc-login-form/index.ts +5 -0
  372. package/ui/components/organisms/vc-login-form/vc-login-form-model.ts +16 -0
  373. package/ui/components/organisms/vc-login-form/vc-login-form.vue +2 -15
  374. package/ui/components/organisms/vc-popup/index.ts +7 -0
  375. package/ui/components/organisms/vc-popup/vc-popup-model.ts +25 -0
  376. package/ui/components/organisms/vc-popup/vc-popup.vue +7 -18
  377. package/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue +21 -27
  378. package/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue +2 -6
  379. package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +9 -3
  380. package/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue +31 -43
  381. package/ui/components/organisms/vc-table/index.ts +7 -0
  382. package/ui/components/organisms/vc-table/vc-table-model.ts +116 -0
  383. package/ui/components/organisms/vc-table/vc-table.vue +108 -139
  384. package/ui/types/index.ts +106 -15
  385. package/ui/types/ts-helpers.ts +23 -3
  386. package/ui/utils/index.ts +1 -0
  387. package/ui/utils/types.ts +2 -0
  388. package/core/composables/useLogger/index.ts +0 -24
  389. package/dist/core/composables/useLogger/index.d.ts +0 -5
  390. package/dist/core/composables/useLogger/index.d.ts.map +0 -1
@@ -4,11 +4,20 @@
4
4
  <VcCol>
5
5
  <VcLabel>
6
6
  <span>{{ label }}</span>
7
- <template v-if="tooltip" v-slot:tooltip>{{ tooltip }}</template>
7
+ <template
8
+ v-if="tooltip"
9
+ v-slot:tooltip
10
+ >{{ tooltip }}</template
11
+ >
8
12
  </VcLabel>
9
13
  </VcCol>
10
14
  <VcCol size="2">
11
- <p class="tw-m-0" v-if="type === 'default'">{{ value }}</p>
15
+ <p
16
+ class="tw-m-0"
17
+ v-if="type === 'default'"
18
+ >
19
+ {{ value }}
20
+ </p>
12
21
  <VcLink v-else-if="type === 'email'">{{ value }}</VcLink>
13
22
  </VcCol>
14
23
  </VcRow>
@@ -16,27 +25,8 @@
16
25
  </template>
17
26
 
18
27
  <script lang="ts" setup>
19
- import { VcLabel, VcRow, VcCol } from "@/ui/components";
28
+ import { VcLabel, VcRow, VcCol } from "./../../../components";
29
+ import { infoRowProps } from "./vc-info-row-model";
20
30
 
21
- defineProps({
22
- label: {
23
- type: String,
24
- default: "",
25
- },
26
-
27
- value: {
28
- type: String,
29
- default: "",
30
- },
31
-
32
- tooltip: {
33
- type: String,
34
- default: "",
35
- },
36
-
37
- type: {
38
- type: String,
39
- default: "default",
40
- },
41
- });
31
+ defineProps(infoRowProps);
42
32
  </script>
@@ -0,0 +1,5 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcLabelProps } from "./vc-label-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Label from "./vc-label.vue";
5
+ export const VcLabel: ComponentConstructor<ComponentPublicInstance<VcLabelProps>> = Label;
@@ -0,0 +1,20 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const labelProps = {
5
+ required: {
6
+ type: Boolean,
7
+ default: false,
8
+ },
9
+ tooltipIcon: {
10
+ type: String,
11
+ default: "fas fa-info-circle",
12
+ },
13
+ };
14
+
15
+ export type VcLabelProps = ExtractTypes<typeof labelProps>;
16
+
17
+ export interface VcLabelSlots {
18
+ default: () => VNode[];
19
+ tooltip: () => VNode[];
20
+ }
@@ -1,10 +1,15 @@
1
1
  <template>
2
- <div class= "tw-flex tw-flex-nowrap tw-font-bold">
2
+ <div class="tw-flex tw-flex-nowrap tw-font-bold">
3
3
  <span><slot></slot></span>
4
- <span v-if="required" class="tw-text-[color:var(--label-required-color)] tw-ml-1"
4
+ <span
5
+ v-if="required"
6
+ class="tw-text-[color:var(--label-required-color)] tw-ml-1"
5
7
  >*</span
6
8
  >
7
- <span v-if="$slots['tooltip']" class="tw-grow tw-basis-0 tw-ml-1">
9
+ <span
10
+ v-if="$slots['tooltip']"
11
+ class="tw-grow tw-basis-0 tw-ml-1"
12
+ >
8
13
  <VcIcon
9
14
  class="tw-text-[color:var(--label-tooltip-color)]"
10
15
  :icon="tooltipIcon"
@@ -23,20 +28,11 @@
23
28
  </template>
24
29
 
25
30
  <script lang="ts" setup>
26
- import { VcIcon } from "@/ui/components";
31
+ import { VcIcon } from "./../../../components";
27
32
  import { ref } from "vue";
33
+ import { labelProps } from "./vc-label-model";
28
34
 
29
- defineProps({
30
- required: {
31
- type: Boolean,
32
- default: false,
33
- },
34
-
35
- tooltipIcon: {
36
- type: String,
37
- default: "fas fa-info-circle",
38
- },
39
- });
35
+ defineProps(labelProps);
40
36
 
41
37
  const tooltipVisible = ref(false);
42
38
  </script>
@@ -0,0 +1,6 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcLinkEmits, VcLinkProps } from "./vc-link-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Link from "./vc-link.vue";
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ export const VcLink: ComponentConstructor<ComponentPublicInstance<VcLinkProps, any, any, any, any, VcLinkEmits>> = Link;
@@ -0,0 +1,24 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const linkProps = {
5
+ active: {
6
+ type: Boolean,
7
+ default: false,
8
+ },
9
+ disabled: {
10
+ type: Boolean,
11
+ default: false,
12
+ },
13
+ };
14
+
15
+ export const linkEmits = {
16
+ click: () => true,
17
+ };
18
+
19
+ export type VcLinkProps = ExtractTypes<typeof linkProps>;
20
+ export type VcLinkEmits = typeof linkEmits;
21
+
22
+ export interface VcLinkSlots {
23
+ default: () => VNode[];
24
+ }
@@ -13,18 +13,11 @@
13
13
  </template>
14
14
 
15
15
  <script lang="ts" setup>
16
- const props = defineProps({
17
- active: {
18
- type: Boolean,
19
- default: false,
20
- },
16
+ import { linkEmits, linkProps } from "./vc-link-model";
17
+
18
+ const props = defineProps(linkProps);
19
+ const emit = defineEmits(linkEmits);
21
20
 
22
- disabled: {
23
- type: Boolean,
24
- default: false,
25
- },
26
- });
27
- const emit = defineEmits(["click"]);
28
21
  function onClick(): void {
29
22
  if (!props.disabled) {
30
23
  emit("click");
@@ -0,0 +1,5 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcLoadingProps } from "./vc-loading-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Loading from "./vc-loading.vue";
5
+ export const VcLoading: ComponentConstructor<ComponentPublicInstance<VcLoadingProps>> = Loading;
@@ -0,0 +1,15 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const loadingProps = {
5
+ active: {
6
+ type: Boolean,
7
+ default: false,
8
+ },
9
+ };
10
+
11
+ export type VcLoadingProps = ExtractTypes<typeof loadingProps>;
12
+
13
+ export interface VcLoadingSlots {
14
+ default: () => VNode[];
15
+ }
@@ -2,17 +2,14 @@
2
2
  <div
3
3
  class="tw-absolute tw-items-center tw-justify-center tw-flex-col tw-z-[9998] tw-hidden tw-w-full tw-h-full tw-box-border"
4
4
  :class="{
5
- '!tw-flex tw-backdrop-blur-[3px] tw-bg-[rgba(255, 255, 255, 0.5)]':
6
- active,
5
+ '!tw-flex tw-backdrop-blur-[3px] tw-bg-[rgba(255, 255, 255, 0.5)]': active,
7
6
  }"
8
7
  >
9
8
  <div class="tw-relative tw-w-[142px] tw-h-[40px] tw-z-[1]">
10
9
  <span
11
10
  class="tw-absolute tw-w-4 tw-h-4 tw-top-[12px] tw-left-[15px] tw-bg-[#319ed4] tw-rounded-full tw-translate-x-0 tw-animate-loadingMarker"
12
11
  ></span>
13
- <div
14
- class="tw-translate-x-0 tw-mt-3 tw-ml-[31px] tw-animate-loadingMarkers"
15
- >
12
+ <div class="tw-translate-x-0 tw-mt-3 tw-ml-[31px] tw-animate-loadingMarkers">
16
13
  <span
17
14
  class="tw-block tw-float-left tw-w-4 tw-h-4 tw-bg-[#319ed4] tw-rounded-full tw-ml-4"
18
15
  v-for="item in 3"
@@ -24,10 +21,7 @@
24
21
  </template>
25
22
 
26
23
  <script lang="ts" setup>
27
- defineProps({
28
- active: {
29
- type: Boolean,
30
- default: false,
31
- },
32
- });
24
+ import { loadingProps } from "./vc-loading-model";
25
+
26
+ defineProps(loadingProps);
33
27
  </script>
@@ -0,0 +1,5 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcProgressProps } from "./vc-progress-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Progress from "./vc-progress.vue";
5
+ export const VcProgress: ComponentConstructor<ComponentPublicInstance<VcProgressProps>> = Progress;
@@ -0,0 +1,19 @@
1
+ import { PropType, VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const progressProps = {
5
+ value: {
6
+ type: Number,
7
+ default: 0,
8
+ },
9
+ variant: {
10
+ type: String as PropType<"default" | "striped">,
11
+ default: "default",
12
+ },
13
+ };
14
+
15
+ export type VcProgressProps = ExtractTypes<typeof progressProps>;
16
+
17
+ export interface VcProgressSlots {
18
+ default: () => VNode[];
19
+ }
@@ -6,25 +6,16 @@
6
6
  ]"
7
7
  >
8
8
  <div
9
- class="vc-progress__value tw-bg-[color:var(--progressbar-foreground-color)] tw-transition tw-duration-200 tw-h-full"
9
+ class="vc-progress__value tw-bg-[color:var(--progressbar-foreground-color)] tw-transition tw-duration-200 tw-h-full"
10
10
  :style="`width: ${value}%`"
11
11
  ></div>
12
12
  </div>
13
13
  </template>
14
14
 
15
15
  <script lang="ts" setup>
16
- defineProps({
17
- value: {
18
- type: Number,
19
- default: 0,
20
- },
16
+ import { progressProps } from "./vc-progress-model";
21
17
 
22
- variant: {
23
- type: String,
24
- default: "default",
25
- enum: ["default", "striped"],
26
- },
27
- });
18
+ defineProps(progressProps);
28
19
  </script>
29
20
 
30
21
  <style lang="scss">
@@ -49,14 +40,8 @@ defineProps({
49
40
  .vc-progress {
50
41
  &.striped {
51
42
  .vc-progress__value {
52
- background: linear-gradient(
53
- 45deg,
54
- transparent 50%,
55
- #acd2f2 50%,
56
- #acd2f2 75%,
57
- transparent 75%
58
- )
59
- left/30px 30px repeat-x,
43
+ background: linear-gradient(45deg, transparent 50%, #acd2f2 50%, #acd2f2 75%, transparent 75%) left/30px 30px
44
+ repeat-x,
60
45
  #e1f0fe;
61
46
  animation: change 1s linear infinite;
62
47
  }
@@ -0,0 +1,2 @@
1
+ import Row from "./vc-row.vue";
2
+ export const VcRow = Row;
@@ -0,0 +1,5 @@
1
+ import { VNode } from "vue";
2
+
3
+ export interface VcRowSlots {
4
+ default: () => VNode[];
5
+ }
@@ -0,0 +1,5 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcStatusProps } from "./vc-status-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Status from "./vc-status.vue";
5
+ export const VcStatus: ComponentConstructor<ComponentPublicInstance<VcStatusProps>> = Status;
@@ -0,0 +1,23 @@
1
+ import { PropType, VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const statusProps = {
5
+ variant: {
6
+ type: String as PropType<"info" | "warning" | "danger" | "success" | "light-danger">,
7
+ default: "info",
8
+ },
9
+ outline: {
10
+ type: Boolean,
11
+ default: true,
12
+ },
13
+ extend: {
14
+ type: Boolean,
15
+ default: false,
16
+ },
17
+ };
18
+
19
+ export type VcStatusProps = ExtractTypes<typeof statusProps>;
20
+
21
+ export interface VcStatusSlots {
22
+ default: () => VNode[];
23
+ }
@@ -1,34 +1,16 @@
1
1
  <template>
2
2
  <div
3
3
  class="vc-status"
4
- :class="[
5
- `vc-status_${variant}`,
6
- { 'vc-status_outline': outline },
7
- { 'vc-status_extended': extend },
8
- ]"
4
+ :class="[`vc-status_${variant}`, { 'vc-status_outline': outline }, { 'vc-status_extended': extend }]"
9
5
  >
10
6
  <slot></slot>
11
7
  </div>
12
8
  </template>
13
9
 
14
10
  <script lang="ts" setup>
15
- defineProps({
16
- variant: {
17
- type: String,
18
- default: "info",
19
- enum: ["info", "warning", "danger", "success", "light-danger"],
20
- },
11
+ import { statusProps } from "./vc-status-model";
21
12
 
22
- outline: {
23
- type: Boolean,
24
- default: true,
25
- },
26
-
27
- extend: {
28
- type: Boolean,
29
- default: false,
30
- },
31
- });
13
+ defineProps(statusProps);
32
14
  </script>
33
15
 
34
16
  <style lang="scss">
@@ -0,0 +1,5 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcStatusIconProps } from "./vc-status-icon-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import StatusIcon from "./vc-status-icon.vue";
5
+ export const VcStatusIcon: ComponentConstructor<ComponentPublicInstance<VcStatusIconProps>> = StatusIcon;
@@ -0,0 +1,15 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const statusIconProps = {
5
+ status: {
6
+ type: Boolean,
7
+ default: false,
8
+ },
9
+ };
10
+
11
+ export type VcStatusIconProps = ExtractTypes<typeof statusIconProps>;
12
+
13
+ export interface VcStatusIconSlots {
14
+ default: () => VNode[];
15
+ }
@@ -1,21 +1,23 @@
1
1
  <template>
2
2
  <div>
3
3
  <template v-if="status">
4
- <VcIcon icon="fas fa-check-circle" class="tw-text-[color:#87b563]"></VcIcon>
4
+ <VcIcon
5
+ icon="fas fa-check-circle"
6
+ class="tw-text-[color:#87b563]"
7
+ ></VcIcon>
5
8
  </template>
6
9
  <template v-else>
7
- <VcIcon icon="fas fa-times-circle" class="tw-text-[color:#bdd1df]"></VcIcon>
10
+ <VcIcon
11
+ icon="fas fa-times-circle"
12
+ class="tw-text-[color:#bdd1df]"
13
+ ></VcIcon>
8
14
  </template>
9
15
  </div>
10
16
  </template>
11
17
 
12
18
  <script lang="ts" setup>
13
- import { VcIcon } from "@/ui/components";
19
+ import { VcIcon } from "./../../../components";
20
+ import { statusIconProps } from "./vc-status-icon-model";
14
21
 
15
- defineProps({
16
- status: {
17
- type: Boolean,
18
- default: false,
19
- },
20
- });
22
+ defineProps(statusIconProps);
21
23
  </script>
@@ -0,0 +1,7 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcSwitchEmits, VcSwitchProps } from "./vc-switch-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Switch from "./vc-switch.vue";
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ export const VcSwitch: ComponentConstructor<ComponentPublicInstance<VcSwitchProps, any, any, any, any, VcSwitchEmits>> =
7
+ Switch;
@@ -0,0 +1,34 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+ import { isBoolean } from "./../../../utils";
4
+
5
+ export const switchProps = {
6
+ modelValue: {
7
+ type: Boolean,
8
+ default: false,
9
+ },
10
+ disabled: {
11
+ type: Boolean,
12
+ default: false,
13
+ },
14
+ tooltip: {
15
+ type: String,
16
+ default: "",
17
+ },
18
+ required: {
19
+ type: Boolean,
20
+ default: false,
21
+ },
22
+ label: String,
23
+ };
24
+
25
+ export const switchEmits = {
26
+ "update:modelValue": (value: boolean) => isBoolean(value),
27
+ };
28
+
29
+ export type VcSwitchProps = ExtractTypes<typeof switchProps>;
30
+ export type VcSwitchEmits = typeof switchEmits;
31
+
32
+ export interface VcSwitchSlots {
33
+ default: () => VNode[];
34
+ }
@@ -1,7 +1,11 @@
1
1
  <template>
2
2
  <div>
3
3
  <!-- Switch label -->
4
- <VcLabel v-if="label" class="tw-mb-2" :required="required">
4
+ <VcLabel
5
+ v-if="label"
6
+ class="tw-mb-2"
7
+ :required="required"
8
+ >
5
9
  <span>{{ label }}</span>
6
10
  </VcLabel>
7
11
  <div class="tw-relative tw-inline-block tw-w-[54px] tw-h-[18px]">
@@ -15,7 +19,10 @@
15
19
  />
16
20
  <span class="vc-switch__slider"></span>
17
21
  </label>
18
- <VcHint class="tw-mt-2 tw-w-max" v-if="tooltip">
22
+ <VcHint
23
+ class="tw-mt-2 tw-w-max"
24
+ v-if="tooltip"
25
+ >
19
26
  {{ tooltip }}
20
27
  </VcHint>
21
28
  </div>
@@ -23,34 +30,11 @@
23
30
  </template>
24
31
 
25
32
  <script lang="ts" setup>
26
- defineProps({
27
- modelValue: {
28
- type: Boolean,
29
- default: false,
30
- },
33
+ import { switchEmits, switchProps } from "./vc-switch-model";
31
34
 
32
- disabled: {
33
- type: Boolean,
34
- default: false,
35
- },
35
+ defineProps(switchProps);
36
36
 
37
- tooltip: {
38
- type: String,
39
- default: "",
40
- },
41
-
42
- required: {
43
- type: Boolean,
44
- default: false,
45
- },
46
-
47
- label: {
48
- type: String,
49
- default: undefined,
50
- },
51
- });
52
-
53
- const emit = defineEmits(["update:modelValue"]);
37
+ const emit = defineEmits(switchEmits);
54
38
 
55
39
  function onInput(e: InputEvent) {
56
40
  const newValue = (e.target as HTMLInputElement).checked;
@@ -0,0 +1,7 @@
1
+ import { ComponentPublicInstance } from "vue";
2
+ import { VcWidgetEmits, VcWidgetProps } from "./vc-widget-model";
3
+ import { ComponentConstructor } from "./../../../types/ts-helpers";
4
+ import Widget from "./vc-widget.vue";
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ export const VcWidget: ComponentConstructor<ComponentPublicInstance<VcWidgetProps, any, any, any, any, VcWidgetEmits>> =
7
+ Widget;
@@ -0,0 +1,23 @@
1
+ import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
3
+
4
+ export const widgetProps = {
5
+ icon: String,
6
+ title: String,
7
+ value: [String, Number],
8
+ disabled: {
9
+ type: Boolean,
10
+ default: false,
11
+ },
12
+ };
13
+
14
+ export const widgetEmits = {
15
+ click: () => true,
16
+ };
17
+
18
+ export type VcWidgetProps = ExtractTypes<typeof widgetProps>;
19
+ export type VcWidgetEmits = typeof widgetEmits;
20
+
21
+ export interface VcWidgetSlots {
22
+ default: () => VNode[];
23
+ }
@@ -10,34 +10,27 @@
10
10
  :icon="icon"
11
11
  size="xxl"
12
12
  ></VcIcon>
13
- <div v-if="title" class="vc-widget__title">{{ title }}</div>
14
- <div v-if="value !== undefined" class="vc-widget__value">{{ value }}</div>
13
+ <div
14
+ v-if="title"
15
+ class="vc-widget__title"
16
+ >
17
+ {{ title }}
18
+ </div>
19
+ <div
20
+ v-if="value !== undefined"
21
+ class="vc-widget__value"
22
+ >
23
+ {{ value }}
24
+ </div>
15
25
  </div>
16
26
  </template>
17
27
 
18
28
  <script lang="ts" setup>
19
- const props = defineProps({
20
- icon: {
21
- type: String,
22
- default: undefined,
23
- },
29
+ import { widgetEmits, widgetProps } from "./vc-widget-model";
24
30
 
25
- title: {
26
- type: String,
27
- default: undefined,
28
- },
31
+ const props = defineProps(widgetProps);
29
32
 
30
- value: {
31
- type: [String, Number],
32
- default: undefined,
33
- },
34
-
35
- disabled: {
36
- type: Boolean,
37
- default: false,
38
- },
39
- });
40
- const emit = defineEmits(["click"]);
33
+ const emit = defineEmits(widgetEmits);
41
34
 
42
35
  function onClick() {
43
36
  if (!props.disabled) {