@vuetify/nightly 3.7.5-master.2024-12-17 → 3.7.6-dev.2024-12-18

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 (281) hide show
  1. package/dist/json/attributes.json +3385 -3377
  2. package/dist/json/importMap-labs.json +24 -24
  3. package/dist/json/importMap.json +154 -154
  4. package/dist/json/tags.json +2 -0
  5. package/dist/json/web-types.json +6391 -6373
  6. package/dist/vuetify-labs.css +3014 -3014
  7. package/dist/vuetify-labs.d.ts +3365 -14377
  8. package/dist/vuetify-labs.esm.js +45 -47
  9. package/dist/vuetify-labs.esm.js.map +1 -1
  10. package/dist/vuetify-labs.js +44 -46
  11. package/dist/vuetify-labs.min.css +2 -2
  12. package/dist/vuetify.css +4326 -4326
  13. package/dist/vuetify.d.ts +3127 -12301
  14. package/dist/vuetify.esm.js +45 -47
  15. package/dist/vuetify.esm.js.map +1 -1
  16. package/dist/vuetify.js +44 -46
  17. package/dist/vuetify.js.map +1 -1
  18. package/dist/vuetify.min.css +2 -2
  19. package/dist/vuetify.min.js +878 -883
  20. package/dist/vuetify.min.js.map +1 -1
  21. package/lib/components/VAlert/VAlert.mjs +1 -1
  22. package/lib/components/VAlert/index.d.mts +8 -86
  23. package/lib/components/VApp/index.d.mts +4 -20
  24. package/lib/components/VAppBar/VAppBar.mjs +1 -1
  25. package/lib/components/VAppBar/VAppBarNavIcon.mjs +1 -1
  26. package/lib/components/VAppBar/VAppBarTitle.mjs +1 -1
  27. package/lib/components/VAppBar/index.d.mts +18 -154
  28. package/lib/components/VAutocomplete/VAutocomplete.mjs +1 -1
  29. package/lib/components/VAutocomplete/index.d.mts +201 -1360
  30. package/lib/components/VAvatar/index.d.mts +4 -31
  31. package/lib/components/VBadge/VBadge.mjs +1 -1
  32. package/lib/components/VBadge/index.d.mts +4 -41
  33. package/lib/components/VBanner/VBanner.mjs +1 -1
  34. package/lib/components/VBanner/index.d.mts +12 -88
  35. package/lib/components/VBottomNavigation/index.d.mts +4 -32
  36. package/lib/components/VBottomSheet/VBottomSheet.mjs +1 -1
  37. package/lib/components/VBottomSheet/index.d.mts +4 -88
  38. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +1 -1
  39. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +1 -1
  40. package/lib/components/VBreadcrumbs/index.d.mts +12 -65
  41. package/lib/components/VBtn/VBtn.mjs +1 -1
  42. package/lib/components/VBtn/index.d.mts +11 -79
  43. package/lib/components/VBtnGroup/VBtnGroup.mjs +1 -1
  44. package/lib/components/VBtnGroup/index.d.mts +4 -28
  45. package/lib/components/VBtnToggle/VBtnToggle.mjs +1 -1
  46. package/lib/components/VBtnToggle/index.d.mts +13 -33
  47. package/lib/components/VCard/VCard.mjs +1 -1
  48. package/lib/components/VCard/VCardItem.mjs +1 -1
  49. package/lib/components/VCard/VCardSubtitle.mjs +1 -1
  50. package/lib/components/VCard/VCardText.mjs +1 -1
  51. package/lib/components/VCard/index.d.mts +24 -190
  52. package/lib/components/VCarousel/VCarousel.mjs +1 -1
  53. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  54. package/lib/components/VCarousel/VCarouselItem.mjs +1 -1
  55. package/lib/components/VCarousel/index.d.mts +17 -95
  56. package/lib/components/VCheckbox/VCheckbox.mjs +4 -4
  57. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  58. package/lib/components/VCheckbox/VCheckboxBtn.mjs +1 -1
  59. package/lib/components/VCheckbox/index.d.mts +8 -90
  60. package/lib/components/VChip/VChip.mjs +16 -9
  61. package/lib/components/VChip/VChip.mjs.map +1 -1
  62. package/lib/components/VChip/index.d.mts +9 -105
  63. package/lib/components/VChipGroup/VChipGroup.mjs +3 -1
  64. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  65. package/lib/components/VChipGroup/index.d.mts +24 -43
  66. package/lib/components/VCode/index.d.mts +4 -18
  67. package/lib/components/VColorPicker/VColorPicker.mjs +1 -1
  68. package/lib/components/VColorPicker/index.d.mts +4 -68
  69. package/lib/components/VCombobox/VCombobox.mjs +1 -1
  70. package/lib/components/VCombobox/index.d.mts +201 -1360
  71. package/lib/components/VConfirmEdit/VConfirmEdit.mjs +1 -1
  72. package/lib/components/VConfirmEdit/__test__/VConfirmEdit.spec.browser.mjs +1 -1
  73. package/lib/components/VConfirmEdit/index.d.mts +6 -13
  74. package/lib/components/VCounter/VCounter.mjs +1 -1
  75. package/lib/components/VCounter/index.d.mts +9 -31
  76. package/lib/components/VDataIterator/index.d.mts +12 -56
  77. package/lib/components/VDataTable/VDataTable.mjs +1 -1
  78. package/lib/components/VDataTable/VDataTableFooter.mjs +1 -1
  79. package/lib/components/VDataTable/VDataTableGroupHeaderRow.mjs +1 -1
  80. package/lib/components/VDataTable/VDataTableHeaders.mjs +1 -1
  81. package/lib/components/VDataTable/VDataTableRow.mjs +1 -1
  82. package/lib/components/VDataTable/VDataTableRows.mjs +1 -1
  83. package/lib/components/VDataTable/VDataTableServer.mjs +1 -1
  84. package/lib/components/VDataTable/VDataTableVirtual.mjs +1 -1
  85. package/lib/components/VDataTable/index.d.mts +36 -388
  86. package/lib/components/VDatePicker/VDatePicker.mjs +1 -1
  87. package/lib/components/VDatePicker/VDatePickerMonth.mjs +1 -1
  88. package/lib/components/VDatePicker/VDatePickerMonths.mjs +1 -1
  89. package/lib/components/VDatePicker/VDatePickerYears.mjs +1 -1
  90. package/lib/components/VDatePicker/index.d.mts +24 -276
  91. package/lib/components/VDefaultsProvider/index.d.mts +4 -20
  92. package/lib/components/VDialog/VDialog.mjs +1 -1
  93. package/lib/components/VDialog/__test__/VDialog.spec.cy.mjs +1 -1
  94. package/lib/components/VDialog/index.d.mts +143 -389
  95. package/lib/components/VDivider/index.d.mts +4 -24
  96. package/lib/components/VEmptyState/VEmptyState.mjs +1 -1
  97. package/lib/components/VEmptyState/index.d.mts +4 -66
  98. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +1 -1
  99. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +1 -1
  100. package/lib/components/VExpansionPanel/index.d.mts +23 -159
  101. package/lib/components/VFab/VFab.mjs +1 -1
  102. package/lib/components/VFab/index.d.mts +15 -84
  103. package/lib/components/VField/VField.mjs +4 -4
  104. package/lib/components/VField/VField.mjs.map +1 -1
  105. package/lib/components/VField/VFieldLabel.mjs +1 -1
  106. package/lib/components/VField/index.d.mts +11 -59
  107. package/lib/components/VFileInput/VFileInput.mjs +1 -1
  108. package/lib/components/VFileInput/index.d.mts +71 -256
  109. package/lib/components/VFooter/VFooter.mjs +1 -1
  110. package/lib/components/VFooter/index.d.mts +4 -29
  111. package/lib/components/VForm/index.d.mts +267 -175
  112. package/lib/components/VGrid/VContainer.mjs +1 -1
  113. package/lib/components/VGrid/index.d.mts +16 -118
  114. package/lib/components/VHover/index.d.mts +4 -33
  115. package/lib/components/VIcon/index.d.mts +17 -75
  116. package/lib/components/VImg/VImg.mjs +1 -1
  117. package/lib/components/VImg/index.d.mts +19 -74
  118. package/lib/components/VInfiniteScroll/VInfiniteScroll.mjs +1 -1
  119. package/lib/components/VInfiniteScroll/index.d.mts +4 -46
  120. package/lib/components/VInput/VInput.mjs +4 -4
  121. package/lib/components/VInput/VInput.mjs.map +1 -1
  122. package/lib/components/VInput/index.d.mts +4 -37
  123. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  124. package/lib/components/VItemGroup/index.d.mts +17 -74
  125. package/lib/components/VKbd/index.d.mts +4 -18
  126. package/lib/components/VLabel/index.d.mts +4 -20
  127. package/lib/components/VLayout/index.d.mts +8 -48
  128. package/lib/components/VLazy/VLazy.mjs +1 -1
  129. package/lib/components/VLazy/index.d.mts +4 -31
  130. package/lib/components/VList/VList.mjs +1 -1
  131. package/lib/components/VList/VListChildren.mjs +1 -1
  132. package/lib/components/VList/VListGroup.mjs +1 -1
  133. package/lib/components/VList/VListItem.mjs +1 -1
  134. package/lib/components/VList/VListItemAction.mjs +1 -1
  135. package/lib/components/VList/VListItemMedia.mjs +1 -1
  136. package/lib/components/VList/VListItemSubtitle.mjs +1 -1
  137. package/lib/components/VList/index.d.mts +48 -291
  138. package/lib/components/VLocaleProvider/index.d.mts +4 -21
  139. package/lib/components/VMain/index.d.mts +4 -25
  140. package/lib/components/VMenu/VMenu.mjs +4 -4
  141. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  142. package/lib/components/VMenu/index.d.mts +155 -397
  143. package/lib/components/VMessages/index.d.mts +4 -27
  144. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +1 -1
  145. package/lib/components/VNavigationDrawer/index.d.mts +7 -62
  146. package/lib/components/VOtpInput/VOtpInput.mjs +1 -1
  147. package/lib/components/VOtpInput/index.d.mts +7 -52
  148. package/lib/components/VOverlay/VOverlay.mjs +1 -1
  149. package/lib/components/VOverlay/index.d.mts +19 -101
  150. package/lib/components/VPagination/VPagination.mjs +1 -1
  151. package/lib/components/VPagination/index.d.mts +4 -64
  152. package/lib/components/VParallax/VParallax.mjs +1 -1
  153. package/lib/components/VParallax/index.d.mts +4 -27
  154. package/lib/components/VProgressCircular/index.d.mts +4 -34
  155. package/lib/components/VProgressLinear/index.d.mts +4 -54
  156. package/lib/components/VRadio/VRadio.mjs +1 -1
  157. package/lib/components/VRadio/index.d.mts +4 -68
  158. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -4
  159. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  160. package/lib/components/VRadioGroup/index.d.mts +4 -48
  161. package/lib/components/VRangeSlider/VRangeSlider.mjs +1 -1
  162. package/lib/components/VRangeSlider/index.d.mts +4 -107
  163. package/lib/components/VRating/VRating.mjs +5 -4
  164. package/lib/components/VRating/VRating.mjs.map +1 -1
  165. package/lib/components/VRating/index.d.mts +4 -42
  166. package/lib/components/VResponsive/index.d.mts +4 -29
  167. package/lib/components/VSelect/VSelect.mjs +1 -1
  168. package/lib/components/VSelect/index.d.mts +200 -1352
  169. package/lib/components/VSelectionControl/VSelectionControl.mjs +4 -4
  170. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  171. package/lib/components/VSelectionControl/index.d.mts +10 -37
  172. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +3 -3
  173. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  174. package/lib/components/VSelectionControlGroup/index.d.mts +4 -26
  175. package/lib/components/VSheet/VSheet.mjs +1 -1
  176. package/lib/components/VSheet/index.d.mts +4 -32
  177. package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs +1 -1
  178. package/lib/components/VSkeletonLoader/index.d.mts +4 -28
  179. package/lib/components/VSlideGroup/index.d.mts +21 -77
  180. package/lib/components/VSlider/VSlider.mjs +1 -1
  181. package/lib/components/VSlider/VSliderThumb.mjs +1 -1
  182. package/lib/components/VSlider/index.d.mts +4 -106
  183. package/lib/components/VSnackbar/VSnackbar.mjs +1 -1
  184. package/lib/components/VSnackbar/index.d.mts +152 -398
  185. package/lib/components/VSparkline/VBarline.mjs +3 -4
  186. package/lib/components/VSparkline/VBarline.mjs.map +1 -1
  187. package/lib/components/VSparkline/VSparkline.mjs +1 -1
  188. package/lib/components/VSparkline/VTrendline.mjs +3 -4
  189. package/lib/components/VSparkline/VTrendline.mjs.map +1 -1
  190. package/lib/components/VSparkline/index.d.mts +4 -49
  191. package/lib/components/VSpeedDial/VSpeedDial.mjs +1 -1
  192. package/lib/components/VSpeedDial/index.d.mts +4 -85
  193. package/lib/components/VStepper/VStepper.mjs +1 -1
  194. package/lib/components/VStepper/VStepperItem.mjs +1 -1
  195. package/lib/components/VStepper/VStepperWindow.mjs +1 -1
  196. package/lib/components/VStepper/VStepperWindowItem.mjs +1 -1
  197. package/lib/components/VStepper/index.d.mts +24 -250
  198. package/lib/components/VSwitch/VSwitch.mjs +4 -4
  199. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  200. package/lib/components/VSwitch/index.d.mts +4 -59
  201. package/lib/components/VSystemBar/VSystemBar.mjs +1 -1
  202. package/lib/components/VSystemBar/index.d.mts +4 -28
  203. package/lib/components/VTable/index.d.mts +4 -33
  204. package/lib/components/VTabs/VTab.mjs +1 -1
  205. package/lib/components/VTabs/VTabs.mjs +1 -1
  206. package/lib/components/VTabs/VTabsWindow.mjs +1 -1
  207. package/lib/components/VTabs/VTabsWindowItem.mjs +1 -1
  208. package/lib/components/VTabs/index.d.mts +105 -401
  209. package/lib/components/VTextField/VTextField.mjs +1 -1
  210. package/lib/components/VTextField/index.d.mts +152 -374
  211. package/lib/components/VTextarea/VTextarea.mjs +1 -1
  212. package/lib/components/VTextarea/index.d.mts +71 -244
  213. package/lib/components/VThemeProvider/index.d.mts +4 -20
  214. package/lib/components/VTimeline/VTimeline.mjs +1 -1
  215. package/lib/components/VTimeline/VTimelineDivider.mjs +1 -1
  216. package/lib/components/VTimeline/VTimelineItem.mjs +1 -1
  217. package/lib/components/VTimeline/index.d.mts +8 -75
  218. package/lib/components/VToolbar/VToolbar.mjs +1 -1
  219. package/lib/components/VToolbar/index.d.mts +12 -90
  220. package/lib/components/VTooltip/VTooltip.mjs +4 -4
  221. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  222. package/lib/components/VTooltip/index.d.mts +147 -386
  223. package/lib/components/VValidation/index.d.mts +10 -24
  224. package/lib/components/VVirtualScroll/VVirtualScroll.mjs +1 -1
  225. package/lib/components/VVirtualScroll/VVirtualScrollItem.mjs +1 -1
  226. package/lib/components/VVirtualScroll/index.d.mts +4 -15
  227. package/lib/components/VWindow/VWindow.mjs +1 -1
  228. package/lib/components/VWindow/VWindowItem.mjs +1 -1
  229. package/lib/components/VWindow/index.d.mts +15 -54
  230. package/lib/components/index.d.mts +2947 -12121
  231. package/lib/components/transitions/dialog-transition.mjs +1 -2
  232. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  233. package/lib/components/transitions/index.d.mts +64 -309
  234. package/lib/composables/group.mjs +3 -3
  235. package/lib/composables/group.mjs.map +1 -1
  236. package/lib/composables/icons.mjs +1 -1
  237. package/lib/composables/layout.mjs +3 -3
  238. package/lib/composables/layout.mjs.map +1 -1
  239. package/lib/composables/nested/nested.mjs +2 -2
  240. package/lib/composables/nested/nested.mjs.map +1 -1
  241. package/lib/composables/validation.mjs +3 -3
  242. package/lib/composables/validation.mjs.map +1 -1
  243. package/lib/composables/variant.mjs +1 -1
  244. package/lib/composables/virtual.mjs +1 -1
  245. package/lib/composables/virtual.mjs.map +1 -1
  246. package/lib/entry-bundler.mjs +1 -1
  247. package/lib/entry-bundler.mjs.map +1 -1
  248. package/lib/framework.mjs +2 -3
  249. package/lib/framework.mjs.map +1 -1
  250. package/lib/index.d.mts +61 -61
  251. package/lib/labs/VCalendar/VCalendar.mjs +1 -1
  252. package/lib/labs/VCalendar/VCalendarDay.mjs +1 -1
  253. package/lib/labs/VCalendar/index.d.mts +24 -211
  254. package/lib/labs/VDateInput/VDateInput.mjs +1 -1
  255. package/lib/labs/VDateInput/index.d.mts +4 -115
  256. package/lib/labs/VFileUpload/VFileUpload.mjs +1 -1
  257. package/lib/labs/VFileUpload/VFileUploadItem.mjs +1 -1
  258. package/lib/labs/VFileUpload/index.d.mts +8 -195
  259. package/lib/labs/VNumberInput/VNumberInput.mjs +1 -1
  260. package/lib/labs/VNumberInput/index.d.mts +577 -1280
  261. package/lib/labs/VPicker/VPicker.mjs +1 -1
  262. package/lib/labs/VPicker/index.d.mts +8 -63
  263. package/lib/labs/VPullToRefresh/index.d.mts +4 -35
  264. package/lib/labs/VSnackbarQueue/VSnackbarQueue.mjs +1 -1
  265. package/lib/labs/VSnackbarQueue/index.d.mts +156 -453
  266. package/lib/labs/VStepperVertical/VStepperVertical.mjs +1 -1
  267. package/lib/labs/VStepperVertical/VStepperVerticalActions.mjs +1 -1
  268. package/lib/labs/VStepperVertical/VStepperVerticalItem.mjs +1 -1
  269. package/lib/labs/VStepperVertical/index.d.mts +12 -227
  270. package/lib/labs/VTimePicker/VTimePicker.mjs +1 -1
  271. package/lib/labs/VTimePicker/VTimePickerControls.mjs +1 -1
  272. package/lib/labs/VTimePicker/index.d.mts +12 -122
  273. package/lib/labs/VTreeview/VTreeview.mjs +1 -1
  274. package/lib/labs/VTreeview/VTreeviewChildren.mjs +1 -1
  275. package/lib/labs/VTreeview/VTreeviewGroup.mjs +1 -1
  276. package/lib/labs/VTreeview/VTreeviewItem.mjs +1 -1
  277. package/lib/labs/VTreeview/index.d.mts +18 -205
  278. package/lib/labs/components.d.mts +1116 -3200
  279. package/lib/util/getCurrentInstance.mjs +1 -15
  280. package/lib/util/getCurrentInstance.mjs.map +1 -1
  281. package/package.json +5 -4
@@ -1 +1 @@
1
- {"version":3,"file":"VCheckbox.mjs","names":["makeVCheckboxBtnProps","VCheckboxBtn","makeVInputProps","VInput","useFocus","useProxiedModel","computed","filterInputAttrs","genericComponent","getUid","omit","propsFactory","useRender","makeVCheckboxProps","VCheckbox","name","inheritAttrs","props","emits","value","focused","setup","_ref","attrs","slots","model","isFocused","focus","blur","uid","id","rootAttrs","controlAttrs","inputProps","filterProps","checkboxProps","_createVNode","_mergeProps","class","$event","style","default","_ref2","messagesId","isDisabled","isReadonly","isValid"],"sources":["../../../src/components/VCheckbox/VCheckbox.tsx"],"sourcesContent":["// Styles\nimport './VCheckbox.sass'\n\n// Components\nimport { makeVCheckboxBtnProps, VCheckboxBtn } from './VCheckboxBtn'\nimport { makeVInputProps, VInput } from '@/components/VInput/VInput'\n\n// Composables\nimport { useFocus } from '@/composables/focus'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed } from 'vue'\nimport { filterInputAttrs, genericComponent, getUid, omit, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { VSelectionControlSlots } from '../VSelectionControl/VSelectionControl'\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport type { GenericProps } from '@/util'\n\nexport type VCheckboxSlots = Omit<VInputSlots, 'default'> & VSelectionControlSlots\n\nexport const makeVCheckboxProps = propsFactory({\n ...makeVInputProps(),\n ...omit(makeVCheckboxBtnProps(), ['inline']),\n}, 'VCheckbox')\n\nexport const VCheckbox = genericComponent<new <T>(\n props: {\n modelValue?: T | null\n 'onUpdate:modelValue'?: (value: T | null) => void\n },\n slots: VCheckboxSlots,\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VCheckbox',\n\n inheritAttrs: false,\n\n props: makeVCheckboxProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n 'update:focused': (focused: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const model = useProxiedModel(props, 'modelValue')\n const { isFocused, focus, blur } = useFocus(props)\n\n const uid = getUid()\n const id = computed(() => props.id || `checkbox-${uid}`)\n\n useRender(() => {\n const [rootAttrs, controlAttrs] = filterInputAttrs(attrs)\n const inputProps = VInput.filterProps(props)\n const checkboxProps = VCheckboxBtn.filterProps(props)\n\n return (\n <VInput\n class={[\n 'v-checkbox',\n props.class,\n ]}\n { ...rootAttrs }\n { ...inputProps }\n v-model={ model.value }\n id={ id.value }\n focused={ isFocused.value }\n style={ props.style }\n >\n {{\n ...slots,\n default: ({\n id,\n messagesId,\n isDisabled,\n isReadonly,\n isValid,\n }) => (\n <VCheckboxBtn\n { ...checkboxProps }\n id={ id.value }\n aria-describedby={ messagesId.value }\n disabled={ isDisabled.value }\n readonly={ isReadonly.value }\n { ...controlAttrs }\n error={ isValid.value === false }\n v-model={ model.value }\n onFocus={ focus }\n onBlur={ blur }\n v-slots={ slots }\n />\n ),\n }}\n </VInput>\n )\n })\n\n return {}\n },\n})\n\nexport type VCheckbox = InstanceType<typeof VCheckbox>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,qBAAqB,EAAEC,YAAY;AAAA,SACnCC,eAAe,EAAEC,MAAM,gCAEhC;AAAA,SACSC,QAAQ;AAAA,SACRC,eAAe,8CAExB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,gBAAgB,EAAEC,gBAAgB,EAAEC,MAAM,EAAEC,IAAI,EAAEC,YAAY,EAAEC,SAAS,gCAElF;AAOA,OAAO,MAAMC,kBAAkB,GAAGF,YAAY,CAAC;EAC7C,GAAGT,eAAe,CAAC,CAAC;EACpB,GAAGQ,IAAI,CAACV,qBAAqB,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC;AAC7C,CAAC,EAAE,WAAW,CAAC;AAEf,OAAO,MAAMc,SAAS,GAAGN,gBAAgB,CAMM,CAAC,CAAC;EAC/CO,IAAI,EAAE,WAAW;EAEjBC,YAAY,EAAE,KAAK;EAEnBC,KAAK,EAAEJ,kBAAkB,CAAC,CAAC;EAE3BK,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK,IAAI;IACzC,gBAAgB,EAAGC,OAAgB,IAAK;EAC1C,CAAC;EAEDC,KAAKA,CAAEJ,KAAK,EAAAK,IAAA,EAAoB;IAAA,IAAlB;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAAF,IAAA;IAC5B,MAAMG,KAAK,GAAGpB,eAAe,CAACY,KAAK,EAAE,YAAY,CAAC;IAClD,MAAM;MAAES,SAAS;MAAEC,KAAK;MAAEC;IAAK,CAAC,GAAGxB,QAAQ,CAACa,KAAK,CAAC;IAElD,MAAMY,GAAG,GAAGpB,MAAM,CAAC,CAAC;IACpB,MAAMqB,EAAE,GAAGxB,QAAQ,CAAC,MAAMW,KAAK,CAACa,EAAE,IAAI,YAAYD,GAAG,EAAE,CAAC;IAExDjB,SAAS,CAAC,MAAM;MACd,MAAM,CAACmB,SAAS,EAAEC,YAAY,CAAC,GAAGzB,gBAAgB,CAACgB,KAAK,CAAC;MACzD,MAAMU,UAAU,GAAG9B,MAAM,CAAC+B,WAAW,CAACjB,KAAK,CAAC;MAC5C,MAAMkB,aAAa,GAAGlC,YAAY,CAACiC,WAAW,CAACjB,KAAK,CAAC;MAErD,OAAAmB,YAAA,CAAAjC,MAAA,EAAAkC,WAAA;QAAA,SAEW,CACL,YAAY,EACZpB,KAAK,CAACqB,KAAK;MACZ,GACIP,SAAS,EACTE,UAAU;QAAA,cACLR,KAAK,CAACN,KAAK;QAAA,uBAAAoB,MAAA,IAAXd,KAAK,CAACN,KAAK,GAAAoB,MAAA;QAAA,MAChBT,EAAE,CAACX,KAAK;QAAA,WACHO,SAAS,CAACP,KAAK;QAAA,SACjBF,KAAK,CAACuB;MAAK;QAGjB,GAAGhB,KAAK;QACRiB,OAAO,EAAEC,KAAA;UAAA,IAAC;YACRZ,EAAE;YACFa,UAAU;YACVC,UAAU;YACVC,UAAU;YACVC;UACF,CAAC,GAAAJ,KAAA;UAAA,OAAAN,YAAA,CAAAnC,YAAA,EAAAoC,WAAA,CAEQF,aAAa;YAAA,MACbL,EAAE,CAACX,KAAK;YAAA,oBACMwB,UAAU,CAACxB,KAAK;YAAA,YACxByB,UAAU,CAACzB,KAAK;YAAA,YAChB0B,UAAU,CAAC1B;UAAK,GACtBa,YAAY;YAAA,SACTc,OAAO,CAAC3B,KAAK,KAAK,KAAK;YAAA,cACrBM,KAAK,CAACN,KAAK;YAAA,uBAAAoB,MAAA,IAAXd,KAAK,CAACN,KAAK,GAAAoB,MAAA;YAAA,WACXZ,KAAK;YAAA,UACNC;UAAI,IACHJ,KAAK;QAAA;MAElB;IAIT,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"VCheckbox.mjs","names":["makeVCheckboxBtnProps","VCheckboxBtn","makeVInputProps","VInput","useFocus","useProxiedModel","computed","useId","filterInputAttrs","genericComponent","omit","propsFactory","useRender","makeVCheckboxProps","VCheckbox","name","inheritAttrs","props","emits","value","focused","setup","_ref","attrs","slots","model","isFocused","focus","blur","uid","id","rootAttrs","controlAttrs","inputProps","filterProps","checkboxProps","_createVNode","_mergeProps","class","$event","style","default","_ref2","messagesId","isDisabled","isReadonly","isValid"],"sources":["../../../src/components/VCheckbox/VCheckbox.tsx"],"sourcesContent":["// Styles\nimport './VCheckbox.sass'\n\n// Components\nimport { makeVCheckboxBtnProps, VCheckboxBtn } from './VCheckboxBtn'\nimport { makeVInputProps, VInput } from '@/components/VInput/VInput'\n\n// Composables\nimport { useFocus } from '@/composables/focus'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, useId } from 'vue'\nimport { filterInputAttrs, genericComponent, omit, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { VSelectionControlSlots } from '../VSelectionControl/VSelectionControl'\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport type { GenericProps } from '@/util'\n\nexport type VCheckboxSlots = Omit<VInputSlots, 'default'> & VSelectionControlSlots\n\nexport const makeVCheckboxProps = propsFactory({\n ...makeVInputProps(),\n ...omit(makeVCheckboxBtnProps(), ['inline']),\n}, 'VCheckbox')\n\nexport const VCheckbox = genericComponent<new <T>(\n props: {\n modelValue?: T | null\n 'onUpdate:modelValue'?: (value: T | null) => void\n },\n slots: VCheckboxSlots,\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VCheckbox',\n\n inheritAttrs: false,\n\n props: makeVCheckboxProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n 'update:focused': (focused: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const model = useProxiedModel(props, 'modelValue')\n const { isFocused, focus, blur } = useFocus(props)\n\n const uid = useId()\n const id = computed(() => props.id || `checkbox-${uid}`)\n\n useRender(() => {\n const [rootAttrs, controlAttrs] = filterInputAttrs(attrs)\n const inputProps = VInput.filterProps(props)\n const checkboxProps = VCheckboxBtn.filterProps(props)\n\n return (\n <VInput\n class={[\n 'v-checkbox',\n props.class,\n ]}\n { ...rootAttrs }\n { ...inputProps }\n v-model={ model.value }\n id={ id.value }\n focused={ isFocused.value }\n style={ props.style }\n >\n {{\n ...slots,\n default: ({\n id,\n messagesId,\n isDisabled,\n isReadonly,\n isValid,\n }) => (\n <VCheckboxBtn\n { ...checkboxProps }\n id={ id.value }\n aria-describedby={ messagesId.value }\n disabled={ isDisabled.value }\n readonly={ isReadonly.value }\n { ...controlAttrs }\n error={ isValid.value === false }\n v-model={ model.value }\n onFocus={ focus }\n onBlur={ blur }\n v-slots={ slots }\n />\n ),\n }}\n </VInput>\n )\n })\n\n return {}\n },\n})\n\nexport type VCheckbox = InstanceType<typeof VCheckbox>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,qBAAqB,EAAEC,YAAY;AAAA,SACnCC,eAAe,EAAEC,MAAM,gCAEhC;AAAA,SACSC,QAAQ;AAAA,SACRC,eAAe,8CAExB;AACA,SAASC,QAAQ,EAAEC,KAAK,QAAQ,KAAK;AAAA,SAC5BC,gBAAgB,EAAEC,gBAAgB,EAAEC,IAAI,EAAEC,YAAY,EAAEC,SAAS,gCAE1E;AAOA,OAAO,MAAMC,kBAAkB,GAAGF,YAAY,CAAC;EAC7C,GAAGT,eAAe,CAAC,CAAC;EACpB,GAAGQ,IAAI,CAACV,qBAAqB,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC;AAC7C,CAAC,EAAE,WAAW,CAAC;AAEf,OAAO,MAAMc,SAAS,GAAGL,gBAAgB,CAMM,CAAC,CAAC;EAC/CM,IAAI,EAAE,WAAW;EAEjBC,YAAY,EAAE,KAAK;EAEnBC,KAAK,EAAEJ,kBAAkB,CAAC,CAAC;EAE3BK,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK,IAAI;IACzC,gBAAgB,EAAGC,OAAgB,IAAK;EAC1C,CAAC;EAEDC,KAAKA,CAAEJ,KAAK,EAAAK,IAAA,EAAoB;IAAA,IAAlB;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAAF,IAAA;IAC5B,MAAMG,KAAK,GAAGpB,eAAe,CAACY,KAAK,EAAE,YAAY,CAAC;IAClD,MAAM;MAAES,SAAS;MAAEC,KAAK;MAAEC;IAAK,CAAC,GAAGxB,QAAQ,CAACa,KAAK,CAAC;IAElD,MAAMY,GAAG,GAAGtB,KAAK,CAAC,CAAC;IACnB,MAAMuB,EAAE,GAAGxB,QAAQ,CAAC,MAAMW,KAAK,CAACa,EAAE,IAAI,YAAYD,GAAG,EAAE,CAAC;IAExDjB,SAAS,CAAC,MAAM;MACd,MAAM,CAACmB,SAAS,EAAEC,YAAY,CAAC,GAAGxB,gBAAgB,CAACe,KAAK,CAAC;MACzD,MAAMU,UAAU,GAAG9B,MAAM,CAAC+B,WAAW,CAACjB,KAAK,CAAC;MAC5C,MAAMkB,aAAa,GAAGlC,YAAY,CAACiC,WAAW,CAACjB,KAAK,CAAC;MAErD,OAAAmB,YAAA,CAAAjC,MAAA,EAAAkC,WAAA;QAAA,SAEW,CACL,YAAY,EACZpB,KAAK,CAACqB,KAAK;MACZ,GACIP,SAAS,EACTE,UAAU;QAAA,cACLR,KAAK,CAACN,KAAK;QAAA,uBAAAoB,MAAA,IAAXd,KAAK,CAACN,KAAK,GAAAoB,MAAA;QAAA,MAChBT,EAAE,CAACX,KAAK;QAAA,WACHO,SAAS,CAACP,KAAK;QAAA,SACjBF,KAAK,CAACuB;MAAK;QAGjB,GAAGhB,KAAK;QACRiB,OAAO,EAAEC,KAAA;UAAA,IAAC;YACRZ,EAAE;YACFa,UAAU;YACVC,UAAU;YACVC,UAAU;YACVC;UACF,CAAC,GAAAJ,KAAA;UAAA,OAAAN,YAAA,CAAAnC,YAAA,EAAAoC,WAAA,CAEQF,aAAa;YAAA,MACbL,EAAE,CAACX,KAAK;YAAA,oBACMwB,UAAU,CAACxB,KAAK;YAAA,YACxByB,UAAU,CAACzB,KAAK;YAAA,YAChB0B,UAAU,CAAC1B;UAAK,GACtBa,YAAY;YAAA,SACTc,OAAO,CAAC3B,KAAK,KAAK,KAAK;YAAA,cACrBM,KAAK,CAACN,KAAK;YAAA,uBAAAoB,MAAA,IAAXd,KAAK,CAACN,KAAK,GAAAoB,MAAA;YAAA,WACXZ,KAAK;YAAA,UACNC;UAAI,IACHJ,KAAK;QAAA;MAElB;IAIT,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC","ignoreList":[]}
@@ -1,4 +1,4 @@
1
- import { createVNode as _createVNode, mergeProps as _mergeProps, resolveDirective as _resolveDirective } from "vue";
1
+ import { mergeProps as _mergeProps, createVNode as _createVNode } from "vue";
2
2
  // Components
3
3
  import { makeVSelectionControlProps, VSelectionControl } from "../VSelectionControl/VSelectionControl.mjs"; // Composables
4
4
  import { IconValue } from "../../composables/icons.mjs";
@@ -128,7 +128,7 @@ type VInputSlots = {
128
128
 
129
129
  type VCheckboxSlots = Omit<VInputSlots, 'default'> & VSelectionControlSlots;
130
130
  declare const VCheckbox: {
131
- new (...args: any[]): vue.CreateComponentPublicInstance<{
131
+ new (...args: any[]): vue.CreateComponentPublicInstanceWithMixins<{
132
132
  error: boolean;
133
133
  direction: "horizontal" | "vertical";
134
134
  style: vue.StyleValue;
@@ -182,58 +182,7 @@ declare const VCheckbox: {
182
182
  }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<{
183
183
  'update:modelValue': (value: any) => true;
184
184
  'update:focused': (focused: boolean) => true;
185
- }, "$children" | "v-slots" | "v-slot:default" | "modelValue" | "v-slot:prepend" | "v-slot:append" | "update:modelValue" | "v-slot:input" | "v-slot:label" | "v-slot:message" | "v-slot:details">, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & {
186
- error: boolean;
187
- direction: "horizontal" | "vertical";
188
- style: vue.StyleValue;
189
- disabled: boolean | null;
190
- multiple: boolean | null;
191
- readonly: boolean | null;
192
- indeterminate: boolean;
193
- messages: string | readonly string[];
194
- focused: boolean;
195
- errorMessages: string | readonly string[] | null;
196
- maxErrors: string | number;
197
- rules: readonly ValidationRule[];
198
- density: Density;
199
- ripple: boolean | {
200
- class: string;
201
- } | undefined;
202
- falseIcon: IconValue;
203
- trueIcon: IconValue;
204
- valueComparator: typeof deepEqual;
205
- indeterminateIcon: IconValue;
206
- centerAffix: boolean;
207
- hideSpinButtons: boolean;
208
- persistentHint: boolean;
209
- } & {
210
- name?: string | undefined;
211
- type?: string | undefined;
212
- id?: string | undefined;
213
- width?: string | number | undefined;
214
- color?: string | undefined;
215
- maxWidth?: string | number | undefined;
216
- minWidth?: string | number | undefined;
217
- value?: any;
218
- label?: string | undefined;
219
- class?: any;
220
- theme?: string | undefined;
221
- 'onUpdate:focused'?: ((args_0: boolean) => void) | undefined;
222
- validateOn?: ("eager" | "lazy" | ("input" | "blur" | "submit" | "invalid-input") | "input lazy" | "blur lazy" | "submit lazy" | "invalid-input lazy" | "input eager" | "blur eager" | "submit eager" | "invalid-input eager" | "lazy input" | "lazy blur" | "lazy submit" | "lazy invalid-input" | "eager input" | "eager blur" | "eager submit" | "eager invalid-input") | undefined;
223
- validationValue?: any;
224
- baseColor?: string | undefined;
225
- prependIcon?: IconValue | undefined;
226
- appendIcon?: IconValue | undefined;
227
- defaultsTarget?: string | undefined;
228
- trueValue?: any;
229
- falseValue?: any;
230
- 'onClick:append'?: ((args_0: MouseEvent) => void) | undefined;
231
- 'onClick:prepend'?: ((args_0: MouseEvent) => void) | undefined;
232
- hint?: string | undefined;
233
- hideDetails?: boolean | "auto" | undefined;
234
- } & {
235
- "onUpdate:focused"?: ((focused: boolean) => any) | undefined;
236
- }, {
185
+ }, "$children" | "v-slots" | "v-slot:default" | "modelValue" | "v-slot:prepend" | "v-slot:append" | "update:modelValue" | "v-slot:input" | "v-slot:label" | "v-slot:message" | "v-slot:details">, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
237
186
  error: boolean;
238
187
  direction: "horizontal" | "vertical";
239
188
  style: vue.StyleValue;
@@ -271,7 +220,7 @@ declare const VCheckbox: {
271
220
  props: Record<string, unknown>;
272
221
  }) => vue.VNode[];
273
222
  input: (arg: SelectionControlSlot) => vue.VNode[];
274
- }>>, {
223
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, {}, any, vue.ComponentProvideOptions, {
275
224
  P: {};
276
225
  B: {};
277
226
  D: {};
@@ -449,7 +398,7 @@ declare const VCheckbox: {
449
398
  props: Record<string, unknown>;
450
399
  }) => vue.VNode[];
451
400
  input: (arg: SelectionControlSlot) => vue.VNode[];
452
- }>>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>(props: {
401
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, vue.ComponentProvideOptions> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>(props: {
453
402
  modelValue?: T | null;
454
403
  "onUpdate:modelValue"?: (value: T | null) => void;
455
404
  }, slots: VCheckboxSlots) => GenericProps<typeof props, typeof slots>) & FilterPropsOptions<{
@@ -650,7 +599,7 @@ declare const VCheckbox: {
650
599
  type VCheckbox = InstanceType<typeof VCheckbox>;
651
600
 
652
601
  declare const VCheckboxBtn: {
653
- new (...args: any[]): vue.CreateComponentPublicInstance<{
602
+ new (...args: any[]): vue.CreateComponentPublicInstanceWithMixins<{
654
603
  inline: boolean;
655
604
  error: boolean;
656
605
  style: vue.StyleValue;
@@ -684,38 +633,7 @@ declare const VCheckboxBtn: {
684
633
  }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<{
685
634
  'update:modelValue': (value: any) => true;
686
635
  'update:indeterminate': (value: boolean) => true;
687
- }, "$children" | "v-slots" | "v-slot:default" | "modelValue" | "update:modelValue" | "v-slot:input" | "v-slot:label">, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & {
688
- inline: boolean;
689
- error: boolean;
690
- style: vue.StyleValue;
691
- disabled: boolean | null;
692
- multiple: boolean | null;
693
- readonly: boolean | null;
694
- indeterminate: boolean;
695
- density: Density;
696
- ripple: boolean | {
697
- class: string;
698
- } | undefined;
699
- falseIcon: IconValue;
700
- trueIcon: IconValue;
701
- valueComparator: typeof deepEqual;
702
- indeterminateIcon: IconValue;
703
- } & {
704
- name?: string | undefined;
705
- type?: string | undefined;
706
- id?: string | undefined;
707
- color?: string | undefined;
708
- value?: any;
709
- label?: string | undefined;
710
- class?: any;
711
- theme?: string | undefined;
712
- baseColor?: string | undefined;
713
- defaultsTarget?: string | undefined;
714
- trueValue?: any;
715
- falseValue?: any;
716
- } & {
717
- "onUpdate:indeterminate"?: ((value: boolean) => any) | undefined;
718
- }, {
636
+ }, "$children" | "v-slots" | "v-slot:default" | "modelValue" | "update:modelValue" | "v-slot:input" | "v-slot:label">, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
719
637
  inline: boolean;
720
638
  error: boolean;
721
639
  style: vue.StyleValue;
@@ -741,7 +659,7 @@ declare const VCheckboxBtn: {
741
659
  props: Record<string, unknown>;
742
660
  }) => vue.VNode[];
743
661
  input: (arg: SelectionControlSlot) => vue.VNode[];
744
- }>>, {
662
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, {}, any, vue.ComponentProvideOptions, {
745
663
  P: {};
746
664
  B: {};
747
665
  D: {};
@@ -859,7 +777,7 @@ declare const VCheckboxBtn: {
859
777
  props: Record<string, unknown>;
860
778
  }) => vue.VNode[];
861
779
  input: (arg: SelectionControlSlot) => vue.VNode[];
862
- }>>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>(props: {
780
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, vue.ComponentProvideOptions> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>(props: {
863
781
  modelValue?: T;
864
782
  "onUpdate:modelValue"?: (value: T) => void;
865
783
  }, slots: VSelectionControlSlots) => GenericProps<typeof props, typeof slots>) & FilterPropsOptions<{
@@ -1,4 +1,4 @@
1
- import { mergeProps as _mergeProps, Fragment as _Fragment, withDirectives as _withDirectives, vShow as _vShow, resolveDirective as _resolveDirective, createVNode as _createVNode } from "vue";
1
+ import { createVNode as _createVNode, vShow as _vShow, withDirectives as _withDirectives, Fragment as _Fragment, mergeProps as _mergeProps, resolveDirective as _resolveDirective } from "vue";
2
2
  /* eslint-disable complexity */
3
3
  // Styles
4
4
  import "./VChip.css";
@@ -30,6 +30,7 @@ export const makeVChipProps = propsFactory({
30
30
  activeClass: String,
31
31
  appendAvatar: String,
32
32
  appendIcon: IconValue,
33
+ baseColor: String,
33
34
  closable: Boolean,
34
35
  closeIcon: {
35
36
  type: IconValue,
@@ -104,11 +105,6 @@ export const VChip = genericComponent()({
104
105
  const {
105
106
  borderClasses
106
107
  } = useBorder(props);
107
- const {
108
- colorClasses,
109
- colorStyles,
110
- variantClasses
111
- } = useVariant(props);
112
108
  const {
113
109
  densityClasses
114
110
  } = useDensity(props);
@@ -138,6 +134,18 @@ export const VChip = genericComponent()({
138
134
  emit('click:close', e);
139
135
  }
140
136
  }));
137
+ const variantProps = computed(() => {
138
+ const showColor = !group || group.isSelected.value;
139
+ return {
140
+ color: showColor ? props.color ?? props.baseColor : props.baseColor,
141
+ variant: props.variant
142
+ };
143
+ });
144
+ const {
145
+ colorClasses,
146
+ colorStyles,
147
+ variantClasses
148
+ } = useVariant(variantProps);
141
149
  function onClick(e) {
142
150
  emit('click', e);
143
151
  if (!isClickable.value) return;
@@ -158,7 +166,6 @@ export const VChip = genericComponent()({
158
166
  const hasFilter = !!(slots.filter || props.filter) && group;
159
167
  const hasPrependMedia = !!(props.prependIcon || props.prependAvatar);
160
168
  const hasPrepend = !!(hasPrependMedia || slots.prepend);
161
- const hasColor = !group || group.isSelected.value;
162
169
  return isActive.value && _withDirectives(_createVNode(Tag, _mergeProps({
163
170
  "class": ['v-chip', {
164
171
  'v-chip--disabled': props.disabled,
@@ -167,8 +174,8 @@ export const VChip = genericComponent()({
167
174
  'v-chip--filter': hasFilter,
168
175
  'v-chip--pill': props.pill,
169
176
  [`${props.activeClass}`]: props.activeClass && link.isActive?.value
170
- }, themeClasses.value, borderClasses.value, hasColor ? colorClasses.value : undefined, densityClasses.value, elevationClasses.value, roundedClasses.value, sizeClasses.value, variantClasses.value, group?.selectedClass.value, props.class],
171
- "style": [hasColor ? colorStyles.value : undefined, props.style],
177
+ }, themeClasses.value, borderClasses.value, colorClasses.value, densityClasses.value, elevationClasses.value, roundedClasses.value, sizeClasses.value, variantClasses.value, group?.selectedClass.value, props.class],
178
+ "style": [colorStyles.value, props.style],
172
179
  "disabled": props.disabled || undefined,
173
180
  "draggable": props.draggable,
174
181
  "tabindex": isClickable.value ? 0 : undefined,
@@ -1 +1 @@
1
- {"version":3,"file":"VChip.mjs","names":["VExpandXTransition","VAvatar","VChipGroupSymbol","VDefaultsProvider","VIcon","makeBorderProps","useBorder","makeComponentProps","makeDensityProps","useDensity","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","IconValue","useLocale","useProxiedModel","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","genOverlays","makeVariantProps","useVariant","Ripple","computed","EventProp","genericComponent","propsFactory","makeVChipProps","activeClass","String","appendAvatar","appendIcon","closable","Boolean","closeIcon","type","default","closeLabel","draggable","filter","filterIcon","label","link","undefined","pill","prependAvatar","prependIcon","ripple","Object","text","modelValue","onClick","onClickOnce","tag","variant","VChip","name","directives","props","emits","e","value","val","click","setup","_ref","attrs","emit","slots","t","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","elevationClasses","roundedClasses","sizeClasses","themeClasses","isActive","group","isLink","isClickable","disabled","closeProps","preventDefault","stopPropagation","navigate","toggle","onKeyDown","key","Tag","hasAppendMedia","hasAppend","append","hasClose","close","hasFilter","hasPrependMedia","hasPrepend","prepend","hasColor","isSelected","_withDirectives","_createVNode","_mergeProps","selectedClass","class","style","linkProps","icon","_vShow","_Fragment","image","start","select","end","size","_resolveDirective"],"sources":["../../../src/components/VChip/VChip.tsx"],"sourcesContent":["/* eslint-disable complexity */\n// Styles\nimport './VChip.sass'\n\n// Components\nimport { VExpandXTransition } from '@/components/transitions'\nimport { VAvatar } from '@/components/VAvatar'\nimport { VChipGroupSymbol } from '@/components/VChipGroup/VChipGroup'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeComponentProps } from '@/composables/component'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { IconValue } from '@/composables/icons'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Utilities\nimport { computed } from 'vue'\nimport { EventProp, genericComponent, propsFactory } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { RippleDirectiveBinding } from '@/directives/ripple'\n\nexport type VChipSlots = {\n default: {\n isSelected: boolean | undefined\n selectedClass: boolean | (string | undefined)[] | undefined\n select: ((value: boolean) => void) | undefined\n toggle: (() => void) | undefined\n value: unknown\n disabled: boolean\n }\n label: never\n prepend: never\n append: never\n close: never\n filter: never\n}\n\nexport const makeVChipProps = propsFactory({\n activeClass: String,\n appendAvatar: String,\n appendIcon: IconValue,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$delete',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n draggable: Boolean,\n filter: Boolean,\n filterIcon: {\n type: IconValue,\n default: '$complete',\n },\n label: Boolean,\n link: {\n type: Boolean,\n default: undefined,\n },\n pill: Boolean,\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: {\n type: [Boolean, Object] as PropType<RippleDirectiveBinding['value']>,\n default: true,\n },\n text: String,\n modelValue: {\n type: Boolean,\n default: true,\n },\n\n onClick: EventProp<[MouseEvent]>(),\n onClickOnce: EventProp<[MouseEvent]>(),\n\n ...makeBorderProps(),\n ...makeComponentProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'span' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChip')\n\nexport const VChip = genericComponent<VChipSlots>()({\n name: 'VChip',\n\n directives: { Ripple },\n\n props: makeVChipProps(),\n\n emits: {\n 'click:close': (e: MouseEvent) => true,\n 'update:modelValue': (value: boolean) => true,\n 'group:selected': (val: { value: boolean }) => true,\n click: (e: MouseEvent | KeyboardEvent) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses } = useSize(props)\n const { themeClasses } = provideTheme(props)\n\n const isActive = useProxiedModel(props, 'modelValue')\n const group = useGroupItem(props, VChipGroupSymbol, false)\n const link = useLink(props, attrs)\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (!!group || props.link || link.isClickable.value)\n )\n const closeProps = computed(() => ({\n 'aria-label': t(props.closeLabel),\n onClick (e: MouseEvent) {\n e.preventDefault()\n e.stopPropagation()\n\n isActive.value = false\n\n emit('click:close', e)\n },\n }))\n\n function onClick (e: MouseEvent) {\n emit('click', e)\n\n if (!isClickable.value) return\n\n link.navigate?.(e)\n group?.toggle()\n }\n\n function onKeyDown (e: KeyboardEvent) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onClick(e as any as MouseEvent)\n }\n }\n\n return () => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasAppendMedia = !!(props.appendIcon || props.appendAvatar)\n const hasAppend = !!(hasAppendMedia || slots.append)\n const hasClose = !!(slots.close || props.closable)\n const hasFilter = !!(slots.filter || props.filter) && group\n const hasPrependMedia = !!(props.prependIcon || props.prependAvatar)\n const hasPrepend = !!(hasPrependMedia || slots.prepend)\n const hasColor = !group || group.isSelected.value\n\n return isActive.value && (\n <Tag\n class={[\n 'v-chip',\n {\n 'v-chip--disabled': props.disabled,\n 'v-chip--label': props.label,\n 'v-chip--link': isClickable.value,\n 'v-chip--filter': hasFilter,\n 'v-chip--pill': props.pill,\n [`${props.activeClass}`]: props.activeClass && link.isActive?.value,\n },\n themeClasses.value,\n borderClasses.value,\n hasColor ? colorClasses.value : undefined,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n group?.selectedClass.value,\n props.class,\n ]}\n style={[\n hasColor ? colorStyles.value : undefined,\n props.style,\n ]}\n disabled={ props.disabled || undefined }\n draggable={ props.draggable }\n tabindex={ isClickable.value ? 0 : undefined }\n onClick={ onClick }\n onKeydown={ isClickable.value && !isLink.value && onKeyDown }\n v-ripple={[isClickable.value && props.ripple, null]}\n { ...link.linkProps }\n >\n { genOverlays(isClickable.value, 'v-chip') }\n\n { hasFilter && (\n <VExpandXTransition key=\"filter\">\n <div\n class=\"v-chip__filter\"\n v-show={ group.isSelected.value }\n >\n { !slots.filter ? (\n <VIcon\n key=\"filter-icon\"\n icon={ props.filterIcon }\n />\n ) : (\n <VDefaultsProvider\n key=\"filter-defaults\"\n disabled={ !props.filterIcon }\n defaults={{\n VIcon: { icon: props.filterIcon },\n }}\n v-slots:default={ slots.filter }\n />\n )}\n </div>\n </VExpandXTransition>\n )}\n\n { hasPrepend && (\n <div key=\"prepend\" class=\"v-chip__prepend\">\n { !slots.prepend ? (\n <>\n { props.prependIcon && (\n <VIcon\n key=\"prepend-icon\"\n icon={ props.prependIcon }\n start\n />\n )}\n\n { props.prependAvatar && (\n <VAvatar\n key=\"prepend-avatar\"\n image={ props.prependAvatar }\n start\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"prepend-defaults\"\n disabled={ !hasPrependMedia }\n defaults={{\n VAvatar: {\n image: props.prependAvatar,\n start: true,\n },\n VIcon: {\n icon: props.prependIcon,\n start: true,\n },\n }}\n v-slots:default={ slots.prepend }\n />\n )}\n </div>\n )}\n\n <div class=\"v-chip__content\" data-no-activator=\"\">\n { slots.default?.({\n isSelected: group?.isSelected.value,\n selectedClass: group?.selectedClass.value,\n select: group?.select,\n toggle: group?.toggle,\n value: group?.value.value,\n disabled: props.disabled,\n }) ?? props.text }\n </div>\n\n { hasAppend && (\n <div key=\"append\" class=\"v-chip__append\">\n { !slots.append ? (\n <>\n { props.appendIcon && (\n <VIcon\n key=\"append-icon\"\n end\n icon={ props.appendIcon }\n />\n )}\n\n { props.appendAvatar && (\n <VAvatar\n key=\"append-avatar\"\n end\n image={ props.appendAvatar }\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"append-defaults\"\n disabled={ !hasAppendMedia }\n defaults={{\n VAvatar: {\n end: true,\n image: props.appendAvatar,\n },\n VIcon: {\n end: true,\n icon: props.appendIcon,\n },\n }}\n v-slots:default={ slots.append }\n />\n )}\n </div>\n )}\n\n { hasClose && (\n <button\n key=\"close\"\n class=\"v-chip__close\"\n type=\"button\"\n data-testid=\"close-chip\"\n { ...closeProps.value }\n >\n { !slots.close ? (\n <VIcon\n key=\"close-icon\"\n icon={ props.closeIcon }\n size=\"x-small\"\n />\n ) : (\n <VDefaultsProvider\n key=\"close-defaults\"\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'x-small',\n },\n }}\n v-slots:default={ slots.close }\n />\n )}\n </button>\n )}\n </Tag>\n )\n }\n },\n})\n\nexport type VChip = InstanceType<typeof VChip>\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"VChip.mjs","names":["VExpandXTransition","VAvatar","VChipGroupSymbol","VDefaultsProvider","VIcon","makeBorderProps","useBorder","makeComponentProps","makeDensityProps","useDensity","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","IconValue","useLocale","useProxiedModel","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","genOverlays","makeVariantProps","useVariant","Ripple","computed","EventProp","genericComponent","propsFactory","makeVChipProps","activeClass","String","appendAvatar","appendIcon","baseColor","closable","Boolean","closeIcon","type","default","closeLabel","draggable","filter","filterIcon","label","link","undefined","pill","prependAvatar","prependIcon","ripple","Object","text","modelValue","onClick","onClickOnce","tag","variant","VChip","name","directives","props","emits","e","value","val","click","setup","_ref","attrs","emit","slots","t","borderClasses","densityClasses","elevationClasses","roundedClasses","sizeClasses","themeClasses","isActive","group","isLink","isClickable","disabled","closeProps","preventDefault","stopPropagation","variantProps","showColor","isSelected","color","colorClasses","colorStyles","variantClasses","navigate","toggle","onKeyDown","key","Tag","hasAppendMedia","hasAppend","append","hasClose","close","hasFilter","hasPrependMedia","hasPrepend","prepend","_withDirectives","_createVNode","_mergeProps","selectedClass","class","style","linkProps","icon","_vShow","_Fragment","image","start","select","end","size","_resolveDirective"],"sources":["../../../src/components/VChip/VChip.tsx"],"sourcesContent":["/* eslint-disable complexity */\n// Styles\nimport './VChip.sass'\n\n// Components\nimport { VExpandXTransition } from '@/components/transitions'\nimport { VAvatar } from '@/components/VAvatar'\nimport { VChipGroupSymbol } from '@/components/VChipGroup/VChipGroup'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeComponentProps } from '@/composables/component'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { IconValue } from '@/composables/icons'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Utilities\nimport { computed } from 'vue'\nimport { EventProp, genericComponent, propsFactory } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { RippleDirectiveBinding } from '@/directives/ripple'\n\nexport type VChipSlots = {\n default: {\n isSelected: boolean | undefined\n selectedClass: boolean | (string | undefined)[] | undefined\n select: ((value: boolean) => void) | undefined\n toggle: (() => void) | undefined\n value: unknown\n disabled: boolean\n }\n label: never\n prepend: never\n append: never\n close: never\n filter: never\n}\n\nexport const makeVChipProps = propsFactory({\n activeClass: String,\n appendAvatar: String,\n appendIcon: IconValue,\n baseColor: String,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$delete',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n draggable: Boolean,\n filter: Boolean,\n filterIcon: {\n type: IconValue,\n default: '$complete',\n },\n label: Boolean,\n link: {\n type: Boolean,\n default: undefined,\n },\n pill: Boolean,\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: {\n type: [Boolean, Object] as PropType<RippleDirectiveBinding['value']>,\n default: true,\n },\n text: String,\n modelValue: {\n type: Boolean,\n default: true,\n },\n\n onClick: EventProp<[MouseEvent]>(),\n onClickOnce: EventProp<[MouseEvent]>(),\n\n ...makeBorderProps(),\n ...makeComponentProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'span' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChip')\n\nexport const VChip = genericComponent<VChipSlots>()({\n name: 'VChip',\n\n directives: { Ripple },\n\n props: makeVChipProps(),\n\n emits: {\n 'click:close': (e: MouseEvent) => true,\n 'update:modelValue': (value: boolean) => true,\n 'group:selected': (val: { value: boolean }) => true,\n click: (e: MouseEvent | KeyboardEvent) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const { borderClasses } = useBorder(props)\n const { densityClasses } = useDensity(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses } = useSize(props)\n const { themeClasses } = provideTheme(props)\n\n const isActive = useProxiedModel(props, 'modelValue')\n const group = useGroupItem(props, VChipGroupSymbol, false)\n const link = useLink(props, attrs)\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (!!group || props.link || link.isClickable.value)\n )\n const closeProps = computed(() => ({\n 'aria-label': t(props.closeLabel),\n onClick (e: MouseEvent) {\n e.preventDefault()\n e.stopPropagation()\n\n isActive.value = false\n\n emit('click:close', e)\n },\n }))\n\n const variantProps = computed(() => {\n const showColor = !group || group.isSelected.value\n return ({\n color: showColor ? props.color ?? props.baseColor : props.baseColor,\n variant: props.variant,\n })\n })\n const { colorClasses, colorStyles, variantClasses } = useVariant(variantProps)\n\n function onClick (e: MouseEvent) {\n emit('click', e)\n\n if (!isClickable.value) return\n\n link.navigate?.(e)\n group?.toggle()\n }\n\n function onKeyDown (e: KeyboardEvent) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onClick(e as any as MouseEvent)\n }\n }\n\n return () => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasAppendMedia = !!(props.appendIcon || props.appendAvatar)\n const hasAppend = !!(hasAppendMedia || slots.append)\n const hasClose = !!(slots.close || props.closable)\n const hasFilter = !!(slots.filter || props.filter) && group\n const hasPrependMedia = !!(props.prependIcon || props.prependAvatar)\n const hasPrepend = !!(hasPrependMedia || slots.prepend)\n\n return isActive.value && (\n <Tag\n class={[\n 'v-chip',\n {\n 'v-chip--disabled': props.disabled,\n 'v-chip--label': props.label,\n 'v-chip--link': isClickable.value,\n 'v-chip--filter': hasFilter,\n 'v-chip--pill': props.pill,\n [`${props.activeClass}`]: props.activeClass && link.isActive?.value,\n },\n themeClasses.value,\n borderClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n group?.selectedClass.value,\n props.class,\n ]}\n style={[\n colorStyles.value,\n props.style,\n ]}\n disabled={ props.disabled || undefined }\n draggable={ props.draggable }\n tabindex={ isClickable.value ? 0 : undefined }\n onClick={ onClick }\n onKeydown={ isClickable.value && !isLink.value && onKeyDown }\n v-ripple={[isClickable.value && props.ripple, null]}\n { ...link.linkProps }\n >\n { genOverlays(isClickable.value, 'v-chip') }\n\n { hasFilter && (\n <VExpandXTransition key=\"filter\">\n <div\n class=\"v-chip__filter\"\n v-show={ group.isSelected.value }\n >\n { !slots.filter ? (\n <VIcon\n key=\"filter-icon\"\n icon={ props.filterIcon }\n />\n ) : (\n <VDefaultsProvider\n key=\"filter-defaults\"\n disabled={ !props.filterIcon }\n defaults={{\n VIcon: { icon: props.filterIcon },\n }}\n v-slots:default={ slots.filter }\n />\n )}\n </div>\n </VExpandXTransition>\n )}\n\n { hasPrepend && (\n <div key=\"prepend\" class=\"v-chip__prepend\">\n { !slots.prepend ? (\n <>\n { props.prependIcon && (\n <VIcon\n key=\"prepend-icon\"\n icon={ props.prependIcon }\n start\n />\n )}\n\n { props.prependAvatar && (\n <VAvatar\n key=\"prepend-avatar\"\n image={ props.prependAvatar }\n start\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"prepend-defaults\"\n disabled={ !hasPrependMedia }\n defaults={{\n VAvatar: {\n image: props.prependAvatar,\n start: true,\n },\n VIcon: {\n icon: props.prependIcon,\n start: true,\n },\n }}\n v-slots:default={ slots.prepend }\n />\n )}\n </div>\n )}\n\n <div class=\"v-chip__content\" data-no-activator=\"\">\n { slots.default?.({\n isSelected: group?.isSelected.value,\n selectedClass: group?.selectedClass.value,\n select: group?.select,\n toggle: group?.toggle,\n value: group?.value.value,\n disabled: props.disabled,\n }) ?? props.text }\n </div>\n\n { hasAppend && (\n <div key=\"append\" class=\"v-chip__append\">\n { !slots.append ? (\n <>\n { props.appendIcon && (\n <VIcon\n key=\"append-icon\"\n end\n icon={ props.appendIcon }\n />\n )}\n\n { props.appendAvatar && (\n <VAvatar\n key=\"append-avatar\"\n end\n image={ props.appendAvatar }\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"append-defaults\"\n disabled={ !hasAppendMedia }\n defaults={{\n VAvatar: {\n end: true,\n image: props.appendAvatar,\n },\n VIcon: {\n end: true,\n icon: props.appendIcon,\n },\n }}\n v-slots:default={ slots.append }\n />\n )}\n </div>\n )}\n\n { hasClose && (\n <button\n key=\"close\"\n class=\"v-chip__close\"\n type=\"button\"\n data-testid=\"close-chip\"\n { ...closeProps.value }\n >\n { !slots.close ? (\n <VIcon\n key=\"close-icon\"\n icon={ props.closeIcon }\n size=\"x-small\"\n />\n ) : (\n <VDefaultsProvider\n key=\"close-defaults\"\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'x-small',\n },\n }}\n v-slots:default={ slots.close }\n />\n )}\n </button>\n )}\n </Tag>\n )\n }\n },\n})\n\nexport type VChip = InstanceType<typeof VChip>\n"],"mappings":"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","ignoreList":[]}
@@ -32,7 +32,7 @@ interface RippleDirectiveBinding extends Omit<DirectiveBinding, 'modifiers' | 'v
32
32
  }
33
33
 
34
34
  declare const VChip: {
35
- new (...args: any[]): vue.CreateComponentPublicInstance<{
35
+ new (...args: any[]): vue.CreateComponentPublicInstanceWithMixins<{
36
36
  replace: boolean;
37
37
  filter: boolean;
38
38
  variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
@@ -68,6 +68,7 @@ declare const VChip: {
68
68
  href?: string | undefined;
69
69
  elevation?: string | number | undefined;
70
70
  rounded?: string | number | boolean | undefined;
71
+ baseColor?: string | undefined;
71
72
  selectedClass?: string | undefined;
72
73
  prependIcon?: IconValue | undefined;
73
74
  appendIcon?: IconValue | undefined;
@@ -140,108 +141,7 @@ declare const VChip: {
140
141
  value: boolean;
141
142
  }) => true;
142
143
  click: (e: MouseEvent | KeyboardEvent) => true;
143
- }, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & {
144
- replace: boolean;
145
- filter: boolean;
146
- variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
147
- exact: boolean;
148
- label: boolean;
149
- style: vue.StyleValue;
150
- draggable: boolean;
151
- disabled: boolean;
152
- size: string | number;
153
- tag: string;
154
- modelValue: boolean;
155
- tile: boolean;
156
- density: Density;
157
- ripple: boolean | {
158
- class: string;
159
- } | undefined;
160
- closable: boolean;
161
- closeIcon: IconValue;
162
- closeLabel: string;
163
- filterIcon: IconValue;
164
- pill: boolean;
165
- } & {
166
- link?: boolean | undefined;
167
- border?: string | number | boolean | undefined;
168
- color?: string | undefined;
169
- value?: any;
170
- text?: string | undefined;
171
- class?: any;
172
- theme?: string | undefined;
173
- to?: vue_router.RouteLocationRaw | undefined;
174
- onClick?: ((args_0: MouseEvent) => void) | undefined;
175
- onClickOnce?: ((args_0: MouseEvent) => void) | undefined;
176
- href?: string | undefined;
177
- elevation?: string | number | undefined;
178
- rounded?: string | number | boolean | undefined;
179
- selectedClass?: string | undefined;
180
- prependIcon?: IconValue | undefined;
181
- appendIcon?: IconValue | undefined;
182
- activeClass?: string | undefined;
183
- appendAvatar?: string | undefined;
184
- prependAvatar?: string | undefined;
185
- } & {
186
- $children?: vue.VNodeChild | {
187
- default?: ((arg: {
188
- isSelected: boolean | undefined;
189
- selectedClass: boolean | (string | undefined)[] | undefined;
190
- select: ((value: boolean) => void) | undefined;
191
- toggle: (() => void) | undefined;
192
- value: unknown;
193
- disabled: boolean;
194
- }) => vue.VNodeChild) | undefined;
195
- label?: (() => vue.VNodeChild) | undefined;
196
- prepend?: (() => vue.VNodeChild) | undefined;
197
- append?: (() => vue.VNodeChild) | undefined;
198
- close?: (() => vue.VNodeChild) | undefined;
199
- filter?: (() => vue.VNodeChild) | undefined;
200
- } | ((arg: {
201
- isSelected: boolean | undefined;
202
- selectedClass: boolean | (string | undefined)[] | undefined;
203
- select: ((value: boolean) => void) | undefined;
204
- toggle: (() => void) | undefined;
205
- value: unknown;
206
- disabled: boolean;
207
- }) => vue.VNodeChild);
208
- 'v-slots'?: {
209
- default?: false | ((arg: {
210
- isSelected: boolean | undefined;
211
- selectedClass: boolean | (string | undefined)[] | undefined;
212
- select: ((value: boolean) => void) | undefined;
213
- toggle: (() => void) | undefined;
214
- value: unknown;
215
- disabled: boolean;
216
- }) => vue.VNodeChild) | undefined;
217
- label?: false | (() => vue.VNodeChild) | undefined;
218
- prepend?: false | (() => vue.VNodeChild) | undefined;
219
- append?: false | (() => vue.VNodeChild) | undefined;
220
- close?: false | (() => vue.VNodeChild) | undefined;
221
- filter?: false | (() => vue.VNodeChild) | undefined;
222
- } | undefined;
223
- } & {
224
- "v-slot:default"?: false | ((arg: {
225
- isSelected: boolean | undefined;
226
- selectedClass: boolean | (string | undefined)[] | undefined;
227
- select: ((value: boolean) => void) | undefined;
228
- toggle: (() => void) | undefined;
229
- value: unknown;
230
- disabled: boolean;
231
- }) => vue.VNodeChild) | undefined;
232
- "v-slot:label"?: false | (() => vue.VNodeChild) | undefined;
233
- "v-slot:prepend"?: false | (() => vue.VNodeChild) | undefined;
234
- "v-slot:append"?: false | (() => vue.VNodeChild) | undefined;
235
- "v-slot:close"?: false | (() => vue.VNodeChild) | undefined;
236
- "v-slot:filter"?: false | (() => vue.VNodeChild) | undefined;
237
- } & {
238
- onClick?: ((e: MouseEvent | KeyboardEvent) => any) | undefined;
239
- "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
240
- "onGroup:selected"?: ((val: {
241
- value: boolean;
242
- }) => any) | undefined;
243
- "onClick:close"?: ((e: MouseEvent) => any) | undefined;
244
- }, {
144
+ }, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
245
145
  replace: boolean;
246
146
  link: boolean;
247
147
  filter: boolean;
@@ -279,7 +179,7 @@ declare const VChip: {
279
179
  append: () => vue.VNode[];
280
180
  close: () => vue.VNode[];
281
181
  filter: () => vue.VNode[];
282
- }>>, {
182
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, {}, any, vue.ComponentProvideOptions, {
283
183
  P: {};
284
184
  B: {};
285
185
  D: {};
@@ -322,6 +222,7 @@ declare const VChip: {
322
222
  href?: string | undefined;
323
223
  elevation?: string | number | undefined;
324
224
  rounded?: string | number | boolean | undefined;
225
+ baseColor?: string | undefined;
325
226
  selectedClass?: string | undefined;
326
227
  prependIcon?: IconValue | undefined;
327
228
  appendIcon?: IconValue | undefined;
@@ -451,6 +352,7 @@ declare const VChip: {
451
352
  href?: string | undefined;
452
353
  elevation?: string | number | undefined;
453
354
  rounded?: string | number | boolean | undefined;
355
+ baseColor?: string | undefined;
454
356
  selectedClass?: string | undefined;
455
357
  prependIcon?: IconValue | undefined;
456
358
  appendIcon?: IconValue | undefined;
@@ -561,7 +463,7 @@ declare const VChip: {
561
463
  append: () => vue.VNode[];
562
464
  close: () => vue.VNode[];
563
465
  filter: () => vue.VNode[];
564
- }>>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
466
+ }>>, vue.GlobalComponents, vue.GlobalDirectives, string, vue.ComponentProvideOptions> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
565
467
  color: StringConstructor;
566
468
  variant: Omit<{
567
469
  type: PropType<Variant>;
@@ -613,6 +515,7 @@ declare const VChip: {
613
515
  activeClass: StringConstructor;
614
516
  appendAvatar: StringConstructor;
615
517
  appendIcon: PropType<IconValue>;
518
+ baseColor: StringConstructor;
616
519
  closable: BooleanConstructor;
617
520
  closeIcon: {
618
521
  type: PropType<IconValue>;
@@ -699,6 +602,7 @@ declare const VChip: {
699
602
  activeClass: StringConstructor;
700
603
  appendAvatar: StringConstructor;
701
604
  appendIcon: PropType<IconValue>;
605
+ baseColor: StringConstructor;
702
606
  closable: BooleanConstructor;
703
607
  closeIcon: {
704
608
  type: PropType<IconValue>;
@@ -1,4 +1,4 @@
1
- import { createVNode as _createVNode, mergeProps as _mergeProps } from "vue";
1
+ import { mergeProps as _mergeProps, createVNode as _createVNode } from "vue";
2
2
  // Styles
3
3
  import "./VChipGroup.css";
4
4
 
@@ -14,6 +14,7 @@ import { toRef } from 'vue';
14
14
  import { deepEqual, genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
15
15
  export const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group');
16
16
  export const makeVChipGroupProps = propsFactory({
17
+ baseColor: String,
17
18
  column: Boolean,
18
19
  filter: Boolean,
19
20
  valueComparator: {
@@ -53,6 +54,7 @@ export const VChipGroup = genericComponent()({
53
54
  } = useGroup(props, VChipGroupSymbol);
54
55
  provideDefaults({
55
56
  VChip: {
57
+ baseColor: toRef(props, 'baseColor'),
56
58
  color: toRef(props, 'color'),
57
59
  disabled: toRef(props, 'disabled'),
58
60
  filter: toRef(props, 'filter'),
@@ -1 +1 @@
1
- {"version":3,"file":"VChipGroup.mjs","names":["makeVSlideGroupProps","VSlideGroup","makeComponentProps","provideDefaults","makeGroupProps","useGroup","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","toRef","deepEqual","genericComponent","propsFactory","useRender","VChipGroupSymbol","Symbol","for","makeVChipGroupProps","column","Boolean","filter","valueComparator","type","Function","default","selectedClass","variant","VChipGroup","name","props","emits","value","setup","_ref","slots","themeClasses","isSelected","select","next","prev","selected","VChip","color","disabled","slideGroupProps","filterProps","_createVNode","_mergeProps","class","style"],"sources":["../../../src/components/VChipGroup/VChipGroup.tsx"],"sourcesContent":["// Styles\nimport './VChipGroup.sass'\n\n// Components\nimport { makeVSlideGroupProps, VSlideGroup } from '@/components/VSlideGroup/VSlideGroup'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { provideDefaults } from '@/composables/defaults'\nimport { makeGroupProps, useGroup } from '@/composables/group'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\n\n// Utilities\nimport { toRef } from 'vue'\nimport { deepEqual, genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { GenericProps } from '@/util'\n\nexport const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group')\n\nexport const makeVChipGroupProps = propsFactory({\n column: Boolean,\n filter: Boolean,\n valueComparator: {\n type: Function as PropType<typeof deepEqual>,\n default: deepEqual,\n },\n\n ...makeVSlideGroupProps(),\n ...makeComponentProps(),\n ...makeGroupProps({ selectedClass: 'v-chip--selected' }),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChipGroup')\n\ntype VChipGroupSlots = {\n default: {\n isSelected: (id: number) => boolean\n select: (id: number, value: boolean) => void\n next: () => void\n prev: () => void\n selected: readonly number[]\n }\n}\n\nexport const VChipGroup = genericComponent<new <T>(\n props: {\n modelValue?: T\n 'onUpdate:modelValue'?: (value: T) => void\n },\n slots: VChipGroupSlots,\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VChipGroup',\n\n props: makeVChipGroupProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { isSelected, select, next, prev, selected } = useGroup(props, VChipGroupSymbol)\n\n provideDefaults({\n VChip: {\n color: toRef(props, 'color'),\n disabled: toRef(props, 'disabled'),\n filter: toRef(props, 'filter'),\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => {\n const slideGroupProps = VSlideGroup.filterProps(props)\n\n return (\n <VSlideGroup\n { ...slideGroupProps }\n class={[\n 'v-chip-group',\n {\n 'v-chip-group--column': props.column,\n },\n themeClasses.value,\n props.class,\n ]}\n style={ props.style }\n >\n { slots.default?.({\n isSelected,\n select,\n next,\n prev,\n selected: selected.value,\n })}\n </VSlideGroup>\n )\n })\n\n return {}\n },\n})\n\nexport type VChipGroup = InstanceType<typeof VChipGroup>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,oBAAoB,EAAEC,WAAW,0CAE1C;AAAA,SACSC,kBAAkB;AAAA,SAClBC,eAAe;AAAA,SACfC,cAAc,EAAEC,QAAQ;AAAA,SACxBC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB,yCAEzB;AACA,SAASC,KAAK,QAAQ,KAAK;AAAA,SAClBC,SAAS,EAAEC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS,gCAE7D;AAIA,OAAO,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAElE,OAAO,MAAMC,mBAAmB,GAAGL,YAAY,CAAC;EAC9CM,MAAM,EAAEC,OAAO;EACfC,MAAM,EAAED,OAAO;EACfE,eAAe,EAAE;IACfC,IAAI,EAAEC,QAAsC;IAC5CC,OAAO,EAAEd;EACX,CAAC;EAED,GAAGX,oBAAoB,CAAC,CAAC;EACzB,GAAGE,kBAAkB,CAAC,CAAC;EACvB,GAAGE,cAAc,CAAC;IAAEsB,aAAa,EAAE;EAAmB,CAAC,CAAC;EACxD,GAAGpB,YAAY,CAAC,CAAC;EACjB,GAAGC,cAAc,CAAC,CAAC;EACnB,GAAGE,gBAAgB,CAAC;IAAEkB,OAAO,EAAE;EAAQ,CAAU;AACnD,CAAC,EAAE,YAAY,CAAC;AAYhB,OAAO,MAAMC,UAAU,GAAGhB,gBAAgB,CAMK,CAAC,CAAC;EAC/CiB,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAEZ,mBAAmB,CAAC,CAAC;EAE5Ba,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAKA,CAAEH,KAAK,EAAAI,IAAA,EAAa;IAAA,IAAX;MAAEC;IAAM,CAAC,GAAAD,IAAA;IACrB,MAAM;MAAEE;IAAa,CAAC,GAAG5B,YAAY,CAACsB,KAAK,CAAC;IAC5C,MAAM;MAAEO,UAAU;MAAEC,MAAM;MAAEC,IAAI;MAAEC,IAAI;MAAEC;IAAS,CAAC,GAAGpC,QAAQ,CAACyB,KAAK,EAAEf,gBAAgB,CAAC;IAEtFZ,eAAe,CAAC;MACduC,KAAK,EAAE;QACLC,KAAK,EAAEjC,KAAK,CAACoB,KAAK,EAAE,OAAO,CAAC;QAC5Bc,QAAQ,EAAElC,KAAK,CAACoB,KAAK,EAAE,UAAU,CAAC;QAClCT,MAAM,EAAEX,KAAK,CAACoB,KAAK,EAAE,QAAQ,CAAC;QAC9BH,OAAO,EAAEjB,KAAK,CAACoB,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFhB,SAAS,CAAC,MAAM;MACd,MAAM+B,eAAe,GAAG5C,WAAW,CAAC6C,WAAW,CAAChB,KAAK,CAAC;MAEtD,OAAAiB,YAAA,CAAA9C,WAAA,EAAA+C,WAAA,CAESH,eAAe;QAAA,SACb,CACL,cAAc,EACd;UACE,sBAAsB,EAAEf,KAAK,CAACX;QAChC,CAAC,EACDiB,YAAY,CAACJ,KAAK,EAClBF,KAAK,CAACmB,KAAK,CACZ;QAAA,SACOnB,KAAK,CAACoB;MAAK;QAAAzB,OAAA,EAAAA,CAAA,MAEjBU,KAAK,CAACV,OAAO,GAAG;UAChBY,UAAU;UACVC,MAAM;UACNC,IAAI;UACJC,IAAI;UACJC,QAAQ,EAAEA,QAAQ,CAACT;QACrB,CAAC,CAAC;MAAA;IAGR,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"VChipGroup.mjs","names":["makeVSlideGroupProps","VSlideGroup","makeComponentProps","provideDefaults","makeGroupProps","useGroup","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","toRef","deepEqual","genericComponent","propsFactory","useRender","VChipGroupSymbol","Symbol","for","makeVChipGroupProps","baseColor","String","column","Boolean","filter","valueComparator","type","Function","default","selectedClass","variant","VChipGroup","name","props","emits","value","setup","_ref","slots","themeClasses","isSelected","select","next","prev","selected","VChip","color","disabled","slideGroupProps","filterProps","_createVNode","_mergeProps","class","style"],"sources":["../../../src/components/VChipGroup/VChipGroup.tsx"],"sourcesContent":["// Styles\nimport './VChipGroup.sass'\n\n// Components\nimport { makeVSlideGroupProps, VSlideGroup } from '@/components/VSlideGroup/VSlideGroup'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { provideDefaults } from '@/composables/defaults'\nimport { makeGroupProps, useGroup } from '@/composables/group'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\n\n// Utilities\nimport { toRef } from 'vue'\nimport { deepEqual, genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { GenericProps } from '@/util'\n\nexport const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group')\n\nexport const makeVChipGroupProps = propsFactory({\n baseColor: String,\n column: Boolean,\n filter: Boolean,\n valueComparator: {\n type: Function as PropType<typeof deepEqual>,\n default: deepEqual,\n },\n\n ...makeVSlideGroupProps(),\n ...makeComponentProps(),\n ...makeGroupProps({ selectedClass: 'v-chip--selected' }),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChipGroup')\n\ntype VChipGroupSlots = {\n default: {\n isSelected: (id: string) => boolean\n select: (id: string, value: boolean) => void\n next: () => void\n prev: () => void\n selected: readonly string[]\n }\n}\n\nexport const VChipGroup = genericComponent<new <T>(\n props: {\n modelValue?: T\n 'onUpdate:modelValue'?: (value: T) => void\n },\n slots: VChipGroupSlots,\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VChipGroup',\n\n props: makeVChipGroupProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { isSelected, select, next, prev, selected } = useGroup(props, VChipGroupSymbol)\n\n provideDefaults({\n VChip: {\n baseColor: toRef(props, 'baseColor'),\n color: toRef(props, 'color'),\n disabled: toRef(props, 'disabled'),\n filter: toRef(props, 'filter'),\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => {\n const slideGroupProps = VSlideGroup.filterProps(props)\n\n return (\n <VSlideGroup\n { ...slideGroupProps }\n class={[\n 'v-chip-group',\n {\n 'v-chip-group--column': props.column,\n },\n themeClasses.value,\n props.class,\n ]}\n style={ props.style }\n >\n { slots.default?.({\n isSelected,\n select,\n next,\n prev,\n selected: selected.value,\n })}\n </VSlideGroup>\n )\n })\n\n return {}\n },\n})\n\nexport type VChipGroup = InstanceType<typeof VChipGroup>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,oBAAoB,EAAEC,WAAW,0CAE1C;AAAA,SACSC,kBAAkB;AAAA,SAClBC,eAAe;AAAA,SACfC,cAAc,EAAEC,QAAQ;AAAA,SACxBC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB,yCAEzB;AACA,SAASC,KAAK,QAAQ,KAAK;AAAA,SAClBC,SAAS,EAAEC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS,gCAE7D;AAIA,OAAO,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAElE,OAAO,MAAMC,mBAAmB,GAAGL,YAAY,CAAC;EAC9CM,SAAS,EAAEC,MAAM;EACjBC,MAAM,EAAEC,OAAO;EACfC,MAAM,EAAED,OAAO;EACfE,eAAe,EAAE;IACfC,IAAI,EAAEC,QAAsC;IAC5CC,OAAO,EAAEhB;EACX,CAAC;EAED,GAAGX,oBAAoB,CAAC,CAAC;EACzB,GAAGE,kBAAkB,CAAC,CAAC;EACvB,GAAGE,cAAc,CAAC;IAAEwB,aAAa,EAAE;EAAmB,CAAC,CAAC;EACxD,GAAGtB,YAAY,CAAC,CAAC;EACjB,GAAGC,cAAc,CAAC,CAAC;EACnB,GAAGE,gBAAgB,CAAC;IAAEoB,OAAO,EAAE;EAAQ,CAAU;AACnD,CAAC,EAAE,YAAY,CAAC;AAYhB,OAAO,MAAMC,UAAU,GAAGlB,gBAAgB,CAMK,CAAC,CAAC;EAC/CmB,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAEd,mBAAmB,CAAC,CAAC;EAE5Be,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAKA,CAAEH,KAAK,EAAAI,IAAA,EAAa;IAAA,IAAX;MAAEC;IAAM,CAAC,GAAAD,IAAA;IACrB,MAAM;MAAEE;IAAa,CAAC,GAAG9B,YAAY,CAACwB,KAAK,CAAC;IAC5C,MAAM;MAAEO,UAAU;MAAEC,MAAM;MAAEC,IAAI;MAAEC,IAAI;MAAEC;IAAS,CAAC,GAAGtC,QAAQ,CAAC2B,KAAK,EAAEjB,gBAAgB,CAAC;IAEtFZ,eAAe,CAAC;MACdyC,KAAK,EAAE;QACLzB,SAAS,EAAET,KAAK,CAACsB,KAAK,EAAE,WAAW,CAAC;QACpCa,KAAK,EAAEnC,KAAK,CAACsB,KAAK,EAAE,OAAO,CAAC;QAC5Bc,QAAQ,EAAEpC,KAAK,CAACsB,KAAK,EAAE,UAAU,CAAC;QAClCT,MAAM,EAAEb,KAAK,CAACsB,KAAK,EAAE,QAAQ,CAAC;QAC9BH,OAAO,EAAEnB,KAAK,CAACsB,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFlB,SAAS,CAAC,MAAM;MACd,MAAMiC,eAAe,GAAG9C,WAAW,CAAC+C,WAAW,CAAChB,KAAK,CAAC;MAEtD,OAAAiB,YAAA,CAAAhD,WAAA,EAAAiD,WAAA,CAESH,eAAe;QAAA,SACb,CACL,cAAc,EACd;UACE,sBAAsB,EAAEf,KAAK,CAACX;QAChC,CAAC,EACDiB,YAAY,CAACJ,KAAK,EAClBF,KAAK,CAACmB,KAAK,CACZ;QAAA,SACOnB,KAAK,CAACoB;MAAK;QAAAzB,OAAA,EAAAA,CAAA,MAEjBU,KAAK,CAACV,OAAO,GAAG;UAChBY,UAAU;UACVC,MAAM;UACNC,IAAI;UACJC,IAAI;UACJC,QAAQ,EAAEA,QAAQ,CAACT;QACrB,CAAC,CAAC;MAAA;IAGR,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC","ignoreList":[]}