@vc-shell/framework 1.0.53 → 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 (354) hide show
  1. package/core/composables/index.ts +0 -1
  2. package/core/composables/useApiClient/index.ts +1 -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 +5 -12
  12. package/core/composables/useSettings/index.ts +2 -3
  13. package/core/composables/useUser/index.ts +25 -64
  14. package/core/plugins/i18n/index.ts +8 -0
  15. package/core/plugins/index.ts +3 -1
  16. package/core/plugins/modularity/index.ts +32 -0
  17. package/core/plugins/moment/humanize.ts +1 -4
  18. package/core/plugins/validation/index.ts +11 -1
  19. package/core/plugins/validation/rules.ts +48 -170
  20. package/core/types/index.ts +3 -5
  21. package/dist/core/composables/index.d.ts +0 -1
  22. package/dist/core/composables/index.d.ts.map +1 -1
  23. package/dist/core/composables/useApiClient/index.d.ts.map +1 -1
  24. package/dist/core/composables/useAsync/index.d.ts.map +1 -1
  25. package/dist/core/composables/useAutosave/index.d.ts.map +1 -1
  26. package/dist/core/composables/useFunctions/debounce.d.ts.map +1 -1
  27. package/dist/core/composables/useFunctions/delay.d.ts.map +1 -1
  28. package/dist/core/composables/useFunctions/once.d.ts.map +1 -1
  29. package/dist/core/composables/useFunctions/throttle.d.ts.map +1 -1
  30. package/dist/core/composables/useI18n/index.d.ts +2 -4
  31. package/dist/core/composables/useI18n/index.d.ts.map +1 -1
  32. package/dist/core/composables/useLoading/index.d.ts.map +1 -1
  33. package/dist/core/composables/useNotifications/index.d.ts.map +1 -1
  34. package/dist/core/composables/useSettings/index.d.ts.map +1 -1
  35. package/dist/core/composables/useUser/index.d.ts.map +1 -1
  36. package/dist/core/plugins/i18n/index.d.ts +3 -0
  37. package/dist/core/plugins/i18n/index.d.ts.map +1 -0
  38. package/dist/core/plugins/index.d.ts +3 -1
  39. package/dist/core/plugins/index.d.ts.map +1 -1
  40. package/dist/core/plugins/modularity/index.d.ts +8 -0
  41. package/dist/core/plugins/modularity/index.d.ts.map +1 -0
  42. package/dist/core/plugins/moment/humanize.d.ts.map +1 -1
  43. package/dist/core/plugins/validation/index.d.ts +3 -1
  44. package/dist/core/plugins/validation/index.d.ts.map +1 -1
  45. package/dist/core/plugins/validation/rules.d.ts +32 -11
  46. package/dist/core/plugins/validation/rules.d.ts.map +1 -1
  47. package/dist/core/types/index.d.ts +0 -1
  48. package/dist/core/types/index.d.ts.map +1 -1
  49. package/dist/framework.esm.js +42553 -0
  50. package/dist/framework.js +77 -75
  51. package/dist/index.d.ts.map +1 -1
  52. package/dist/shared/app-switcher/composables/useAppSwitcher/index.d.ts.map +1 -1
  53. package/dist/shared/app-switcher/index.d.ts +2 -3
  54. package/dist/shared/app-switcher/index.d.ts.map +1 -1
  55. package/dist/shared/assets/components/index.d.ts +1 -1
  56. package/dist/shared/assets/components/index.d.ts.map +1 -1
  57. package/dist/shared/assets/index.d.ts +2 -3
  58. package/dist/shared/assets/index.d.ts.map +1 -1
  59. package/dist/shared/blade-navigation/composables/index.d.ts +1 -1
  60. package/dist/shared/blade-navigation/composables/index.d.ts.map +1 -1
  61. package/dist/shared/blade-navigation/composables/useBladeNavigation/index.d.ts +1 -1
  62. package/dist/shared/blade-navigation/composables/useBladeNavigation/index.d.ts.map +1 -1
  63. package/dist/shared/blade-navigation/index.d.ts +2 -3
  64. package/dist/shared/blade-navigation/index.d.ts.map +1 -1
  65. package/dist/shared/index.d.ts +4 -1
  66. package/dist/shared/index.d.ts.map +1 -1
  67. package/dist/style.css +1 -1
  68. package/dist/tsconfig.tsbuildinfo +1 -1
  69. package/dist/ui/components/atoms/vc-badge/index.d.ts +2 -2
  70. package/dist/ui/components/atoms/vc-badge/index.d.ts.map +1 -1
  71. package/dist/ui/components/atoms/vc-badge/vc-badge-model.d.ts +20 -15
  72. package/dist/ui/components/atoms/vc-badge/vc-badge-model.d.ts.map +1 -1
  73. package/dist/ui/components/atoms/vc-button/index.d.ts +2 -2
  74. package/dist/ui/components/atoms/vc-button/index.d.ts.map +1 -1
  75. package/dist/ui/components/atoms/vc-button/vc-button-model.d.ts +30 -10
  76. package/dist/ui/components/atoms/vc-button/vc-button-model.d.ts.map +1 -1
  77. package/dist/ui/components/atoms/vc-card/index.d.ts +2 -2
  78. package/dist/ui/components/atoms/vc-card/index.d.ts.map +1 -1
  79. package/dist/ui/components/atoms/vc-card/vc-card-model.d.ts +28 -11
  80. package/dist/ui/components/atoms/vc-card/vc-card-model.d.ts.map +1 -1
  81. package/dist/ui/components/atoms/vc-checkbox/index.d.ts +2 -2
  82. package/dist/ui/components/atoms/vc-checkbox/index.d.ts.map +1 -1
  83. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox-model.d.ts +25 -8
  84. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox-model.d.ts.map +1 -1
  85. package/dist/ui/components/atoms/vc-col/index.d.ts.map +1 -1
  86. package/dist/ui/components/atoms/vc-col/vc-col-model.d.ts +8 -3
  87. package/dist/ui/components/atoms/vc-col/vc-col-model.d.ts.map +1 -1
  88. package/dist/ui/components/atoms/vc-container/index.d.ts +2 -2
  89. package/dist/ui/components/atoms/vc-container/index.d.ts.map +1 -1
  90. package/dist/ui/components/atoms/vc-container/vc-container-model.d.ts +20 -6
  91. package/dist/ui/components/atoms/vc-container/vc-container-model.d.ts.map +1 -1
  92. package/dist/ui/components/atoms/vc-hint/vc-hint-model.d.ts +5 -0
  93. package/dist/ui/components/atoms/vc-hint/vc-hint-model.d.ts.map +1 -0
  94. package/dist/ui/components/atoms/vc-icon/index.d.ts.map +1 -1
  95. package/dist/ui/components/atoms/vc-icon/vc-icon-model.d.ts +13 -5
  96. package/dist/ui/components/atoms/vc-icon/vc-icon-model.d.ts.map +1 -1
  97. package/dist/ui/components/atoms/vc-image/index.d.ts +2 -2
  98. package/dist/ui/components/atoms/vc-image/index.d.ts.map +1 -1
  99. package/dist/ui/components/atoms/vc-image/vc-image-model.d.ts +34 -11
  100. package/dist/ui/components/atoms/vc-image/vc-image-model.d.ts.map +1 -1
  101. package/dist/ui/components/atoms/vc-image/vc-image.stories.d.ts.map +1 -1
  102. package/dist/ui/components/atoms/vc-info-row/index.d.ts.map +1 -1
  103. package/dist/ui/components/atoms/vc-info-row/vc-info-row-model.d.ts +21 -7
  104. package/dist/ui/components/atoms/vc-info-row/vc-info-row-model.d.ts.map +1 -1
  105. package/dist/ui/components/atoms/vc-label/index.d.ts.map +1 -1
  106. package/dist/ui/components/atoms/vc-label/vc-label-model.d.ts +12 -4
  107. package/dist/ui/components/atoms/vc-label/vc-label-model.d.ts.map +1 -1
  108. package/dist/ui/components/atoms/vc-link/index.d.ts +2 -2
  109. package/dist/ui/components/atoms/vc-link/index.d.ts.map +1 -1
  110. package/dist/ui/components/atoms/vc-link/vc-link-model.d.ts +16 -5
  111. package/dist/ui/components/atoms/vc-link/vc-link-model.d.ts.map +1 -1
  112. package/dist/ui/components/atoms/vc-loading/index.d.ts.map +1 -1
  113. package/dist/ui/components/atoms/vc-loading/vc-loading-model.d.ts +8 -3
  114. package/dist/ui/components/atoms/vc-loading/vc-loading-model.d.ts.map +1 -1
  115. package/dist/ui/components/atoms/vc-progress/index.d.ts.map +1 -1
  116. package/dist/ui/components/atoms/vc-progress/vc-progress-model.d.ts +13 -5
  117. package/dist/ui/components/atoms/vc-progress/vc-progress-model.d.ts.map +1 -1
  118. package/dist/ui/components/atoms/vc-status/index.d.ts.map +1 -1
  119. package/dist/ui/components/atoms/vc-status/vc-status-model.d.ts +17 -6
  120. package/dist/ui/components/atoms/vc-status/vc-status-model.d.ts.map +1 -1
  121. package/dist/ui/components/atoms/vc-status-icon/index.d.ts.map +1 -1
  122. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon-model.d.ts +8 -3
  123. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon-model.d.ts.map +1 -1
  124. package/dist/ui/components/atoms/vc-switch/index.d.ts +2 -2
  125. package/dist/ui/components/atoms/vc-switch/index.d.ts.map +1 -1
  126. package/dist/ui/components/atoms/vc-switch/vc-switch-model.d.ts +25 -8
  127. package/dist/ui/components/atoms/vc-switch/vc-switch-model.d.ts.map +1 -1
  128. package/dist/ui/components/atoms/vc-widget/index.d.ts +2 -2
  129. package/dist/ui/components/atoms/vc-widget/index.d.ts.map +1 -1
  130. package/dist/ui/components/atoms/vc-widget/vc-widget-model.d.ts +15 -7
  131. package/dist/ui/components/atoms/vc-widget/vc-widget-model.d.ts.map +1 -1
  132. package/dist/ui/components/index.d.ts.map +1 -1
  133. package/dist/ui/components/molecules/vc-breadcrumbs/index.d.ts.map +1 -1
  134. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.d.ts +15 -10
  135. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.d.ts.map +1 -1
  136. package/dist/ui/components/molecules/vc-editor/index.d.ts +2 -2
  137. package/dist/ui/components/molecules/vc-editor/index.d.ts.map +1 -1
  138. package/dist/ui/components/molecules/vc-editor/vc-editor-model.d.ts +28 -11
  139. package/dist/ui/components/molecules/vc-editor/vc-editor-model.d.ts.map +1 -1
  140. package/dist/ui/components/molecules/vc-file-upload/index.d.ts +2 -2
  141. package/dist/ui/components/molecules/vc-file-upload/index.d.ts.map +1 -1
  142. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload-model.d.ts +30 -10
  143. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload-model.d.ts.map +1 -1
  144. package/dist/ui/components/molecules/vc-form/vc-form-model.d.ts +5 -0
  145. package/dist/ui/components/molecules/vc-form/vc-form-model.d.ts.map +1 -0
  146. package/dist/ui/components/molecules/vc-input/index.d.ts +2 -2
  147. package/dist/ui/components/molecules/vc-input/index.d.ts.map +1 -1
  148. package/dist/ui/components/molecules/vc-input/vc-input-model.d.ts +48 -25
  149. package/dist/ui/components/molecules/vc-input/vc-input-model.d.ts.map +1 -1
  150. package/dist/ui/components/molecules/vc-input-currency/index.d.ts +2 -2
  151. package/dist/ui/components/molecules/vc-input-currency/index.d.ts.map +1 -1
  152. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency-model.d.ts +36 -28
  153. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency-model.d.ts.map +1 -1
  154. package/dist/ui/components/molecules/vc-notification/index.d.ts +2 -2
  155. package/dist/ui/components/molecules/vc-notification/index.d.ts.map +1 -1
  156. package/dist/ui/components/molecules/vc-notification/vc-notification-model.d.ts +13 -5
  157. package/dist/ui/components/molecules/vc-notification/vc-notification-model.d.ts.map +1 -1
  158. package/dist/ui/components/molecules/vc-pagination/index.d.ts +2 -2
  159. package/dist/ui/components/molecules/vc-pagination/index.d.ts.map +1 -1
  160. package/dist/ui/components/molecules/vc-pagination/vc-pagination-model.d.ts +20 -6
  161. package/dist/ui/components/molecules/vc-pagination/vc-pagination-model.d.ts.map +1 -1
  162. package/dist/ui/components/molecules/vc-rating/index.d.ts.map +1 -1
  163. package/dist/ui/components/molecules/vc-rating/vc-rating-model.d.ts +17 -9
  164. package/dist/ui/components/molecules/vc-rating/vc-rating-model.d.ts.map +1 -1
  165. package/dist/ui/components/molecules/vc-select/index.d.ts +2 -2
  166. package/dist/ui/components/molecules/vc-select/index.d.ts.map +1 -1
  167. package/dist/ui/components/molecules/vc-select/vc-select-model.d.ts +67 -32
  168. package/dist/ui/components/molecules/vc-select/vc-select-model.d.ts.map +1 -1
  169. package/dist/ui/components/molecules/vc-slider/index.d.ts.map +1 -1
  170. package/dist/ui/components/molecules/vc-slider/vc-slider-model.d.ts +25 -8
  171. package/dist/ui/components/molecules/vc-slider/vc-slider-model.d.ts.map +1 -1
  172. package/dist/ui/components/molecules/vc-textarea/index.d.ts +2 -2
  173. package/dist/ui/components/molecules/vc-textarea/index.d.ts.map +1 -1
  174. package/dist/ui/components/molecules/vc-textarea/vc-textarea-model.d.ts +32 -12
  175. package/dist/ui/components/molecules/vc-textarea/vc-textarea-model.d.ts.map +1 -1
  176. package/dist/ui/components/organisms/vc-app/index.d.ts +2 -2
  177. package/dist/ui/components/organisms/vc-app/index.d.ts.map +1 -1
  178. package/dist/ui/components/organisms/vc-app/vc-app-model.d.ts +52 -17
  179. package/dist/ui/components/organisms/vc-app/vc-app-model.d.ts.map +1 -1
  180. package/dist/ui/components/organisms/vc-blade/index.d.ts +2 -2
  181. package/dist/ui/components/organisms/vc-blade/index.d.ts.map +1 -1
  182. package/dist/ui/components/organisms/vc-blade/vc-blade-model.d.ts +28 -11
  183. package/dist/ui/components/organisms/vc-blade/vc-blade-model.d.ts.map +1 -1
  184. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts.map +1 -1
  185. package/dist/ui/components/organisms/vc-dynamic-property/index.d.ts.map +1 -1
  186. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.d.ts +39 -10
  187. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.d.ts.map +1 -1
  188. package/dist/ui/components/organisms/vc-gallery/index.d.ts +2 -2
  189. package/dist/ui/components/organisms/vc-gallery/index.d.ts.map +1 -1
  190. package/dist/ui/components/organisms/vc-gallery/vc-gallery-model.d.ts +69 -27
  191. package/dist/ui/components/organisms/vc-gallery/vc-gallery-model.d.ts.map +1 -1
  192. package/dist/ui/components/organisms/vc-login-form/index.d.ts.map +1 -1
  193. package/dist/ui/components/organisms/vc-login-form/vc-login-form-model.d.ts +10 -5
  194. package/dist/ui/components/organisms/vc-login-form/vc-login-form-model.d.ts.map +1 -1
  195. package/dist/ui/components/organisms/vc-popup/index.d.ts +2 -2
  196. package/dist/ui/components/organisms/vc-popup/index.d.ts.map +1 -1
  197. package/dist/ui/components/organisms/vc-popup/vc-popup-model.d.ts +18 -7
  198. package/dist/ui/components/organisms/vc-popup/vc-popup-model.d.ts.map +1 -1
  199. package/dist/ui/components/organisms/vc-table/index.d.ts +2 -2
  200. package/dist/ui/components/organisms/vc-table/index.d.ts.map +1 -1
  201. package/dist/ui/components/organisms/vc-table/vc-table-model.d.ts +103 -34
  202. package/dist/ui/components/organisms/vc-table/vc-table-model.d.ts.map +1 -1
  203. package/dist/ui/types/index.d.ts +48 -46
  204. package/dist/ui/types/index.d.ts.map +1 -1
  205. package/dist/ui/types/ts-helpers.d.ts +14 -4
  206. package/dist/ui/types/ts-helpers.d.ts.map +1 -1
  207. package/dist/ui/utils/index.d.ts +2 -0
  208. package/dist/ui/utils/index.d.ts.map +1 -0
  209. package/dist/ui/utils/types.d.ts +3 -0
  210. package/dist/ui/utils/types.d.ts.map +1 -0
  211. package/dist/vite.config.d.ts +1 -1
  212. package/dist/vite.config.d.ts.map +1 -1
  213. package/package.json +8 -11
  214. package/shared/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +2 -5
  215. package/shared/app-switcher/composables/useAppSwitcher/index.ts +2 -7
  216. package/shared/app-switcher/index.ts +3 -10
  217. package/shared/assets/components/assets-details/assets-details.vue +7 -28
  218. package/shared/assets/components/index.ts +1 -1
  219. package/shared/assets/index.ts +3 -15
  220. package/shared/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue +2 -7
  221. package/shared/blade-navigation/composables/index.ts +1 -1
  222. package/shared/blade-navigation/composables/useBladeNavigation/index.ts +7 -36
  223. package/shared/blade-navigation/index.ts +3 -10
  224. package/shared/index.ts +9 -11
  225. package/ui/components/atoms/vc-badge/index.ts +4 -4
  226. package/ui/components/atoms/vc-badge/vc-badge-model.ts +22 -15
  227. package/ui/components/atoms/vc-badge/vc-badge.vue +5 -10
  228. package/ui/components/atoms/vc-button/index.ts +4 -4
  229. package/ui/components/atoms/vc-button/vc-button-model.ts +32 -17
  230. package/ui/components/atoms/vc-button/vc-button.vue +8 -13
  231. package/ui/components/atoms/vc-card/index.ts +3 -4
  232. package/ui/components/atoms/vc-card/vc-card-model.ts +31 -11
  233. package/ui/components/atoms/vc-card/vc-card.vue +20 -11
  234. package/ui/components/atoms/vc-checkbox/index.ts +3 -2
  235. package/ui/components/atoms/vc-checkbox/vc-checkbox-model.ts +28 -8
  236. package/ui/components/atoms/vc-checkbox/vc-checkbox.vue +15 -11
  237. package/ui/components/atoms/vc-col/index.ts +1 -2
  238. package/ui/components/atoms/vc-col/vc-col-model.ts +9 -3
  239. package/ui/components/atoms/vc-col/vc-col.vue +2 -4
  240. package/ui/components/atoms/vc-container/index.ts +3 -2
  241. package/ui/components/atoms/vc-container/vc-container-model.ts +24 -8
  242. package/ui/components/atoms/vc-container/vc-container.vue +6 -14
  243. package/ui/components/atoms/vc-hint/vc-hint-model.ts +5 -0
  244. package/ui/components/atoms/vc-icon/index.ts +1 -3
  245. package/ui/components/atoms/vc-icon/vc-icon-model.ts +15 -6
  246. package/ui/components/atoms/vc-icon/vc-icon.vue +2 -5
  247. package/ui/components/atoms/vc-image/index.ts +4 -4
  248. package/ui/components/atoms/vc-image/vc-image-model.ts +36 -22
  249. package/ui/components/atoms/vc-image/vc-image.stories.ts +1 -2
  250. package/ui/components/atoms/vc-image/vc-image.vue +13 -17
  251. package/ui/components/atoms/vc-info-row/index.ts +1 -3
  252. package/ui/components/atoms/vc-info-row/vc-info-row-model.ts +22 -7
  253. package/ui/components/atoms/vc-info-row/vc-info-row.vue +13 -9
  254. package/ui/components/atoms/vc-label/index.ts +1 -3
  255. package/ui/components/atoms/vc-label/vc-label-model.ts +13 -4
  256. package/ui/components/atoms/vc-label/vc-label.vue +6 -6
  257. package/ui/components/atoms/vc-link/index.ts +3 -4
  258. package/ui/components/atoms/vc-link/vc-link-model.ts +18 -5
  259. package/ui/components/atoms/vc-link/vc-link.vue +4 -6
  260. package/ui/components/atoms/vc-loading/index.ts +1 -3
  261. package/ui/components/atoms/vc-loading/vc-loading-model.ts +9 -3
  262. package/ui/components/atoms/vc-loading/vc-loading.vue +4 -9
  263. package/ui/components/atoms/vc-progress/index.ts +1 -3
  264. package/ui/components/atoms/vc-progress/vc-progress-model.ts +14 -5
  265. package/ui/components/atoms/vc-progress/vc-progress.vue +4 -13
  266. package/ui/components/atoms/vc-status/index.ts +1 -3
  267. package/ui/components/atoms/vc-status/vc-status-model.ts +18 -12
  268. package/ui/components/atoms/vc-status/vc-status.vue +3 -11
  269. package/ui/components/atoms/vc-status-icon/index.ts +1 -3
  270. package/ui/components/atoms/vc-status-icon/vc-status-icon-model.ts +9 -3
  271. package/ui/components/atoms/vc-status-icon/vc-status-icon.vue +2 -4
  272. package/ui/components/atoms/vc-switch/index.ts +4 -4
  273. package/ui/components/atoms/vc-switch/vc-switch-model.ts +28 -8
  274. package/ui/components/atoms/vc-switch/vc-switch.vue +12 -10
  275. package/ui/components/atoms/vc-widget/index.ts +4 -4
  276. package/ui/components/atoms/vc-widget/vc-widget-model.ts +17 -7
  277. package/ui/components/atoms/vc-widget/vc-widget.vue +16 -7
  278. package/ui/components/index.ts +1 -1
  279. package/ui/components/molecules/vc-breadcrumbs/index.ts +1 -3
  280. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs-model.ts +18 -10
  281. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue +6 -5
  282. package/ui/components/molecules/vc-editor/index.ts +4 -4
  283. package/ui/components/molecules/vc-editor/vc-editor-model.ts +31 -11
  284. package/ui/components/molecules/vc-editor/vc-editor.vue +17 -11
  285. package/ui/components/molecules/vc-file-upload/index.ts +3 -2
  286. package/ui/components/molecules/vc-file-upload/vc-file-upload-model.ts +33 -11
  287. package/ui/components/molecules/vc-file-upload/vc-file-upload.vue +10 -14
  288. package/ui/components/molecules/vc-form/vc-form-model.ts +5 -0
  289. package/ui/components/molecules/vc-input/index.ts +4 -5
  290. package/ui/components/molecules/vc-input/vc-input-model.ts +53 -35
  291. package/ui/components/molecules/vc-input/vc-input.vue +41 -29
  292. package/ui/components/molecules/vc-input-currency/index.ts +3 -2
  293. package/ui/components/molecules/vc-input-currency/vc-input-currency-model.ts +42 -32
  294. package/ui/components/molecules/vc-input-currency/vc-input-currency.vue +12 -7
  295. package/ui/components/molecules/vc-notification/index.ts +4 -3
  296. package/ui/components/molecules/vc-notification/vc-notification-model.ts +15 -5
  297. package/ui/components/molecules/vc-notification/vc-notification.vue +3 -5
  298. package/ui/components/molecules/vc-pagination/index.ts +4 -3
  299. package/ui/components/molecules/vc-pagination/vc-pagination-model.ts +23 -6
  300. package/ui/components/molecules/vc-pagination/vc-pagination.vue +19 -11
  301. package/ui/components/molecules/vc-rating/index.ts +2 -4
  302. package/ui/components/molecules/vc-rating/vc-rating-model.ts +18 -9
  303. package/ui/components/molecules/vc-rating/vc-rating.vue +10 -4
  304. package/ui/components/molecules/vc-select/index.ts +5 -5
  305. package/ui/components/molecules/vc-select/vc-select-model.ts +74 -44
  306. package/ui/components/molecules/vc-select/vc-select.vue +126 -171
  307. package/ui/components/molecules/vc-slider/index.ts +2 -4
  308. package/ui/components/molecules/vc-slider/vc-slider-model.ts +30 -11
  309. package/ui/components/molecules/vc-slider/vc-slider.vue +2 -8
  310. package/ui/components/molecules/vc-textarea/index.ts +4 -3
  311. package/ui/components/molecules/vc-textarea/vc-textarea-model.ts +35 -12
  312. package/ui/components/molecules/vc-textarea/vc-textarea.vue +16 -12
  313. package/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue +13 -9
  314. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue +12 -3
  315. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue +18 -16
  316. package/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue +8 -2
  317. package/ui/components/organisms/vc-app/index.ts +4 -4
  318. package/ui/components/organisms/vc-app/vc-app-model.ts +55 -17
  319. package/ui/components/organisms/vc-app/vc-app.vue +8 -25
  320. package/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue +22 -7
  321. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue +19 -13
  322. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue +13 -11
  323. package/ui/components/organisms/vc-blade/index.ts +5 -5
  324. package/ui/components/organisms/vc-blade/vc-blade-model.ts +30 -11
  325. package/ui/components/organisms/vc-blade/vc-blade.stories.ts +1 -2
  326. package/ui/components/organisms/vc-blade/vc-blade.vue +12 -14
  327. package/ui/components/organisms/vc-dynamic-property/index.ts +2 -4
  328. package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property-model.ts +53 -20
  329. package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue +41 -37
  330. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue +9 -2
  331. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue +14 -9
  332. package/ui/components/organisms/vc-gallery/index.ts +4 -3
  333. package/ui/components/organisms/vc-gallery/vc-gallery-model.ts +72 -27
  334. package/ui/components/organisms/vc-gallery/vc-gallery.vue +7 -20
  335. package/ui/components/organisms/vc-login-form/index.ts +2 -4
  336. package/ui/components/organisms/vc-login-form/vc-login-form-model.ts +10 -5
  337. package/ui/components/organisms/vc-login-form/vc-login-form.vue +2 -4
  338. package/ui/components/organisms/vc-popup/index.ts +5 -5
  339. package/ui/components/organisms/vc-popup/vc-popup-model.ts +20 -7
  340. package/ui/components/organisms/vc-popup/vc-popup.vue +7 -7
  341. package/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue +19 -25
  342. package/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue +2 -6
  343. package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +8 -2
  344. package/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue +27 -39
  345. package/ui/components/organisms/vc-table/index.ts +5 -5
  346. package/ui/components/organisms/vc-table/vc-table-model.ts +98 -38
  347. package/ui/components/organisms/vc-table/vc-table.vue +105 -103
  348. package/ui/types/index.ts +64 -160
  349. package/ui/types/ts-helpers.ts +23 -3
  350. package/ui/utils/index.ts +1 -0
  351. package/ui/utils/types.ts +2 -0
  352. package/core/composables/useLogger/index.ts +0 -24
  353. package/dist/core/composables/useLogger/index.d.ts +0 -5
  354. package/dist/core/composables/useLogger/index.d.ts.map +0 -1
@@ -36,15 +36,11 @@
36
36
 
37
37
  <script lang="ts" setup>
38
38
  import { ref, onMounted, computed, nextTick } from "vue";
39
- import { VcContainerProps } from "./vc-container-model";
39
+ import { containerProps, containerEmits } from "./vc-container-model";
40
40
 
41
- const props = withDefaults(defineProps<VcContainerProps>(), {
42
- shadow: false,
43
- noPadding: false,
44
- usePtr: false,
45
- });
41
+ const props = defineProps(containerProps);
46
42
 
47
- const emit = defineEmits(["scroll:ptr"]);
43
+ const emit = defineEmits(containerEmits);
48
44
 
49
45
  const component = ref<HTMLElement>();
50
46
  const scroll = ref(false);
@@ -57,8 +53,7 @@ const delta = ref(0);
57
53
 
58
54
  onMounted(() => {
59
55
  const observer = new ResizeObserver(() => {
60
- scroll.value = (component.value &&
61
- component.value.clientHeight < component.value.scrollHeight) as boolean;
56
+ scroll.value = (component.value && component.value.clientHeight < component.value.scrollHeight) as boolean;
62
57
  });
63
58
 
64
59
  if (component.value) {
@@ -66,9 +61,7 @@ onMounted(() => {
66
61
  }
67
62
  });
68
63
 
69
- const touchable = computed(
70
- () => status.value !== "refresh" && status.value !== "success"
71
- );
64
+ const touchable = computed(() => status.value !== "refresh" && status.value !== "success");
72
65
 
73
66
  const scrollTop = () => {
74
67
  if (component.value) {
@@ -164,8 +157,7 @@ defineExpose({
164
157
  --container-scroll-color-hover: #cce4f5;
165
158
  --container-scroll-width: 8px;
166
159
  --container-scroll-padding: 8px;
167
- --container-scroll-shadow: 0 3px 2px rgba(0, 0, 0, 0.1) inset,
168
- 0 -3px 2px rgba(0, 0, 0, 0.1) inset;
160
+ --container-scroll-shadow: 0 3px 2px rgba(0, 0, 0, 0.1) inset, 0 -3px 2px rgba(0, 0, 0, 0.1) inset;
169
161
  }
170
162
 
171
163
  .vc-container {
@@ -0,0 +1,5 @@
1
+ import { VNode } from "vue";
2
+
3
+ export interface VcHintSlots {
4
+ default: () => VNode[];
5
+ }
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcIconProps } from "./vc-icon-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Icon from "./vc-icon.vue";
5
- export const VcIcon: ComponentConstructor<
6
- ComponentPublicInstance<VcIconProps>
7
- > = Icon;
5
+ export const VcIcon: ComponentConstructor<ComponentPublicInstance<VcIconProps>> = Icon;
@@ -1,10 +1,19 @@
1
- import {VNode} from "vue";
1
+ import { VNode, PropType } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcIconProps {
4
- icon?: string | undefined
5
- size?: "xs" | "s" | "m" | "l" | "xl" | "xxl"
6
- }
4
+ export const iconProps = {
5
+ icon: {
6
+ type: String,
7
+ default: "fas fa-square-full",
8
+ },
9
+ size: {
10
+ type: String as PropType<"xs" | "s" | "m" | "l" | "xl" | "xxl">,
11
+ default: "m",
12
+ },
13
+ };
14
+
15
+ export type VcIconProps = ExtractTypes<typeof iconProps>;
7
16
 
8
17
  export interface VcIconSlots {
9
- default: () => VNode[];
18
+ default: () => VNode[];
10
19
  }
@@ -3,12 +3,9 @@
3
3
  </template>
4
4
 
5
5
  <script lang="ts" setup>
6
- import { VcIconProps } from "./vc-icon-model";
6
+ import { iconProps } from "./vc-icon-model";
7
7
 
8
- withDefaults(defineProps<VcIconProps>(), {
9
- icon: "fas fa-square-full",
10
- size: "m",
11
- });
8
+ defineProps(iconProps);
12
9
  </script>
13
10
 
14
11
  <style lang="scss">
@@ -1,7 +1,7 @@
1
1
  import { ComponentPublicInstance } from "vue";
2
- import { VcImageProps } from "./vc-image-model";
2
+ import { VcImageEmits, VcImageProps } from "./vc-image-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Image from "./vc-image.vue";
5
- export const VcImage: ComponentConstructor<
6
- ComponentPublicInstance<VcImageProps>
7
- > = Image;
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ export const VcImage: ComponentConstructor<ComponentPublicInstance<VcImageProps, any, any, any, any, VcImageEmits>> =
7
+ Image;
@@ -1,26 +1,40 @@
1
- import { VNode } from "vue";
1
+ import { VNode, PropType } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcImageProps {
4
- aspect?: string | undefined;
5
- rounded?: boolean | undefined;
6
- bordered?: boolean | undefined;
7
- clickable?: boolean | undefined;
8
- src?: string | undefined;
9
- size?:
10
- | "auto"
11
- | "1x1"
12
- | "16x9"
13
- | "4x3"
14
- | "3x2"
15
- | "xs"
16
- | "s"
17
- | "m"
18
- | "l"
19
- | "xl"
20
- | "xxl";
21
- background?: "cover" | "contain" | "auto";
22
- onClick?: () => void;
23
- }
4
+ export const imageProps = {
5
+ aspect: {
6
+ type: String,
7
+ default: "1x1",
8
+ },
9
+ rounded: {
10
+ type: Boolean,
11
+ default: false,
12
+ },
13
+ bordered: {
14
+ type: Boolean,
15
+ default: false,
16
+ },
17
+ clickable: {
18
+ type: Boolean,
19
+ default: false,
20
+ },
21
+ src: String,
22
+ size: {
23
+ type: String as PropType<"auto" | "1x1" | "16x9" | "4x3" | "3x2" | "xs" | "s" | "m" | "l" | "xl" | "xxl">,
24
+ default: "auto",
25
+ },
26
+ background: {
27
+ type: String as PropType<"cover" | "contain" | "auto">,
28
+ default: "cover",
29
+ },
30
+ };
31
+
32
+ export const imageEmits = {
33
+ click: () => true,
34
+ };
35
+
36
+ export type VcImageProps = ExtractTypes<typeof imageProps>;
37
+ export type VcImageEmits = typeof imageEmits;
24
38
 
25
39
  export interface VcImageSlots {
26
40
  default: () => VNode[];
@@ -25,8 +25,7 @@ const Template: Story = (args) => ({
25
25
  setup() {
26
26
  return { args };
27
27
  },
28
- template:
29
- '<div style="width: 400px"><vc-image v-bind="args"></vc-image></div>',
28
+ template: '<div style="width: 400px"><vc-image v-bind="args"></vc-image></div>',
30
29
  });
31
30
 
32
31
  export const Image = Template.bind({});
@@ -1,12 +1,14 @@
1
1
  <template>
2
- <div class="vc-image" :class="[`vc-image_${size}`]">
2
+ <div
3
+ class="vc-image"
4
+ :class="[`vc-image_${size}`]"
5
+ >
3
6
  <div
4
7
  :class="[
5
8
  `vc-image_${aspect}`,
6
9
  {
7
10
  'tw-rounded-full tw-pb-[var(--image-padding-bottom-1x1)]': rounded,
8
- 'tw-rounded-[3px] tw-border tw-border-solid tw-border-[color:#efefef]':
9
- bordered,
11
+ 'tw-rounded-[3px] tw-border tw-border-solid tw-border-[color:#efefef]': bordered,
10
12
  'tw-cursor-pointer': clickable,
11
13
  },
12
14
  'tw-relative',
@@ -18,7 +20,10 @@
18
20
  v-if="!src"
19
21
  class="tw-absolute tw-w-full tw-h-full tw-flex tw-items-center tw-justify-center tw-text-[#83a3be]"
20
22
  >
21
- <VcIcon icon="fas fa-image" size="xl"></VcIcon>
23
+ <VcIcon
24
+ icon="fas fa-image"
25
+ size="xl"
26
+ ></VcIcon>
22
27
  </div>
23
28
  </div>
24
29
  </div>
@@ -26,24 +31,15 @@
26
31
 
27
32
  <script lang="ts" setup>
28
33
  import { computed } from "vue";
29
- import { VcImageProps } from "./vc-image-model";
34
+ import { imageProps, imageEmits } from "./vc-image-model";
30
35
 
31
- const props = withDefaults(defineProps<VcImageProps>(), {
32
- aspect: "1x1",
33
- rounded: false,
34
- bordered: false,
35
- clickable: false,
36
- size: "auto",
37
- background: "cover",
38
- });
36
+ const props = defineProps(imageProps);
39
37
 
40
- const emit = defineEmits(["click"]);
38
+ const emit = defineEmits(imageEmits);
41
39
 
42
40
  const imageHandler = computed(() => {
43
41
  if (props.src) {
44
- return `background: url(${encodeURI(props.src)}) center / ${
45
- props.background
46
- } no-repeat`;
42
+ return `background: url(${encodeURI(props.src)}) center / ${props.background} no-repeat`;
47
43
  }
48
44
  return undefined;
49
45
  });
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcInfoRowProps } from "./vc-info-row-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import InfoRow from "./vc-info-row.vue";
5
- export const VcInfoRow: ComponentConstructor<
6
- ComponentPublicInstance<VcInfoRowProps>
7
- > = InfoRow;
5
+ export const VcInfoRow: ComponentConstructor<ComponentPublicInstance<VcInfoRowProps>> = InfoRow;
@@ -1,11 +1,26 @@
1
- import { VNode } from "vue";
1
+ import { VNode, PropType } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcInfoRowProps {
4
- label?: string | undefined;
5
- value?: string | undefined;
6
- tooltip?: string | undefined;
7
- type?: "default" | "email";
8
- }
4
+ export const infoRowProps = {
5
+ label: {
6
+ type: String,
7
+ default: "",
8
+ },
9
+ value: {
10
+ type: String,
11
+ default: "",
12
+ },
13
+ tooltip: {
14
+ type: String,
15
+ default: "",
16
+ },
17
+ type: {
18
+ type: String as PropType<"default" | "email">,
19
+ default: "",
20
+ },
21
+ };
22
+
23
+ export type VcInfoRowProps = ExtractTypes<typeof infoRowProps>;
9
24
 
10
25
  export interface VcInfoRowSlots {
11
26
  default: () => VNode[];
@@ -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>
@@ -17,12 +26,7 @@
17
26
 
18
27
  <script lang="ts" setup>
19
28
  import { VcLabel, VcRow, VcCol } from "./../../../components";
20
- import { VcInfoRowProps } from "./vc-info-row-model";
29
+ import { infoRowProps } from "./vc-info-row-model";
21
30
 
22
- withDefaults(defineProps<VcInfoRowProps>(), {
23
- label: "",
24
- value: "",
25
- tooltip: "",
26
- type: "default",
27
- });
31
+ defineProps(infoRowProps);
28
32
  </script>
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcLabelProps } from "./vc-label-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Label from "./vc-label.vue";
5
- export const VcLabel: ComponentConstructor<
6
- ComponentPublicInstance<VcLabelProps>
7
- > = Label;
5
+ export const VcLabel: ComponentConstructor<ComponentPublicInstance<VcLabelProps>> = Label;
@@ -1,9 +1,18 @@
1
1
  import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcLabelProps {
4
- required?: boolean | undefined;
5
- tooltipIcon?: string | undefined;
6
- }
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>;
7
16
 
8
17
  export interface VcLabelSlots {
9
18
  default: () => VNode[];
@@ -6,7 +6,10 @@
6
6
  class="tw-text-[color:var(--label-required-color)] tw-ml-1"
7
7
  >*</span
8
8
  >
9
- <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
+ >
10
13
  <VcIcon
11
14
  class="tw-text-[color:var(--label-tooltip-color)]"
12
15
  :icon="tooltipIcon"
@@ -27,12 +30,9 @@
27
30
  <script lang="ts" setup>
28
31
  import { VcIcon } from "./../../../components";
29
32
  import { ref } from "vue";
30
- import { VcLabelProps } from "./vc-label-model";
33
+ import { labelProps } from "./vc-label-model";
31
34
 
32
- withDefaults(defineProps<VcLabelProps>(), {
33
- required: false,
34
- tooltipIcon: "fas fa-info-circle",
35
- });
35
+ defineProps(labelProps);
36
36
 
37
37
  const tooltipVisible = ref(false);
38
38
  </script>
@@ -1,7 +1,6 @@
1
1
  import { ComponentPublicInstance } from "vue";
2
- import { VcLinkProps } from "./vc-link-model";
2
+ import { VcLinkEmits, VcLinkProps } from "./vc-link-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Link from "./vc-link.vue";
5
- export const VcLink: ComponentConstructor<
6
- ComponentPublicInstance<VcLinkProps>
7
- > = Link;
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ export const VcLink: ComponentConstructor<ComponentPublicInstance<VcLinkProps, any, any, any, any, VcLinkEmits>> = Link;
@@ -1,10 +1,23 @@
1
1
  import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcLinkProps {
4
- active?: boolean | undefined;
5
- disabled?: boolean | undefined;
6
- onClick?: () => void;
7
- }
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;
8
21
 
9
22
  export interface VcLinkSlots {
10
23
  default: () => VNode[];
@@ -13,13 +13,11 @@
13
13
  </template>
14
14
 
15
15
  <script lang="ts" setup>
16
- import { VcLinkProps } from "./vc-link-model";
16
+ import { linkEmits, linkProps } from "./vc-link-model";
17
+
18
+ const props = defineProps(linkProps);
19
+ const emit = defineEmits(linkEmits);
17
20
 
18
- const props = withDefaults(defineProps<VcLinkProps>(), {
19
- active: false,
20
- disabled: false,
21
- });
22
- const emit = defineEmits(["click"]);
23
21
  function onClick(): void {
24
22
  if (!props.disabled) {
25
23
  emit("click");
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcLoadingProps } from "./vc-loading-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Loading from "./vc-loading.vue";
5
- export const VcLoading: ComponentConstructor<
6
- ComponentPublicInstance<VcLoadingProps>
7
- > = Loading;
5
+ export const VcLoading: ComponentConstructor<ComponentPublicInstance<VcLoadingProps>> = Loading;
@@ -1,8 +1,14 @@
1
1
  import { VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcLoadingProps {
4
- active?: boolean | undefined;
5
- }
4
+ export const loadingProps = {
5
+ active: {
6
+ type: Boolean,
7
+ default: false,
8
+ },
9
+ };
10
+
11
+ export type VcLoadingProps = ExtractTypes<typeof loadingProps>;
6
12
 
7
13
  export interface VcLoadingSlots {
8
14
  default: () => VNode[];
@@ -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,9 +21,7 @@
24
21
  </template>
25
22
 
26
23
  <script lang="ts" setup>
27
- import { VcLoadingProps } from "./vc-loading-model";
24
+ import { loadingProps } from "./vc-loading-model";
28
25
 
29
- withDefaults(defineProps<VcLoadingProps>(), {
30
- active: false,
31
- });
26
+ defineProps(loadingProps);
32
27
  </script>
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcProgressProps } from "./vc-progress-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Progress from "./vc-progress.vue";
5
- export const VcProgress: ComponentConstructor<
6
- ComponentPublicInstance<VcProgressProps>
7
- > = Progress;
5
+ export const VcProgress: ComponentConstructor<ComponentPublicInstance<VcProgressProps>> = Progress;
@@ -1,9 +1,18 @@
1
- import { VNode } from "vue";
1
+ import { PropType, VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcProgressProps {
4
- value?: number | undefined;
5
- variant?: "default" | "striped" | undefined;
6
- }
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>;
7
16
 
8
17
  export interface VcProgressSlots {
9
18
  default: () => VNode[];
@@ -13,12 +13,9 @@
13
13
  </template>
14
14
 
15
15
  <script lang="ts" setup>
16
- import { VcProgressProps } from "./vc-progress-model";
16
+ import { progressProps } from "./vc-progress-model";
17
17
 
18
- withDefaults(defineProps<VcProgressProps>(), {
19
- value: 0,
20
- variant: "default",
21
- });
18
+ defineProps(progressProps);
22
19
  </script>
23
20
 
24
21
  <style lang="scss">
@@ -43,14 +40,8 @@ withDefaults(defineProps<VcProgressProps>(), {
43
40
  .vc-progress {
44
41
  &.striped {
45
42
  .vc-progress__value {
46
- background: linear-gradient(
47
- 45deg,
48
- transparent 50%,
49
- #acd2f2 50%,
50
- #acd2f2 75%,
51
- transparent 75%
52
- )
53
- left/30px 30px repeat-x,
43
+ background: linear-gradient(45deg, transparent 50%, #acd2f2 50%, #acd2f2 75%, transparent 75%) left/30px 30px
44
+ repeat-x,
54
45
  #e1f0fe;
55
46
  animation: change 1s linear infinite;
56
47
  }
@@ -2,6 +2,4 @@ import { ComponentPublicInstance } from "vue";
2
2
  import { VcStatusProps } from "./vc-status-model";
3
3
  import { ComponentConstructor } from "./../../../types/ts-helpers";
4
4
  import Status from "./vc-status.vue";
5
- export const VcStatus: ComponentConstructor<
6
- ComponentPublicInstance<VcStatusProps>
7
- > = Status;
5
+ export const VcStatus: ComponentConstructor<ComponentPublicInstance<VcStatusProps>> = Status;
@@ -1,16 +1,22 @@
1
- import { VNode } from "vue";
1
+ import { PropType, VNode } from "vue";
2
+ import { ExtractTypes } from "./../../../types/ts-helpers";
2
3
 
3
- export interface VcStatusProps {
4
- variant?:
5
- | "info"
6
- | "warning"
7
- | "danger"
8
- | "success"
9
- | "light-danger"
10
- | undefined;
11
- outline?: boolean | undefined;
12
- extend?: boolean | undefined;
13
- }
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>;
14
20
 
15
21
  export interface VcStatusSlots {
16
22
  default: () => VNode[];
@@ -1,24 +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
- import { VcStatusProps } from "./vc-status-model";
11
+ import { statusProps } from "./vc-status-model";
16
12
 
17
- withDefaults(defineProps<VcStatusProps>(), {
18
- variant: "info",
19
- outline: true,
20
- extend: false,
21
- });
13
+ defineProps(statusProps);
22
14
  </script>
23
15
 
24
16
  <style lang="scss">