@vuetify/nightly 3.2.0-dev-20230309.0 → 3.2.0-dev-20230322.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 (256) hide show
  1. package/CHANGELOG.md +2 -2
  2. package/dist/json/attributes.json +210 -30
  3. package/dist/json/importMap.json +4 -4
  4. package/dist/json/tags.json +47 -2
  5. package/dist/json/web-types.json +529 -63
  6. package/dist/vuetify-labs.css +1186 -1146
  7. package/dist/vuetify-labs.d.ts +56928 -14280
  8. package/dist/vuetify-labs.esm.js +557 -363
  9. package/dist/vuetify-labs.esm.js.map +1 -1
  10. package/dist/vuetify-labs.js +557 -363
  11. package/dist/vuetify-labs.min.css +2 -2
  12. package/dist/vuetify.css +204 -179
  13. package/dist/vuetify.d.ts +55330 -15866
  14. package/dist/vuetify.esm.js +400 -306
  15. package/dist/vuetify.esm.js.map +1 -1
  16. package/dist/vuetify.js +400 -306
  17. package/dist/vuetify.js.map +1 -1
  18. package/dist/vuetify.min.css +2 -2
  19. package/dist/vuetify.min.js +668 -667
  20. package/dist/vuetify.min.js.map +1 -1
  21. package/lib/blueprints/index.d.ts +6 -9
  22. package/lib/blueprints/md1.d.ts +6 -9
  23. package/lib/blueprints/md2.d.ts +6 -9
  24. package/lib/blueprints/md3.d.ts +6 -9
  25. package/lib/blueprints/md3.mjs +6 -0
  26. package/lib/blueprints/md3.mjs.map +1 -1
  27. package/lib/components/VAlert/VAlert.mjs +29 -15
  28. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  29. package/lib/components/VAlert/index.d.ts +510 -82
  30. package/lib/components/VApp/VApp.css +1 -0
  31. package/lib/components/VApp/VApp.sass +1 -0
  32. package/lib/components/VApp/index.d.ts +158 -20
  33. package/lib/components/VAppBar/VAppBar.mjs +2 -2
  34. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  35. package/lib/components/VAppBar/index.d.ts +616 -110
  36. package/lib/components/VAutocomplete/VAutocomplete.mjs +13 -7
  37. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  38. package/lib/components/VAutocomplete/index.d.ts +1656 -130
  39. package/lib/components/VAvatar/index.d.ts +205 -29
  40. package/lib/components/VBadge/index.d.ts +284 -42
  41. package/lib/components/VBanner/VBanner.mjs +19 -12
  42. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  43. package/lib/components/VBanner/index.d.ts +478 -84
  44. package/lib/components/VBottomNavigation/index.d.ts +321 -40
  45. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +11 -7
  46. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  47. package/lib/components/VBreadcrumbs/index.d.ts +325 -45
  48. package/lib/components/VBtn/VBtn.css +0 -5
  49. package/lib/components/VBtn/VBtn.mjs +65 -58
  50. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  51. package/lib/components/VBtn/VBtn.sass +0 -7
  52. package/lib/components/VBtn/_variables.scss +0 -2
  53. package/lib/components/VBtn/index.d.ts +452 -69
  54. package/lib/components/VBtnGroup/VBtnGroup.mjs +1 -7
  55. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  56. package/lib/components/VBtnGroup/index.d.ts +185 -26
  57. package/lib/components/VBtnToggle/VBtnToggle.mjs +2 -2
  58. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  59. package/lib/components/VBtnToggle/index.d.ts +245 -35
  60. package/lib/components/VCard/VCard.mjs +10 -6
  61. package/lib/components/VCard/VCard.mjs.map +1 -1
  62. package/lib/components/VCard/VCardItem.mjs +27 -23
  63. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  64. package/lib/components/VCard/index.d.ts +938 -172
  65. package/lib/components/VCarousel/index.d.ts +561 -123
  66. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  67. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  68. package/lib/components/VCheckbox/VCheckboxBtn.mjs +1 -4
  69. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  70. package/lib/components/VCheckbox/index.d.ts +831 -147
  71. package/lib/components/VChip/VChip.css +110 -90
  72. package/lib/components/VChip/VChip.mjs +70 -48
  73. package/lib/components/VChip/VChip.mjs.map +1 -1
  74. package/lib/components/VChip/_mixins.scss +27 -23
  75. package/lib/components/VChip/index.d.ts +474 -76
  76. package/lib/components/VChipGroup/index.d.ts +227 -32
  77. package/lib/components/VCode/index.d.ts +109 -16
  78. package/lib/components/VColorPicker/index.d.ts +284 -20
  79. package/lib/components/VCombobox/VCombobox.mjs +13 -7
  80. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  81. package/lib/components/VCombobox/index.d.ts +1668 -130
  82. package/lib/components/VCounter/index.d.ts +1894 -87
  83. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -1
  84. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  85. package/lib/components/VDefaultsProvider/index.d.ts +133 -21
  86. package/lib/components/VDialog/VDialog.css +31 -24
  87. package/lib/components/VDialog/VDialog.mjs +2 -2
  88. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  89. package/lib/components/VDialog/VDialog.sass +19 -12
  90. package/lib/components/VDialog/index.d.ts +2362 -146
  91. package/lib/components/VDivider/index.d.ts +130 -23
  92. package/lib/components/VExpansionPanel/index.d.ts +719 -119
  93. package/lib/components/VField/index.d.ts +163 -21
  94. package/lib/components/VFileInput/index.d.ts +1038 -104
  95. package/lib/components/VFooter/VFooter.css +2 -0
  96. package/lib/components/VFooter/VFooter.sass +2 -0
  97. package/lib/components/VFooter/_variables.scss +2 -0
  98. package/lib/components/VFooter/index.d.ts +203 -28
  99. package/lib/components/VForm/index.d.ts +204 -23
  100. package/lib/components/VGrid/VCol.mjs +6 -5
  101. package/lib/components/VGrid/VCol.mjs.map +1 -1
  102. package/lib/components/VGrid/VRow.mjs +4 -4
  103. package/lib/components/VGrid/VRow.mjs.map +1 -1
  104. package/lib/components/VGrid/index.d.ts +733 -76
  105. package/lib/components/VHover/index.d.ts +182 -35
  106. package/lib/components/VIcon/index.d.ts +494 -50
  107. package/lib/components/VImg/VImg.mjs +2 -2
  108. package/lib/components/VImg/VImg.mjs.map +1 -1
  109. package/lib/components/VImg/index.d.ts +275 -46
  110. package/lib/components/VInput/index.d.ts +315 -53
  111. package/lib/components/VItemGroup/index.d.ts +308 -52
  112. package/lib/components/VKbd/VKbd.css +1 -0
  113. package/lib/components/VKbd/VKbd.sass +1 -0
  114. package/lib/components/VKbd/_variables.scss +1 -0
  115. package/lib/components/VKbd/index.d.ts +109 -16
  116. package/lib/components/VLabel/index.d.ts +113 -20
  117. package/lib/components/VLayout/index.d.ts +296 -41
  118. package/lib/components/VLazy/VLazy.mjs +4 -1
  119. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  120. package/lib/components/VLazy/index.d.ts +219 -30
  121. package/lib/components/VList/VListChildren.mjs +2 -2
  122. package/lib/components/VList/VListChildren.mjs.map +1 -1
  123. package/lib/components/VList/VListGroup.mjs +1 -4
  124. package/lib/components/VList/VListGroup.mjs.map +1 -1
  125. package/lib/components/VList/VListItem.mjs +23 -19
  126. package/lib/components/VList/VListItem.mjs.map +1 -1
  127. package/lib/components/VList/index.d.ts +1461 -223
  128. package/lib/components/VLocaleProvider/index.d.ts +121 -20
  129. package/lib/components/VMain/index.d.ts +118 -17
  130. package/lib/components/VMenu/VMenu.css +4 -4
  131. package/lib/components/VMenu/VMenu.mjs +2 -2
  132. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  133. package/lib/components/VMenu/VMenu.sass +1 -1
  134. package/lib/components/VMenu/index.d.ts +2368 -142
  135. package/lib/components/VMessages/index.d.ts +1921 -98
  136. package/lib/components/VNavigationDrawer/index.d.ts +379 -56
  137. package/lib/components/VOverlay/VOverlay.css +2 -2
  138. package/lib/components/VOverlay/VOverlay.mjs +1 -4
  139. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  140. package/lib/components/VOverlay/VOverlay.sass +1 -1
  141. package/lib/components/VOverlay/_variables.scss +1 -1
  142. package/lib/components/VOverlay/index.d.ts +519 -85
  143. package/lib/components/VPagination/index.d.ts +502 -68
  144. package/lib/components/VParallax/VParallax.mjs +3 -3
  145. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  146. package/lib/components/VParallax/index.d.ts +141 -28
  147. package/lib/components/VProgressCircular/index.d.ts +186 -25
  148. package/lib/components/VProgressLinear/index.d.ts +319 -48
  149. package/lib/components/VRadio/index.d.ts +313 -57
  150. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -6
  151. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  152. package/lib/components/VRadioGroup/index.d.ts +463 -83
  153. package/lib/components/VRangeSlider/index.d.ts +528 -80
  154. package/lib/components/VRating/VRating.mjs.map +1 -1
  155. package/lib/components/VRating/index.d.ts +305 -43
  156. package/lib/components/VResponsive/index.d.ts +142 -27
  157. package/lib/components/VSelect/VSelect.mjs +13 -7
  158. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  159. package/lib/components/VSelect/index.d.ts +3060 -328
  160. package/lib/components/VSelectionControl/VSelectionControl.mjs +1 -4
  161. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  162. package/lib/components/VSelectionControl/index.d.ts +76 -4
  163. package/lib/components/VSelectionControlGroup/index.d.ts +242 -38
  164. package/lib/components/VSheet/VSheet.mjs +1 -7
  165. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  166. package/lib/components/VSheet/index.d.ts +194 -31
  167. package/lib/components/VSlideGroup/index.d.ts +475 -83
  168. package/lib/components/VSlider/VSliderTrack.mjs +1 -0
  169. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  170. package/lib/components/VSlider/index.d.ts +521 -79
  171. package/lib/components/VSlider/slider.mjs +5 -6
  172. package/lib/components/VSlider/slider.mjs.map +1 -1
  173. package/lib/components/VSnackbar/VSnackbar.css +2 -7
  174. package/lib/components/VSnackbar/VSnackbar.mjs +4 -3
  175. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  176. package/lib/components/VSnackbar/VSnackbar.sass +3 -8
  177. package/lib/components/VSnackbar/index.d.ts +1219 -81
  178. package/lib/components/VSwitch/VSwitch.mjs +2 -2
  179. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  180. package/lib/components/VSwitch/index.d.ts +498 -92
  181. package/lib/components/VSystemBar/index.d.ts +184 -27
  182. package/lib/components/VTable/index.d.ts +190 -35
  183. package/lib/components/VTabs/VTab.mjs +7 -23
  184. package/lib/components/VTabs/VTab.mjs.map +1 -1
  185. package/lib/components/VTabs/index.d.ts +623 -71
  186. package/lib/components/VTextField/VTextField.mjs +8 -5
  187. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  188. package/lib/components/VTextField/index.d.ts +1404 -106
  189. package/lib/components/VTextarea/VTextarea.mjs +7 -1
  190. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  191. package/lib/components/VTextarea/index.d.ts +1014 -102
  192. package/lib/components/VThemeProvider/index.d.ts +124 -19
  193. package/lib/components/VTimeline/VTimelineDivider.mjs +18 -10
  194. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  195. package/lib/components/VTimeline/index.d.ts +441 -71
  196. package/lib/components/VToolbar/VToolbar.mjs +10 -9
  197. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  198. package/lib/components/VToolbar/index.d.ts +542 -93
  199. package/lib/components/VTooltip/VTooltip.css +3 -3
  200. package/lib/components/VTooltip/VTooltip.mjs +2 -2
  201. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  202. package/lib/components/VTooltip/VTooltip.sass +1 -1
  203. package/lib/components/VTooltip/index.d.ts +1276 -82
  204. package/lib/components/VValidation/index.d.ts +201 -30
  205. package/lib/components/VWindow/index.d.ts +527 -95
  206. package/lib/components/index.d.ts +55255 -15788
  207. package/lib/components/transitions/index.d.ts +2097 -308
  208. package/lib/composables/defaults.mjs +2 -0
  209. package/lib/composables/defaults.mjs.map +1 -1
  210. package/lib/composables/display.mjs +2 -0
  211. package/lib/composables/display.mjs.map +1 -1
  212. package/lib/composables/form.mjs.map +1 -1
  213. package/lib/entry-bundler.mjs +1 -1
  214. package/lib/framework.mjs +1 -1
  215. package/lib/index.d.ts +7 -10
  216. package/lib/labs/VDataTable/VDataTable.css +15 -0
  217. package/lib/labs/VDataTable/VDataTable.mjs +41 -17
  218. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  219. package/lib/labs/VDataTable/VDataTable.sass +9 -0
  220. package/lib/labs/VDataTable/VDataTableFooter.mjs +3 -2
  221. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  222. package/lib/labs/VDataTable/VDataTableRow.mjs +8 -2
  223. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  224. package/lib/labs/VDataTable/VDataTableRows.mjs +2 -1
  225. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  226. package/lib/labs/VDataTable/VDataTableServer.mjs +39 -17
  227. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  228. package/lib/labs/VDataTable/VDataTableVirtual.mjs +23 -12
  229. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  230. package/lib/labs/VDataTable/composables/expand.mjs +1 -1
  231. package/lib/labs/VDataTable/composables/expand.mjs.map +1 -1
  232. package/lib/labs/VDataTable/composables/group.mjs +12 -1
  233. package/lib/labs/VDataTable/composables/group.mjs.map +1 -1
  234. package/lib/labs/VDataTable/composables/options.mjs +0 -12
  235. package/lib/labs/VDataTable/composables/options.mjs.map +1 -1
  236. package/lib/labs/VDataTable/composables/paginate.mjs +25 -4
  237. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  238. package/lib/labs/VDataTable/composables/select.mjs +1 -1
  239. package/lib/labs/VDataTable/composables/select.mjs.map +1 -1
  240. package/lib/labs/VDataTable/composables/sort.mjs +19 -3
  241. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  242. package/lib/labs/VDataTable/index.d.ts +4179 -1017
  243. package/lib/labs/VVirtualScroll/index.d.ts +32 -1
  244. package/lib/labs/components.d.ts +4214 -1026
  245. package/lib/locale/adapters/vue-i18n.d.ts +1 -1
  246. package/lib/locale/adapters/vue-i18n.mjs +1 -1
  247. package/lib/locale/adapters/vue-i18n.mjs.map +1 -1
  248. package/lib/styles/main.css +4 -0
  249. package/lib/styles/settings/_utilities.scss +7 -0
  250. package/lib/util/animation.mjs +8 -1
  251. package/lib/util/animation.mjs.map +1 -1
  252. package/lib/util/defineComponent.mjs +15 -7
  253. package/lib/util/defineComponent.mjs.map +1 -1
  254. package/lib/util/helpers.mjs +4 -0
  255. package/lib/util/helpers.mjs.map +1 -1
  256. package/package.json +5 -10
@@ -1 +1 @@
1
- {"version":3,"file":"VRating.mjs","names":["VBtn","IconValue","makeDensityProps","makeSizeProps","makeTagProps","makeThemeProps","provideTheme","useLocale","useProxiedModel","computed","ref","clamp","createRange","genericComponent","getUid","useRender","VRating","name","props","String","itemAriaLabel","type","default","activeColor","color","clearable","Boolean","disabled","emptyIcon","fullIcon","halfIncrements","hover","length","Number","readonly","modelValue","itemLabels","Array","itemLabelPosition","validator","v","includes","ripple","emits","value","setup","slots","t","themeClasses","rating","normalizedValue","parseFloat","range","increments","flatMap","hoverIndex","itemState","map","isHovering","isFilled","isHovered","isFullIcon","icon","eventState","onMouseenter","onMouseleave","onClick","undefined","VRatingItem","index","showStar","id","replace","btnProps","density","size","variant","item","createLabel","labelProps","label","hasLabels","i"],"sources":["../../../src/components/VRating/VRating.tsx"],"sourcesContent":["// Styles\nimport './VRating.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Composables\nimport { IconValue } from '@/composables/icons'\nimport { makeDensityProps } from '@/composables/density'\nimport { makeSizeProps } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { clamp, createRange, genericComponent, getUid, useRender } from '@/util'\n\n// Types\nimport type { Prop } from 'vue'\nimport type { Variant } from '@/composables/variant'\n\ntype VRatingItemSlot = {\n value: number\n index: number\n isFilled: boolean\n isHovered: boolean\n icon: IconValue\n color?: string\n props: Record<string, unknown>\n rating: number\n}\n\ntype VRatingItemLabelSlot = {\n value: number\n index: number\n label?: string\n}\n\ntype VRatingSlots = {\n item: [VRatingItemSlot]\n 'item-label': [VRatingItemLabelSlot]\n}\n\nexport const VRating = genericComponent<VRatingSlots>()({\n name: 'VRating',\n\n props: {\n name: String,\n itemAriaLabel: {\n type: String,\n default: '$vuetify.rating.ariaLabel.item',\n },\n activeColor: String,\n color: String,\n clearable: Boolean,\n disabled: Boolean,\n emptyIcon: {\n type: IconValue,\n default: '$ratingEmpty',\n },\n fullIcon: {\n type: IconValue,\n default: '$ratingFull',\n },\n halfIncrements: Boolean,\n hover: Boolean,\n length: {\n type: [Number, String],\n default: 5,\n },\n readonly: Boolean,\n modelValue: {\n type: [Number, String],\n default: 0,\n },\n itemLabels: Array as Prop<string[]>,\n itemLabelPosition: {\n type: String,\n default: 'top',\n validator: (v: any) => ['top', 'bottom'].includes(v),\n },\n ripple: Boolean,\n\n ...makeDensityProps(),\n ...makeSizeProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n },\n\n emits: {\n 'update:modelValue': (value: number | string) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const { themeClasses } = provideTheme(props)\n const rating = useProxiedModel(props, 'modelValue')\n const normalizedValue = computed(() => clamp(parseFloat(rating.value), 0, +props.length))\n\n const range = computed(() => createRange(Number(props.length), 1))\n const increments = computed(() => range.value.flatMap(v => props.halfIncrements ? [v - 0.5, v] : [v]))\n const hoverIndex = ref(-1)\n\n const itemState = computed(() => increments.value.map(value => {\n const isHovering = props.hover && hoverIndex.value > -1\n const isFilled = normalizedValue.value >= value\n const isHovered = hoverIndex.value >= value\n const isFullIcon = isHovering ? isHovered : isFilled\n const icon = isFullIcon ? props.fullIcon : props.emptyIcon\n const activeColor = props.activeColor ?? props.color\n const color = (isFilled || isHovered) ? activeColor : props.color\n\n return { isFilled, isHovered, icon, color }\n }))\n\n const eventState = computed(() => [0, ...increments.value].map(value => {\n function onMouseenter () {\n hoverIndex.value = value\n }\n\n function onMouseleave () {\n hoverIndex.value = -1\n }\n\n function onClick () {\n if (props.disabled || props.readonly) return\n rating.value = normalizedValue.value === value && props.clearable ? 0 : value\n }\n\n return {\n onMouseenter: props.hover ? onMouseenter : undefined,\n onMouseleave: props.hover ? onMouseleave : undefined,\n onClick,\n }\n }))\n\n const name = computed(() => props.name ?? `v-rating-${getUid()}`)\n\n function VRatingItem ({ value, index, showStar = true }: { value: number, index: number, showStar?: boolean }) {\n const { onMouseenter, onMouseleave, onClick } = eventState.value[index + 1]\n const id = `${name.value}-${String(value).replace('.', '-')}`\n const btnProps = {\n color: itemState.value[index]?.color,\n density: props.density,\n disabled: props.disabled,\n icon: itemState.value[index]?.icon,\n ripple: props.ripple,\n size: props.size,\n variant: 'plain' as Variant,\n }\n\n return (\n <>\n <label\n for={ id }\n class={{\n 'v-rating__item--half': props.halfIncrements && value % 1 > 0,\n 'v-rating__item--full': props.halfIncrements && value % 1 === 0,\n }}\n onMouseenter={ onMouseenter }\n onMouseleave={ onMouseleave }\n onClick={ onClick }\n >\n <span class=\"v-rating__hidden\">{ t(props.itemAriaLabel, value, props.length) }</span>\n {\n !showStar ? undefined\n : slots.item ? slots.item({\n ...itemState.value[index],\n props: btnProps,\n value,\n index,\n rating: normalizedValue.value,\n })\n : (\n <VBtn { ...btnProps } />\n )\n }\n </label>\n\n <input\n class=\"v-rating__hidden\"\n name={ name.value }\n id={ id }\n type=\"radio\"\n value={ value }\n checked={ normalizedValue.value === value }\n tabindex={-1}\n readonly={ props.readonly }\n disabled={ props.disabled }\n />\n </>\n )\n }\n\n function createLabel (labelProps: { value: number, index: number, label?: string }) {\n if (slots['item-label']) return slots['item-label'](labelProps)\n\n if (labelProps.label) return <span>{ labelProps.label }</span>\n\n return <span>&nbsp;</span>\n }\n\n useRender(() => {\n const hasLabels = !!props.itemLabels?.length || slots['item-label']\n\n return (\n <props.tag\n class={[\n 'v-rating',\n {\n 'v-rating--hover': props.hover,\n 'v-rating--readonly': props.readonly,\n },\n themeClasses.value,\n ]}\n >\n <VRatingItem value={ 0 } index={ -1 } showStar={ false } />\n\n { range.value.map((value, i) => (\n <div class=\"v-rating__wrapper\">\n {\n hasLabels && props.itemLabelPosition === 'top'\n ? createLabel({ value, index: i, label: props.itemLabels?.[i] })\n : undefined\n }\n <div class=\"v-rating__item\">\n { props.halfIncrements ? (\n <>\n <VRatingItem value={ value - 0.5 } index={ i * 2 } />\n <VRatingItem value={ value } index={ (i * 2) + 1 } />\n </>\n ) : (\n <VRatingItem value={ value } index={ i } />\n )}\n </div>\n {\n hasLabels && props.itemLabelPosition === 'bottom'\n ? createLabel({ value, index: i, label: props.itemLabels?.[i] })\n : undefined\n }\n </div>\n ))}\n </props.tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VRating = InstanceType<typeof VRating>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VRating.mjs","names":["VBtn","IconValue","makeDensityProps","makeSizeProps","makeTagProps","makeThemeProps","provideTheme","useLocale","useProxiedModel","computed","ref","clamp","createRange","genericComponent","getUid","useRender","VRating","name","props","String","itemAriaLabel","type","default","activeColor","color","clearable","Boolean","disabled","emptyIcon","fullIcon","halfIncrements","hover","length","Number","readonly","modelValue","itemLabels","Array","itemLabelPosition","validator","v","includes","ripple","emits","value","setup","slots","t","themeClasses","rating","normalizedValue","parseFloat","range","increments","flatMap","hoverIndex","itemState","map","isHovering","isFilled","isHovered","isFullIcon","icon","eventState","onMouseenter","onMouseleave","onClick","undefined","VRatingItem","index","showStar","id","replace","btnProps","density","size","variant","item","createLabel","labelProps","label","hasLabels","i"],"sources":["../../../src/components/VRating/VRating.tsx"],"sourcesContent":["// Styles\nimport './VRating.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Composables\nimport { IconValue } from '@/composables/icons'\nimport { makeDensityProps } from '@/composables/density'\nimport { makeSizeProps } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { clamp, createRange, genericComponent, getUid, useRender } from '@/util'\n\n// Types\nimport type { Prop } from 'vue'\nimport type { Variant } from '@/composables/variant'\n\ntype VRatingItemSlot = {\n value: number\n index: number\n isFilled: boolean\n isHovered: boolean\n icon: IconValue\n color?: string\n props: Record<string, unknown>\n rating: number\n}\n\ntype VRatingItemLabelSlot = {\n value: number\n index: number\n label?: string\n}\n\ntype VRatingSlots = {\n item: [VRatingItemSlot]\n 'item-label': [VRatingItemLabelSlot]\n}\n\nexport const VRating = genericComponent<VRatingSlots>()({\n name: 'VRating',\n\n props: {\n name: String,\n itemAriaLabel: {\n type: String,\n default: '$vuetify.rating.ariaLabel.item',\n },\n activeColor: String,\n color: String,\n clearable: Boolean,\n disabled: Boolean,\n emptyIcon: {\n type: IconValue,\n default: '$ratingEmpty',\n },\n fullIcon: {\n type: IconValue,\n default: '$ratingFull',\n },\n halfIncrements: Boolean,\n hover: Boolean,\n length: {\n type: [Number, String],\n default: 5,\n },\n readonly: Boolean,\n modelValue: {\n type: [Number, String],\n default: 0,\n },\n itemLabels: Array as Prop<string[]>,\n itemLabelPosition: {\n type: String,\n default: 'top',\n validator: (v: any) => ['top', 'bottom'].includes(v),\n },\n ripple: Boolean,\n\n ...makeDensityProps(),\n ...makeSizeProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n },\n\n emits: {\n 'update:modelValue': (value: number | string) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const { themeClasses } = provideTheme(props)\n const rating = useProxiedModel(props, 'modelValue')\n const normalizedValue = computed(() => clamp(parseFloat(rating.value), 0, +props.length))\n\n const range = computed(() => createRange(Number(props.length), 1))\n const increments = computed(() => range.value.flatMap(v => props.halfIncrements ? [v - 0.5, v] : [v]))\n const hoverIndex = ref(-1)\n\n const itemState = computed(() => increments.value.map(value => {\n const isHovering = props.hover && hoverIndex.value > -1\n const isFilled = normalizedValue.value >= value\n const isHovered = hoverIndex.value >= value\n const isFullIcon = isHovering ? isHovered : isFilled\n const icon = isFullIcon ? props.fullIcon : props.emptyIcon\n const activeColor = props.activeColor ?? props.color\n const color = (isFilled || isHovered) ? activeColor : props.color\n\n return { isFilled, isHovered, icon, color }\n }))\n\n const eventState = computed(() => [0, ...increments.value].map(value => {\n function onMouseenter () {\n hoverIndex.value = value\n }\n\n function onMouseleave () {\n hoverIndex.value = -1\n }\n\n function onClick () {\n if (props.disabled || props.readonly) return\n rating.value = normalizedValue.value === value && props.clearable ? 0 : value\n }\n\n return {\n onMouseenter: props.hover ? onMouseenter : undefined,\n onMouseleave: props.hover ? onMouseleave : undefined,\n onClick,\n }\n }))\n\n const name = computed(() => props.name ?? `v-rating-${getUid()}`)\n\n function VRatingItem ({ value, index, showStar = true }: { value: number, index: number, showStar?: boolean }) {\n const { onMouseenter, onMouseleave, onClick } = eventState.value[index + 1]\n const id = `${name.value}-${String(value).replace('.', '-')}`\n const btnProps = {\n color: itemState.value[index]?.color,\n density: props.density,\n disabled: props.disabled,\n icon: itemState.value[index]?.icon,\n ripple: props.ripple,\n size: props.size,\n variant: 'plain' as Variant,\n }\n\n return (\n <>\n <label\n for={ id }\n class={{\n 'v-rating__item--half': props.halfIncrements && value % 1 > 0,\n 'v-rating__item--full': props.halfIncrements && value % 1 === 0,\n }}\n onMouseenter={ onMouseenter }\n onMouseleave={ onMouseleave }\n onClick={ onClick }\n >\n <span class=\"v-rating__hidden\">{ t(props.itemAriaLabel, value, props.length) }</span>\n {\n !showStar ? undefined\n : slots.item ? slots.item({\n ...itemState.value[index],\n props: btnProps,\n value,\n index,\n rating: normalizedValue.value,\n })\n : (\n <VBtn { ...btnProps } />\n )\n }\n </label>\n\n <input\n class=\"v-rating__hidden\"\n name={ name.value }\n id={ id }\n type=\"radio\"\n value={ value }\n checked={ normalizedValue.value === value }\n tabindex={ -1 }\n readonly={ props.readonly }\n disabled={ props.disabled }\n />\n </>\n )\n }\n\n function createLabel (labelProps: { value: number, index: number, label?: string }) {\n if (slots['item-label']) return slots['item-label'](labelProps)\n\n if (labelProps.label) return <span>{ labelProps.label }</span>\n\n return <span>&nbsp;</span>\n }\n\n useRender(() => {\n const hasLabels = !!props.itemLabels?.length || slots['item-label']\n\n return (\n <props.tag\n class={[\n 'v-rating',\n {\n 'v-rating--hover': props.hover,\n 'v-rating--readonly': props.readonly,\n },\n themeClasses.value,\n ]}\n >\n <VRatingItem value={ 0 } index={ -1 } showStar={ false } />\n\n { range.value.map((value, i) => (\n <div class=\"v-rating__wrapper\">\n {\n hasLabels && props.itemLabelPosition === 'top'\n ? createLabel({ value, index: i, label: props.itemLabels?.[i] })\n : undefined\n }\n <div class=\"v-rating__item\">\n { props.halfIncrements ? (\n <>\n <VRatingItem value={ value - 0.5 } index={ i * 2 } />\n <VRatingItem value={ value } index={ (i * 2) + 1 } />\n </>\n ) : (\n <VRatingItem value={ value } index={ i } />\n )}\n </div>\n {\n hasLabels && props.itemLabelPosition === 'bottom'\n ? createLabel({ value, index: i, label: props.itemLabels?.[i] })\n : undefined\n }\n </div>\n ))}\n </props.tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VRating = InstanceType<typeof VRating>\n"],"mappings":"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"}
@@ -1,5 +1,9 @@
1
1
  import * as vue from 'vue';
2
- import { JSXComponent, PropType } from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes, JSXComponent, PropType, Prop } from 'vue';
3
+
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
3
7
 
4
8
  type Density = null | 'default' | 'comfortable' | 'compact';
5
9
 
@@ -21,7 +25,203 @@ type VRatingItemLabelSlot = {
21
25
  index: number;
22
26
  label?: string;
23
27
  };
24
- declare const VRating: vue.DefineComponent<{
28
+ declare const VRating: {
29
+ new (...args: any[]): {
30
+ $: vue.ComponentInternalInstance;
31
+ $data: {};
32
+ $props: Partial<{
33
+ length: string | number;
34
+ disabled: boolean;
35
+ size: string | number;
36
+ readonly: boolean;
37
+ tag: string;
38
+ density: Density;
39
+ modelValue: string | number;
40
+ ripple: boolean;
41
+ clearable: boolean;
42
+ hover: boolean;
43
+ halfIncrements: boolean;
44
+ itemAriaLabel: string;
45
+ emptyIcon: IconValue;
46
+ fullIcon: IconValue;
47
+ itemLabelPosition: string;
48
+ }> & Omit<{
49
+ length: string | number;
50
+ disabled: boolean;
51
+ size: string | number;
52
+ readonly: boolean;
53
+ tag: string;
54
+ density: Density;
55
+ modelValue: string | number;
56
+ ripple: boolean;
57
+ clearable: boolean;
58
+ hover: boolean;
59
+ halfIncrements: boolean;
60
+ itemAriaLabel: string;
61
+ emptyIcon: IconValue;
62
+ fullIcon: IconValue;
63
+ itemLabelPosition: string;
64
+ } & {
65
+ name?: string | undefined;
66
+ color?: string | undefined;
67
+ theme?: string | undefined;
68
+ activeColor?: string | undefined;
69
+ itemLabels?: string[] | undefined;
70
+ } & {
71
+ $children?: {} | vue.VNodeChild | {
72
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
73
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
74
+ };
75
+ $slots?: {
76
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
77
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
78
+ } | undefined;
79
+ 'v-slots'?: {
80
+ item?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
81
+ 'item-label'?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
82
+ } | undefined;
83
+ } & {
84
+ "v-slot:item"?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
85
+ "v-slot:item-label"?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
86
+ } & {
87
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
88
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "length" | "disabled" | "size" | "readonly" | "tag" | "density" | "modelValue" | "ripple" | "clearable" | "hover" | "halfIncrements" | "itemAriaLabel" | "emptyIcon" | "fullIcon" | "itemLabelPosition">;
89
+ $attrs: {
90
+ [x: string]: unknown;
91
+ };
92
+ $refs: {
93
+ [x: string]: unknown;
94
+ };
95
+ $slots: Readonly<{
96
+ [name: string]: vue.Slot | undefined;
97
+ }>;
98
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
99
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
100
+ $emit: (event: "update:modelValue", value: string | number) => void;
101
+ $el: any;
102
+ $options: vue.ComponentOptionsBase<{
103
+ length: string | number;
104
+ disabled: boolean;
105
+ size: string | number;
106
+ readonly: boolean;
107
+ tag: string;
108
+ density: Density;
109
+ modelValue: string | number;
110
+ ripple: boolean;
111
+ clearable: boolean;
112
+ hover: boolean;
113
+ halfIncrements: boolean;
114
+ itemAriaLabel: string;
115
+ emptyIcon: IconValue;
116
+ fullIcon: IconValue;
117
+ itemLabelPosition: string;
118
+ } & {
119
+ name?: string | undefined;
120
+ color?: string | undefined;
121
+ theme?: string | undefined;
122
+ activeColor?: string | undefined;
123
+ itemLabels?: string[] | undefined;
124
+ } & {
125
+ $children?: {} | vue.VNodeChild | {
126
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
127
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
128
+ };
129
+ $slots?: {
130
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
131
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
132
+ } | undefined;
133
+ 'v-slots'?: {
134
+ item?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
135
+ 'item-label'?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
136
+ } | undefined;
137
+ } & {
138
+ "v-slot:item"?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
139
+ "v-slot:item-label"?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
140
+ } & {
141
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
142
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
143
+ 'update:modelValue': (value: number | string) => boolean;
144
+ }, string, {
145
+ length: string | number;
146
+ disabled: boolean;
147
+ size: string | number;
148
+ readonly: boolean;
149
+ tag: string;
150
+ density: Density;
151
+ modelValue: string | number;
152
+ ripple: boolean;
153
+ clearable: boolean;
154
+ hover: boolean;
155
+ halfIncrements: boolean;
156
+ itemAriaLabel: string;
157
+ emptyIcon: IconValue;
158
+ fullIcon: IconValue;
159
+ itemLabelPosition: string;
160
+ }, {}, string> & {
161
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
162
+ created?: ((() => void) | (() => void)[]) | undefined;
163
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
164
+ mounted?: ((() => void) | (() => void)[]) | undefined;
165
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
166
+ updated?: ((() => void) | (() => void)[]) | undefined;
167
+ activated?: ((() => void) | (() => void)[]) | undefined;
168
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
169
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
170
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
171
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
172
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
173
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
174
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
175
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
176
+ };
177
+ $forceUpdate: () => void;
178
+ $nextTick: typeof vue.nextTick;
179
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
180
+ } & {
181
+ length: string | number;
182
+ disabled: boolean;
183
+ size: string | number;
184
+ readonly: boolean;
185
+ tag: string;
186
+ density: Density;
187
+ modelValue: string | number;
188
+ ripple: boolean;
189
+ clearable: boolean;
190
+ hover: boolean;
191
+ halfIncrements: boolean;
192
+ itemAriaLabel: string;
193
+ emptyIcon: IconValue;
194
+ fullIcon: IconValue;
195
+ itemLabelPosition: string;
196
+ } & {
197
+ name?: string | undefined;
198
+ color?: string | undefined;
199
+ theme?: string | undefined;
200
+ activeColor?: string | undefined;
201
+ itemLabels?: string[] | undefined;
202
+ } & {
203
+ $children?: {} | vue.VNodeChild | {
204
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
205
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
206
+ };
207
+ $slots?: {
208
+ item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
209
+ 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
210
+ } | undefined;
211
+ 'v-slots'?: {
212
+ item?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
213
+ 'item-label'?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
214
+ } | undefined;
215
+ } & {
216
+ "v-slot:item"?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
217
+ "v-slot:item-label"?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
218
+ } & {
219
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
220
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
221
+ __isFragment?: undefined;
222
+ __isTeleport?: undefined;
223
+ __isSuspense?: undefined;
224
+ } & vue.ComponentOptionsBase<{
25
225
  length: string | number;
26
226
  disabled: boolean;
27
227
  size: string | number;
@@ -59,9 +259,11 @@ declare const VRating: vue.DefineComponent<{
59
259
  } & {
60
260
  "v-slot:item"?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
61
261
  "v-slot:item-label"?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
262
+ } & {
263
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
62
264
  }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
63
265
  'update:modelValue': (value: number | string) => boolean;
64
- }, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
266
+ }, string, {
65
267
  length: string | number;
66
268
  disabled: boolean;
67
269
  size: string | number;
@@ -77,47 +279,107 @@ declare const VRating: vue.DefineComponent<{
77
279
  emptyIcon: IconValue;
78
280
  fullIcon: IconValue;
79
281
  itemLabelPosition: string;
80
- } & {
81
- name?: string | undefined;
82
- color?: string | undefined;
83
- theme?: string | undefined;
84
- activeColor?: string | undefined;
85
- itemLabels?: string[] | undefined;
86
- } & {
87
- $children?: {} | vue.VNodeChild | {
88
- item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
89
- 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
282
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
283
+ theme: StringConstructor;
284
+ tag: {
285
+ type: StringConstructor;
286
+ default: string;
90
287
  };
91
- $slots?: {
92
- item?: ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
93
- 'item-label'?: ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
94
- } | undefined;
95
- 'v-slots'?: {
96
- item?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
97
- 'item-label'?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
98
- } | undefined;
99
- } & {
100
- "v-slot:item"?: false | ((args_0: VRatingItemSlot) => vue.VNodeChild) | undefined;
101
- "v-slot:item-label"?: false | ((args_0: VRatingItemLabelSlot) => vue.VNodeChild) | undefined;
102
- } & {
103
- "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
104
- }, {
105
- length: string | number;
106
- disabled: boolean;
107
- size: string | number;
108
- readonly: boolean;
109
- tag: string;
110
- density: Density;
111
- modelValue: string | number;
112
- ripple: boolean;
113
- clearable: boolean;
114
- hover: boolean;
115
- halfIncrements: boolean;
116
- itemAriaLabel: string;
117
- emptyIcon: IconValue;
118
- fullIcon: IconValue;
119
- itemLabelPosition: string;
120
- }>;
288
+ size: {
289
+ type: (StringConstructor | NumberConstructor)[];
290
+ default: string;
291
+ };
292
+ density: {
293
+ type: vue.PropType<Density>;
294
+ default: string;
295
+ validator: (v: any) => boolean;
296
+ };
297
+ name: StringConstructor;
298
+ itemAriaLabel: {
299
+ type: StringConstructor;
300
+ default: string;
301
+ };
302
+ activeColor: StringConstructor;
303
+ color: StringConstructor;
304
+ clearable: BooleanConstructor;
305
+ disabled: BooleanConstructor;
306
+ emptyIcon: {
307
+ type: vue.PropType<IconValue>;
308
+ default: string;
309
+ };
310
+ fullIcon: {
311
+ type: vue.PropType<IconValue>;
312
+ default: string;
313
+ };
314
+ halfIncrements: BooleanConstructor;
315
+ hover: BooleanConstructor;
316
+ length: {
317
+ type: (StringConstructor | NumberConstructor)[];
318
+ default: number;
319
+ };
320
+ readonly: BooleanConstructor;
321
+ modelValue: {
322
+ type: (StringConstructor | NumberConstructor)[];
323
+ default: number;
324
+ };
325
+ itemLabels: Prop<string[], string[]>;
326
+ itemLabelPosition: {
327
+ type: StringConstructor;
328
+ default: string;
329
+ validator: (v: any) => boolean;
330
+ };
331
+ ripple: BooleanConstructor;
332
+ }, vue.ExtractPropTypes<{
333
+ theme: StringConstructor;
334
+ tag: {
335
+ type: StringConstructor;
336
+ default: string;
337
+ };
338
+ size: {
339
+ type: (StringConstructor | NumberConstructor)[];
340
+ default: string;
341
+ };
342
+ density: {
343
+ type: vue.PropType<Density>;
344
+ default: string;
345
+ validator: (v: any) => boolean;
346
+ };
347
+ name: StringConstructor;
348
+ itemAriaLabel: {
349
+ type: StringConstructor;
350
+ default: string;
351
+ };
352
+ activeColor: StringConstructor;
353
+ color: StringConstructor;
354
+ clearable: BooleanConstructor;
355
+ disabled: BooleanConstructor;
356
+ emptyIcon: {
357
+ type: vue.PropType<IconValue>;
358
+ default: string;
359
+ };
360
+ fullIcon: {
361
+ type: vue.PropType<IconValue>;
362
+ default: string;
363
+ };
364
+ halfIncrements: BooleanConstructor;
365
+ hover: BooleanConstructor;
366
+ length: {
367
+ type: (StringConstructor | NumberConstructor)[];
368
+ default: number;
369
+ };
370
+ readonly: BooleanConstructor;
371
+ modelValue: {
372
+ type: (StringConstructor | NumberConstructor)[];
373
+ default: number;
374
+ };
375
+ itemLabels: Prop<string[], string[]>;
376
+ itemLabelPosition: {
377
+ type: StringConstructor;
378
+ default: string;
379
+ validator: (v: any) => boolean;
380
+ };
381
+ ripple: BooleanConstructor;
382
+ }>>;
121
383
  type VRating = InstanceType<typeof VRating>;
122
384
 
123
385
  export { VRating };
@@ -1,31 +1,128 @@
1
1
  import * as vue from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes } from 'vue';
2
3
 
3
- declare const VResponsive: vue.DefineComponent<{} & {
4
- height?: string | number | undefined;
5
- width?: string | number | undefined;
6
- aspectRatio?: string | number | undefined;
7
- maxHeight?: string | number | undefined;
8
- maxWidth?: string | number | undefined;
9
- minHeight?: string | number | undefined;
10
- minWidth?: string | number | undefined;
11
- contentClass?: string | undefined;
12
- } & {
13
- $children?: {} | vue.VNodeChild | {
14
- default?: (() => vue.VNodeChild) | undefined;
15
- additional?: (() => vue.VNodeChild) | undefined;
16
- };
17
- $slots?: {
18
- default?: (() => vue.VNodeChild) | undefined;
19
- additional?: (() => vue.VNodeChild) | undefined;
20
- } | undefined;
21
- 'v-slots'?: {
22
- default?: false | (() => vue.VNodeChild) | undefined;
23
- additional?: false | (() => vue.VNodeChild) | undefined;
24
- } | undefined;
25
- } & {
26
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
27
- "v-slot:additional"?: false | (() => vue.VNodeChild) | undefined;
28
- }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {} & {
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
7
+
8
+ declare const VResponsive: {
9
+ new (...args: any[]): {
10
+ $: vue.ComponentInternalInstance;
11
+ $data: {};
12
+ $props: Partial<{}> & Omit<{} & {
13
+ height?: string | number | undefined;
14
+ width?: string | number | undefined;
15
+ aspectRatio?: string | number | undefined;
16
+ maxHeight?: string | number | undefined;
17
+ maxWidth?: string | number | undefined;
18
+ minHeight?: string | number | undefined;
19
+ minWidth?: string | number | undefined;
20
+ contentClass?: string | undefined;
21
+ } & {
22
+ $children?: {} | vue.VNodeChild | {
23
+ default?: (() => vue.VNodeChild) | undefined;
24
+ additional?: (() => vue.VNodeChild) | undefined;
25
+ };
26
+ $slots?: {
27
+ default?: (() => vue.VNodeChild) | undefined;
28
+ additional?: (() => vue.VNodeChild) | undefined;
29
+ } | undefined;
30
+ 'v-slots'?: {
31
+ default?: false | (() => vue.VNodeChild) | undefined;
32
+ additional?: false | (() => vue.VNodeChild) | undefined;
33
+ } | undefined;
34
+ } & {
35
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
36
+ "v-slot:additional"?: false | (() => vue.VNodeChild) | undefined;
37
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, never>;
38
+ $attrs: {
39
+ [x: string]: unknown;
40
+ };
41
+ $refs: {
42
+ [x: string]: unknown;
43
+ };
44
+ $slots: Readonly<{
45
+ [name: string]: vue.Slot | undefined;
46
+ }>;
47
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
48
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
49
+ $emit: (event: string, ...args: any[]) => void;
50
+ $el: any;
51
+ $options: vue.ComponentOptionsBase<{} & {
52
+ height?: string | number | undefined;
53
+ width?: string | number | undefined;
54
+ aspectRatio?: string | number | undefined;
55
+ maxHeight?: string | number | undefined;
56
+ maxWidth?: string | number | undefined;
57
+ minHeight?: string | number | undefined;
58
+ minWidth?: string | number | undefined;
59
+ contentClass?: string | undefined;
60
+ } & {
61
+ $children?: {} | vue.VNodeChild | {
62
+ default?: (() => vue.VNodeChild) | undefined;
63
+ additional?: (() => vue.VNodeChild) | undefined;
64
+ };
65
+ $slots?: {
66
+ default?: (() => vue.VNodeChild) | undefined;
67
+ additional?: (() => vue.VNodeChild) | undefined;
68
+ } | undefined;
69
+ 'v-slots'?: {
70
+ default?: false | (() => vue.VNodeChild) | undefined;
71
+ additional?: false | (() => vue.VNodeChild) | undefined;
72
+ } | undefined;
73
+ } & {
74
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
75
+ "v-slot:additional"?: false | (() => vue.VNodeChild) | undefined;
76
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {}, {}, string> & {
77
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
78
+ created?: ((() => void) | (() => void)[]) | undefined;
79
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
80
+ mounted?: ((() => void) | (() => void)[]) | undefined;
81
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
82
+ updated?: ((() => void) | (() => void)[]) | undefined;
83
+ activated?: ((() => void) | (() => void)[]) | undefined;
84
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
85
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
86
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
87
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
88
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
89
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
90
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
91
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
92
+ };
93
+ $forceUpdate: () => void;
94
+ $nextTick: typeof vue.nextTick;
95
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
96
+ } & {} & {
97
+ height?: string | number | undefined;
98
+ width?: string | number | undefined;
99
+ aspectRatio?: string | number | undefined;
100
+ maxHeight?: string | number | undefined;
101
+ maxWidth?: string | number | undefined;
102
+ minHeight?: string | number | undefined;
103
+ minWidth?: string | number | undefined;
104
+ contentClass?: string | undefined;
105
+ } & {
106
+ $children?: {} | vue.VNodeChild | {
107
+ default?: (() => vue.VNodeChild) | undefined;
108
+ additional?: (() => vue.VNodeChild) | undefined;
109
+ };
110
+ $slots?: {
111
+ default?: (() => vue.VNodeChild) | undefined;
112
+ additional?: (() => vue.VNodeChild) | undefined;
113
+ } | undefined;
114
+ 'v-slots'?: {
115
+ default?: false | (() => vue.VNodeChild) | undefined;
116
+ additional?: false | (() => vue.VNodeChild) | undefined;
117
+ } | undefined;
118
+ } & {
119
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
120
+ "v-slot:additional"?: false | (() => vue.VNodeChild) | undefined;
121
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
122
+ __isFragment?: undefined;
123
+ __isTeleport?: undefined;
124
+ __isSuspense?: undefined;
125
+ } & vue.ComponentOptionsBase<{} & {
29
126
  height?: string | number | undefined;
30
127
  width?: string | number | undefined;
31
128
  aspectRatio?: string | number | undefined;
@@ -50,7 +147,25 @@ declare const VResponsive: vue.DefineComponent<{} & {
50
147
  } & {
51
148
  "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
52
149
  "v-slot:additional"?: false | (() => vue.VNodeChild) | undefined;
53
- }, {}>;
150
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {}, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
151
+ height: (StringConstructor | NumberConstructor)[];
152
+ maxHeight: (StringConstructor | NumberConstructor)[];
153
+ maxWidth: (StringConstructor | NumberConstructor)[];
154
+ minHeight: (StringConstructor | NumberConstructor)[];
155
+ minWidth: (StringConstructor | NumberConstructor)[];
156
+ width: (StringConstructor | NumberConstructor)[];
157
+ aspectRatio: (StringConstructor | NumberConstructor)[];
158
+ contentClass: StringConstructor;
159
+ }, vue.ExtractPropTypes<{
160
+ height: (StringConstructor | NumberConstructor)[];
161
+ maxHeight: (StringConstructor | NumberConstructor)[];
162
+ maxWidth: (StringConstructor | NumberConstructor)[];
163
+ minHeight: (StringConstructor | NumberConstructor)[];
164
+ minWidth: (StringConstructor | NumberConstructor)[];
165
+ width: (StringConstructor | NumberConstructor)[];
166
+ aspectRatio: (StringConstructor | NumberConstructor)[];
167
+ contentClass: StringConstructor;
168
+ }>>;
54
169
  type VResponsive = InstanceType<typeof VResponsive>;
55
170
 
56
171
  export { VResponsive };