@dimailn/vuetify 2.7.2-alpha31 → 2.7.2-alpha33

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 (302) hide show
  1. package/dist/vuetify.js +551 -368
  2. package/dist/vuetify.js.map +1 -1
  3. package/dist/vuetify.min.css +1 -1
  4. package/dist/vuetify.min.js +2 -2
  5. package/es5/components/VCalendar/VCalendarWeekly.js +10 -5
  6. package/es5/components/VCalendar/VCalendarWeekly.js.map +1 -1
  7. package/es5/components/VCheckbox/VCheckbox.js +7 -9
  8. package/es5/components/VCheckbox/VCheckbox.js.map +1 -1
  9. package/es5/components/VContent/VContent.js +24 -5
  10. package/es5/components/VContent/VContent.js.map +1 -1
  11. package/es5/components/VCounter/VCounter.js.map +1 -1
  12. package/es5/components/VDatePicker/VDatePicker.js +15 -7
  13. package/es5/components/VDatePicker/VDatePicker.js.map +1 -1
  14. package/es5/components/VDatePicker/VDatePickerTitle.js +30 -19
  15. package/es5/components/VDatePicker/VDatePickerTitle.js.map +1 -1
  16. package/es5/components/VDatePicker/mixins/date-picker-table.js +1 -1
  17. package/es5/components/VDatePicker/mixins/date-picker-table.js.map +1 -1
  18. package/es5/components/VDatePicker/util/eventHelpers.js +27 -17
  19. package/es5/components/VDatePicker/util/eventHelpers.js.map +1 -1
  20. package/es5/components/VExpansionPanel/VExpansionPanelContent.js.map +1 -1
  21. package/es5/components/VExpansionPanel/VExpansionPanelHeader.js.map +1 -1
  22. package/es5/components/VGrid/VCol.js +3 -1
  23. package/es5/components/VGrid/VCol.js.map +1 -1
  24. package/es5/components/VGrid/VContainer.js +23 -10
  25. package/es5/components/VGrid/VContainer.js.map +1 -1
  26. package/es5/components/VGrid/grid.js +33 -15
  27. package/es5/components/VGrid/grid.js.map +1 -1
  28. package/es5/components/VHover/VHover.js +23 -17
  29. package/es5/components/VHover/VHover.js.map +1 -1
  30. package/es5/components/VIcon/VIcon.js +77 -53
  31. package/es5/components/VIcon/VIcon.js.map +1 -1
  32. package/es5/components/VItemGroup/VItem.js +7 -3
  33. package/es5/components/VItemGroup/VItem.js.map +1 -1
  34. package/es5/components/VLabel/VLabel.js +3 -1
  35. package/es5/components/VLabel/VLabel.js.map +1 -1
  36. package/es5/components/VOtpInput/VOtpInput.js +54 -33
  37. package/es5/components/VOtpInput/VOtpInput.js.map +1 -1
  38. package/es5/components/VOverflowBtn/VOverflowBtn.js +14 -13
  39. package/es5/components/VOverflowBtn/VOverflowBtn.js.map +1 -1
  40. package/es5/components/VProgressLinear/VProgressLinear.js +12 -33
  41. package/es5/components/VProgressLinear/VProgressLinear.js.map +1 -1
  42. package/es5/components/VSelect/VSelect.js +4 -1
  43. package/es5/components/VSelect/VSelect.js.map +1 -1
  44. package/es5/components/VStepper/VStepper.js +1 -1
  45. package/es5/components/VStepper/VStepper.js.map +1 -1
  46. package/es5/components/VStepper/VStepperContent.js +2 -5
  47. package/es5/components/VStepper/VStepperContent.js.map +1 -1
  48. package/es5/components/VSwitch/VSwitch.js +1 -1
  49. package/es5/components/VSwitch/VSwitch.js.map +1 -1
  50. package/es5/components/VTextField/VTextField.js +2 -1
  51. package/es5/components/VTextField/VTextField.js.map +1 -1
  52. package/es5/components/VTooltip/VTooltip.js +0 -7
  53. package/es5/components/VTooltip/VTooltip.js.map +1 -1
  54. package/es5/directives/color/index.js +6 -3
  55. package/es5/directives/color/index.js.map +1 -1
  56. package/es5/directives/ripple/index.js +5 -2
  57. package/es5/directives/ripple/index.js.map +1 -1
  58. package/es5/directives/scroll/index.js +1 -2
  59. package/es5/directives/scroll/index.js.map +1 -1
  60. package/es5/directives/touch/index.js +7 -4
  61. package/es5/directives/touch/index.js.map +1 -1
  62. package/es5/framework.js +1 -1
  63. package/es5/mixins/activatable/index.js +0 -8
  64. package/es5/mixins/activatable/index.js.map +1 -1
  65. package/es5/mixins/groupable/index.js.map +1 -1
  66. package/es5/mixins/positionable/index.js.map +1 -1
  67. package/es5/mixins/proxyable/index.js.map +1 -1
  68. package/es5/mixins/registrable/index.js.map +1 -1
  69. package/es5/mixins/selectable/index.js +4 -2
  70. package/es5/mixins/selectable/index.js.map +1 -1
  71. package/es5/mixins/toggleable/index.js.map +1 -1
  72. package/es5/services/goto/util.js +42 -3
  73. package/es5/services/goto/util.js.map +1 -1
  74. package/es5/services/theme/index.js +20 -71
  75. package/es5/services/theme/index.js.map +1 -1
  76. package/es5/util/mergeData.js +6 -5
  77. package/es5/util/mergeData.js.map +1 -1
  78. package/es5/util/mixins.js +4 -3
  79. package/es5/util/mixins.js.map +1 -1
  80. package/lib/components/VCalendar/VCalendarWeekly.js +11 -6
  81. package/lib/components/VCalendar/VCalendarWeekly.js.map +1 -1
  82. package/lib/components/VCheckbox/VCheckbox.js +5 -8
  83. package/lib/components/VCheckbox/VCheckbox.js.map +1 -1
  84. package/lib/components/VContent/VContent.js +18 -3
  85. package/lib/components/VContent/VContent.js.map +1 -1
  86. package/lib/components/VCounter/VCounter.js.map +1 -1
  87. package/lib/components/VDatePicker/VDatePicker.js +17 -7
  88. package/lib/components/VDatePicker/VDatePicker.js.map +1 -1
  89. package/lib/components/VDatePicker/VDatePickerTitle.js +25 -14
  90. package/lib/components/VDatePicker/VDatePickerTitle.js.map +1 -1
  91. package/lib/components/VDatePicker/mixins/date-picker-table.js +1 -1
  92. package/lib/components/VDatePicker/mixins/date-picker-table.js.map +1 -1
  93. package/lib/components/VDatePicker/util/eventHelpers.js +26 -14
  94. package/lib/components/VDatePicker/util/eventHelpers.js.map +1 -1
  95. package/lib/components/VExpansionPanel/VExpansionPanelContent.js.map +1 -1
  96. package/lib/components/VExpansionPanel/VExpansionPanelHeader.js.map +1 -1
  97. package/lib/components/VGrid/VCol.js +3 -1
  98. package/lib/components/VGrid/VCol.js.map +1 -1
  99. package/lib/components/VGrid/VContainer.js +11 -10
  100. package/lib/components/VGrid/VContainer.js.map +1 -1
  101. package/lib/components/VGrid/grid.js +15 -14
  102. package/lib/components/VGrid/grid.js.map +1 -1
  103. package/lib/components/VHover/VHover.js +23 -18
  104. package/lib/components/VHover/VHover.js.map +1 -1
  105. package/lib/components/VIcon/VIcon.js +79 -57
  106. package/lib/components/VIcon/VIcon.js.map +1 -1
  107. package/lib/components/VItemGroup/VItem.js +3 -2
  108. package/lib/components/VItemGroup/VItem.js.map +1 -1
  109. package/lib/components/VLabel/VLabel.js +3 -1
  110. package/lib/components/VLabel/VLabel.js.map +1 -1
  111. package/lib/components/VOtpInput/VOtpInput.js +58 -34
  112. package/lib/components/VOtpInput/VOtpInput.js.map +1 -1
  113. package/lib/components/VOverflowBtn/VOverflowBtn.js +14 -14
  114. package/lib/components/VOverflowBtn/VOverflowBtn.js.map +1 -1
  115. package/lib/components/VProgressLinear/VProgressLinear.js +12 -16
  116. package/lib/components/VProgressLinear/VProgressLinear.js.map +1 -1
  117. package/lib/components/VSelect/VSelect.js +4 -1
  118. package/lib/components/VSelect/VSelect.js.map +1 -1
  119. package/lib/components/VStepper/VStepper.js +1 -1
  120. package/lib/components/VStepper/VStepper.js.map +1 -1
  121. package/lib/components/VStepper/VStepperContent.js +3 -6
  122. package/lib/components/VStepper/VStepperContent.js.map +1 -1
  123. package/lib/components/VSwitch/VSwitch.js +1 -1
  124. package/lib/components/VSwitch/VSwitch.js.map +1 -1
  125. package/lib/components/VTextField/VTextField.js +2 -1
  126. package/lib/components/VTextField/VTextField.js.map +1 -1
  127. package/lib/components/VTooltip/VTooltip.js +1 -8
  128. package/lib/components/VTooltip/VTooltip.js.map +1 -1
  129. package/lib/directives/color/index.js +6 -3
  130. package/lib/directives/color/index.js.map +1 -1
  131. package/lib/directives/ripple/index.js +5 -3
  132. package/lib/directives/ripple/index.js.map +1 -1
  133. package/lib/directives/scroll/index.js +1 -2
  134. package/lib/directives/scroll/index.js.map +1 -1
  135. package/lib/directives/touch/index.js +7 -4
  136. package/lib/directives/touch/index.js.map +1 -1
  137. package/lib/framework.js +1 -1
  138. package/lib/mixins/activatable/index.js +1 -8
  139. package/lib/mixins/activatable/index.js.map +1 -1
  140. package/lib/mixins/groupable/index.js.map +1 -1
  141. package/lib/mixins/positionable/index.js.map +1 -1
  142. package/lib/mixins/proxyable/index.js.map +1 -1
  143. package/lib/mixins/registrable/index.js.map +1 -1
  144. package/lib/mixins/selectable/index.js +9 -7
  145. package/lib/mixins/selectable/index.js.map +1 -1
  146. package/lib/mixins/toggleable/index.js.map +1 -1
  147. package/lib/services/goto/util.js +42 -3
  148. package/lib/services/goto/util.js.map +1 -1
  149. package/lib/services/theme/index.js +18 -64
  150. package/lib/services/theme/index.js.map +1 -1
  151. package/lib/util/mergeData.js +6 -5
  152. package/lib/util/mergeData.js.map +1 -1
  153. package/lib/util/mixins.js +3 -2
  154. package/lib/util/mixins.js.map +1 -1
  155. package/package.json +2 -2
  156. package/src/components/VAlert/__tests__/__snapshots__/VAlert.spec.ts.snap +4 -4
  157. package/src/components/VAppBar/__tests__/__snapshots__/VAppBarNavIcon.spec.ts.snap +2 -2
  158. package/src/components/VAutocomplete/__tests__/VAutocomplete.spec.ts +75 -20
  159. package/src/components/VAutocomplete/__tests__/VAutocomplete2.spec.ts +38 -40
  160. package/src/components/VAutocomplete/__tests__/VAutocomplete3.spec.ts +26 -26
  161. package/src/components/VBanner/__tests__/__snapshots__/VBanner.spec.ts.snap +2 -2
  162. package/src/components/VBtn/__tests__/VBtn.spec.ts +8 -4
  163. package/src/components/VCalendar/VCalendarWeekly.ts +12 -5
  164. package/src/components/VCalendar/__tests__/VCalendar.spec.ts +1 -1
  165. package/src/components/VCalendar/__tests__/VCalendarCategory.spec.ts +5 -5
  166. package/src/components/VCalendar/__tests__/__snapshots__/VCalendar.spec.ts.snap +167 -168
  167. package/src/components/VCheckbox/VCheckbox.ts +4 -9
  168. package/src/components/VCheckbox/__tests__/VCheckbox.spec.ts +7 -1
  169. package/src/components/VCheckbox/__tests__/__snapshots__/VCheckbox.spec.ts.snap +54 -50
  170. package/src/components/VColorPicker/__tests__/__snapshots__/VColorPicker.spec.ts.snap +18 -18
  171. package/src/components/VColorPicker/__tests__/__snapshots__/VColorPickerEdit.spec.ts.snap +10 -10
  172. package/src/components/VCombobox/__tests__/VCombobox-multiple.spec.ts +89 -69
  173. package/src/components/VCombobox/__tests__/VCombobox.spec.ts +17 -12
  174. package/src/components/VContent/VContent.ts +10 -2
  175. package/src/components/VCounter/VCounter.ts +1 -1
  176. package/src/components/VCounter/__tests__/VCounter.spec.ts +10 -25
  177. package/src/components/VDataIterator/__tests__/__snapshots__/VDataFooter.spec.ts.snap +42 -42
  178. package/src/components/VDataIterator/__tests__/__snapshots__/VDataIterator.spec.ts.snap +30 -30
  179. package/src/components/VDataTable/__tests__/VDataTable.spec.ts +1 -1
  180. package/src/components/VDataTable/__tests__/VDataTableHeader.spec.ts +6 -10
  181. package/src/components/VDataTable/__tests__/VEditDialog.spec.ts +24 -21
  182. package/src/components/VDataTable/__tests__/__snapshots__/VDataTable.spec.ts.snap +409 -409
  183. package/src/components/VDataTable/__tests__/__snapshots__/VDataTableHeader.spec.ts.snap +70 -70
  184. package/src/components/VDataTable/mixins/__tests__/__snapshots__/header.spec.ts.snap +8 -8
  185. package/src/components/VDataTable/mixins/__tests__/header.spec.ts +3 -3
  186. package/src/components/VDatePicker/VDatePicker.ts +23 -7
  187. package/src/components/VDatePicker/VDatePickerTitle.ts +28 -16
  188. package/src/components/VDatePicker/__tests__/VDatePicker.date.spec.ts +86 -124
  189. package/src/components/VDatePicker/__tests__/VDatePicker.month.spec.ts +85 -63
  190. package/src/components/VDatePicker/__tests__/VDatePickerHeader.spec.ts +12 -27
  191. package/src/components/VDatePicker/__tests__/VDatePickerTitle.spec.ts +9 -5
  192. package/src/components/VDatePicker/__tests__/VDatePickerYears.spec.ts +4 -4
  193. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePicker.date.spec.ts.snap +27 -9
  194. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePicker.month.spec.ts.snap +45 -35
  195. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePickerTitle.spec.ts.snap +15 -5
  196. package/src/components/VDatePicker/mixins/date-picker-table.ts +1 -1
  197. package/src/components/VDatePicker/util/eventHelpers.ts +33 -13
  198. package/src/components/VExpansionPanel/VExpansionPanelContent.ts +5 -8
  199. package/src/components/VExpansionPanel/VExpansionPanelHeader.ts +10 -14
  200. package/src/components/VExpansionPanel/__tests__/VExpansionPanelHeader.spec.ts +6 -4
  201. package/src/components/VExpansionPanel/__tests__/VExpansionPanels.spec.ts +9 -5
  202. package/src/components/VExpansionPanel/__tests__/__snapshots__/VExpansionPanel.spec.ts.snap +4 -4
  203. package/src/components/VFileInput/__tests__/__snapshots__/VFileInput.spec.ts.snap +38 -38
  204. package/src/components/VFooter/__tests__/VFooter.spec.ts +28 -21
  205. package/src/components/VGrid/VCol.ts +1 -1
  206. package/src/components/VGrid/VContainer.ts +12 -10
  207. package/src/components/VGrid/__tests__/VCol.spec.ts +4 -2
  208. package/src/components/VGrid/__tests__/VGrid.spec.ts +2 -3
  209. package/src/components/VGrid/grid.ts +14 -17
  210. package/src/components/VHover/VHover.ts +21 -17
  211. package/src/components/VHover/__tests__/VHover.spec.ts +44 -28
  212. package/src/components/VIcon/VIcon.ts +72 -53
  213. package/src/components/VIcon/__tests__/VIcon.spec.ts +86 -176
  214. package/src/components/VIcon/__tests__/__snapshots__/VIcon.spec.ts.snap +19 -74
  215. package/src/components/VItemGroup/VItem.ts +1 -1
  216. package/src/components/VItemGroup/__tests__/VItem.spec.ts +20 -12
  217. package/src/components/VLabel/VLabel.ts +1 -1
  218. package/src/components/VList/__tests__/VListGroup.spec.ts +1 -1
  219. package/src/components/VList/__tests__/VListItemAction.spec.ts +32 -31
  220. package/src/components/VList/__tests__/__snapshots__/VListGroup.spec.ts.snap +2 -2
  221. package/src/components/VList/__tests__/__snapshots__/VListItemAction.spec.ts.snap +20 -6
  222. package/src/components/VOtpInput/VOtpInput.ts +57 -32
  223. package/src/components/VOtpInput/__tests__/VOtpInput.spec.ts +75 -78
  224. package/src/components/VOverflowBtn/VOverflowBtn.ts +13 -10
  225. package/src/components/VOverflowBtn/__tests__/VOverflowBtn.spec.ts +6 -6
  226. package/src/components/VOverflowBtn/__tests__/__snapshots__/VOverflowBtn.spec.ts.snap +38 -46
  227. package/src/components/VPagination/__tests__/__snapshots__/VPagination.spec.ts.snap +32 -32
  228. package/src/components/VProgressLinear/VProgressLinear.ts +13 -18
  229. package/src/components/VProgressLinear/__tests__/VProgressLinear.spec.ts +20 -12
  230. package/src/components/VRadioGroup/__tests__/VRadio.spec.ts +57 -44
  231. package/src/components/VRadioGroup/__tests__/VRadioGroup.spec.ts +4 -4
  232. package/src/components/VRadioGroup/__tests__/__snapshots__/VRadio.spec.ts.snap +29 -33
  233. package/src/components/VRadioGroup/__tests__/__snapshots__/VRadioGroup.spec.ts.snap +10 -18
  234. package/src/components/VRating/__tests__/VRating.spec.ts +24 -29
  235. package/src/components/VResponsive/__tests__/VResponsive.spec.ts +10 -5
  236. package/src/components/VSelect/VSelect.ts +5 -1
  237. package/src/components/VSelect/__tests__/VSelect2.spec.ts +5 -5
  238. package/src/components/VSelect/__tests__/VSelect3.spec.ts +7 -7
  239. package/src/components/VSelect/__tests__/VSelect4.spec.ts +2 -2
  240. package/src/components/VSelect/__tests__/__snapshots__/VSelect2.spec.ts.snap +4 -4
  241. package/src/components/VSelect/__tests__/__snapshots__/VSelect3.spec.ts.snap +0 -284
  242. package/src/components/VSelect/__tests__/__snapshots__/VSelectList.spec.ts.snap +30 -27
  243. package/src/components/VSlideGroup/__tests__/VSlideGroup.spec.ts +70 -62
  244. package/src/components/VSlideGroup/__tests__/__snapshots__/VSlideGroup.spec.ts.snap +13 -34
  245. package/src/components/VSnackbar/__tests__/VSnackbar.spec.ts +46 -37
  246. package/src/components/VStepper/VStepper.ts +2 -2
  247. package/src/components/VStepper/VStepperContent.ts +7 -12
  248. package/src/components/VStepper/__tests__/VStepper.spec.ts +3 -3
  249. package/src/components/VStepper/__tests__/VStepperContent.spec.ts +25 -6
  250. package/src/components/VStepper/__tests__/__snapshots__/VStepperStep.spec.ts.snap +10 -12
  251. package/src/components/VSwitch/VSwitch.ts +1 -1
  252. package/src/components/VSwitch/__tests__/VSwitch.spec.ts +4 -7
  253. package/src/components/VSwitch/__tests__/__snapshots__/VSwitch.spec.ts.snap +11 -15
  254. package/src/components/VTextField/VTextField.ts +2 -1
  255. package/src/components/VTextField/__tests__/VTextField.spec.ts +24 -27
  256. package/src/components/VTextField/__tests__/__snapshots__/VTextField.spec.ts.snap +49 -73
  257. package/src/components/VTextarea/__tests__/__snapshots__/VTextarea.spec.ts.snap +16 -6
  258. package/src/components/VThemeProvider/__tests__/VThemeProvider.spec.ts +49 -10
  259. package/src/components/VTimePicker/__tests__/VTimePicker.spec.ts +3 -3
  260. package/src/components/VTimePicker/__tests__/VTimePickerTitle.spec.ts +3 -3
  261. package/src/components/VTimeline/__tests__/__snapshots__/VTimelineItem.spec.ts.snap +2 -2
  262. package/src/components/VTooltip/VTooltip.ts +0 -6
  263. package/src/components/VTooltip/__tests__/VTooltip.spec.ts +12 -11
  264. package/src/components/VTreeview/__tests__/__snapshots__/VTreeview.spec.ts.snap +42 -42
  265. package/src/components/VTreeview/__tests__/__snapshots__/VTreeviewNode.spec.ts.snap +2 -2
  266. package/src/directives/click-outside/__tests__/click-outside-shadow-dom.spec.ts +4 -4
  267. package/src/directives/click-outside/__tests__/click-outside.spec.ts +3 -3
  268. package/src/directives/color/__tests__/color.spec.ts +54 -34
  269. package/src/directives/color/index.ts +7 -3
  270. package/src/directives/intersect/__tests__/intersect.spec.ts +7 -7
  271. package/src/directives/mutate/__tests__/mutate.spec.ts +32 -26
  272. package/src/directives/resize/__tests__/resize.spec.ts +5 -5
  273. package/src/directives/ripple/__tests__/ripple.spec.ts +34 -36
  274. package/src/directives/ripple/index.ts +3 -6
  275. package/src/directives/scroll/__tests__/scroll.spec.ts +13 -13
  276. package/src/directives/scroll/index.ts +0 -1
  277. package/src/directives/touch/__tests__/touch.spec.ts +23 -16
  278. package/src/directives/touch/index.ts +6 -4
  279. package/src/globals.d.ts +6 -6
  280. package/src/mixins/activatable/__tests__/activatable.spec.ts +55 -55
  281. package/src/mixins/activatable/index.ts +0 -6
  282. package/src/mixins/dependent/__tests__/dependent.spec.ts +72 -33
  283. package/src/mixins/detachable/__tests__/detachable.spec.ts +45 -31
  284. package/src/mixins/groupable/index.ts +6 -6
  285. package/src/mixins/positionable/index.ts +2 -2
  286. package/src/mixins/proxyable/index.ts +2 -2
  287. package/src/mixins/registrable/index.ts +4 -4
  288. package/src/mixins/selectable/index.ts +10 -7
  289. package/src/mixins/toggleable/index.ts +2 -2
  290. package/src/services/goto/__tests__/goto.spec.ts +146 -1
  291. package/src/services/goto/util.ts +44 -5
  292. package/src/services/theme/__tests__/__snapshots__/theme.spec.ts.snap +0 -1128
  293. package/src/services/theme/__tests__/theme.spec.ts +81 -83
  294. package/src/services/theme/index.ts +22 -60
  295. package/src/util/__tests__/dom.spec.ts +8 -5
  296. package/src/util/__tests__/helpers.spec.ts +1 -1
  297. package/src/util/__tests__/mergeData.spec.ts +8 -8
  298. package/src/util/mergeData.ts +10 -5
  299. package/src/util/mixins.ts +24 -7
  300. package/types/alacarte.d.ts +14 -14
  301. package/types/index.d.ts +8 -8
  302. package/types/lib.d.ts +173 -173
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VGrid/VCol.ts"],"names":[],"mappings":"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","sourcesContent":["import './VGrid.sass'\n\nimport { defineComponent, VNode, PropOptions, getCurrentInstance } from 'vue'\nimport mergeData from '../../util/mergeData'\nimport { upperFirst } from '../../util/helpers'\nimport {h} from 'vue'\n// no xs\nconst breakpoints = ['sm', 'md', 'lg', 'xl']\n\nconst breakpointProps = (() => {\n return breakpoints.reduce((props, val) => {\n props[val] = {\n type: [Boolean, String, Number],\n default: false,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst offsetProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['offset' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst orderProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['order' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst propMap = {\n col: Object.keys(breakpointProps),\n offset: Object.keys(offsetProps),\n order: Object.keys(orderProps),\n}\n\nfunction breakpointClass (type: keyof typeof propMap, prop: string, val: boolean | string | number) {\n let className = type\n if (val == null || val === false) {\n return undefined\n }\n if (prop) {\n const breakpoint = prop.replace(type, '')\n className += `-${breakpoint}`\n }\n // Handling the boolean style prop when accepting [Boolean, String, Number]\n // means Vue will not convert <v-col sm></v-col> to sm: true for us.\n // Since the default is false, an empty string indicates the prop's presence.\n if (type === 'col' && (val === '' || val === true)) {\n // .col-md\n return className.toLowerCase()\n }\n // .order-md-6\n className += `-${val}`\n return className.toLowerCase()\n}\n\nconst cache = new Map<string, any[]>()\n\nexport default defineComponent({\n name: 'v-col',\n inheritAttrs: false,\n props: {\n cols: {\n type: [Boolean, String, Number],\n default: false,\n },\n ...breakpointProps,\n offset: {\n type: [String, Number],\n default: null,\n },\n ...offsetProps,\n order: {\n type: [String, Number],\n default: null,\n },\n ...orderProps,\n alignSelf: {\n type: String,\n default: null,\n validator: (str: any) => ['auto', 'start', 'end', 'center', 'baseline', 'stretch'].includes(str),\n },\n tag: {\n type: String,\n default: 'div',\n },\n },\n render (): VNode {\n const props = this.$props\n const data = this.$attrs\n const children = this.$slots.default()\n // const {parent} = getCurrentInstance()\n\n // Super-fast memoization based on props, 5x faster than JSON.stringify\n let cacheKey = ''\n for (const prop in props) {\n cacheKey += String((props as any)[prop])\n }\n let classList = cache.get(cacheKey)\n\n if (!classList) {\n classList = []\n // Loop through `col`, `offset`, `order` breakpoint props\n let type: keyof typeof propMap\n for (type in propMap) {\n propMap[type].forEach(prop => {\n const value: string | number | boolean = (props as any)[prop]\n const className = breakpointClass(type, prop, value)\n if (className) classList!.push(className)\n })\n }\n\n const hasColClasses = classList.some(className => className.startsWith('col-'))\n\n classList.push({\n // Default to .col if no other col-{bp}-* classes generated nor `cols` specified.\n col: !hasColClasses || !props.cols,\n [`col-${props.cols}`]: props.cols,\n [`offset-${props.offset}`]: props.offset,\n [`order-${props.order}`]: props.order,\n [`align-self-${props.alignSelf}`]: props.alignSelf,\n })\n\n cache.set(cacheKey, classList)\n }\n\n return h(props.tag, mergeData({ class: classList }, data), children)\n },\n})\n"],"sourceRoot":"","file":"VCol.js"}
1
+ {"version":3,"sources":["../../../src/components/VGrid/VCol.ts"],"names":[],"mappings":"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","sourcesContent":["import './VGrid.sass'\n\nimport { defineComponent, VNode, PropOptions, getCurrentInstance } from 'vue'\nimport mergeData from '../../util/mergeData'\nimport { upperFirst } from '../../util/helpers'\nimport {h} from 'vue'\n// no xs\nconst breakpoints = ['sm', 'md', 'lg', 'xl']\n\nconst breakpointProps = (() => {\n return breakpoints.reduce((props, val) => {\n props[val] = {\n type: [Boolean, String, Number],\n default: false,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst offsetProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['offset' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst orderProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['order' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary<PropOptions>)\n})()\n\nconst propMap = {\n col: Object.keys(breakpointProps),\n offset: Object.keys(offsetProps),\n order: Object.keys(orderProps),\n}\n\nfunction breakpointClass (type: keyof typeof propMap, prop: string, val: boolean | string | number) {\n let className = type\n if (val == null || val === false) {\n return undefined\n }\n if (prop) {\n const breakpoint = prop.replace(type, '')\n className += `-${breakpoint}`\n }\n // Handling the boolean style prop when accepting [Boolean, String, Number]\n // means Vue will not convert <v-col sm></v-col> to sm: true for us.\n // Since the default is false, an empty string indicates the prop's presence.\n if (type === 'col' && (val === '' || val === true)) {\n // .col-md\n return className.toLowerCase()\n }\n // .order-md-6\n className += `-${val}`\n return className.toLowerCase()\n}\n\nconst cache = new Map<string, any[]>()\n\nexport default defineComponent({\n name: 'v-col',\n inheritAttrs: false,\n props: {\n cols: {\n type: [Boolean, String, Number],\n default: false,\n },\n ...breakpointProps,\n offset: {\n type: [String, Number],\n default: null,\n },\n ...offsetProps,\n order: {\n type: [String, Number],\n default: null,\n },\n ...orderProps,\n alignSelf: {\n type: String,\n default: null,\n validator: (str: any) => ['auto', 'start', 'end', 'center', 'baseline', 'stretch'].includes(str),\n },\n tag: {\n type: String,\n default: 'div',\n },\n },\n render (): VNode {\n const props = this.$props\n const data = this.$attrs\n const children = this.$slots.default?.() || []\n // const {parent} = getCurrentInstance()\n\n // Super-fast memoization based on props, 5x faster than JSON.stringify\n let cacheKey = ''\n for (const prop in props) {\n cacheKey += String((props as any)[prop])\n }\n let classList = cache.get(cacheKey)\n\n if (!classList) {\n classList = []\n // Loop through `col`, `offset`, `order` breakpoint props\n let type: keyof typeof propMap\n for (type in propMap) {\n propMap[type].forEach(prop => {\n const value: string | number | boolean = (props as any)[prop]\n const className = breakpointClass(type, prop, value)\n if (className) classList!.push(className)\n })\n }\n\n const hasColClasses = classList.some(className => className.startsWith('col-'))\n\n classList.push({\n // Default to .col if no other col-{bp}-* classes generated nor `cols` specified.\n col: !hasColClasses || !props.cols,\n [`col-${props.cols}`]: props.cols,\n [`offset-${props.offset}`]: props.offset,\n [`order-${props.order}`]: props.order,\n [`align-self-${props.alignSelf}`]: props.alignSelf,\n })\n\n cache.set(cacheKey, classList)\n }\n\n return h(props.tag, mergeData({ class: classList }, data), children)\n },\n})\n"],"sourceRoot":"","file":"VCol.js"}
@@ -8,7 +8,6 @@ import { defineComponent, h } from 'vue';
8
8
  export default defineComponent({
9
9
  name: 'v-container',
10
10
  extends: Grid('container'),
11
- functional: true,
12
11
  props: {
13
12
  id: String,
14
13
  tag: {
@@ -44,17 +43,19 @@ export default defineComponent({
44
43
 
45
44
  return value || typeof value === 'string';
46
45
  });
47
- } // if (props.id) {
48
- // data.domProps = data.domProps || {}
49
- // data.domProps.id = props.id
50
- // }
51
-
46
+ }
52
47
 
53
- return h(this.tag, mergeData(this.$attrs, {
54
- class: Array({
48
+ const data = mergeData(this.$attrs, {
49
+ class: ['container', {
55
50
  'container--fluid': this.fluid
56
- }).concat(classes || []).concat('container')
57
- }), (_b = (_a = this.$slots).default) === null || _b === void 0 ? void 0 : _b.call(_a));
51
+ }, ...(classes || [])]
52
+ });
53
+
54
+ if (this.id) {
55
+ data.id = this.id;
56
+ }
57
+
58
+ return h(this.tag, data, (_b = (_a = this.$slots).default) === null || _b === void 0 ? void 0 : _b.call(_a));
58
59
  }
59
60
 
60
61
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VGrid/VContainer.ts"],"names":[],"mappings":"AAAA,OAAO,0CAAP;AACA,OAAO,0CAAP;AAEA,OAAO,IAAP,MAAiB,QAAjB;AAEA,OAAO,SAAP,MAAsB,sBAAtB;AACA,SAAS,eAAT,EAA0B,CAA1B,QAAmC,KAAnC;AAEA;;AACA,eAAe,eAAe,CAAC;AAC7B,EAAA,IAAI,EAAE,aADuB;AAE7B,EAAA,OAAO,EAAE,IAAI,CAAC,WAAD,CAFgB;AAG7B,EAAA,UAAU,EAAE,IAHiB;AAI7B,EAAA,KAAK,EAAE;AACL,IAAA,EAAE,EAAE,MADC;AAEL,IAAA,GAAG,EAAE;AACH,MAAA,IAAI,EAAE,MADH;AAEH,MAAA,OAAO,EAAE;AAFN,KAFA;AAML,IAAA,KAAK,EAAE;AACL,MAAA,IAAI,EAAE,OADD;AAEL,MAAA,OAAO,EAAE;AAFJ;AANF,GAJsB;;AAe7B,EAAA,MAAM,GAAA;;;AACJ,QAAI,OAAJ,CADI,CAEJ;;AAEA,UAAM,KAAK,GAAG,KAAK,MAAnB;;AAEA,QAAI,KAAJ,EAAW;AACT;AACA,MAAA,OAAO,GAAG,MAAM,CAAC,IAAP,CAAY,KAAZ,EAAmB,MAAnB,CAA0B,GAAG,IAAG;AACxC;AACA;AACA,YAAI,GAAG,KAAK,MAAZ,EAAoB,OAAO,KAAP;AAEpB,cAAM,KAAK,GAAG,KAAK,CAAC,GAAD,CAAnB,CALwC,CAOxC;AACA;;AACA,YAAI,GAAG,CAAC,UAAJ,CAAe,OAAf,CAAJ,EAA6B;AAC3B;AACA,iBAAO,KAAP;AACD;;AAED,eAAO,KAAK,IAAI,OAAO,KAAP,KAAiB,QAAjC;AACD,OAfS,CAAV;AAgBD,KAxBG,CA0BJ;AACA;AACA;AACA;;;AAEA,WAAO,CAAC,CACN,KAAK,GADC,EAEN,SAAS,CAAC,KAAK,MAAN,EAAc;AACrB,MAAA,KAAK,EAAE,KAAK,CAAM;AAChB,4BAAoB,KAAK;AADT,OAAN,CAAL,CAEJ,MAFI,CAEG,OAAO,IAAI,EAFd,EAEkB,MAFlB,CAEyB,WAFzB;AADc,KAAd,CAFH,EAON,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,KAAK,MAAL,EAAY,OAAZ,MAAmB,IAAnB,IAAmB,EAAA,KAAA,KAAA,CAAnB,GAAmB,KAAA,CAAnB,GAAmB,EAAA,CAAA,IAAA,CAAA,EAAA,CAPb,CAAR;AASD;;AAvD4B,CAAD,CAA9B","sourcesContent":["import './_grid.sass'\nimport './VGrid.sass'\n\nimport Grid from './grid'\n\nimport mergeData from '../../util/mergeData'\nimport { defineComponent, h } from 'vue'\n\n/* @vue/component */\nexport default defineComponent({\n name: 'v-container',\n extends: Grid('container'),\n functional: true,\n props: {\n id: String,\n tag: {\n type: String,\n default: 'div',\n },\n fluid: {\n type: Boolean,\n default: false,\n },\n },\n render () {\n let classes\n // const { attrs } = data\n\n const attrs = this.$attrs\n\n if (attrs) {\n // reset attrs to extract utility clases like pa-3\n classes = Object.keys(attrs).filter(key => {\n // TODO: Remove once resolved\n // https://github.com/vuejs/vue/issues/7841\n if (key === 'slot') return false\n\n const value = attrs[key]\n\n // add back data attributes like data-test=\"foo\" but do not\n // add them as classes\n if (key.startsWith('data-')) {\n // data.attrs![key] = value\n return false\n }\n\n return value || typeof value === 'string'\n })\n }\n\n // if (props.id) {\n // data.domProps = data.domProps || {}\n // data.domProps.id = props.id\n // }\n\n return h(\n this.tag,\n mergeData(this.$attrs, {\n class: Array<any>({\n 'container--fluid': this.fluid,\n }).concat(classes || []).concat('container'),\n }),\n this.$slots.default?.()\n )\n },\n})\n"],"sourceRoot":"","file":"VContainer.js"}
1
+ {"version":3,"sources":["../../../src/components/VGrid/VContainer.ts"],"names":[],"mappings":"AAAA,OAAO,0CAAP;AACA,OAAO,0CAAP;AAEA,OAAO,IAAP,MAAiB,QAAjB;AAEA,OAAO,SAAP,MAAsB,sBAAtB;AACA,SAAS,eAAT,EAA0B,CAA1B,QAAmC,KAAnC;AAEA;;AACA,eAAe,eAAe,CAAC;AAC7B,EAAA,IAAI,EAAE,aADuB;AAE7B,EAAA,OAAO,EAAE,IAAI,CAAC,WAAD,CAFgB;AAG7B,EAAA,KAAK,EAAE;AACL,IAAA,EAAE,EAAE,MADC;AAEL,IAAA,GAAG,EAAE;AACH,MAAA,IAAI,EAAE,MADH;AAEH,MAAA,OAAO,EAAE;AAFN,KAFA;AAML,IAAA,KAAK,EAAE;AACL,MAAA,IAAI,EAAE,OADD;AAEL,MAAA,OAAO,EAAE;AAFJ;AANF,GAHsB;;AAc7B,EAAA,MAAM,GAAA;;;AACJ,QAAI,OAAJ,CADI,CAEJ;;AAEA,UAAM,KAAK,GAAG,KAAK,MAAnB;;AAEA,QAAI,KAAJ,EAAW;AACT;AACA,MAAA,OAAO,GAAG,MAAM,CAAC,IAAP,CAAY,KAAZ,EAAmB,MAAnB,CAA0B,GAAG,IAAG;AACxC;AACA;AACA,YAAI,GAAG,KAAK,MAAZ,EAAoB,OAAO,KAAP;AAEpB,cAAM,KAAK,GAAG,KAAK,CAAC,GAAD,CAAnB,CALwC,CAOxC;AACA;;AACA,YAAI,GAAG,CAAC,UAAJ,CAAe,OAAf,CAAJ,EAA6B;AAC3B;AACA,iBAAO,KAAP;AACD;;AAED,eAAO,KAAK,IAAI,OAAO,KAAP,KAAiB,QAAjC;AACD,OAfS,CAAV;AAgBD;;AAED,UAAM,IAAI,GAAG,SAAS,CAAC,KAAK,MAAN,EAAc;AAClC,MAAA,KAAK,EAAE,CACL,WADK,EAEL;AAAE,4BAAoB,KAAK;AAA3B,OAFK,EAGL,IAAI,OAAO,IAAI,EAAf,CAHK;AAD2B,KAAd,CAAtB;;AAQA,QAAI,KAAK,EAAT,EAAa;AACX,MAAA,IAAI,CAAC,EAAL,GAAU,KAAK,EAAf;AACD;;AAED,WAAO,CAAC,CACN,KAAK,GADC,EAEN,IAFM,EAGN,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,KAAK,MAAL,EAAY,OAAZ,MAAmB,IAAnB,IAAmB,EAAA,KAAA,KAAA,CAAnB,GAAmB,KAAA,CAAnB,GAAmB,EAAA,CAAA,IAAA,CAAA,EAAA,CAHb,CAAR;AAKD;;AAzD4B,CAAD,CAA9B","sourcesContent":["import './_grid.sass'\nimport './VGrid.sass'\n\nimport Grid from './grid'\n\nimport mergeData from '../../util/mergeData'\nimport { defineComponent, h } from 'vue'\n\n/* @vue/component */\nexport default defineComponent({\n name: 'v-container',\n extends: Grid('container'),\n props: {\n id: String,\n tag: {\n type: String,\n default: 'div',\n },\n fluid: {\n type: Boolean,\n default: false,\n },\n },\n render () {\n let classes\n // const { attrs } = data\n\n const attrs = this.$attrs\n\n if (attrs) {\n // reset attrs to extract utility clases like pa-3\n classes = Object.keys(attrs).filter(key => {\n // TODO: Remove once resolved\n // https://github.com/vuejs/vue/issues/7841\n if (key === 'slot') return false\n\n const value = attrs[key]\n\n // add back data attributes like data-test=\"foo\" but do not\n // add them as classes\n if (key.startsWith('data-')) {\n // data.attrs![key] = value\n return false\n }\n\n return value || typeof value === 'string'\n })\n }\n\n const data = mergeData(this.$attrs, {\n class: [\n 'container',\n { 'container--fluid': this.fluid },\n ...(classes || []),\n ],\n })\n\n if (this.id) {\n data.id = this.id\n }\n\n return h(\n this.tag,\n data,\n this.$slots.default?.()\n )\n },\n})\n"],"sourceRoot":"","file":"VContainer.js"}
@@ -4,7 +4,6 @@ export default function VGrid(name) {
4
4
  /* @vue/component */
5
5
  return defineComponent({
6
6
  name: `v-${name}`,
7
- functional: true,
8
7
  props: {
9
8
  id: String,
10
9
  tag: {
@@ -14,22 +13,25 @@ export default function VGrid(name) {
14
13
  },
15
14
 
16
15
  render() {
17
- const data = this.$attrs;
18
- const children = this.$slots.default();
19
- const props = this.$props;
20
- data.staticClass = `${name} ${data.staticClass || ''}`.trim();
16
+ var _a, _b;
17
+
18
+ const data = { ...this.$attrs
19
+ };
20
+ const children = ((_b = (_a = this.$slots) === null || _a === void 0 ? void 0 : _a.default) === null || _b === void 0 ? void 0 : _b.call(_a)) || [];
21
+ const componentProps = this.$props;
22
+ data.class = [name, data.class].filter(Boolean);
21
23
  const {
22
- attrs
24
+ attrs: dataAttrs
23
25
  } = data;
24
26
 
25
- if (attrs) {
27
+ if (dataAttrs) {
26
28
  // reset attrs to extract utility clases like pa-3
27
29
  data.attrs = {};
28
- const classes = Object.keys(attrs).filter(key => {
30
+ const classes = Object.keys(dataAttrs).filter(key => {
29
31
  // TODO: Remove once resolved
30
32
  // https://github.com/vuejs/vue/issues/7841
31
33
  if (key === 'slot') return false;
32
- const value = attrs[key]; // add back data attributes like data-test="foo" but do not
34
+ const value = dataAttrs[key]; // add back data attributes like data-test="foo" but do not
33
35
  // add them as classes
34
36
 
35
37
  if (key.startsWith('data-')) {
@@ -39,15 +41,14 @@ export default function VGrid(name) {
39
41
 
40
42
  return value || typeof value === 'string';
41
43
  });
42
- if (classes.length) data.staticClass += ` ${classes.join(' ')}`;
44
+ if (classes.length) data.class = [...data.class, ...classes];
43
45
  }
44
46
 
45
- if (props.id) {
46
- data.domProps = data.domProps || {};
47
- data.domProps.id = props.id;
47
+ if (componentProps === null || componentProps === void 0 ? void 0 : componentProps.id) {
48
+ data.id = componentProps.id;
48
49
  }
49
50
 
50
- return h(props.tag, data, children);
51
+ return h((componentProps === null || componentProps === void 0 ? void 0 : componentProps.tag) || 'div', data, children);
51
52
  }
52
53
 
53
54
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VGrid/grid.ts"],"names":[],"mappings":"AAAA;AACA,SAAS,eAAT,EAAiC,CAAjC,QAA0C,KAA1C;AAEA,eAAc,SAAU,KAAV,CAAiB,IAAjB,EAA6B;AACzC;AACA,SAAO,eAAe,CAAC;AACrB,IAAA,IAAI,EAAE,KAAK,IAAI,EADM;AAGrB,IAAA,UAAU,EAAE,IAHS;AAKrB,IAAA,KAAK,EAAE;AACL,MAAA,EAAE,EAAE,MADC;AAEL,MAAA,GAAG,EAAE;AACH,QAAA,IAAI,EAAE,MADH;AAEH,QAAA,OAAO,EAAE;AAFN;AAFA,KALc;;AAarB,IAAA,MAAM,GAAA;AACJ,YAAM,IAAI,GAAG,KAAK,MAAlB;AACA,YAAM,QAAQ,GAAG,KAAK,MAAL,CAAY,OAAZ,EAAjB;AACA,YAAM,KAAK,GAAG,KAAK,MAAnB;AAEA,MAAA,IAAI,CAAC,WAAL,GAAoB,GAAG,IAAI,IAAI,IAAI,CAAC,WAAL,IAAoB,EAAE,EAAlC,CAAsC,IAAtC,EAAnB;AAEA,YAAM;AAAE,QAAA;AAAF,UAAY,IAAlB;;AACA,UAAI,KAAJ,EAAW;AACT;AACA,QAAA,IAAI,CAAC,KAAL,GAAa,EAAb;AACA,cAAM,OAAO,GAAG,MAAM,CAAC,IAAP,CAAY,KAAZ,EAAmB,MAAnB,CAA0B,GAAG,IAAG;AAC9C;AACA;AACA,cAAI,GAAG,KAAK,MAAZ,EAAoB,OAAO,KAAP;AAEpB,gBAAM,KAAK,GAAG,KAAK,CAAC,GAAD,CAAnB,CAL8C,CAO9C;AACA;;AACA,cAAI,GAAG,CAAC,UAAJ,CAAe,OAAf,CAAJ,EAA6B;AAC3B,YAAA,IAAI,CAAC,KAAL,CAAY,GAAZ,IAAmB,KAAnB;AACA,mBAAO,KAAP;AACD;;AAED,iBAAO,KAAK,IAAI,OAAO,KAAP,KAAiB,QAAjC;AACD,SAfe,CAAhB;AAiBA,YAAI,OAAO,CAAC,MAAZ,EAAoB,IAAI,CAAC,WAAL,IAAoB,IAAI,OAAO,CAAC,IAAR,CAAa,GAAb,CAAiB,EAAzC;AACrB;;AAED,UAAI,KAAK,CAAC,EAAV,EAAc;AACZ,QAAA,IAAI,CAAC,QAAL,GAAgB,IAAI,CAAC,QAAL,IAAiB,EAAjC;AACA,QAAA,IAAI,CAAC,QAAL,CAAc,EAAd,GAAmB,KAAK,CAAC,EAAzB;AACD;;AAED,aAAO,CAAC,CAAC,KAAK,CAAC,GAAP,EAAY,IAAZ,EAAkB,QAAlB,CAAR;AACD;;AAlDoB,GAAD,CAAtB;AAoDD","sourcesContent":["// Types\nimport { defineComponent, VNode, h } from 'vue'\n\nexport default function VGrid (name: string) {\n /* @vue/component */\n return defineComponent({\n name: `v-${name}`,\n\n functional: true,\n\n props: {\n id: String,\n tag: {\n type: String,\n default: 'div',\n },\n },\n\n render (): VNode {\n const data = this.$attrs\n const children = this.$slots.default()\n const props = this.$props\n\n data.staticClass = (`${name} ${data.staticClass || ''}`).trim()\n\n const { attrs } = data\n if (attrs) {\n // reset attrs to extract utility clases like pa-3\n data.attrs = {}\n const classes = Object.keys(attrs).filter(key => {\n // TODO: Remove once resolved\n // https://github.com/vuejs/vue/issues/7841\n if (key === 'slot') return false\n\n const value = attrs[key]\n\n // add back data attributes like data-test=\"foo\" but do not\n // add them as classes\n if (key.startsWith('data-')) {\n data.attrs![key] = value\n return false\n }\n\n return value || typeof value === 'string'\n })\n\n if (classes.length) data.staticClass += ` ${classes.join(' ')}`\n }\n\n if (props.id) {\n data.domProps = data.domProps || {}\n data.domProps.id = props.id\n }\n\n return h(props.tag, data, children)\n },\n })\n}\n"],"sourceRoot":"","file":"grid.js"}
1
+ {"version":3,"sources":["../../../src/components/VGrid/grid.ts"],"names":[],"mappings":"AAAA;AACA,SAAS,eAAT,EAAiC,CAAjC,QAA0C,KAA1C;AAEA,eAAc,SAAU,KAAV,CAAiB,IAAjB,EAA6B;AACzC;AACA,SAAO,eAAe,CAAC;AACrB,IAAA,IAAI,EAAE,KAAK,IAAI,EADM;AAGrB,IAAA,KAAK,EAAE;AACL,MAAA,EAAE,EAAE,MADC;AAEL,MAAA,GAAG,EAAE;AACH,QAAA,IAAI,EAAE,MADH;AAEH,QAAA,OAAO,EAAE;AAFN;AAFA,KAHc;;AAWrB,IAAA,MAAM,GAAA;;;AACJ,YAAM,IAAI,GAAQ,EAAE,GAAG,KAAK;AAAV,OAAlB;AACA,YAAM,QAAQ,GAAG,CAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,KAAK,MAAL,MAAW,IAAX,IAAW,EAAA,KAAA,KAAA,CAAX,GAAW,KAAA,CAAX,GAAW,EAAA,CAAE,OAAb,MAAoB,IAApB,IAAoB,EAAA,KAAA,KAAA,CAApB,GAAoB,KAAA,CAApB,GAAoB,EAAA,CAAA,IAAA,CAAA,EAAA,CAApB,KAA4B,EAA7C;AACA,YAAM,cAAc,GAAG,KAAK,MAA5B;AAEA,MAAA,IAAI,CAAC,KAAL,GAAa,CAAC,IAAD,EAAO,IAAI,CAAC,KAAZ,EAAmB,MAAnB,CAA0B,OAA1B,CAAb;AAEA,YAAM;AAAE,QAAA,KAAK,EAAE;AAAT,UAAuB,IAA7B;;AACA,UAAI,SAAJ,EAAe;AACb;AACA,QAAA,IAAI,CAAC,KAAL,GAAa,EAAb;AACA,cAAM,OAAO,GAAG,MAAM,CAAC,IAAP,CAAY,SAAZ,EAAuB,MAAvB,CAA8B,GAAG,IAAG;AAClD;AACA;AACA,cAAI,GAAG,KAAK,MAAZ,EAAoB,OAAO,KAAP;AAEpB,gBAAM,KAAK,GAAG,SAAS,CAAC,GAAD,CAAvB,CALkD,CAOlD;AACA;;AACA,cAAI,GAAG,CAAC,UAAJ,CAAe,OAAf,CAAJ,EAA6B;AAC3B,YAAA,IAAI,CAAC,KAAL,CAAY,GAAZ,IAAmB,KAAnB;AACA,mBAAO,KAAP;AACD;;AAED,iBAAO,KAAK,IAAI,OAAO,KAAP,KAAiB,QAAjC;AACD,SAfe,CAAhB;AAiBA,YAAI,OAAO,CAAC,MAAZ,EAAoB,IAAI,CAAC,KAAL,GAAa,CAAC,GAAG,IAAI,CAAC,KAAT,EAAgB,GAAG,OAAnB,CAAb;AACrB;;AAED,UAAI,cAAc,KAAA,IAAd,IAAA,cAAc,KAAA,KAAA,CAAd,GAAc,KAAA,CAAd,GAAA,cAAc,CAAE,EAApB,EAAwB;AACtB,QAAA,IAAI,CAAC,EAAL,GAAU,cAAc,CAAC,EAAzB;AACD;;AAED,aAAO,CAAC,CAAC,CAAA,cAAc,KAAA,IAAd,IAAA,cAAc,KAAA,KAAA,CAAd,GAAc,KAAA,CAAd,GAAA,cAAc,CAAE,GAAhB,KAAuB,KAAxB,EAA+B,IAA/B,EAAqC,QAArC,CAAR;AACD;;AA/CoB,GAAD,CAAtB;AAiDD","sourcesContent":["// Types\nimport { defineComponent, VNode, h } from 'vue'\n\nexport default function VGrid (name: string) {\n /* @vue/component */\n return defineComponent({\n name: `v-${name}`,\n\n props: {\n id: String,\n tag: {\n type: String,\n default: 'div',\n },\n },\n\n render() {\n const data: any = { ...this.$attrs }\n const children = this.$slots?.default?.() || []\n const componentProps = this.$props\n\n data.class = [name, data.class].filter(Boolean)\n\n const { attrs: dataAttrs } = data\n if (dataAttrs) {\n // reset attrs to extract utility clases like pa-3\n data.attrs = {}\n const classes = Object.keys(dataAttrs).filter(key => {\n // TODO: Remove once resolved\n // https://github.com/vuejs/vue/issues/7841\n if (key === 'slot') return false\n\n const value = dataAttrs[key]\n\n // add back data attributes like data-test=\"foo\" but do not\n // add them as classes\n if (key.startsWith('data-')) {\n data.attrs![key] = value\n return false\n }\n\n return value || typeof value === 'string'\n })\n\n if (classes.length) data.class = [...data.class, ...classes]\n }\n\n if (componentProps?.id) {\n data.id = componentProps.id\n }\n\n return h(componentProps?.tag || 'div', data, children)\n }\n })\n}\n"],"sourceRoot":"","file":"grid.js"}
@@ -3,7 +3,9 @@ import Delayable from '../../mixins/delayable';
3
3
  import Toggleable from '../../mixins/toggleable'; // Utilities
4
4
 
5
5
  import mixins from '../../util/mixins';
6
- import { consoleWarn } from '../../util/console';
6
+ import { consoleWarn } from '../../util/console'; // Types
7
+
8
+ import { mergeProps } from 'vue';
7
9
  export default mixins(Delayable, Toggleable
8
10
  /* @vue/component */
9
11
  ).extend({
@@ -13,7 +15,7 @@ export default mixins(Delayable, Toggleable
13
15
  type: Boolean,
14
16
  default: false
15
17
  },
16
- value: {
18
+ modelValue: {
17
19
  type: Boolean,
18
20
  default: undefined
19
21
  }
@@ -21,45 +23,48 @@ export default mixins(Delayable, Toggleable
21
23
  emits: ['update:modelValue'],
22
24
  methods: {
23
25
  onMouseEnter() {
26
+ if (this.disabled) return;
24
27
  this.runDelay('open');
25
28
  },
26
29
 
27
30
  onMouseLeave() {
31
+ if (this.disabled) return;
28
32
  this.runDelay('close');
29
33
  }
30
34
 
31
35
  },
32
36
 
33
37
  render() {
34
- if (!this.$slots.default && this.value === undefined) {
38
+ if (!this.$slots.default && this.modelValue === undefined) {
35
39
  consoleWarn('v-hover is missing a default scopedSlot or bound value', this);
36
40
  return null;
37
41
  }
38
42
 
39
- let element;
40
- /* istanbul ignore else */
43
+ if (!this.$slots.default) return null;
44
+ const slotContent = this.$slots.default({
45
+ hover: this.isActive
46
+ });
41
47
 
42
- if (this.$slots.default) {
43
- element = this.$slots.default({
44
- hover: this.isActive
45
- });
48
+ if (!(slotContent === null || slotContent === void 0 ? void 0 : slotContent.length)) {
49
+ consoleWarn('v-hover slot returned empty content', this);
50
+ return null;
46
51
  }
47
52
 
48
- if (Array.isArray(element) && element.length === 1) {
49
- element = element[0];
53
+ const element = slotContent[0];
54
+
55
+ if (!(element === null || element === void 0 ? void 0 : element.type)) {
56
+ consoleWarn('v-hover should only contain valid VNode elements', this);
57
+ return element;
50
58
  }
51
59
 
52
- if (!element || Array.isArray(element) || !element.tag) {
60
+ if (slotContent.length > 1) {
53
61
  consoleWarn('v-hover should only contain a single element', this);
54
- return element;
55
62
  }
56
63
 
57
64
  if (!this.disabled) {
58
- element.data = element.data || {};
59
-
60
- this._g(element.data, {
61
- mouseenter: this.onMouseEnter,
62
- mouseleave: this.onMouseLeave
65
+ element.props = mergeProps(element.props || {}, {
66
+ onMouseenter: this.onMouseEnter,
67
+ onMouseleave: this.onMouseLeave
63
68
  });
64
69
  }
65
70
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VHover/VHover.ts"],"names":[],"mappings":"AAAA;AACA,OAAO,SAAP,MAAsB,wBAAtB;AACA,OAAO,UAAP,MAAuB,yBAAvB,C,CAEA;;AACA,OAAO,MAAP,MAAmB,mBAAnB;AACA,SAAS,WAAT,QAA4B,oBAA5B;AAKA,eAAe,MAAM,CACnB,SADmB,EAEnB;AACA;AAHmB,CAAN,CAIb,MAJa,CAIN;AACP,EAAA,IAAI,EAAE,SADC;AAGP,EAAA,KAAK,EAAE;AACL,IAAA,QAAQ,EAAE;AACR,MAAA,IAAI,EAAE,OADE;AAER,MAAA,OAAO,EAAE;AAFD,KADL;AAKL,IAAA,KAAK,EAAE;AACL,MAAA,IAAI,EAAE,OADD;AAEL,MAAA,OAAO,EAAE;AAFJ;AALF,GAHA;AAcP,EAAA,KAAK,EAAE,CAAC,mBAAD,CAdA;AAgBP,EAAA,OAAO,EAAE;AACP,IAAA,YAAY,GAAA;AACV,WAAK,QAAL,CAAc,MAAd;AACD,KAHM;;AAIP,IAAA,YAAY,GAAA;AACV,WAAK,QAAL,CAAc,OAAd;AACD;;AANM,GAhBF;;AAyBP,EAAA,MAAM,GAAA;AACJ,QAAI,CAAC,KAAK,MAAL,CAAY,OAAb,IAAwB,KAAK,KAAL,KAAe,SAA3C,EAAsD;AACpD,MAAA,WAAW,CAAC,wDAAD,EAA2D,IAA3D,CAAX;AAEA,aAAO,IAAP;AACD;;AAED,QAAI,OAAJ;AAEA;;AACA,QAAI,KAAK,MAAL,CAAY,OAAhB,EAAyB;AACvB,MAAA,OAAO,GAAG,KAAK,MAAL,CAAY,OAAZ,CAAoB;AAAE,QAAA,KAAK,EAAE,KAAK;AAAd,OAApB,CAAV;AACD;;AAED,QAAI,KAAK,CAAC,OAAN,CAAc,OAAd,KAA0B,OAAO,CAAC,MAAR,KAAmB,CAAjD,EAAoD;AAClD,MAAA,OAAO,GAAG,OAAO,CAAC,CAAD,CAAjB;AACD;;AAED,QAAI,CAAC,OAAD,IAAY,KAAK,CAAC,OAAN,CAAc,OAAd,CAAZ,IAAsC,CAAC,OAAO,CAAC,GAAnD,EAAwD;AACtD,MAAA,WAAW,CAAC,8CAAD,EAAiD,IAAjD,CAAX;AAEA,aAAO,OAAP;AACD;;AAED,QAAI,CAAC,KAAK,QAAV,EAAoB;AAClB,MAAA,OAAO,CAAC,IAAR,GAAe,OAAO,CAAC,IAAR,IAAgB,EAA/B;;AACA,WAAK,EAAL,CAAQ,OAAO,CAAC,IAAhB,EAAsB;AACpB,QAAA,UAAU,EAAE,KAAK,YADG;AAEpB,QAAA,UAAU,EAAE,KAAK;AAFG,OAAtB;AAID;;AAED,WAAO,OAAP;AACD;;AA1DM,CAJM,CAAf","sourcesContent":["// Mixins\nimport Delayable from '../../mixins/delayable'\nimport Toggleable from '../../mixins/toggleable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { consoleWarn } from '../../util/console'\n\n// Types\nimport { VNode, ScopedSlotChildren } from 'vue/types/vnode'\n\nexport default mixins(\n Delayable,\n Toggleable\n /* @vue/component */\n).extend({\n name: 'v-hover',\n\n props: {\n disabled: {\n type: Boolean,\n default: false,\n },\n value: {\n type: Boolean,\n default: undefined,\n },\n },\n\n emits: ['update:modelValue'],\n\n methods: {\n onMouseEnter () {\n this.runDelay('open')\n },\n onMouseLeave () {\n this.runDelay('close')\n },\n },\n\n render (): VNode {\n if (!this.$slots.default && this.value === undefined) {\n consoleWarn('v-hover is missing a default scopedSlot or bound value', this)\n\n return null as any\n }\n\n let element: VNode | ScopedSlotChildren\n\n /* istanbul ignore else */\n if (this.$slots.default) {\n element = this.$slots.default({ hover: this.isActive })\n }\n\n if (Array.isArray(element) && element.length === 1) {\n element = element[0]\n }\n\n if (!element || Array.isArray(element) || !element.tag) {\n consoleWarn('v-hover should only contain a single element', this)\n\n return element as any\n }\n\n if (!this.disabled) {\n element.data = element.data || {}\n this._g(element.data, {\n mouseenter: this.onMouseEnter,\n mouseleave: this.onMouseLeave,\n })\n }\n\n return element\n },\n})\n"],"sourceRoot":"","file":"VHover.js"}
1
+ {"version":3,"sources":["../../../src/components/VHover/VHover.ts"],"names":[],"mappings":"AAAA;AACA,OAAO,SAAP,MAAsB,wBAAtB;AACA,OAAO,UAAP,MAAuB,yBAAvB,C,CAEA;;AACA,OAAO,MAAP,MAAmB,mBAAnB;AACA,SAAS,WAAT,QAA4B,oBAA5B,C,CAEA;;AACA,SAAgB,UAAhB,QAAkC,KAAlC;AAGA,eAAe,MAAM,CACnB,SADmB,EAEnB;AACA;AAHmB,CAAN,CAIb,MAJa,CAIN;AACP,EAAA,IAAI,EAAE,SADC;AAGP,EAAA,KAAK,EAAE;AACL,IAAA,QAAQ,EAAE;AACR,MAAA,IAAI,EAAE,OADE;AAER,MAAA,OAAO,EAAE;AAFD,KADL;AAKL,IAAA,UAAU,EAAE;AACV,MAAA,IAAI,EAAE,OADI;AAEV,MAAA,OAAO,EAAE;AAFC;AALP,GAHA;AAcP,EAAA,KAAK,EAAE,CAAC,mBAAD,CAdA;AAgBP,EAAA,OAAO,EAAE;AACP,IAAA,YAAY,GAAA;AACV,UAAI,KAAK,QAAT,EAAmB;AACnB,WAAK,QAAL,CAAc,MAAd;AACD,KAJM;;AAKP,IAAA,YAAY,GAAA;AACV,UAAI,KAAK,QAAT,EAAmB;AACnB,WAAK,QAAL,CAAc,OAAd;AACD;;AARM,GAhBF;;AA2BP,EAAA,MAAM,GAAA;AACJ,QAAI,CAAC,KAAK,MAAL,CAAY,OAAb,IAAwB,KAAK,UAAL,KAAoB,SAAhD,EAA2D;AACzD,MAAA,WAAW,CAAC,wDAAD,EAA2D,IAA3D,CAAX;AACA,aAAO,IAAP;AACD;;AAED,QAAI,CAAC,KAAK,MAAL,CAAY,OAAjB,EAA0B,OAAO,IAAP;AAE1B,UAAM,WAAW,GAAG,KAAK,MAAL,CAAY,OAAZ,CAAoB;AAAE,MAAA,KAAK,EAAE,KAAK;AAAd,KAApB,CAApB;;AAEA,QAAI,EAAC,WAAW,KAAA,IAAX,IAAA,WAAW,KAAA,KAAA,CAAX,GAAW,KAAA,CAAX,GAAA,WAAW,CAAE,MAAd,CAAJ,EAA0B;AACxB,MAAA,WAAW,CAAC,qCAAD,EAAwC,IAAxC,CAAX;AACA,aAAO,IAAP;AACD;;AAED,UAAM,OAAO,GAAG,WAAW,CAAC,CAAD,CAA3B;;AAEA,QAAI,EAAC,OAAO,KAAA,IAAP,IAAA,OAAO,KAAA,KAAA,CAAP,GAAO,KAAA,CAAP,GAAA,OAAO,CAAE,IAAV,CAAJ,EAAoB;AAClB,MAAA,WAAW,CAAC,kDAAD,EAAqD,IAArD,CAAX;AACA,aAAO,OAAP;AACD;;AAED,QAAI,WAAW,CAAC,MAAZ,GAAqB,CAAzB,EAA4B;AAC1B,MAAA,WAAW,CAAC,8CAAD,EAAiD,IAAjD,CAAX;AACD;;AAED,QAAI,CAAC,KAAK,QAAV,EAAoB;AAClB,MAAA,OAAO,CAAC,KAAR,GAAgB,UAAU,CAAC,OAAO,CAAC,KAAR,IAAiB,EAAlB,EAAsB;AAC9C,QAAA,YAAY,EAAE,KAAK,YAD2B;AAE9C,QAAA,YAAY,EAAE,KAAK;AAF2B,OAAtB,CAA1B;AAID;;AAED,WAAO,OAAP;AACD;;AA7DM,CAJM,CAAf","sourcesContent":["// Mixins\nimport Delayable from '../../mixins/delayable'\nimport Toggleable from '../../mixins/toggleable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { consoleWarn } from '../../util/console'\n\n// Types\nimport { VNode, mergeProps } from 'vue'\nimport { ScopedSlotChildren } from 'vue/types/vnode'\n\nexport default mixins(\n Delayable,\n Toggleable\n /* @vue/component */\n).extend({\n name: 'v-hover',\n\n props: {\n disabled: {\n type: Boolean,\n default: false,\n },\n modelValue: {\n type: Boolean,\n default: undefined,\n },\n },\n\n emits: ['update:modelValue'],\n\n methods: {\n onMouseEnter () {\n if (this.disabled) return\n this.runDelay('open')\n },\n onMouseLeave () {\n if (this.disabled) return\n this.runDelay('close')\n },\n },\n\n render (): VNode {\n if (!this.$slots.default && this.modelValue === undefined) {\n consoleWarn('v-hover is missing a default scopedSlot or bound value', this)\n return null as any\n }\n\n if (!this.$slots.default) return null as any\n\n const slotContent = this.$slots.default({ hover: this.isActive })\n\n if (!slotContent?.length) {\n consoleWarn('v-hover slot returned empty content', this)\n return null as any\n }\n\n const element = slotContent[0]\n\n if (!element?.type) {\n consoleWarn('v-hover should only contain valid VNode elements', this)\n return element as any\n }\n\n if (slotContent.length > 1) {\n consoleWarn('v-hover should only contain a single element', this)\n }\n\n if (!this.disabled) {\n element.props = mergeProps(element.props || {}, {\n onMouseenter: this.onMouseEnter,\n onMouseleave: this.onMouseLeave,\n })\n }\n\n return element\n },\n})\n"],"sourceRoot":"","file":"VHover.js"}
@@ -9,7 +9,7 @@ import { convertToUnit, keys, remapInternalIcon } from '../../util/helpers'; //
9
9
 
10
10
  import { defineComponent, h } from 'vue';
11
11
  import mixins from '../../util/mixins';
12
- import { normalizeAttrs } from '../../util/helpers';
12
+ import { normalizeClasses } from '../../util/helpers';
13
13
  var SIZE_MAP;
14
14
 
15
15
  (function (SIZE_MAP) {
@@ -29,7 +29,11 @@ function isSvgPath(icon) {
29
29
  return /^[mzlhvcsqta]\s*[-+.0-9][^mlhvzcsqta]+/i.test(icon) && /[\dz]$/i.test(icon) && icon.length > 4;
30
30
  }
31
31
 
32
- const VIcon = mixins(BindsAttrs, Colorable, Sizeable, Themeable
32
+ function classesToString(classObj) {
33
+ return Object.keys(classObj).filter(key => classObj[key]).join(' ');
34
+ }
35
+
36
+ export const VIconInternal = mixins(BindsAttrs, Colorable, Sizeable, Themeable
33
37
  /* @vue/component */
34
38
  ).extend({
35
39
  name: 'v-icon',
@@ -60,8 +64,15 @@ const VIcon = mixins(BindsAttrs, Colorable, Sizeable, Themeable
60
64
  let iconName = '';
61
65
 
62
66
  if (this.$slots.default) {
63
- const children = this.$slots.default()[0].children;
64
- if (typeof children === 'string') iconName = this.$slots.default()[0].children.trim();
67
+ const slotChildren = this.$slots.default();
68
+
69
+ if (slotChildren && slotChildren[0]) {
70
+ const children = slotChildren[0].children;
71
+
72
+ if (typeof children === 'string') {
73
+ iconName = children.trim();
74
+ }
75
+ }
65
76
  }
66
77
 
67
78
  return remapInternalIcon(this, iconName);
@@ -104,29 +115,37 @@ const VIcon = mixins(BindsAttrs, Colorable, Sizeable, Themeable
104
115
  return data;
105
116
  },
106
117
 
118
+ applyColors(data) {
119
+ this.setTextColor(this.color, data);
120
+ },
121
+
107
122
  getSvgWrapperData() {
108
123
  const fontSize = this.getSize();
109
- const wrapperData = { ...this.getDefaultData(),
124
+ const defaultData = this.getDefaultData();
125
+ const normalizedClasses = normalizeClasses([defaultData.class, this.themeClasses]);
126
+ const wrapperData = {
127
+ class: classesToString(normalizedClasses),
128
+ 'aria-hidden': defaultData['aria-hidden'],
129
+ type: defaultData.type,
110
130
  style: fontSize ? {
111
131
  fontSize,
112
132
  height: fontSize,
113
133
  width: fontSize
114
- } : undefined
134
+ } : undefined,
135
+ ...this.listeners$
115
136
  };
137
+
138
+ if (this.hasClickListener && this.disabled) {
139
+ wrapperData.disabled = true;
140
+ }
141
+
116
142
  this.applyColors(wrapperData);
117
143
  return wrapperData;
118
144
  },
119
145
 
120
- applyColors(data) {
121
- data.class = { ...data.class,
122
- ...this.themeClasses
123
- };
124
- this.setTextColor(this.color, data);
125
- },
126
-
127
146
  renderFontIcon(icon) {
128
147
  const newChildren = [];
129
- let data = this.getDefaultData();
148
+ const defaultData = this.getDefaultData();
130
149
  let iconType = 'material-icons'; // Material Icon delimiter is _
131
150
  // https://material.io/icons/
132
151
 
@@ -139,76 +158,79 @@ const VIcon = mixins(BindsAttrs, Colorable, Sizeable, Themeable
139
158
  } else {
140
159
  iconType = icon.slice(0, delimiterIndex);
141
160
  if (isFontAwesome5(iconType)) iconType = '';
142
- }
161
+ } // Создаем объект классов для иконки
143
162
 
144
- if (typeof data.class === 'string') {
145
- data.class = data.class.split(' ').reduce((classes, className) => {
146
- classes[className] = true;
147
- return classes;
148
- }, {});
163
+
164
+ const iconClasses = {
165
+ [iconType]: true
166
+ };
167
+
168
+ if (!isMaterialIcon) {
169
+ iconClasses[icon] = true;
149
170
  }
150
171
 
151
- data.class[iconType] = true;
152
- data.class[icon] = !isMaterialIcon;
172
+ const allClasses = normalizeClasses([defaultData.class, this.themeClasses, iconClasses]);
153
173
  const fontSize = this.getSize();
154
- if (fontSize) data.style = {
155
- fontSize
174
+ const fontData = {
175
+ class: classesToString(allClasses),
176
+ 'aria-hidden': defaultData['aria-hidden'],
177
+ type: defaultData.type,
178
+ style: fontSize ? {
179
+ fontSize
180
+ } : undefined,
181
+ ...this.listeners$
156
182
  };
157
- this.applyColors(data);
158
- return h(this.hasClickListener ? 'button' : this.tag, normalizeAttrs(data), {
183
+
184
+ if (this.hasClickListener && this.disabled) {
185
+ fontData.disabled = true;
186
+ }
187
+
188
+ this.applyColors(fontData);
189
+ return h(this.hasClickListener ? 'button' : this.tag, fontData, {
159
190
  default: () => newChildren
160
191
  });
161
192
  },
162
193
 
163
194
  renderSvgIcon(icon) {
164
- const svgData = {
195
+ const size = this.getSize();
196
+ const svgProps = {
165
197
  class: 'v-icon__svg',
166
- attrs: {
167
- xmlns: 'http://www.w3.org/2000/svg',
168
- viewBox: '0 0 24 24',
169
- role: 'img',
170
- 'aria-hidden': true
171
- }
198
+ xmlns: 'http://www.w3.org/2000/svg',
199
+ viewBox: '0 0 24 24',
200
+ role: 'img',
201
+ 'aria-hidden': true
172
202
  };
173
- const size = this.getSize();
174
203
 
175
204
  if (size) {
176
- svgData.style = {
205
+ svgProps.style = {
177
206
  fontSize: size,
178
207
  height: size,
179
208
  width: size
180
209
  };
181
210
  }
182
211
 
183
- return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), [h('svg', svgData, [h('path', {
184
- attrs: {
185
- d: icon
186
- }
212
+ return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), [h('svg', svgProps, [h('path', {
213
+ d: icon
187
214
  })])]);
188
215
  },
189
216
 
190
217
  renderSvgIconComponent(icon) {
191
- const data = {
192
- class: {
193
- 'v-icon__component': true
194
- }
195
- };
196
218
  const size = this.getSize();
197
-
198
- if (size) {
199
- data.style = {
219
+ const componentClasses = normalizeClasses([{
220
+ 'v-icon__component': true
221
+ }, this.themeClasses]);
222
+ const componentData = {
223
+ class: classesToString(componentClasses),
224
+ style: size ? {
200
225
  fontSize: size,
201
226
  height: size,
202
227
  width: size
203
- };
204
- }
205
-
206
- this.applyColors(data);
207
- const component = icon.component;
208
- data.props = icon.props;
209
- data.nativeOn = data.on;
228
+ } : undefined,
229
+ ...icon.props
230
+ };
231
+ this.applyColors(componentData);
210
232
  return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), {
211
- default: () => [h(component, data)]
233
+ default: () => [h(icon.component, componentData)]
212
234
  });
213
235
  }
214
236
 
@@ -231,7 +253,7 @@ const VIcon = mixins(BindsAttrs, Colorable, Sizeable, Themeable
231
253
  });
232
254
  export default defineComponent({
233
255
  name: 'v-icon',
234
- $_wrapperFor: VIcon,
256
+ $_wrapperFor: VIconInternal,
235
257
  functional: true,
236
258
 
237
259
  mounted() {
@@ -242,7 +264,7 @@ export default defineComponent({
242
264
  const data = { ...this.$attrs
243
265
  }; // console.log(children && children[0]?.children)
244
266
 
245
- return h(VIcon, data, {
267
+ return h(VIconInternal, data, {
246
268
  default: () => {
247
269
  var _a, _b, _c, _d;
248
270
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VIcon/VIcon.ts"],"names":[],"mappings":"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","sourcesContent":["import './VIcon.sass'\n\n// Mixins\nimport BindsAttrs from '../../mixins/binds-attrs'\nimport Colorable from '../../mixins/colorable'\nimport Sizeable from '../../mixins/sizeable'\nimport Themeable from '../../mixins/themeable'\n\n// Util\nimport { convertToUnit, keys, remapInternalIcon } from '../../util/helpers'\n\n// Types\nimport { defineComponent, CreateElement, VNode, VNodeChildren, VNodeData, h } from 'vue'\nimport mixins from '../../util/mixins'\nimport { VuetifyIcon, VuetifyIconComponent } from 'vuetify/types/services/icons'\nimport { normalizeAttrs } from '../../util/helpers'\n\nenum SIZE_MAP {\n xSmall = '12px',\n small = '16px',\n default = '24px',\n medium = '28px',\n large = '36px',\n xLarge = '40px'\n}\n\nfunction isFontAwesome5 (iconType: string): boolean {\n return ['fas', 'far', 'fal', 'fab', 'fad', 'fak'].some(val => iconType.includes(val))\n}\n\nfunction isSvgPath (icon: string): boolean {\n return (/^[mzlhvcsqta]\\s*[-+.0-9][^mlhvzcsqta]+/i.test(icon) && /[\\dz]$/i.test(icon) && icon.length > 4)\n}\n\n\nconst VIcon = mixins(\n BindsAttrs,\n Colorable,\n Sizeable,\n Themeable\n /* @vue/component */\n).extend({\n name: 'v-icon',\n\n props: {\n dense: Boolean,\n disabled: Boolean,\n left: Boolean,\n right: Boolean,\n size: [Number, String],\n tag: {\n type: String,\n required: false,\n default: 'i',\n },\n },\n\n computed: {\n medium () {\n return false\n },\n hasClickListener (): boolean {\n return Boolean(\n this.listeners$.onClick\n )\n },\n },\n\n methods: {\n getIcon (): VuetifyIcon {\n let iconName = ''\n if (this.$slots.default) {\n const children = this.$slots.default()[0].children\n if(typeof children === 'string')\n iconName = this.$slots.default()[0].children!.trim()\n\n }\n return remapInternalIcon(this, iconName)\n },\n getSize (): string | undefined {\n const sizes = {\n xSmall: this.xSmall,\n small: this.small,\n medium: this.medium,\n large: this.large,\n xLarge: this.xLarge,\n }\n\n const explicitSize = keys(sizes).find(key => sizes[key])\n\n return (\n (explicitSize && SIZE_MAP[explicitSize]) || convertToUnit(this.size)\n )\n },\n // Component data for both font icon and SVG wrapper span\n getDefaultData (): VNodeData {\n const data = {\n class: {\n 'v-icon--disabled': this.disabled,\n 'v-icon--left': this.left,\n 'v-icon--link': this.hasClickListener,\n 'v-icon--right': this.right,\n 'v-icon--dense': this.dense,\n 'v-icon': true,\n 'notranslate': true\n },\n 'aria-hidden': !this.hasClickListener,\n type: this.hasClickListener ? 'button' : undefined,\n // ...this.attrs$,\n ...this.listeners$,\n }\n\n if(this.hasClickListener && this.disabled) {\n data.disabled = true\n }\n return data\n },\n getSvgWrapperData () {\n const fontSize = this.getSize()\n const wrapperData = {\n ...this.getDefaultData(),\n style: fontSize ? {\n fontSize,\n height: fontSize,\n width: fontSize,\n } : undefined,\n }\n this.applyColors(wrapperData)\n\n return wrapperData\n },\n applyColors (data: VNodeData): void {\n data.class = { ...data.class, ...this.themeClasses }\n this.setTextColor(this.color, data)\n },\n renderFontIcon (icon: string): VNode {\n const newChildren: VNodeChildren = []\n let data = this.getDefaultData()\n\n let iconType = 'material-icons'\n // Material Icon delimiter is _\n // https://material.io/icons/\n const delimiterIndex = icon.indexOf('-')\n const isMaterialIcon = delimiterIndex <= -1\n\n if (isMaterialIcon) {\n // Material icon uses ligatures.\n newChildren.push(icon)\n } else {\n iconType = icon.slice(0, delimiterIndex)\n if (isFontAwesome5(iconType)) iconType = ''\n }\n\n if(typeof data.class === 'string') {\n data.class = data.class.split(' ').reduce((classes, className) => {\n classes[className] = true\n return classes\n }, {})\n }\n\n data.class[iconType] = true\n data.class[icon] = !isMaterialIcon\n\n const fontSize = this.getSize()\n if (fontSize) data.style = { fontSize }\n\n this.applyColors(data)\n\n return h(this.hasClickListener ? 'button' : this.tag, normalizeAttrs(data), {default: () => newChildren})\n },\n renderSvgIcon (icon: string): VNode {\n const svgData: VNodeData = {\n class: 'v-icon__svg',\n attrs: {\n xmlns: 'http://www.w3.org/2000/svg',\n viewBox: '0 0 24 24',\n role: 'img',\n 'aria-hidden': true,\n },\n }\n\n const size = this.getSize()\n if (size) {\n svgData.style = {\n fontSize: size,\n height: size,\n width: size,\n }\n }\n\n return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), [\n h('svg', svgData, [\n h('path', {\n attrs: {\n d: icon,\n },\n }),\n ]),\n ])\n },\n renderSvgIconComponent (\n icon: VuetifyIconComponent\n ): VNode {\n const data: VNodeData = {\n class: {\n 'v-icon__component': true,\n },\n }\n\n const size = this.getSize()\n if (size) {\n data.style = {\n fontSize: size,\n height: size,\n width: size,\n }\n }\n\n this.applyColors(data)\n\n const component = icon.component\n data.props = icon.props\n data.nativeOn = data.on\n\n return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), {default: () =>[\n h(component, data),\n ]})\n },\n },\n\n render (): VNode {\n const icon = this.getIcon()\n\n if (typeof icon === 'string') {\n if (isSvgPath(icon)) {\n return this.renderSvgIcon(icon)\n }\n return this.renderFontIcon(icon)\n }\n\n return this.renderSvgIconComponent(icon)\n },\n})\n\nexport default defineComponent({\n name: 'v-icon',\n\n $_wrapperFor: VIcon,\n\n functional: true,\n\n mounted() {\n this.$el.innerHTML = ''\n },\n\n render (): VNode {\n const data = { ...this.$attrs }\n\n\n // console.log(children && children[0]?.children)\n return h(VIcon, data, {\n default: () => {\n let iconName = ''\n\n // Support usage of v-text and v-html\n // if (data.domProps) {\n if(this.$.vnode.props?.textContent) {\n iconName = this.$.vnode.props.textContent ||\n this.$.vnode.props.innerHTML ||\n iconName\n }\n\n const children = this.$slots.default?.()\n\n return iconName ? [iconName] : children && children[0]?.children\n }\n })\n }\n})\n"],"sourceRoot":"","file":"VIcon.js"}
1
+ {"version":3,"sources":["../../../src/components/VIcon/VIcon.ts"],"names":[],"mappings":"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","sourcesContent":["import './VIcon.sass'\n\n// Mixins\nimport BindsAttrs from '../../mixins/binds-attrs'\nimport Colorable from '../../mixins/colorable'\nimport Sizeable from '../../mixins/sizeable'\nimport Themeable from '../../mixins/themeable'\n\n// Util\nimport { convertToUnit, keys, remapInternalIcon } from '../../util/helpers'\n\n// Types\nimport { defineComponent, CreateElement, VNode, VNodeChildren, VNodeData, h } from 'vue'\nimport mixins from '../../util/mixins'\nimport { VuetifyIcon, VuetifyIconComponent } from 'vuetify/types/services/icons'\nimport { normalizeAttrs, normalizeClasses } from '../../util/helpers'\n\nenum SIZE_MAP {\n xSmall = '12px',\n small = '16px',\n default = '24px',\n medium = '28px',\n large = '36px',\n xLarge = '40px'\n}\n\nfunction isFontAwesome5 (iconType: string): boolean {\n return ['fas', 'far', 'fal', 'fab', 'fad', 'fak'].some(val => iconType.includes(val))\n}\n\nfunction isSvgPath (icon: string): boolean {\n return (/^[mzlhvcsqta]\\s*[-+.0-9][^mlhvzcsqta]+/i.test(icon) && /[\\dz]$/i.test(icon) && icon.length > 4)\n}\n\nfunction classesToString (classObj: Record<string, boolean>): string {\n return Object.keys(classObj).filter(key => classObj[key]).join(' ')\n}\n\n\nexport const VIconInternal = mixins(\n BindsAttrs,\n Colorable,\n Sizeable,\n Themeable\n /* @vue/component */\n).extend({\n name: 'v-icon',\n\n props: {\n dense: Boolean,\n disabled: Boolean,\n left: Boolean,\n right: Boolean,\n size: [Number, String],\n tag: {\n type: String,\n required: false,\n default: 'i',\n },\n },\n\n computed: {\n medium () {\n return false\n },\n hasClickListener (): boolean {\n return Boolean(\n this.listeners$.onClick\n )\n },\n },\n\n methods: {\n getIcon (): VuetifyIcon {\n let iconName = ''\n if (this.$slots.default) {\n const slotChildren = this.$slots.default()\n if (slotChildren && slotChildren[0]) {\n const children = slotChildren[0].children\n if(typeof children === 'string') {\n iconName = children.trim()\n }\n }\n }\n return remapInternalIcon(this, iconName)\n },\n getSize (): string | undefined {\n const sizes = {\n xSmall: this.xSmall,\n small: this.small,\n medium: this.medium,\n large: this.large,\n xLarge: this.xLarge,\n }\n\n const explicitSize = keys(sizes).find(key => sizes[key])\n\n return (\n (explicitSize && SIZE_MAP[explicitSize]) || convertToUnit(this.size)\n )\n },\n // Component data for both font icon and SVG wrapper span\n getDefaultData (): VNodeData {\n const data = {\n class: {\n 'v-icon--disabled': this.disabled,\n 'v-icon--left': this.left,\n 'v-icon--link': this.hasClickListener,\n 'v-icon--right': this.right,\n 'v-icon--dense': this.dense,\n 'v-icon': true,\n 'notranslate': true\n },\n 'aria-hidden': !this.hasClickListener,\n type: this.hasClickListener ? 'button' : undefined,\n // ...this.attrs$,\n ...this.listeners$,\n }\n\n if(this.hasClickListener && this.disabled) {\n data.disabled = true\n }\n return data\n },\n applyColors (data: any): void {\n this.setTextColor(this.color, data)\n },\n getSvgWrapperData () {\n const fontSize = this.getSize()\n\n const defaultData = this.getDefaultData()\n const normalizedClasses = normalizeClasses([defaultData.class, this.themeClasses])\n\n const wrapperData: any = {\n class: classesToString(normalizedClasses),\n 'aria-hidden': defaultData['aria-hidden'],\n type: defaultData.type,\n style: fontSize ? {\n fontSize,\n height: fontSize,\n width: fontSize,\n } : undefined,\n ...this.listeners$,\n }\n\n if(this.hasClickListener && this.disabled) {\n wrapperData.disabled = true\n }\n\n this.applyColors(wrapperData)\n\n return wrapperData\n },\n renderFontIcon (icon: string): VNode {\n const newChildren: VNodeChildren = []\n const defaultData = this.getDefaultData()\n\n let iconType = 'material-icons'\n // Material Icon delimiter is _\n // https://material.io/icons/\n const delimiterIndex = icon.indexOf('-')\n const isMaterialIcon = delimiterIndex <= -1\n\n if (isMaterialIcon) {\n // Material icon uses ligatures.\n newChildren.push(icon)\n } else {\n iconType = icon.slice(0, delimiterIndex)\n if (isFontAwesome5(iconType)) iconType = ''\n }\n\n // Создаем объект классов для иконки\n const iconClasses = { [iconType]: true }\n if (!isMaterialIcon) {\n iconClasses[icon] = true\n }\n\n const allClasses = normalizeClasses([defaultData.class, this.themeClasses, iconClasses])\n\n const fontSize = this.getSize()\n const fontData: any = {\n class: classesToString(allClasses),\n 'aria-hidden': defaultData['aria-hidden'],\n type: defaultData.type,\n style: fontSize ? { fontSize } : undefined,\n ...this.listeners$,\n }\n\n if(this.hasClickListener && this.disabled) {\n fontData.disabled = true\n }\n\n this.applyColors(fontData)\n\n return h(this.hasClickListener ? 'button' : this.tag, fontData, {default: () => newChildren})\n },\n renderSvgIcon (icon: string): VNode {\n const size = this.getSize()\n const svgProps: any = {\n class: 'v-icon__svg',\n xmlns: 'http://www.w3.org/2000/svg',\n viewBox: '0 0 24 24',\n role: 'img',\n 'aria-hidden': true,\n }\n\n if (size) {\n svgProps.style = {\n fontSize: size,\n height: size,\n width: size,\n }\n }\n\n return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), [\n h('svg', svgProps, [\n h('path', {\n d: icon,\n }),\n ]),\n ])\n },\n renderSvgIconComponent (\n icon: VuetifyIconComponent\n ): VNode {\n const size = this.getSize()\n const componentClasses = normalizeClasses([\n { 'v-icon__component': true },\n this.themeClasses\n ])\n\n const componentData: any = {\n class: classesToString(componentClasses),\n style: size ? {\n fontSize: size,\n height: size,\n width: size,\n } : undefined,\n ...icon.props,\n }\n\n this.applyColors(componentData)\n\n return h(this.hasClickListener ? 'button' : 'span', this.getSvgWrapperData(), {default: () =>[\n h(icon.component, componentData),\n ]})\n },\n },\n\n render (): VNode {\n const icon = this.getIcon()\n\n if (typeof icon === 'string') {\n if (isSvgPath(icon)) {\n return this.renderSvgIcon(icon)\n }\n return this.renderFontIcon(icon)\n }\n\n return this.renderSvgIconComponent(icon)\n },\n})\n\nexport default defineComponent({\n name: 'v-icon',\n\n $_wrapperFor: VIconInternal,\n\n functional: true,\n\n mounted() {\n this.$el.innerHTML = ''\n },\n\n render (): VNode {\n const data = { ...this.$attrs }\n\n\n // console.log(children && children[0]?.children)\n return h(VIconInternal, data, {\n default: () => {\n let iconName = ''\n\n // Support usage of v-text and v-html\n // if (data.domProps) {\n if(this.$.vnode.props?.textContent) {\n iconName = this.$.vnode.props.textContent ||\n this.$.vnode.props.innerHTML ||\n iconName\n }\n\n const children = this.$slots.default?.()\n\n return iconName ? [iconName] : children && children[0]?.children\n }\n })\n }\n})\n"],"sourceRoot":"","file":"VIcon.js"}
@@ -55,8 +55,9 @@ export const BaseItem = defineComponent({
55
55
  }
56
56
 
57
57
  element.props = mergeProps(element.props || {}, {
58
- class: {
59
- [this.activeClass]: this.isActive,
58
+ class: { ...(this.$activeClass && {
59
+ [this.$activeClass]: this.isActive
60
+ }),
60
61
  "v-item--disabled": this.disabled
61
62
  }
62
63
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VItemGroup/VItem.ts"],"names":[],"mappings":"AAAA;AACA,OAAO,+CAAP,C,CAEA;;AACA,SAAS,OAAO,IAAI,gBAApB,QAA4C,wBAA5C,C,CAEA;;AACA,OAAO,MAAP,MAAmB,mBAAnB;AACA,SAAS,WAAT,QAA4B,oBAA5B;AACA,SAAS,eAAT,EAA0B,UAA1B,QAA4C,KAA5C;AAIA;;AACA,OAAO,MAAM,QAAQ,GAAG,eAAe,CAAC;AACtC,EAAA,KAAK,EAAE;AACL,IAAA,WAAW,EAAE,MADR;AAEL,IAAA,KAAK,EAAE;AACL,MAAA,QAAQ,EAAE;AADL,KAFF;AAKL,IAAA,QAAQ,EAAE;AALL,GAD+B;AAStC,EAAA,IAAI,EAAE,OAAO;AACX,IAAA,QAAQ,EAAE;AADC,GAAP,CATgC;AAatC,EAAA,OAAO,EAAE;AACP,IAAA,MAAM,GAAA;AACJ,WAAK,QAAL,GAAgB,CAAC,KAAK,QAAtB;AACD;;AAHM,GAb6B;;AAmBtC,EAAA,MAAM,GAAA;AACJ,QAAI,CAAC,KAAK,MAAL,CAAY,OAAjB,EAA0B;AACxB,MAAA,WAAW,CAAC,wCAAD,EAA2C,IAA3C,CAAX;AACA,aAAO,IAAP;AACD;;AAED,UAAM,WAAW,GAAG,KAAK,MAAL,CAAY,OAAZ,CAAoB;AACtC,MAAA,MAAM,EAAE,KAAK,QADyB;AAEtC,MAAA,MAAM,EAAE,KAAK;AAFyB,KAApB,CAApB;;AAKA,QAAI,CAAC,WAAD,IAAgB,WAAW,CAAC,MAAZ,KAAuB,CAA3C,EAA8C;AAC5C,MAAA,WAAW,CAAC,oCAAD,EAAuC,IAAvC,CAAX;AACA,aAAO,IAAP;AACD;;AAED,QAAI,OAAO,GAAG,WAAW,CAAC,CAAD,CAAzB;;AAEA,QAAI,CAAC,OAAL,EAAc;AACZ,MAAA,WAAW,CAAC,4CAAD,EAA+C,IAA/C,CAAX;AACA,aAAO,IAAP;AACD;;AAED,QAAI,CAAC,OAAO,CAAC,IAAb,EAAmB;AACjB,MAAA,WAAW,CAAC,iDAAD,EAAoD,IAApD,CAAX;AACA,aAAO,OAAP;AACD;;AAED,IAAA,OAAO,CAAC,KAAR,GAAgB,UAAU,CAAC,OAAO,CAAC,KAAR,IAAiB,EAAlB,EAAsB;AAC9C,MAAA,KAAK,EAAE;AACL,SAAC,KAAK,WAAN,GAAoB,KAAK,QADpB;AAEL,4BAAoB,KAAK;AAFpB;AADuC,KAAtB,CAA1B;;AAOA,QAAI,KAAK,QAAT,EAAmB;AACjB,MAAA,OAAO,CAAC,KAAR,GAAgB,UAAU,CAAC,OAAO,CAAC,KAAR,IAAiB,EAAlB,EAAsB;AAC9C,QAAA,QAAQ,EAAE,CAAC;AADmC,OAAtB,CAA1B;AAGD;;AAED,WAAO,OAAP;AACD;;AA7DqC,CAAD,CAAhC;AAgEP,eAAe,MAAM,CACnB,QADmB,EAEnB,gBAAgB,CAAC,WAAD,EAAc,QAAd,EAAwB,cAAxB,CAFG,CAAN,CAGb,MAHa,CAGN;AACP,EAAA,IAAI,EAAE,QADC;AAGP,EAAA,KAAK,EAAE,CACL,QADK;AAHA,CAHM,CAAf","sourcesContent":["// Styles\nimport './VItem.sass'\n\n// Mixins\nimport { factory as GroupableFactory } from '../../mixins/groupable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { consoleWarn } from '../../util/console'\nimport { defineComponent, mergeProps } from \"vue\"\n\nimport type { VNode } from 'vue'\n\n/* @vue/component */\nexport const BaseItem = defineComponent({\n props: {\n activeClass: String,\n value: {\n required: false,\n },\n disabled: Boolean,\n },\n\n data: () => ({\n isActive: false,\n }),\n\n methods: {\n toggle () {\n this.isActive = !this.isActive\n },\n },\n\n render (): VNode | null {\n if (!this.$slots.default) {\n consoleWarn('v-item is missing a default scopedSlot', this)\n return null\n }\n\n const slotContent = this.$slots.default({\n active: this.isActive,\n toggle: this.toggle,\n })\n\n if (!slotContent || slotContent.length === 0) {\n consoleWarn('v-item slot returned empty content', this)\n return null\n }\n\n let element = slotContent[0]\n\n if (!element) {\n consoleWarn('v-item should contain at least one element', this)\n return null\n }\n\n if (!element.type) {\n consoleWarn('v-item should only contain valid VNode elements', this)\n return element\n }\n\n element.props = mergeProps(element.props || {}, {\n class: {\n [this.activeClass]: this.isActive,\n \"v-item--disabled\": this.disabled\n }\n })\n\n if (this.disabled) {\n element.props = mergeProps(element.props || {}, {\n tabindex: -1\n })\n }\n\n return element\n },\n})\n\nexport default mixins(\n BaseItem,\n GroupableFactory('itemGroup', 'v-item', 'v-item-group')\n).extend({\n name: 'v-item',\n\n emits: [\n 'change',\n ],\n})\n"],"sourceRoot":"","file":"VItem.js"}
1
+ {"version":3,"sources":["../../../src/components/VItemGroup/VItem.ts"],"names":[],"mappings":"AAAA;AACA,OAAO,+CAAP,C,CAEA;;AACA,SAAS,OAAO,IAAI,gBAApB,QAA4C,wBAA5C,C,CAEA;;AACA,OAAO,MAAP,MAAmB,mBAAnB;AACA,SAAS,WAAT,QAA4B,oBAA5B;AACA,SAAS,eAAT,EAA0B,UAA1B,QAA4C,KAA5C;AAIA;;AACA,OAAO,MAAM,QAAQ,GAAG,eAAe,CAAC;AACtC,EAAA,KAAK,EAAE;AACL,IAAA,WAAW,EAAE,MADR;AAEL,IAAA,KAAK,EAAE;AACL,MAAA,QAAQ,EAAE;AADL,KAFF;AAKL,IAAA,QAAQ,EAAE;AALL,GAD+B;AAStC,EAAA,IAAI,EAAE,OAAO;AACX,IAAA,QAAQ,EAAE;AADC,GAAP,CATgC;AAatC,EAAA,OAAO,EAAE;AACP,IAAA,MAAM,GAAA;AACJ,WAAK,QAAL,GAAgB,CAAC,KAAK,QAAtB;AACD;;AAHM,GAb6B;;AAmBtC,EAAA,MAAM,GAAA;AACJ,QAAI,CAAC,KAAK,MAAL,CAAY,OAAjB,EAA0B;AACxB,MAAA,WAAW,CAAC,wCAAD,EAA2C,IAA3C,CAAX;AACA,aAAO,IAAP;AACD;;AAED,UAAM,WAAW,GAAG,KAAK,MAAL,CAAY,OAAZ,CAAoB;AACtC,MAAA,MAAM,EAAE,KAAK,QADyB;AAEtC,MAAA,MAAM,EAAE,KAAK;AAFyB,KAApB,CAApB;;AAKA,QAAI,CAAC,WAAD,IAAgB,WAAW,CAAC,MAAZ,KAAuB,CAA3C,EAA8C;AAC5C,MAAA,WAAW,CAAC,oCAAD,EAAuC,IAAvC,CAAX;AACA,aAAO,IAAP;AACD;;AAED,QAAI,OAAO,GAAG,WAAW,CAAC,CAAD,CAAzB;;AAEA,QAAI,CAAC,OAAL,EAAc;AACZ,MAAA,WAAW,CAAC,4CAAD,EAA+C,IAA/C,CAAX;AACA,aAAO,IAAP;AACD;;AAED,QAAI,CAAC,OAAO,CAAC,IAAb,EAAmB;AACjB,MAAA,WAAW,CAAC,iDAAD,EAAoD,IAApD,CAAX;AACA,aAAO,OAAP;AACD;;AAED,IAAA,OAAO,CAAC,KAAR,GAAgB,UAAU,CAAC,OAAO,CAAC,KAAR,IAAiB,EAAlB,EAAsB;AAC9C,MAAA,KAAK,EAAE,EACL,IAAI,KAAK,YAAL,IAAqB;AAAE,WAAC,KAAK,YAAN,GAAqB,KAAK;AAA5B,SAAzB,CADK;AAEL,4BAAoB,KAAK;AAFpB;AADuC,KAAtB,CAA1B;;AAOA,QAAI,KAAK,QAAT,EAAmB;AACjB,MAAA,OAAO,CAAC,KAAR,GAAgB,UAAU,CAAC,OAAO,CAAC,KAAR,IAAiB,EAAlB,EAAsB;AAC9C,QAAA,QAAQ,EAAE,CAAC;AADmC,OAAtB,CAA1B;AAGD;;AAED,WAAO,OAAP;AACD;;AA7DqC,CAAD,CAAhC;AAgEP,eAAe,MAAM,CACnB,QADmB,EAEnB,gBAAgB,CAAC,WAAD,EAAc,QAAd,EAAwB,cAAxB,CAFG,CAAN,CAGb,MAHa,CAGN;AACP,EAAA,IAAI,EAAE,QADC;AAGP,EAAA,KAAK,EAAE,CACL,QADK;AAHA,CAHM,CAAf","sourcesContent":["// Styles\nimport './VItem.sass'\n\n// Mixins\nimport { factory as GroupableFactory } from '../../mixins/groupable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { consoleWarn } from '../../util/console'\nimport { defineComponent, mergeProps } from \"vue\"\n\nimport type { VNode } from 'vue'\n\n/* @vue/component */\nexport const BaseItem = defineComponent({\n props: {\n activeClass: String,\n value: {\n required: false,\n },\n disabled: Boolean,\n },\n\n data: () => ({\n isActive: false,\n }),\n\n methods: {\n toggle () {\n this.isActive = !this.isActive\n },\n },\n\n render (): VNode | null {\n if (!this.$slots.default) {\n consoleWarn('v-item is missing a default scopedSlot', this)\n return null\n }\n\n const slotContent = this.$slots.default({\n active: this.isActive,\n toggle: this.toggle,\n })\n\n if (!slotContent || slotContent.length === 0) {\n consoleWarn('v-item slot returned empty content', this)\n return null\n }\n\n let element = slotContent[0]\n\n if (!element) {\n consoleWarn('v-item should contain at least one element', this)\n return null\n }\n\n if (!element.type) {\n consoleWarn('v-item should only contain valid VNode elements', this)\n return element\n }\n\n element.props = mergeProps(element.props || {}, {\n class: {\n ...(this.$activeClass && { [this.$activeClass]: this.isActive }),\n \"v-item--disabled\": this.disabled\n }\n })\n\n if (this.disabled) {\n element.props = mergeProps(element.props || {}, {\n tabindex: -1\n })\n }\n\n return element\n },\n})\n\nexport default mixins(\n BaseItem,\n GroupableFactory('itemGroup', 'v-item', 'v-item-group')\n).extend({\n name: 'v-item',\n\n emits: [\n 'change',\n ],\n})\n"],"sourceRoot":"","file":"VItem.js"}