@vuetify/nightly 3.0.0-beta.4 → 3.0.0-beta.5

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 (333) hide show
  1. package/CHANGELOG.md +13 -24
  2. package/dist/json/attributes.json +66 -122
  3. package/dist/json/importMap.json +121 -137
  4. package/dist/json/tags.json +20 -68
  5. package/dist/json/web-types.json +201 -482
  6. package/dist/vuetify.css +1672 -1536
  7. package/dist/vuetify.d.ts +494 -464
  8. package/dist/vuetify.esm.js +3835 -3452
  9. package/dist/vuetify.esm.js.map +1 -1
  10. package/dist/vuetify.js +3834 -3451
  11. package/dist/vuetify.js.map +1 -1
  12. package/dist/vuetify.min.css +2 -2
  13. package/dist/vuetify.min.js +1027 -1012
  14. package/dist/vuetify.min.js.map +1 -1
  15. package/lib/blueprints/index.mjs +4 -0
  16. package/lib/blueprints/index.mjs.map +1 -0
  17. package/lib/blueprints/md1.mjs +63 -0
  18. package/lib/blueprints/md1.mjs.map +1 -0
  19. package/lib/blueprints/md2.mjs +60 -0
  20. package/lib/blueprints/md2.mjs.map +1 -0
  21. package/lib/blueprints/md3.mjs +74 -0
  22. package/lib/blueprints/md3.mjs.map +1 -0
  23. package/lib/components/VAlert/VAlert.mjs +7 -1
  24. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  25. package/lib/components/VApp/VApp.css +2 -5
  26. package/lib/components/VApp/VApp.mjs +3 -4
  27. package/lib/components/VApp/VApp.mjs.map +1 -1
  28. package/lib/components/VApp/VApp.sass +11 -12
  29. package/lib/components/VApp/variables.scss +6 -0
  30. package/lib/components/VAppBar/VAppBar.mjs +4 -3
  31. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  32. package/lib/components/VAppBar/VAppBarNavIcon.mjs +7 -12
  33. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  34. package/lib/components/VAppBar/VAppBarTitle.mjs +4 -3
  35. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  36. package/lib/components/VAppBar/_variables.scss +2 -0
  37. package/lib/components/VAutocomplete/VAutocomplete.mjs +9 -5
  38. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  39. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  40. package/lib/components/VBadge/VBadge.mjs +8 -7
  41. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  42. package/lib/components/VBadge/_variables.scss +2 -2
  43. package/lib/components/VBanner/VBanner.css +7 -7
  44. package/lib/components/VBanner/VBanner.mjs +24 -17
  45. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  46. package/lib/components/VBanner/VBanner.sass +6 -7
  47. package/lib/components/VBanner/VBannerActions.mjs +1 -1
  48. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  49. package/lib/components/VBanner/index.mjs +0 -2
  50. package/lib/components/VBanner/index.mjs.map +1 -1
  51. package/lib/components/VBottomNavigation/VBottomNavigation.css +4 -11
  52. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +4 -3
  53. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  54. package/lib/components/VBottomNavigation/VBottomNavigation.sass +5 -12
  55. package/lib/components/VBottomNavigation/_variables.scss +7 -8
  56. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +31 -16
  57. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  58. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +5 -8
  59. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  60. package/lib/components/VBtn/VBtn.css +42 -9
  61. package/lib/components/VBtn/VBtn.mjs +60 -29
  62. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  63. package/lib/components/VBtn/VBtn.sass +36 -5
  64. package/lib/components/VBtn/_variables.scss +7 -3
  65. package/lib/components/VBtnGroup/VBtnGroup.css +1 -1
  66. package/lib/components/VBtnGroup/_variables.scss +2 -0
  67. package/lib/components/VBtnToggle/_variables.scss +1 -0
  68. package/lib/components/VCard/VCard.css +78 -61
  69. package/lib/components/VCard/VCard.mjs +51 -65
  70. package/lib/components/VCard/VCard.mjs.map +1 -1
  71. package/lib/components/VCard/VCard.sass +71 -58
  72. package/lib/components/VCard/VCardActions.mjs +1 -1
  73. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  74. package/lib/components/VCard/VCardItem.mjs +88 -0
  75. package/lib/components/VCard/VCardItem.mjs.map +1 -0
  76. package/lib/components/VCard/_variables.scss +39 -24
  77. package/lib/components/VCard/index.mjs +1 -5
  78. package/lib/components/VCard/index.mjs.map +1 -1
  79. package/lib/components/VCarousel/VCarousel.mjs +5 -4
  80. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  81. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  82. package/lib/components/VCarousel/_variables.scss +1 -0
  83. package/lib/components/VChip/VChip.css +137 -60
  84. package/lib/components/VChip/VChip.mjs +74 -36
  85. package/lib/components/VChip/VChip.mjs.map +1 -1
  86. package/lib/components/VChip/VChip.sass +6 -0
  87. package/lib/components/VChip/_mixins.scss +26 -6
  88. package/lib/components/VChip/_variables.scss +1 -5
  89. package/lib/components/VChipGroup/VChipGroup.mjs +4 -3
  90. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  91. package/lib/components/VChipGroup/VChipGroup.sass +1 -1
  92. package/lib/components/VChipGroup/_variables.scss +1 -1
  93. package/lib/components/VColorPicker/VColorPicker.mjs +16 -10
  94. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  95. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +5 -4
  96. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  97. package/lib/components/VColorPicker/VColorPickerEdit.mjs +4 -3
  98. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  99. package/lib/components/VColorPicker/VColorPickerPreview.mjs +4 -3
  100. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  101. package/lib/components/VColorPicker/VColorPickerSwatches.mjs +6 -5
  102. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  103. package/lib/components/VColorPicker/_variables.scss +17 -10
  104. package/lib/components/VCombobox/VCombobox.mjs +8 -4
  105. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  106. package/lib/components/VCounter/VCounter.mjs +16 -16
  107. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  108. package/lib/components/VCounter/VCounter.sass +1 -1
  109. package/lib/components/VCounter/_variables.scss +2 -1
  110. package/lib/components/VDialog/VDialog.css +2 -5
  111. package/lib/components/VDialog/VDialog.mjs +24 -25
  112. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  113. package/lib/components/VDialog/VDialog.sass +1 -4
  114. package/lib/components/VDialog/_variables.scss +0 -1
  115. package/lib/components/VDivider/VDivider.mjs +16 -17
  116. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  117. package/lib/components/VDivider/_variables.scss +3 -1
  118. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +6 -4
  119. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  120. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +5 -5
  121. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  122. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  123. package/lib/components/VExpansionPanel/_variables.scss +15 -10
  124. package/lib/components/VField/VField.mjs +17 -10
  125. package/lib/components/VField/VField.mjs.map +1 -1
  126. package/lib/components/VField/VFieldLabel.mjs +8 -9
  127. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  128. package/lib/components/VFileInput/VFileInput.mjs +3 -3
  129. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  130. package/lib/components/VFooter/VFooter.mjs +4 -3
  131. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  132. package/lib/components/VFooter/_variables.scss +2 -1
  133. package/lib/components/VForm/VForm.mjs +3 -3
  134. package/lib/components/VForm/VForm.mjs.map +1 -1
  135. package/lib/components/VGrid/VCol.mjs.map +1 -1
  136. package/lib/components/VGrid/VContainer.mjs +4 -3
  137. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  138. package/lib/components/VGrid/VRow.mjs.map +1 -1
  139. package/lib/components/VIcon/VIcon.css +0 -8
  140. package/lib/components/VIcon/VIcon.mjs +20 -21
  141. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  142. package/lib/components/VIcon/VIcon.sass +0 -8
  143. package/lib/components/VIcon/_variables.scss +2 -5
  144. package/lib/components/VIcon/index.mjs.map +1 -1
  145. package/lib/components/VInput/VInput.mjs +9 -5
  146. package/lib/components/VInput/VInput.mjs.map +1 -1
  147. package/lib/components/VLabel/VLabel.mjs +4 -3
  148. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  149. package/lib/components/VLabel/_variables.scss +1 -0
  150. package/lib/components/VLazy/VLazy.mjs +5 -3
  151. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  152. package/lib/components/VList/VList.mjs +15 -17
  153. package/lib/components/VList/VList.mjs.map +1 -1
  154. package/lib/components/VList/VListChildren.mjs +2 -2
  155. package/lib/components/VList/VListChildren.mjs.map +1 -1
  156. package/lib/components/VList/VListGroup.mjs +8 -7
  157. package/lib/components/VList/VListGroup.mjs.map +1 -1
  158. package/lib/components/VList/VListItem.mjs +13 -8
  159. package/lib/components/VList/VListItem.mjs.map +1 -1
  160. package/lib/components/VList/VListItemAction.mjs +8 -9
  161. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  162. package/lib/components/VList/VListItemAvatar.mjs +4 -3
  163. package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
  164. package/lib/components/VList/VListItemIcon.mjs +4 -3
  165. package/lib/components/VList/VListItemIcon.mjs.map +1 -1
  166. package/lib/components/VList/VListItemMedia.mjs +4 -3
  167. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  168. package/lib/components/VList/VListSubheader.mjs +4 -3
  169. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  170. package/lib/components/VList/index.mjs +2 -2
  171. package/lib/components/VList/index.mjs.map +1 -1
  172. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -3
  173. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  174. package/lib/components/VMain/VMain.mjs +4 -3
  175. package/lib/components/VMain/VMain.mjs.map +1 -1
  176. package/lib/components/VMain/_variables.scss +1 -1
  177. package/lib/components/VMenu/VMenu.mjs +5 -5
  178. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  179. package/lib/components/VMessages/VMessages.mjs +5 -3
  180. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  181. package/lib/components/VMessages/_variables.scss +1 -1
  182. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +5 -3
  183. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  184. package/lib/components/VNavigationDrawer/_variables.scss +2 -1
  185. package/lib/components/VNavigationDrawer/touch.mjs +5 -2
  186. package/lib/components/VNavigationDrawer/touch.mjs.map +1 -1
  187. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  188. package/lib/components/VOverlay/VOverlay.mjs +10 -8
  189. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  190. package/lib/components/VOverlay/locationStrategies.mjs +267 -78
  191. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  192. package/lib/components/VOverlay/useActivator.mjs +4 -3
  193. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  194. package/lib/components/VOverlay/util/point.mjs +3 -3
  195. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  196. package/lib/components/VPagination/VPagination.mjs +18 -14
  197. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  198. package/lib/components/VParallax/VParallax.mjs +5 -5
  199. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  200. package/lib/components/VProgressCircular/VProgressCircular.mjs +6 -5
  201. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  202. package/lib/components/VProgressCircular/_variables.scss +2 -0
  203. package/lib/components/VProgressLinear/VProgressLinear.mjs +5 -3
  204. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  205. package/lib/components/VProgressLinear/_variables.scss +1 -0
  206. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -2
  207. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  208. package/lib/components/VRadioGroup/VRadioGroup.sass +5 -3
  209. package/lib/components/VRadioGroup/_variables.scss +3 -4
  210. package/lib/components/VRangeSlider/VRangeSlider.mjs +12 -13
  211. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  212. package/lib/components/VRating/VRating.mjs +6 -5
  213. package/lib/components/VRating/VRating.mjs.map +1 -1
  214. package/lib/components/VRating/VRating.sass +2 -0
  215. package/lib/components/VResponsive/VResponsive.mjs +7 -6
  216. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  217. package/lib/components/VSelect/VSelect.mjs +8 -4
  218. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  219. package/lib/components/VSelectionControl/VSelectionControl.mjs +6 -5
  220. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  221. package/lib/components/VSelectionControl/_variables.scss +1 -0
  222. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +3 -3
  223. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  224. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +1 -5
  225. package/lib/components/VSelectionControlGroup/_variables.scss +1 -4
  226. package/lib/components/VSheet/VSheet.mjs +3 -3
  227. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  228. package/lib/components/VSheet/_variables.scss +3 -2
  229. package/lib/components/VSlideGroup/VSlideGroup.mjs +47 -49
  230. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  231. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +4 -3
  232. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  233. package/lib/components/VSlideGroup/_variables.scss +0 -5
  234. package/lib/components/VSlideGroup/index.mjs +2 -2
  235. package/lib/components/VSlideGroup/index.mjs.map +1 -1
  236. package/lib/components/VSlider/VSlider.mjs +7 -9
  237. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  238. package/lib/components/VSlider/VSliderThumb.mjs +6 -5
  239. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  240. package/lib/components/VSlider/VSliderTrack.mjs +11 -10
  241. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  242. package/lib/components/VSlider/slider.mjs +4 -4
  243. package/lib/components/VSlider/slider.mjs.map +1 -1
  244. package/lib/components/VSnackbar/VSnackbar.mjs +45 -49
  245. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  246. package/lib/components/VSnackbar/_variables.scss +2 -0
  247. package/lib/components/VSwitch/_variables.scss +1 -0
  248. package/lib/components/VSystemBar/VSystemBar.mjs +4 -12
  249. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  250. package/lib/components/VSystemBar/_variables.scss +2 -1
  251. package/lib/components/VTable/VTable.mjs +9 -8
  252. package/lib/components/VTable/VTable.mjs.map +1 -1
  253. package/lib/components/VTable/_variables.scss +2 -0
  254. package/lib/components/VTabs/VTab.mjs +4 -4
  255. package/lib/components/VTabs/VTab.mjs.map +1 -1
  256. package/lib/components/VTabs/VTabs.mjs +9 -7
  257. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  258. package/lib/components/VTabs/_variables.scss +3 -1
  259. package/lib/components/VTextField/VTextField.mjs +5 -5
  260. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  261. package/lib/components/VTextField/_variables.scss +1 -1
  262. package/lib/components/VTextarea/VTextarea.mjs +4 -4
  263. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  264. package/lib/components/VTextarea/_variables.scss +1 -0
  265. package/lib/components/VTimeline/VTimeline.mjs +24 -25
  266. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  267. package/lib/components/VTimeline/VTimeline.sass +3 -2
  268. package/lib/components/VTimeline/VTimelineDivider.mjs +41 -38
  269. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  270. package/lib/components/VTimeline/VTimelineItem.mjs +10 -11
  271. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  272. package/lib/components/VTimeline/_variables.scss +11 -6
  273. package/lib/components/VToolbar/VToolbar.css +15 -6
  274. package/lib/components/VToolbar/VToolbar.mjs +9 -9
  275. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  276. package/lib/components/VToolbar/VToolbar.sass +15 -6
  277. package/lib/components/VToolbar/VToolbarItems.mjs +12 -8
  278. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  279. package/lib/components/VToolbar/_variables.scss +6 -2
  280. package/lib/components/VTooltip/VTooltip.mjs +37 -38
  281. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  282. package/lib/components/VTooltip/_variables.scss +1 -0
  283. package/lib/components/VWindow/VWindow.mjs +4 -4
  284. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  285. package/lib/components/VWindow/VWindowItem.mjs +10 -9
  286. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  287. package/lib/components/VWindow/_variables.scss +1 -0
  288. package/lib/components/index.d.ts +486 -445
  289. package/lib/components/transitions/dialog-transition.mjs +3 -0
  290. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  291. package/lib/composables/border.mjs +5 -6
  292. package/lib/composables/border.mjs.map +1 -1
  293. package/lib/composables/location.mjs +4 -8
  294. package/lib/composables/location.mjs.map +1 -1
  295. package/lib/composables/size.mjs +2 -2
  296. package/lib/composables/size.mjs.map +1 -1
  297. package/lib/composables/validation.mjs +1 -1
  298. package/lib/composables/validation.mjs.map +1 -1
  299. package/lib/composables/variant.mjs +2 -0
  300. package/lib/composables/variant.mjs.map +1 -1
  301. package/lib/entry-bundler.mjs +1 -1
  302. package/lib/framework.mjs +7 -2
  303. package/lib/framework.mjs.map +1 -1
  304. package/lib/index.d.ts +42 -43
  305. package/lib/util/anchor.mjs +34 -28
  306. package/lib/util/anchor.mjs.map +1 -1
  307. package/lib/util/animation.mjs +2 -2
  308. package/lib/util/animation.mjs.map +1 -1
  309. package/lib/util/box.mjs +12 -0
  310. package/lib/util/box.mjs.map +1 -1
  311. package/lib/util/helpers.mjs +9 -1
  312. package/lib/util/helpers.mjs.map +1 -1
  313. package/package.json +6 -8
  314. package/lib/components/VBanner/VBannerAvatar.mjs +0 -20
  315. package/lib/components/VBanner/VBannerAvatar.mjs.map +0 -1
  316. package/lib/components/VBanner/VBannerIcon.mjs +0 -20
  317. package/lib/components/VBanner/VBannerIcon.mjs.map +0 -1
  318. package/lib/components/VBreadcrumbs/shared.mjs +0 -2
  319. package/lib/components/VBreadcrumbs/shared.mjs.map +0 -1
  320. package/lib/components/VCard/VCardAvatar.mjs +0 -3
  321. package/lib/components/VCard/VCardAvatar.mjs.map +0 -1
  322. package/lib/components/VCard/VCardContent.mjs +0 -3
  323. package/lib/components/VCard/VCardContent.mjs.map +0 -1
  324. package/lib/components/VCard/VCardHeader.mjs +0 -3
  325. package/lib/components/VCard/VCardHeader.mjs.map +0 -1
  326. package/lib/components/VCard/VCardHeaderText.mjs +0 -3
  327. package/lib/components/VCard/VCardHeaderText.mjs.map +0 -1
  328. package/lib/components/VCard/VCardImg.mjs +0 -3
  329. package/lib/components/VCard/VCardImg.mjs.map +0 -1
  330. package/lib/components/VTimeline/shared.mjs +0 -2
  331. package/lib/components/VTimeline/shared.mjs.map +0 -1
  332. package/lib/presets/default/index.mjs +0 -71
  333. package/lib/presets/default/index.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForwardRef","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","item","find","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","noDataText","onClick","prepend","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { PropType } from 'vue'\nimport type { MakeSlots } from '@/util'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n if (props.multiple) return _search.value\n\n const item = items.value.find(item => item.value === model.value[0]?.value)\n\n return item?.value\n },\n set: val => {\n if (props.multiple) {\n _search.value = val\n } else {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }) => slots.item?.({\n item,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ props: slotProps, item, index })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForwardRef","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","item","find","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","noDataText","onClick","prepend","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots } from '@/util'\nimport type { PropType } from 'vue'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n item: [{ item: T, index: number, props: Record<string, unknown> }]\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n if (props.multiple) return _search.value\n\n const item = items.value.find(item => item.value === model.value[0]?.value)\n\n return item?.value\n },\n set: val => {\n if (props.multiple) {\n _search.value = val\n } else {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n key={ index }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
@@ -2,11 +2,12 @@ import { withDirectives as _withDirectives, createVNode as _createVNode, vShow a
2
2
  // Styles
3
3
  import "./VCounter.css"; // Components
4
4
 
5
- import { VSlideYTransition } from "../transitions/index.mjs"; // Utilities
5
+ import { VSlideYTransition } from "../transitions/index.mjs"; // Composables
6
+
7
+ import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs"; // Utilities
6
8
 
7
- import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs";
8
9
  import { computed } from 'vue';
9
- import { defineComponent } from "../../util/index.mjs";
10
+ import { defineComponent, useRender } from "../../util/index.mjs";
10
11
  export const VCounter = defineComponent({
11
12
  name: 'VCounter',
12
13
  functional: true,
@@ -31,19 +32,18 @@ export const VCounter = defineComponent({
31
32
  const counter = computed(() => {
32
33
  return props.max ? `${props.value} / ${props.max}` : String(props.value);
33
34
  });
34
- return () => {
35
- return _createVNode(MaybeTransition, {
36
- "transition": props.transition
37
- }, {
38
- default: () => [_withDirectives(_createVNode("div", {
39
- "class": "v-counter"
40
- }, [slots.default ? slots.default({
41
- counter: counter.value,
42
- max: props.max,
43
- value: props.value
44
- }) : counter.value]), [[_vShow, props.active]])]
45
- });
46
- };
35
+ useRender(() => _createVNode(MaybeTransition, {
36
+ "transition": props.transition
37
+ }, {
38
+ default: () => [_withDirectives(_createVNode("div", {
39
+ "class": "v-counter"
40
+ }, [slots.default ? slots.default({
41
+ counter: counter.value,
42
+ max: props.max,
43
+ value: props.value
44
+ }) : counter.value]), [[_vShow, props.active]])]
45
+ }));
46
+ return {};
47
47
  }
48
48
 
49
49
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VCounter.mjs","names":["VSlideYTransition","makeTransitionProps","MaybeTransition","computed","defineComponent","VCounter","name","functional","props","active","Boolean","max","Number","String","value","type","default","transition","component","setup","slots","counter"],"sources":["../../../src/components/VCounter/VCounter.tsx"],"sourcesContent":["// Styles\nimport './VCounter.sass'\n\n// Components\nimport { VSlideYTransition } from '@/components/transitions'\n\n// Utilities\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\nimport { computed } from 'vue'\nimport { defineComponent } from '@/util'\n\nexport const VCounter = defineComponent({\n name: 'VCounter',\n\n functional: true,\n\n props: {\n active: Boolean,\n max: [Number, String],\n value: {\n type: [Number, String],\n default: 0,\n },\n\n ...makeTransitionProps({\n transition: { component: VSlideYTransition },\n }),\n },\n\n setup (props, { slots }) {\n const counter = computed(() => {\n return props.max ? `${props.value} / ${props.max}` : String(props.value)\n })\n\n return () => {\n return (\n <MaybeTransition transition={ props.transition }>\n <div\n v-show={ props.active }\n class=\"v-counter\"\n >\n { slots.default\n ? slots.default({\n counter: counter.value,\n max: props.max,\n value: props.value,\n })\n : counter.value\n }\n </div>\n </MaybeTransition>\n )\n }\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;SACSA,iB,oCAET;;SACSC,mB,EAAqBC,e;AAC9B,SAASC,QAAT,QAAyB,KAAzB;SACSC,e;AAET,OAAO,MAAMC,QAAQ,GAAGD,eAAe,CAAC;EACtCE,IAAI,EAAE,UADgC;EAGtCC,UAAU,EAAE,IAH0B;EAKtCC,KAAK,EAAE;IACLC,MAAM,EAAEC,OADH;IAELC,GAAG,EAAE,CAACC,MAAD,EAASC,MAAT,CAFA;IAGLC,KAAK,EAAE;MACLC,IAAI,EAAE,CAACH,MAAD,EAASC,MAAT,CADD;MAELG,OAAO,EAAE;IAFJ,CAHF;IAQL,GAAGf,mBAAmB,CAAC;MACrBgB,UAAU,EAAE;QAAEC,SAAS,EAAElB;MAAb;IADS,CAAD;EARjB,CAL+B;;EAkBtCmB,KAAK,CAAEX,KAAF,QAAoB;IAAA,IAAX;MAAEY;IAAF,CAAW;IACvB,MAAMC,OAAO,GAAGlB,QAAQ,CAAC,MAAM;MAC7B,OAAOK,KAAK,CAACG,GAAN,GAAa,GAAEH,KAAK,CAACM,KAAM,MAAKN,KAAK,CAACG,GAAI,EAA1C,GAA8CE,MAAM,CAACL,KAAK,CAACM,KAAP,CAA3D;IACD,CAFuB,CAAxB;IAIA,OAAO,MAAM;MACX;QAAA,cACgCN,KAAK,CAACS;MADtC;QAAA;UAAA,SAIY;QAJZ,IAMQG,KAAK,CAACJ,OAAN,GACEI,KAAK,CAACJ,OAAN,CAAc;UACdK,OAAO,EAAEA,OAAO,CAACP,KADH;UAEdH,GAAG,EAAEH,KAAK,CAACG,GAFG;UAGdG,KAAK,EAAEN,KAAK,CAACM;QAHC,CAAd,CADF,GAMEO,OAAO,CAACP,KAZlB,cAGeN,KAAK,CAACC,MAHrB;MAAA;IAiBD,CAlBD;EAmBD;;AA1CqC,CAAD,CAAhC"}
1
+ {"version":3,"file":"VCounter.mjs","names":["VSlideYTransition","makeTransitionProps","MaybeTransition","computed","defineComponent","useRender","VCounter","name","functional","props","active","Boolean","max","Number","String","value","type","default","transition","component","setup","slots","counter"],"sources":["../../../src/components/VCounter/VCounter.tsx"],"sourcesContent":["// Styles\nimport './VCounter.sass'\n\n// Components\nimport { VSlideYTransition } from '@/components/transitions'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\nexport const VCounter = defineComponent({\n name: 'VCounter',\n\n functional: true,\n\n props: {\n active: Boolean,\n max: [Number, String],\n value: {\n type: [Number, String],\n default: 0,\n },\n\n ...makeTransitionProps({\n transition: { component: VSlideYTransition },\n }),\n },\n\n setup (props, { slots }) {\n const counter = computed(() => {\n return props.max ? `${props.value} / ${props.max}` : String(props.value)\n })\n\n useRender(() => (\n <MaybeTransition transition={ props.transition }>\n <div\n v-show={ props.active }\n class=\"v-counter\"\n >\n { slots.default\n ? slots.default({\n counter: counter.value,\n max: props.max,\n value: props.value,\n })\n : counter.value\n }\n </div>\n </MaybeTransition>\n ))\n\n return {}\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;SACSA,iB,oCAET;;SACSC,mB,EAAqBC,e,4CAE9B;;AACA,SAASC,QAAT,QAAyB,KAAzB;SACSC,e,EAAiBC,S;AAE1B,OAAO,MAAMC,QAAQ,GAAGF,eAAe,CAAC;EACtCG,IAAI,EAAE,UADgC;EAGtCC,UAAU,EAAE,IAH0B;EAKtCC,KAAK,EAAE;IACLC,MAAM,EAAEC,OADH;IAELC,GAAG,EAAE,CAACC,MAAD,EAASC,MAAT,CAFA;IAGLC,KAAK,EAAE;MACLC,IAAI,EAAE,CAACH,MAAD,EAASC,MAAT,CADD;MAELG,OAAO,EAAE;IAFJ,CAHF;IAQL,GAAGhB,mBAAmB,CAAC;MACrBiB,UAAU,EAAE;QAAEC,SAAS,EAAEnB;MAAb;IADS,CAAD;EARjB,CAL+B;;EAkBtCoB,KAAK,CAAEX,KAAF,QAAoB;IAAA,IAAX;MAAEY;IAAF,CAAW;IACvB,MAAMC,OAAO,GAAGnB,QAAQ,CAAC,MAAM;MAC7B,OAAOM,KAAK,CAACG,GAAN,GAAa,GAAEH,KAAK,CAACM,KAAM,MAAKN,KAAK,CAACG,GAAI,EAA1C,GAA8CE,MAAM,CAACL,KAAK,CAACM,KAAP,CAA3D;IACD,CAFuB,CAAxB;IAIAV,SAAS,CAAC;MAAA,cACsBI,KAAK,CAACS;IAD5B;MAAA;QAAA,SAIE;MAJF,IAMFG,KAAK,CAACJ,OAAN,GACEI,KAAK,CAACJ,OAAN,CAAc;QACdK,OAAO,EAAEA,OAAO,CAACP,KADH;QAEdH,GAAG,EAAEH,KAAK,CAACG,GAFG;QAGdG,KAAK,EAAEN,KAAK,CAACM;MAHC,CAAd,CADF,GAMEO,OAAO,CAACP,KAZR,cAGKN,KAAK,CAACC,MAHX;IAAA,EAAD,CAAT;IAkBA,OAAO,EAAP;EACD;;AA1CqC,CAAD,CAAhC"}
@@ -3,6 +3,6 @@
3
3
 
4
4
  .v-counter
5
5
  color: $counter-color
6
- flex: 0 1 auto
6
+ flex: $counter-flex
7
7
  font-size: $counter-font-size
8
8
  transition-duration: $counter-transition-duration
@@ -1,5 +1,6 @@
1
- // Defaults
1
+ // VCounter
2
2
  $counter-color: rgba(var(--v-theme-on-surface), var(--v-medium-emphasis-opacity)) !default;
3
+ $counter-flex: 0 1 auto !default;
3
4
  $counter-font-size: 12px !default;
4
5
  $counter-line-height: $counter-font-size !default;
5
6
  $counter-min-height: 12px !default;
@@ -19,13 +19,10 @@
19
19
  display: flex;
20
20
  flex-direction: column;
21
21
  }
22
- .v-dialog .v-overlay__content > .v-card > .v-card-avatar {
23
- padding: 0;
24
- }
25
- .v-dialog .v-overlay__content > .v-card > .v-card-header {
22
+ .v-dialog .v-overlay__content > .v-card > .v-card-item {
26
23
  padding: 14px 24px 0;
27
24
  }
28
- .v-dialog .v-overlay__content > .v-card > .v-card-header + .v-card-text {
25
+ .v-dialog .v-overlay__content > .v-card > .v-card-item + .v-card-text {
29
26
  padding-top: 10px;
30
27
  }
31
28
  .v-dialog .v-overlay__content > .v-card > .v-card-text {
@@ -10,8 +10,8 @@ import { makeTransitionProps } from "../../composables/transition.mjs";
10
10
  import { useProxiedModel } from "../../composables/proxiedModel.mjs";
11
11
  import { useScopeId } from "../../composables/scopeId.mjs"; // Utilities
12
12
 
13
- import { nextTick, ref, watch } from 'vue';
14
- import { genericComponent, IN_BROWSER } from "../../util/index.mjs"; // Types
13
+ import { genericComponent, IN_BROWSER, useRender } from "../../util/index.mjs";
14
+ import { nextTick, ref, watch } from 'vue'; // Types
15
15
 
16
16
  export const VDialog = genericComponent()({
17
17
  name: 'VDialog',
@@ -103,29 +103,28 @@ export const VDialog = genericComponent()({
103
103
  });
104
104
  }
105
105
  });
106
- return () => {
107
- return _createVNode(VOverlay, _mergeProps({
108
- "modelValue": isActive.value,
109
- "onUpdate:modelValue": $event => isActive.value = $event,
110
- "class": ['v-dialog', {
111
- 'v-dialog--fullscreen': props.fullscreen,
112
- 'v-dialog--scrollable': props.scrollable
113
- }],
114
- "style": dimensionStyles.value,
115
- "transition": props.transition,
116
- "ref": overlay,
117
- "aria-role": "dialog",
118
- "aria-modal": "true",
119
- "activatorProps": {
120
- 'aria-haspopup': 'dialog',
121
- 'aria-expanded': String(isActive.value)
122
- },
123
- "z-index": 2400
124
- }, scopeId, attrs), {
125
- default: slots.default,
126
- activator: slots.activator
127
- });
128
- };
106
+ useRender(() => _createVNode(VOverlay, _mergeProps({
107
+ "modelValue": isActive.value,
108
+ "onUpdate:modelValue": $event => isActive.value = $event,
109
+ "class": ['v-dialog', {
110
+ 'v-dialog--fullscreen': props.fullscreen,
111
+ 'v-dialog--scrollable': props.scrollable
112
+ }],
113
+ "style": dimensionStyles.value,
114
+ "transition": props.transition,
115
+ "ref": overlay,
116
+ "aria-role": "dialog",
117
+ "aria-modal": "true",
118
+ "activatorProps": {
119
+ 'aria-haspopup': 'dialog',
120
+ 'aria-expanded': String(isActive.value)
121
+ },
122
+ "z-index": 2400
123
+ }, scopeId, attrs), {
124
+ default: slots.default,
125
+ activator: slots.activator
126
+ }));
127
+ return {};
129
128
  }
130
129
 
131
130
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VOverlay","makeDimensionProps","useDimension","makeTransitionProps","useProxiedModel","useScopeId","nextTick","ref","watch","genericComponent","IN_BROWSER","VDialog","name","inheritAttrs","props","fullscreen","Boolean","origin","type","String","default","retainFocus","scrollable","modelValue","width","transition","component","emits","value","setup","attrs","slots","isActive","dimensionStyles","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","isTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activator"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\n\n// Utilities\nimport { nextTick, ref, watch } from 'vue'\nimport { genericComponent, IN_BROWSER } from '@/util'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<new () => {\n $slots: OverlaySlots\n}>()({\n name: 'VDialog',\n\n inheritAttrs: false,\n\n props: {\n fullscreen: Boolean,\n origin: {\n type: String,\n default: 'center center',\n },\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n modelValue: Boolean,\n\n ...makeDimensionProps({ width: 'auto' }),\n ...makeTransitionProps({\n transition: { component: VDialogTransition },\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { dimensionStyles } = useDimension(props)\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.isTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n return () => {\n return (\n <VOverlay\n v-model={ isActive.value }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n style={ dimensionStyles.value }\n transition={ props.transition }\n ref={ overlay }\n aria-role=\"dialog\"\n aria-modal=\"true\"\n activatorProps={{\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }}\n z-index={ 2400 }\n { ...scopeId }\n { ...attrs }\n v-slots={{\n default: slots.default,\n activator: slots.activator,\n }}\n />\n )\n }\n },\n})\n\nexport type VDialog = InstanceType<typeof VDialog>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VOverlay","makeDimensionProps","useDimension","makeTransitionProps","useProxiedModel","useScopeId","genericComponent","IN_BROWSER","useRender","nextTick","ref","watch","VDialog","name","inheritAttrs","props","fullscreen","Boolean","origin","type","String","default","retainFocus","scrollable","modelValue","width","transition","component","emits","value","setup","attrs","slots","isActive","dimensionStyles","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","isTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activator"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\n\n// Utilities\nimport { genericComponent, IN_BROWSER, useRender } from '@/util'\nimport { nextTick, ref, watch } from 'vue'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<new () => {\n $slots: OverlaySlots\n}>()({\n name: 'VDialog',\n\n inheritAttrs: false,\n\n props: {\n fullscreen: Boolean,\n origin: {\n type: String,\n default: 'center center',\n },\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n modelValue: Boolean,\n\n ...makeDimensionProps({ width: 'auto' }),\n ...makeTransitionProps({\n transition: { component: VDialogTransition },\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { dimensionStyles } = useDimension(props)\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.isTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n useRender(() => (\n <VOverlay\n v-model={ isActive.value }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n style={ dimensionStyles.value }\n transition={ props.transition }\n ref={ overlay }\n aria-role=\"dialog\"\n aria-modal=\"true\"\n activatorProps={{\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }}\n z-index={ 2400 }\n { ...scopeId }\n { ...attrs }\n v-slots={{\n default: slots.default,\n activator: slots.activator,\n }}\n />\n ))\n\n return {}\n },\n})\n\nexport type VDialog = InstanceType<typeof VDialog>\n"],"mappings":"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"}
@@ -24,10 +24,7 @@
24
24
  display: flex
25
25
  flex-direction: column
26
26
 
27
- > .v-card-avatar
28
- padding: $dialog-card-avatar-padding
29
-
30
- > .v-card-header
27
+ > .v-card-item
31
28
  padding: $dialog-card-header-padding
32
29
 
33
30
  + .v-card-text
@@ -7,7 +7,6 @@ $dialog-elevation: 24 !default;
7
7
  $dialog-border-radius: settings.$border-radius-root !default;
8
8
  $dialog-margin: 24px !default;
9
9
 
10
- $dialog-card-avatar-padding: 0 !default;
11
10
  $dialog-card-header-padding: 14px 24px 0 !default;
12
11
  $dialog-card-header-text-padding-top: 10px !default;
13
12
  $dialog-card-text-padding: 16px 24px 10px !default;
@@ -1,12 +1,12 @@
1
1
  import { createVNode as _createVNode } from "vue";
2
2
  // Styles
3
- import "./VDivider.css"; // Utilities
4
-
5
- import { computed, toRef } from 'vue';
6
- import { convertToUnit, defineComponent } from "../../util/index.mjs"; // Composables
3
+ import "./VDivider.css"; // Composables
7
4
 
8
5
  import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
9
- import { useBackgroundColor } from "../../composables/color.mjs"; // Types
6
+ import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
7
+
8
+ import { computed, toRef } from 'vue';
9
+ import { convertToUnit, defineComponent, useRender } from "../../util/index.mjs"; // Types
10
10
 
11
11
  export const VDivider = defineComponent({
12
12
  name: 'VDivider',
@@ -43,18 +43,17 @@ export const VDivider = defineComponent({
43
43
 
44
44
  return styles;
45
45
  });
46
- return () => {
47
- return _createVNode("hr", {
48
- "class": [{
49
- 'v-divider': true,
50
- 'v-divider--inset': props.inset,
51
- 'v-divider--vertical': props.vertical
52
- }, themeClasses.value, backgroundColorClasses.value],
53
- "style": [dividerStyles.value, backgroundColorStyles.value],
54
- "aria-orientation": !attrs.role || attrs.role === 'separator' ? props.vertical ? 'vertical' : 'horizontal' : undefined,
55
- "role": `${attrs.role || 'separator'}`
56
- }, null);
57
- };
46
+ useRender(() => _createVNode("hr", {
47
+ "class": [{
48
+ 'v-divider': true,
49
+ 'v-divider--inset': props.inset,
50
+ 'v-divider--vertical': props.vertical
51
+ }, themeClasses.value, backgroundColorClasses.value],
52
+ "style": [dividerStyles.value, backgroundColorStyles.value],
53
+ "aria-orientation": !attrs.role || attrs.role === 'separator' ? props.vertical ? 'vertical' : 'horizontal' : undefined,
54
+ "role": `${attrs.role || 'separator'}`
55
+ }, null));
56
+ return {};
58
57
  }
59
58
 
60
59
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VDivider.mjs","names":["computed","toRef","convertToUnit","defineComponent","makeThemeProps","provideTheme","useBackgroundColor","VDivider","name","props","color","String","inset","Boolean","length","Number","thickness","vertical","setup","attrs","themeClasses","backgroundColorClasses","backgroundColorStyles","dividerStyles","styles","value","role","undefined"],"sources":["../../../src/components/VDivider/VDivider.tsx"],"sourcesContent":["// Styles\nimport './VDivider.sass'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { convertToUnit, defineComponent } from '@/util'\n\n// Composables\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Types\ntype DividerKey = 'borderRightWidth' | 'borderTopWidth' | 'maxHeight' | 'maxWidth'\ntype DividerStyles = Partial<Record<DividerKey, string>>\n\nexport const VDivider = defineComponent({\n name: 'VDivider',\n\n props: {\n color: String,\n inset: Boolean,\n length: [Number, String],\n thickness: [Number, String],\n vertical: Boolean,\n ...makeThemeProps(),\n },\n\n setup (props, { attrs }) {\n const { themeClasses } = provideTheme(props)\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const dividerStyles = computed(() => {\n const styles: DividerStyles = {}\n\n if (props.length) {\n styles[props.vertical ? 'maxHeight' : 'maxWidth'] = convertToUnit(props.length)\n }\n\n if (props.thickness) {\n styles[props.vertical ? 'borderRightWidth' : 'borderTopWidth'] = convertToUnit(props.thickness)\n }\n\n return styles\n })\n\n return () => {\n return (\n <hr\n class={[\n {\n 'v-divider': true,\n 'v-divider--inset': props.inset,\n 'v-divider--vertical': props.vertical,\n },\n themeClasses.value,\n backgroundColorClasses.value,\n ]}\n style={[\n dividerStyles.value,\n backgroundColorStyles.value,\n ]}\n aria-orientation={\n !attrs.role || attrs.role === 'separator'\n ? props.vertical ? 'vertical' : 'horizontal'\n : undefined\n }\n role={`${attrs.role || 'separator'}`}\n />\n )\n }\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;AACA,SAASA,QAAT,EAAmBC,KAAnB,QAAgC,KAAhC;SACSC,a,EAAeC,e,gCAExB;;SACSC,c,EAAgBC,Y;SAChBC,kB,uCAET;;AAIA,OAAO,MAAMC,QAAQ,GAAGJ,eAAe,CAAC;EACtCK,IAAI,EAAE,UADgC;EAGtCC,KAAK,EAAE;IACLC,KAAK,EAAEC,MADF;IAELC,KAAK,EAAEC,OAFF;IAGLC,MAAM,EAAE,CAACC,MAAD,EAASJ,MAAT,CAHH;IAILK,SAAS,EAAE,CAACD,MAAD,EAASJ,MAAT,CAJN;IAKLM,QAAQ,EAAEJ,OALL;IAML,GAAGT,cAAc;EANZ,CAH+B;;EAYtCc,KAAK,CAAET,KAAF,QAAoB;IAAA,IAAX;MAAEU;IAAF,CAAW;IACvB,MAAM;MAAEC;IAAF,IAAmBf,YAAY,CAACI,KAAD,CAArC;IACA,MAAM;MAAEY,sBAAF;MAA0BC;IAA1B,IAAoDhB,kBAAkB,CAACL,KAAK,CAACQ,KAAD,EAAQ,OAAR,CAAN,CAA5E;IACA,MAAMc,aAAa,GAAGvB,QAAQ,CAAC,MAAM;MACnC,MAAMwB,MAAqB,GAAG,EAA9B;;MAEA,IAAIf,KAAK,CAACK,MAAV,EAAkB;QAChBU,MAAM,CAACf,KAAK,CAACQ,QAAN,GAAiB,WAAjB,GAA+B,UAAhC,CAAN,GAAoDf,aAAa,CAACO,KAAK,CAACK,MAAP,CAAjE;MACD;;MAED,IAAIL,KAAK,CAACO,SAAV,EAAqB;QACnBQ,MAAM,CAACf,KAAK,CAACQ,QAAN,GAAiB,kBAAjB,GAAsC,gBAAvC,CAAN,GAAiEf,aAAa,CAACO,KAAK,CAACO,SAAP,CAA9E;MACD;;MAED,OAAOQ,MAAP;IACD,CAZ6B,CAA9B;IAcA,OAAO,MAAM;MACX;QAAA,SAEW,CACL;UACE,aAAa,IADf;UAEE,oBAAoBf,KAAK,CAACG,KAF5B;UAGE,uBAAuBH,KAAK,CAACQ;QAH/B,CADK,EAMLG,YAAY,CAACK,KANR,EAOLJ,sBAAsB,CAACI,KAPlB,CAFX;QAAA,SAWW,CACLF,aAAa,CAACE,KADT,EAELH,qBAAqB,CAACG,KAFjB,CAXX;QAAA,oBAgBM,CAACN,KAAK,CAACO,IAAP,IAAeP,KAAK,CAACO,IAAN,KAAe,WAA9B,GACIjB,KAAK,CAACQ,QAAN,GAAiB,UAAjB,GAA8B,YADlC,GAEIU,SAlBV;QAAA,QAoBW,GAAER,KAAK,CAACO,IAAN,IAAc,WAAY;MApBvC;IAuBD,CAxBD;EAyBD;;AAtDqC,CAAD,CAAhC"}
1
+ {"version":3,"file":"VDivider.mjs","names":["makeThemeProps","provideTheme","useBackgroundColor","computed","toRef","convertToUnit","defineComponent","useRender","VDivider","name","props","color","String","inset","Boolean","length","Number","thickness","vertical","setup","attrs","themeClasses","backgroundColorClasses","backgroundColorStyles","dividerStyles","styles","value","role","undefined"],"sources":["../../../src/components/VDivider/VDivider.tsx"],"sourcesContent":["// Styles\nimport './VDivider.sass'\n\n// Composables\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { convertToUnit, defineComponent, useRender } from '@/util'\n\n// Types\ntype DividerKey = 'borderRightWidth' | 'borderTopWidth' | 'maxHeight' | 'maxWidth'\ntype DividerStyles = Partial<Record<DividerKey, string>>\n\nexport const VDivider = defineComponent({\n name: 'VDivider',\n\n props: {\n color: String,\n inset: Boolean,\n length: [Number, String],\n thickness: [Number, String],\n vertical: Boolean,\n\n ...makeThemeProps(),\n },\n\n setup (props, { attrs }) {\n const { themeClasses } = provideTheme(props)\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const dividerStyles = computed(() => {\n const styles: DividerStyles = {}\n\n if (props.length) {\n styles[props.vertical ? 'maxHeight' : 'maxWidth'] = convertToUnit(props.length)\n }\n\n if (props.thickness) {\n styles[props.vertical ? 'borderRightWidth' : 'borderTopWidth'] = convertToUnit(props.thickness)\n }\n\n return styles\n })\n\n useRender(() => (\n <hr\n class={[\n {\n 'v-divider': true,\n 'v-divider--inset': props.inset,\n 'v-divider--vertical': props.vertical,\n },\n themeClasses.value,\n backgroundColorClasses.value,\n ]}\n style={[\n dividerStyles.value,\n backgroundColorStyles.value,\n ]}\n aria-orientation={\n !attrs.role || attrs.role === 'separator'\n ? props.vertical ? 'vertical' : 'horizontal'\n : undefined\n }\n role={`${attrs.role || 'separator'}`}\n />\n ))\n\n return {}\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;SACSA,c,EAAgBC,Y;SAChBC,kB,uCAET;;AACA,SAASC,QAAT,EAAmBC,KAAnB,QAAgC,KAAhC;SACSC,a,EAAeC,e,EAAiBC,S,gCAEzC;;AAIA,OAAO,MAAMC,QAAQ,GAAGF,eAAe,CAAC;EACtCG,IAAI,EAAE,UADgC;EAGtCC,KAAK,EAAE;IACLC,KAAK,EAAEC,MADF;IAELC,KAAK,EAAEC,OAFF;IAGLC,MAAM,EAAE,CAACC,MAAD,EAASJ,MAAT,CAHH;IAILK,SAAS,EAAE,CAACD,MAAD,EAASJ,MAAT,CAJN;IAKLM,QAAQ,EAAEJ,OALL;IAOL,GAAGd,cAAc;EAPZ,CAH+B;;EAatCmB,KAAK,CAAET,KAAF,QAAoB;IAAA,IAAX;MAAEU;IAAF,CAAW;IACvB,MAAM;MAAEC;IAAF,IAAmBpB,YAAY,CAACS,KAAD,CAArC;IACA,MAAM;MAAEY,sBAAF;MAA0BC;IAA1B,IAAoDrB,kBAAkB,CAACE,KAAK,CAACM,KAAD,EAAQ,OAAR,CAAN,CAA5E;IACA,MAAMc,aAAa,GAAGrB,QAAQ,CAAC,MAAM;MACnC,MAAMsB,MAAqB,GAAG,EAA9B;;MAEA,IAAIf,KAAK,CAACK,MAAV,EAAkB;QAChBU,MAAM,CAACf,KAAK,CAACQ,QAAN,GAAiB,WAAjB,GAA+B,UAAhC,CAAN,GAAoDb,aAAa,CAACK,KAAK,CAACK,MAAP,CAAjE;MACD;;MAED,IAAIL,KAAK,CAACO,SAAV,EAAqB;QACnBQ,MAAM,CAACf,KAAK,CAACQ,QAAN,GAAiB,kBAAjB,GAAsC,gBAAvC,CAAN,GAAiEb,aAAa,CAACK,KAAK,CAACO,SAAP,CAA9E;MACD;;MAED,OAAOQ,MAAP;IACD,CAZ6B,CAA9B;IAcAlB,SAAS,CAAC;MAAA,SAEC,CACL;QACE,aAAa,IADf;QAEE,oBAAoBG,KAAK,CAACG,KAF5B;QAGE,uBAAuBH,KAAK,CAACQ;MAH/B,CADK,EAMLG,YAAY,CAACK,KANR,EAOLJ,sBAAsB,CAACI,KAPlB,CAFD;MAAA,SAWC,CACLF,aAAa,CAACE,KADT,EAELH,qBAAqB,CAACG,KAFjB,CAXD;MAAA,oBAgBJ,CAACN,KAAK,CAACO,IAAP,IAAeP,KAAK,CAACO,IAAN,KAAe,WAA9B,GACIjB,KAAK,CAACQ,QAAN,GAAiB,UAAjB,GAA8B,YADlC,GAEIU,SAlBA;MAAA,QAoBC,GAAER,KAAK,CAACO,IAAN,IAAc,WAAY;IApB7B,QAAD,CAAT;IAwBA,OAAO,EAAP;EACD;;AAvDqC,CAAD,CAAhC"}
@@ -1,6 +1,6 @@
1
1
  @use '../../styles/settings';
2
2
 
3
- // Defaults
3
+ // VDivider
4
4
  $divider-border-color: settings.$border-color-root !default;
5
5
  $divider-border-style: settings.$border-style-root !default;
6
6
  $divider-border-width: thin 0 0 0 !default;
@@ -14,6 +14,8 @@ $divider-vertical-inset-margin-top: $divider-margin !default;
14
14
  $divider-vertical-inset-max-height: calc(100% - #{$divider-margin * 2}) !default;
15
15
  $divider-vertical-margin-left: -1px !default;
16
16
 
17
+
18
+ // Lists
17
19
  $divider-border: (
18
20
  $divider-border-color,
19
21
  $divider-border-style,
@@ -1,15 +1,15 @@
1
1
  import { createVNode as _createVNode } from "vue";
2
2
  // Components
3
3
  import { makeVExpansionPanelTitleProps, VExpansionPanelTitle } from "./VExpansionPanelTitle.mjs";
4
- import { VExpansionPanelText } from "./VExpansionPanelText.mjs";
5
- import { VExpansionPanelSymbol } from "./VExpansionPanels.mjs"; // Composables
4
+ import { VExpansionPanelSymbol } from "./VExpansionPanels.mjs";
5
+ import { VExpansionPanelText } from "./VExpansionPanelText.mjs"; // Composables
6
6
 
7
7
  import { makeElevationProps, useElevation } from "../../composables/elevation.mjs";
8
8
  import { makeGroupItemProps, useGroupItem } from "../../composables/group.mjs";
9
+ import { makeLazyProps } from "../../composables/lazy.mjs";
9
10
  import { makeRoundedProps, useRounded } from "../../composables/rounded.mjs";
10
- import { useBackgroundColor } from "../../composables/color.mjs";
11
11
  import { makeTagProps } from "../../composables/tag.mjs";
12
- import { makeLazyProps } from "../../composables/lazy.mjs"; // Utilities
12
+ import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
13
13
 
14
14
  import { computed, provide } from 'vue';
15
15
  import { defineComponent, useRender } from "../../util/index.mjs";
@@ -74,6 +74,7 @@ export const VExpansionPanel = defineComponent({
74
74
  default: () => [_createVNode("div", {
75
75
  "class": ['v-expansion-panel__shadow', ...elevationClasses.value]
76
76
  }, null), hasTitle && _createVNode(VExpansionPanelTitle, {
77
+ "key": "title",
77
78
  "collapseIcon": props.collapseIcon,
78
79
  "color": props.color,
79
80
  "expandIcon": props.expandIcon,
@@ -82,6 +83,7 @@ export const VExpansionPanel = defineComponent({
82
83
  }, {
83
84
  default: () => [slots.title ? slots.title() : props.title]
84
85
  }), hasText && _createVNode(VExpansionPanelText, {
86
+ "key": "text",
85
87
  "eager": props.eager
86
88
  }, {
87
89
  default: () => [slots.text ? slots.text() : props.text]
@@ -1 +1 @@
1
- {"version":3,"file":"VExpansionPanel.mjs","names":["makeVExpansionPanelTitleProps","VExpansionPanelTitle","VExpansionPanelText","VExpansionPanelSymbol","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","makeRoundedProps","useRounded","useBackgroundColor","makeTagProps","makeLazyProps","computed","provide","defineComponent","useRender","VExpansionPanel","name","props","title","String","text","bgColor","setup","slots","groupItem","backgroundColorClasses","backgroundColorStyles","elevationClasses","roundedClasses","isDisabled","disabled","value","selectedIndices","group","items","reduce","arr","item","index","selected","includes","id","push","isBeforeSelected","findIndex","isSelected","some","selectedIndex","isAfterSelected","hasText","hasTitle","collapseIcon","color","expandIcon","hideActions","ripple","eager","default"],"sources":["../../../src/components/VExpansionPanel/VExpansionPanel.tsx"],"sourcesContent":["// Components\nimport { makeVExpansionPanelTitleProps, VExpansionPanelTitle } from './VExpansionPanelTitle'\nimport { VExpansionPanelText } from './VExpansionPanelText'\nimport { VExpansionPanelSymbol } from './VExpansionPanels'\n\n// Composables\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { useBackgroundColor } from '@/composables/color'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeLazyProps } from '@/composables/lazy'\n\n// Utilities\nimport { computed, provide } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\nexport const VExpansionPanel = defineComponent({\n name: 'VExpansionPanel',\n\n props: {\n title: String,\n text: String,\n bgColor: String,\n\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeLazyProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeVExpansionPanelTitleProps(),\n },\n\n setup (props, { slots }) {\n const groupItem = useGroupItem(props, VExpansionPanelSymbol)\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(props, 'bgColor')\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const isDisabled = computed(() => groupItem?.disabled.value || props.disabled)\n\n const selectedIndices = computed(() => groupItem.group.items.value.reduce<number[]>((arr, item, index) => {\n if (groupItem.group.selected.value.includes(item.id)) arr.push(index)\n return arr\n }, []))\n\n const isBeforeSelected = computed(() => {\n const index = groupItem.group.items.value.findIndex(item => item.id === groupItem.id)\n return !groupItem.isSelected.value &&\n selectedIndices.value.some(selectedIndex => selectedIndex - index === 1)\n })\n\n const isAfterSelected = computed(() => {\n const index = groupItem.group.items.value.findIndex(item => item.id === groupItem.id)\n return !groupItem.isSelected.value &&\n selectedIndices.value.some(selectedIndex => selectedIndex - index === -1)\n })\n\n provide(VExpansionPanelSymbol, groupItem)\n\n useRender(() => {\n const hasText = !!(slots.text || props.text)\n const hasTitle = !!(slots.title || props.title)\n\n return (\n <props.tag\n class={[\n 'v-expansion-panel',\n {\n 'v-expansion-panel--active': groupItem.isSelected.value,\n 'v-expansion-panel--before-active': isBeforeSelected.value,\n 'v-expansion-panel--after-active': isAfterSelected.value,\n 'v-expansion-panel--disabled': isDisabled.value,\n },\n roundedClasses.value,\n backgroundColorClasses.value,\n ]}\n style={ backgroundColorStyles.value }\n aria-expanded={ groupItem.isSelected.value }\n >\n <div\n class={[\n 'v-expansion-panel__shadow',\n ...elevationClasses.value,\n ]}\n />\n\n { hasTitle && (\n <VExpansionPanelTitle\n collapseIcon={ props.collapseIcon }\n color={ props.color }\n expandIcon={ props.expandIcon }\n hideActions={ props.hideActions }\n ripple={ props.ripple }\n >\n { slots.title ? slots.title() : props.title }\n </VExpansionPanelTitle>\n ) }\n\n { hasText && (\n <VExpansionPanelText eager={ props.eager }>\n { slots.text ? slots.text() : props.text }\n </VExpansionPanelText>\n ) }\n\n { slots.default?.() }\n </props.tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VExpansionPanel = InstanceType<typeof VExpansionPanel>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VExpansionPanel.mjs","names":["makeVExpansionPanelTitleProps","VExpansionPanelTitle","VExpansionPanelSymbol","VExpansionPanelText","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","makeLazyProps","makeRoundedProps","useRounded","makeTagProps","useBackgroundColor","computed","provide","defineComponent","useRender","VExpansionPanel","name","props","title","String","text","bgColor","setup","slots","groupItem","backgroundColorClasses","backgroundColorStyles","elevationClasses","roundedClasses","isDisabled","disabled","value","selectedIndices","group","items","reduce","arr","item","index","selected","includes","id","push","isBeforeSelected","findIndex","isSelected","some","selectedIndex","isAfterSelected","hasText","hasTitle","collapseIcon","color","expandIcon","hideActions","ripple","eager","default"],"sources":["../../../src/components/VExpansionPanel/VExpansionPanel.tsx"],"sourcesContent":["// Components\nimport { makeVExpansionPanelTitleProps, VExpansionPanelTitle } from './VExpansionPanelTitle'\nimport { VExpansionPanelSymbol } from './VExpansionPanels'\nimport { VExpansionPanelText } from './VExpansionPanelText'\n\n// Composables\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { makeLazyProps } from '@/composables/lazy'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Utilities\nimport { computed, provide } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\nexport const VExpansionPanel = defineComponent({\n name: 'VExpansionPanel',\n\n props: {\n title: String,\n text: String,\n bgColor: String,\n\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeLazyProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeVExpansionPanelTitleProps(),\n },\n\n setup (props, { slots }) {\n const groupItem = useGroupItem(props, VExpansionPanelSymbol)\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(props, 'bgColor')\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const isDisabled = computed(() => groupItem?.disabled.value || props.disabled)\n\n const selectedIndices = computed(() => groupItem.group.items.value.reduce<number[]>((arr, item, index) => {\n if (groupItem.group.selected.value.includes(item.id)) arr.push(index)\n return arr\n }, []))\n\n const isBeforeSelected = computed(() => {\n const index = groupItem.group.items.value.findIndex(item => item.id === groupItem.id)\n return !groupItem.isSelected.value &&\n selectedIndices.value.some(selectedIndex => selectedIndex - index === 1)\n })\n\n const isAfterSelected = computed(() => {\n const index = groupItem.group.items.value.findIndex(item => item.id === groupItem.id)\n return !groupItem.isSelected.value &&\n selectedIndices.value.some(selectedIndex => selectedIndex - index === -1)\n })\n\n provide(VExpansionPanelSymbol, groupItem)\n\n useRender(() => {\n const hasText = !!(slots.text || props.text)\n const hasTitle = !!(slots.title || props.title)\n\n return (\n <props.tag\n class={[\n 'v-expansion-panel',\n {\n 'v-expansion-panel--active': groupItem.isSelected.value,\n 'v-expansion-panel--before-active': isBeforeSelected.value,\n 'v-expansion-panel--after-active': isAfterSelected.value,\n 'v-expansion-panel--disabled': isDisabled.value,\n },\n roundedClasses.value,\n backgroundColorClasses.value,\n ]}\n style={ backgroundColorStyles.value }\n aria-expanded={ groupItem.isSelected.value }\n >\n <div\n class={[\n 'v-expansion-panel__shadow',\n ...elevationClasses.value,\n ]}\n />\n\n { hasTitle && (\n <VExpansionPanelTitle\n key=\"title\"\n collapseIcon={ props.collapseIcon }\n color={ props.color }\n expandIcon={ props.expandIcon }\n hideActions={ props.hideActions }\n ripple={ props.ripple }\n >\n { slots.title ? slots.title() : props.title }\n </VExpansionPanelTitle>\n ) }\n\n { hasText && (\n <VExpansionPanelText key=\"text\" eager={ props.eager }>\n { slots.text ? slots.text() : props.text }\n </VExpansionPanelText>\n ) }\n\n { slots.default?.() }\n </props.tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VExpansionPanel = InstanceType<typeof VExpansionPanel>\n"],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  import { withDirectives as _withDirectives, resolveDirective as _resolveDirective, createVNode as _createVNode } from "vue";
2
2
  // Components
3
- import { VIcon } from "../VIcon/index.mjs";
4
- import { VExpansionPanelSymbol } from "./VExpansionPanels.mjs"; // Composables
3
+ import { VExpansionPanelSymbol } from "./VExpansionPanels.mjs";
4
+ import { VIcon } from "../VIcon/index.mjs"; // Directives
5
5
 
6
- import { useBackgroundColor } from "../../composables/color.mjs";
7
- import { IconValue } from "../../composables/icons.mjs"; // Directives
6
+ import { Ripple } from "../../directives/ripple/index.mjs"; // Composables
8
7
 
9
- import { Ripple } from "../../directives/ripple/index.mjs"; // Utilities
8
+ import { IconValue } from "../../composables/icons.mjs";
9
+ import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
10
10
 
11
11
  import { computed, inject } from 'vue';
12
12
  import { defineComponent, propsFactory, useRender } from "../../util/index.mjs";