@dimailn/vuetify 2.7.2-alpha4 → 2.7.2-alpha40

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 (1034) hide show
  1. package/dist/vuetify.js +4383 -2392
  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/VAlert/VAlert.js +39 -9
  6. package/es5/components/VAlert/VAlert.js.map +1 -1
  7. package/es5/components/VAppBar/VAppBar.js +23 -17
  8. package/es5/components/VAppBar/VAppBar.js.map +1 -1
  9. package/es5/components/VAppBar/VAppBarNavIcon.js +5 -1
  10. package/es5/components/VAppBar/VAppBarNavIcon.js.map +1 -1
  11. package/es5/components/VAutocomplete/VAutocomplete.js +11 -7
  12. package/es5/components/VAutocomplete/VAutocomplete.js.map +1 -1
  13. package/es5/components/VBadge/VBadge.js +46 -14
  14. package/es5/components/VBadge/VBadge.js.map +1 -1
  15. package/es5/components/VBanner/VBanner.js +51 -15
  16. package/es5/components/VBanner/VBanner.js.map +1 -1
  17. package/es5/components/VBottomNavigation/VBottomNavigation.js +36 -14
  18. package/es5/components/VBottomNavigation/VBottomNavigation.js.map +1 -1
  19. package/es5/components/VBreadcrumbs/VBreadcrumbs.js +22 -8
  20. package/es5/components/VBreadcrumbs/VBreadcrumbs.js.map +1 -1
  21. package/es5/components/VBreadcrumbs/VBreadcrumbsItem.js +4 -0
  22. package/es5/components/VBreadcrumbs/VBreadcrumbsItem.js.map +1 -1
  23. package/es5/components/VBtn/VBtn.js +20 -16
  24. package/es5/components/VBtn/VBtn.js.map +1 -1
  25. package/es5/components/VCalendar/VCalendar.js +27 -29
  26. package/es5/components/VCalendar/VCalendar.js.map +1 -1
  27. package/es5/components/VCalendar/VCalendarCategory.js +26 -34
  28. package/es5/components/VCalendar/VCalendarCategory.js.map +1 -1
  29. package/es5/components/VCalendar/VCalendarDaily.js +43 -60
  30. package/es5/components/VCalendar/VCalendarDaily.js.map +1 -1
  31. package/es5/components/VCalendar/VCalendarMonthly.js +2 -2
  32. package/es5/components/VCalendar/VCalendarMonthly.js.map +1 -1
  33. package/es5/components/VCalendar/VCalendarWeekly.js +36 -40
  34. package/es5/components/VCalendar/VCalendarWeekly.js.map +1 -1
  35. package/es5/components/VCalendar/mixins/calendar-base.js +5 -10
  36. package/es5/components/VCalendar/mixins/calendar-base.js.map +1 -1
  37. package/es5/components/VCalendar/mixins/calendar-with-events.js +43 -58
  38. package/es5/components/VCalendar/mixins/calendar-with-events.js.map +1 -1
  39. package/es5/components/VCalendar/mixins/calendar-with-intervals.js +2 -2
  40. package/es5/components/VCalendar/mixins/calendar-with-intervals.js.map +1 -1
  41. package/es5/components/VCalendar/mixins/times.js.map +1 -1
  42. package/es5/components/VCarousel/VCarousel.js +61 -17
  43. package/es5/components/VCarousel/VCarousel.js.map +1 -1
  44. package/es5/components/VCarousel/VCarouselItem.js +7 -3
  45. package/es5/components/VCarousel/VCarouselItem.js.map +1 -1
  46. package/es5/components/VCheckbox/VCheckbox.js +40 -9
  47. package/es5/components/VCheckbox/VCheckbox.js.map +1 -1
  48. package/es5/components/VCheckbox/VSimpleCheckbox.js +94 -38
  49. package/es5/components/VCheckbox/VSimpleCheckbox.js.map +1 -1
  50. package/es5/components/VChip/VChip.js +16 -7
  51. package/es5/components/VChip/VChip.js.map +1 -1
  52. package/es5/components/VColorPicker/VColorPicker.js +54 -39
  53. package/es5/components/VColorPicker/VColorPicker.js.map +1 -1
  54. package/es5/components/VColorPicker/VColorPickerCanvas.js +45 -46
  55. package/es5/components/VColorPicker/VColorPickerCanvas.js.map +1 -1
  56. package/es5/components/VColorPicker/VColorPickerEdit.js +27 -26
  57. package/es5/components/VColorPicker/VColorPickerEdit.js.map +1 -1
  58. package/es5/components/VColorPicker/VColorPickerPreview.js +41 -30
  59. package/es5/components/VColorPicker/VColorPickerPreview.js.map +1 -1
  60. package/es5/components/VColorPicker/VColorPickerSwatches.js +13 -10
  61. package/es5/components/VColorPicker/VColorPickerSwatches.js.map +1 -1
  62. package/es5/components/VCombobox/VCombobox.js +1 -0
  63. package/es5/components/VCombobox/VCombobox.js.map +1 -1
  64. package/es5/components/VContent/VContent.js +25 -6
  65. package/es5/components/VContent/VContent.js.map +1 -1
  66. package/es5/components/VCounter/VCounter.js.map +1 -1
  67. package/es5/components/VData/VData.js +15 -2
  68. package/es5/components/VData/VData.js.map +1 -1
  69. package/es5/components/VDataIterator/VDataFooter.js +21 -7
  70. package/es5/components/VDataIterator/VDataFooter.js.map +1 -1
  71. package/es5/components/VDataIterator/VDataIterator.js +47 -50
  72. package/es5/components/VDataIterator/VDataIterator.js.map +1 -1
  73. package/es5/components/VDataTable/RowGroup.js +46 -15
  74. package/es5/components/VDataTable/RowGroup.js.map +1 -1
  75. package/es5/components/VDataTable/VDataTable.js +41 -44
  76. package/es5/components/VDataTable/VDataTable.js.map +1 -1
  77. package/es5/components/VDataTable/VDataTableHeader.js +5 -8
  78. package/es5/components/VDataTable/VDataTableHeader.js.map +1 -1
  79. package/es5/components/VDataTable/VDataTableHeaderDesktop.js +8 -2
  80. package/es5/components/VDataTable/VDataTableHeaderDesktop.js.map +1 -1
  81. package/es5/components/VDataTable/VDataTableHeaderMobile.js +29 -37
  82. package/es5/components/VDataTable/VDataTableHeaderMobile.js.map +1 -1
  83. package/es5/components/VDataTable/VEditDialog.js +26 -22
  84. package/es5/components/VDataTable/VEditDialog.js.map +1 -1
  85. package/es5/components/VDataTable/VSimpleTable.js +1 -1
  86. package/es5/components/VDataTable/VSimpleTable.js.map +1 -1
  87. package/es5/components/VDataTable/VVirtualTable.js +6 -6
  88. package/es5/components/VDataTable/VVirtualTable.js.map +1 -1
  89. package/es5/components/VDataTable/mixins/header.js +7 -9
  90. package/es5/components/VDataTable/mixins/header.js.map +1 -1
  91. package/es5/components/VDatePicker/VDatePicker.js +51 -36
  92. package/es5/components/VDatePicker/VDatePicker.js.map +1 -1
  93. package/es5/components/VDatePicker/VDatePickerHeader.js +68 -24
  94. package/es5/components/VDatePicker/VDatePickerHeader.js.map +1 -1
  95. package/es5/components/VDatePicker/VDatePickerMonthTable.js +6 -3
  96. package/es5/components/VDatePicker/VDatePickerMonthTable.js.map +1 -1
  97. package/es5/components/VDatePicker/VDatePickerTitle.js +61 -16
  98. package/es5/components/VDatePicker/VDatePickerTitle.js.map +1 -1
  99. package/es5/components/VDatePicker/VDatePickerYears.js +47 -23
  100. package/es5/components/VDatePicker/VDatePickerYears.js.map +1 -1
  101. package/es5/components/VDatePicker/mixins/date-picker-table.js +52 -31
  102. package/es5/components/VDatePicker/mixins/date-picker-table.js.map +1 -1
  103. package/es5/components/VDatePicker/util/createNativeLocaleFormatter.js +4 -0
  104. package/es5/components/VDatePicker/util/createNativeLocaleFormatter.js.map +1 -1
  105. package/es5/components/VDatePicker/util/eventHelpers.js +27 -17
  106. package/es5/components/VDatePicker/util/eventHelpers.js.map +1 -1
  107. package/es5/components/VDialog/VDialog.js +59 -33
  108. package/es5/components/VDialog/VDialog.js.map +1 -1
  109. package/es5/components/VExpansionPanel/VExpansionPanel.js +1 -0
  110. package/es5/components/VExpansionPanel/VExpansionPanel.js.map +1 -1
  111. package/es5/components/VExpansionPanel/VExpansionPanelContent.js +12 -10
  112. package/es5/components/VExpansionPanel/VExpansionPanelContent.js.map +1 -1
  113. package/es5/components/VExpansionPanel/VExpansionPanelHeader.js +17 -20
  114. package/es5/components/VExpansionPanel/VExpansionPanelHeader.js.map +1 -1
  115. package/es5/components/VFileInput/VFileInput.js +50 -27
  116. package/es5/components/VFileInput/VFileInput.js.map +1 -1
  117. package/es5/components/VFooter/VFooter.js +1 -1
  118. package/es5/components/VFooter/VFooter.js.map +1 -1
  119. package/es5/components/VForm/VForm.js +45 -30
  120. package/es5/components/VForm/VForm.js.map +1 -1
  121. package/es5/components/VGrid/VCol.js +6 -4
  122. package/es5/components/VGrid/VCol.js.map +1 -1
  123. package/es5/components/VGrid/VContainer.js +27 -10
  124. package/es5/components/VGrid/VContainer.js.map +1 -1
  125. package/es5/components/VGrid/VRow.js +1 -1
  126. package/es5/components/VGrid/VRow.js.map +1 -1
  127. package/es5/components/VGrid/grid.js +35 -15
  128. package/es5/components/VGrid/grid.js.map +1 -1
  129. package/es5/components/VHover/VHover.js +24 -17
  130. package/es5/components/VHover/VHover.js.map +1 -1
  131. package/es5/components/VIcon/VIcon.js +77 -53
  132. package/es5/components/VIcon/VIcon.js.map +1 -1
  133. package/es5/components/VImg/VImg.js +10 -8
  134. package/es5/components/VImg/VImg.js.map +1 -1
  135. package/es5/components/VInput/VInput.js +65 -12
  136. package/es5/components/VInput/VInput.js.map +1 -1
  137. package/es5/components/VItemGroup/VItem.js +21 -17
  138. package/es5/components/VItemGroup/VItem.js.map +1 -1
  139. package/es5/components/VItemGroup/VItemGroup.js +11 -2
  140. package/es5/components/VItemGroup/VItemGroup.js.map +1 -1
  141. package/es5/components/VLabel/VLabel.js +3 -1
  142. package/es5/components/VLabel/VLabel.js.map +1 -1
  143. package/es5/components/VLazy/VLazy.js +8 -15
  144. package/es5/components/VLazy/VLazy.js.map +1 -1
  145. package/es5/components/VList/VList.js +2 -2
  146. package/es5/components/VList/VList.js.map +1 -1
  147. package/es5/components/VList/VListGroup.js +73 -40
  148. package/es5/components/VList/VListGroup.js.map +1 -1
  149. package/es5/components/VList/VListItem.js +63 -18
  150. package/es5/components/VList/VListItem.js.map +1 -1
  151. package/es5/components/VList/VListItemAction.js +23 -9
  152. package/es5/components/VList/VListItemAction.js.map +1 -1
  153. package/es5/components/VList/VListItemIcon.js +3 -1
  154. package/es5/components/VList/VListItemIcon.js.map +1 -1
  155. package/es5/components/VMain/VMain.js +1 -1
  156. package/es5/components/VMain/VMain.js.map +1 -1
  157. package/es5/components/VMenu/VMenu.js +62 -32
  158. package/es5/components/VMenu/VMenu.js.map +1 -1
  159. package/es5/components/VMessages/VMessages.js +33 -6
  160. package/es5/components/VMessages/VMessages.js.map +1 -1
  161. package/es5/components/VNavigationDrawer/VNavigationDrawer.js +41 -19
  162. package/es5/components/VNavigationDrawer/VNavigationDrawer.js.map +1 -1
  163. package/es5/components/VOtpInput/VOtpInput.js +87 -34
  164. package/es5/components/VOtpInput/VOtpInput.js.map +1 -1
  165. package/es5/components/VOverflowBtn/VOverflowBtn.js +18 -14
  166. package/es5/components/VOverflowBtn/VOverflowBtn.js.map +1 -1
  167. package/es5/components/VOverlay/VOverlay.js +31 -3
  168. package/es5/components/VOverlay/VOverlay.js.map +1 -1
  169. package/es5/components/VPagination/VPagination.js +48 -27
  170. package/es5/components/VPagination/VPagination.js.map +1 -1
  171. package/es5/components/VPicker/VPicker.js +7 -4
  172. package/es5/components/VPicker/VPicker.js.map +1 -1
  173. package/es5/components/VProgressCircular/VProgressCircular.js +6 -13
  174. package/es5/components/VProgressCircular/VProgressCircular.js.map +1 -1
  175. package/es5/components/VProgressLinear/VProgressLinear.js +51 -30
  176. package/es5/components/VProgressLinear/VProgressLinear.js.map +1 -1
  177. package/es5/components/VRadioGroup/VRadio.js +11 -2
  178. package/es5/components/VRadioGroup/VRadio.js.map +1 -1
  179. package/es5/components/VRadioGroup/VRadioGroup.js +30 -2
  180. package/es5/components/VRadioGroup/VRadioGroup.js.map +1 -1
  181. package/es5/components/VRangeSlider/VRangeSlider.js +57 -32
  182. package/es5/components/VRangeSlider/VRangeSlider.js.map +1 -1
  183. package/es5/components/VRating/VRating.js +45 -17
  184. package/es5/components/VRating/VRating.js.map +1 -1
  185. package/es5/components/VSelect/VSelect.js +161 -81
  186. package/es5/components/VSelect/VSelect.js.map +1 -1
  187. package/es5/components/VSelect/VSelectList.js +109 -44
  188. package/es5/components/VSelect/VSelectList.js.map +1 -1
  189. package/es5/components/VSheet/VSheet.js +3 -1
  190. package/es5/components/VSheet/VSheet.js.map +1 -1
  191. package/es5/components/VSlideGroup/VSlideGroup.js +40 -28
  192. package/es5/components/VSlideGroup/VSlideGroup.js.map +1 -1
  193. package/es5/components/VSlideGroup/VSlideItem.js +2 -1
  194. package/es5/components/VSlideGroup/VSlideItem.js.map +1 -1
  195. package/es5/components/VSlider/VSlider.js +73 -41
  196. package/es5/components/VSlider/VSlider.js.map +1 -1
  197. package/es5/components/VSnackbar/VSnackbar.js +8 -3
  198. package/es5/components/VSnackbar/VSnackbar.js.map +1 -1
  199. package/es5/components/VSparkline/VSparkline.js +48 -68
  200. package/es5/components/VSparkline/VSparkline.js.map +1 -1
  201. package/es5/components/VSpeedDial/VSpeedDial.js +13 -17
  202. package/es5/components/VSpeedDial/VSpeedDial.js.map +1 -1
  203. package/es5/components/VStepper/VStepper.js +3 -2
  204. package/es5/components/VStepper/VStepper.js.map +1 -1
  205. package/es5/components/VStepper/VStepperContent.js +9 -8
  206. package/es5/components/VStepper/VStepperContent.js.map +1 -1
  207. package/es5/components/VStepper/VStepperStep.js +12 -20
  208. package/es5/components/VStepper/VStepperStep.js.map +1 -1
  209. package/es5/components/VSubheader/VSubheader.js +1 -1
  210. package/es5/components/VSubheader/VSubheader.js.map +1 -1
  211. package/es5/components/VSwitch/VSwitch.js +11 -9
  212. package/es5/components/VSwitch/VSwitch.js.map +1 -1
  213. package/es5/components/VTabs/VTab.js +1 -0
  214. package/es5/components/VTabs/VTab.js.map +1 -1
  215. package/es5/components/VTabs/VTabs.js +68 -24
  216. package/es5/components/VTabs/VTabs.js.map +1 -1
  217. package/es5/components/VTabs/VTabsBar.js +3 -0
  218. package/es5/components/VTabs/VTabsBar.js.map +1 -1
  219. package/es5/components/VTabs/VTabsItems.js +1 -0
  220. package/es5/components/VTabs/VTabsItems.js.map +1 -1
  221. package/es5/components/VTextField/VTextField.js +42 -29
  222. package/es5/components/VTextField/VTextField.js.map +1 -1
  223. package/es5/components/VTextarea/VTextarea.js +1 -1
  224. package/es5/components/VTextarea/VTextarea.js.map +1 -1
  225. package/es5/components/VTimePicker/VTimePicker.js +72 -44
  226. package/es5/components/VTimePicker/VTimePicker.js.map +1 -1
  227. package/es5/components/VTimePicker/VTimePickerClock.js +37 -48
  228. package/es5/components/VTimePicker/VTimePickerClock.js.map +1 -1
  229. package/es5/components/VTimePicker/VTimePickerTitle.js +13 -11
  230. package/es5/components/VTimePicker/VTimePickerTitle.js.map +1 -1
  231. package/es5/components/VToolbar/VToolbar.js +3 -6
  232. package/es5/components/VToolbar/VToolbar.js.map +1 -1
  233. package/es5/components/VTooltip/VTooltip.js +14 -20
  234. package/es5/components/VTooltip/VTooltip.js.map +1 -1
  235. package/es5/components/VTreeview/VTreeview.js +24 -18
  236. package/es5/components/VTreeview/VTreeview.js.map +1 -1
  237. package/es5/components/VTreeview/VTreeviewNode.js +12 -6
  238. package/es5/components/VTreeview/VTreeviewNode.js.map +1 -1
  239. package/es5/components/VVirtualScroll/VVirtualScroll.js +15 -19
  240. package/es5/components/VVirtualScroll/VVirtualScroll.js.map +1 -1
  241. package/es5/components/VWindow/VWindow.js +13 -8
  242. package/es5/components/VWindow/VWindow.js.map +1 -1
  243. package/es5/components/VWindow/VWindowItem.js +10 -10
  244. package/es5/components/VWindow/VWindowItem.js.map +1 -1
  245. package/es5/components/transitions/createTransition.js +8 -2
  246. package/es5/components/transitions/createTransition.js.map +1 -1
  247. package/es5/components/transitions/expand-transition.js +1 -0
  248. package/es5/components/transitions/expand-transition.js.map +1 -1
  249. package/es5/directives/color/index.js +6 -3
  250. package/es5/directives/color/index.js.map +1 -1
  251. package/es5/directives/intersect/index.js +20 -7
  252. package/es5/directives/intersect/index.js.map +1 -1
  253. package/es5/directives/mutate/index.js +13 -13
  254. package/es5/directives/mutate/index.js.map +1 -1
  255. package/es5/directives/resize/index.js +8 -8
  256. package/es5/directives/resize/index.js.map +1 -1
  257. package/es5/directives/ripple/index.js +5 -2
  258. package/es5/directives/ripple/index.js.map +1 -1
  259. package/es5/directives/scroll/index.js +8 -8
  260. package/es5/directives/scroll/index.js.map +1 -1
  261. package/es5/directives/touch/index.js +11 -8
  262. package/es5/directives/touch/index.js.map +1 -1
  263. package/es5/framework.js +1 -1
  264. package/es5/install.js +10 -33
  265. package/es5/install.js.map +1 -1
  266. package/es5/mixins/activatable/index.js +11 -13
  267. package/es5/mixins/activatable/index.js.map +1 -1
  268. package/es5/mixins/applicationable/index.js +4 -4
  269. package/es5/mixins/applicationable/index.js.map +1 -1
  270. package/es5/mixins/binds-attrs/index.js +1 -1
  271. package/es5/mixins/binds-attrs/index.js.map +1 -1
  272. package/es5/mixins/bootable/index.js +1 -2
  273. package/es5/mixins/bootable/index.js.map +1 -1
  274. package/es5/mixins/detachable/index.js +13 -10
  275. package/es5/mixins/detachable/index.js.map +1 -1
  276. package/es5/mixins/groupable/index.js +6 -2
  277. package/es5/mixins/groupable/index.js.map +1 -1
  278. package/es5/mixins/intersectable/index.js +2 -2
  279. package/es5/mixins/intersectable/index.js.map +1 -1
  280. package/es5/mixins/menuable/index.js +1 -1
  281. package/es5/mixins/menuable/index.js.map +1 -1
  282. package/es5/mixins/mouse/index.js +10 -5
  283. package/es5/mixins/mouse/index.js.map +1 -1
  284. package/es5/mixins/overlayable/index.js +5 -3
  285. package/es5/mixins/overlayable/index.js.map +1 -1
  286. package/es5/mixins/picker/index.js +13 -3
  287. package/es5/mixins/picker/index.js.map +1 -1
  288. package/es5/mixins/positionable/index.js.map +1 -1
  289. package/es5/mixins/proxyable/index.js +5 -2
  290. package/es5/mixins/proxyable/index.js.map +1 -1
  291. package/es5/mixins/registrable/index.js.map +1 -1
  292. package/es5/mixins/routable/index.js +5 -2
  293. package/es5/mixins/routable/index.js.map +1 -1
  294. package/es5/mixins/selectable/index.js +9 -7
  295. package/es5/mixins/selectable/index.js.map +1 -1
  296. package/es5/mixins/toggleable/index.js.map +1 -1
  297. package/es5/mixins/translatable/index.js +1 -1
  298. package/es5/mixins/translatable/index.js.map +1 -1
  299. package/es5/mixins/validatable/index.js +34 -7
  300. package/es5/mixins/validatable/index.js.map +1 -1
  301. package/es5/services/goto/util.js +42 -3
  302. package/es5/services/goto/util.js.map +1 -1
  303. package/es5/services/theme/index.js +20 -71
  304. package/es5/services/theme/index.js.map +1 -1
  305. package/es5/util/console.js +49 -18
  306. package/es5/util/console.js.map +1 -1
  307. package/es5/util/helpers.js +58 -3
  308. package/es5/util/helpers.js.map +1 -1
  309. package/es5/util/legacyEventsMixin.js +48 -0
  310. package/es5/util/legacyEventsMixin.js.map +1 -0
  311. package/es5/util/mergeData.js +6 -5
  312. package/es5/util/mergeData.js.map +1 -1
  313. package/es5/util/mixins.js +4 -3
  314. package/es5/util/mixins.js.map +1 -1
  315. package/lib/components/VAlert/VAlert.js +13 -7
  316. package/lib/components/VAlert/VAlert.js.map +1 -1
  317. package/lib/components/VAppBar/VAppBar.js +23 -16
  318. package/lib/components/VAppBar/VAppBar.js.map +1 -1
  319. package/lib/components/VAppBar/VAppBarNavIcon.js +1 -1
  320. package/lib/components/VAppBar/VAppBarNavIcon.js.map +1 -1
  321. package/lib/components/VAutocomplete/VAutocomplete.js +12 -8
  322. package/lib/components/VAutocomplete/VAutocomplete.js.map +1 -1
  323. package/lib/components/VBadge/VBadge.js +26 -13
  324. package/lib/components/VBadge/VBadge.js.map +1 -1
  325. package/lib/components/VBanner/VBanner.js +20 -13
  326. package/lib/components/VBanner/VBanner.js.map +1 -1
  327. package/lib/components/VBottomNavigation/VBottomNavigation.js +19 -15
  328. package/lib/components/VBottomNavigation/VBottomNavigation.js.map +1 -1
  329. package/lib/components/VBreadcrumbs/VBreadcrumbs.js +7 -5
  330. package/lib/components/VBreadcrumbs/VBreadcrumbs.js.map +1 -1
  331. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.js +4 -0
  332. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.js.map +1 -1
  333. package/lib/components/VBtn/VBtn.js +21 -20
  334. package/lib/components/VBtn/VBtn.js.map +1 -1
  335. package/lib/components/VCalendar/VCalendar.js +26 -31
  336. package/lib/components/VCalendar/VCalendar.js.map +1 -1
  337. package/lib/components/VCalendar/VCalendarCategory.js +8 -10
  338. package/lib/components/VCalendar/VCalendarCategory.js.map +1 -1
  339. package/lib/components/VCalendar/VCalendarDaily.js +21 -33
  340. package/lib/components/VCalendar/VCalendarDaily.js.map +1 -1
  341. package/lib/components/VCalendar/VCalendarMonthly.js +2 -2
  342. package/lib/components/VCalendar/VCalendarMonthly.js.map +1 -1
  343. package/lib/components/VCalendar/VCalendarWeekly.js +28 -36
  344. package/lib/components/VCalendar/VCalendarWeekly.js.map +1 -1
  345. package/lib/components/VCalendar/mixins/calendar-base.js +7 -11
  346. package/lib/components/VCalendar/mixins/calendar-base.js.map +1 -1
  347. package/lib/components/VCalendar/mixins/calendar-with-events.js +16 -39
  348. package/lib/components/VCalendar/mixins/calendar-with-events.js.map +1 -1
  349. package/lib/components/VCalendar/mixins/calendar-with-intervals.js +2 -2
  350. package/lib/components/VCalendar/mixins/calendar-with-intervals.js.map +1 -1
  351. package/lib/components/VCalendar/mixins/times.js.map +1 -1
  352. package/lib/components/VCarousel/VCarousel.js +36 -16
  353. package/lib/components/VCarousel/VCarousel.js.map +1 -1
  354. package/lib/components/VCarousel/VCarouselItem.js +1 -1
  355. package/lib/components/VCarousel/VCarouselItem.js.map +1 -1
  356. package/lib/components/VCheckbox/VCheckbox.js +19 -9
  357. package/lib/components/VCheckbox/VCheckbox.js.map +1 -1
  358. package/lib/components/VCheckbox/VSimpleCheckbox.js +83 -39
  359. package/lib/components/VCheckbox/VSimpleCheckbox.js.map +1 -1
  360. package/lib/components/VChip/VChip.js +17 -8
  361. package/lib/components/VChip/VChip.js.map +1 -1
  362. package/lib/components/VColorPicker/VColorPicker.js +47 -44
  363. package/lib/components/VColorPicker/VColorPicker.js.map +1 -1
  364. package/lib/components/VColorPicker/VColorPickerCanvas.js +41 -43
  365. package/lib/components/VColorPicker/VColorPickerCanvas.js.map +1 -1
  366. package/lib/components/VColorPicker/VColorPickerEdit.js +25 -31
  367. package/lib/components/VColorPicker/VColorPickerEdit.js.map +1 -1
  368. package/lib/components/VColorPicker/VColorPickerPreview.js +45 -32
  369. package/lib/components/VColorPicker/VColorPickerPreview.js.map +1 -1
  370. package/lib/components/VColorPicker/VColorPickerSwatches.js +15 -9
  371. package/lib/components/VColorPicker/VColorPickerSwatches.js.map +1 -1
  372. package/lib/components/VCombobox/VCombobox.js +1 -0
  373. package/lib/components/VCombobox/VCombobox.js.map +1 -1
  374. package/lib/components/VContent/VContent.js +19 -4
  375. package/lib/components/VContent/VContent.js.map +1 -1
  376. package/lib/components/VCounter/VCounter.js.map +1 -1
  377. package/lib/components/VData/VData.js +16 -2
  378. package/lib/components/VData/VData.js.map +1 -1
  379. package/lib/components/VDataIterator/VDataFooter.js +15 -7
  380. package/lib/components/VDataIterator/VDataFooter.js.map +1 -1
  381. package/lib/components/VDataIterator/VDataIterator.js +31 -34
  382. package/lib/components/VDataIterator/VDataIterator.js.map +1 -1
  383. package/lib/components/VDataTable/RowGroup.js +30 -14
  384. package/lib/components/VDataTable/RowGroup.js.map +1 -1
  385. package/lib/components/VDataTable/VDataTable.js +20 -33
  386. package/lib/components/VDataTable/VDataTable.js.map +1 -1
  387. package/lib/components/VDataTable/VDataTableHeader.js +7 -9
  388. package/lib/components/VDataTable/VDataTableHeader.js.map +1 -1
  389. package/lib/components/VDataTable/VDataTableHeaderDesktop.js +7 -1
  390. package/lib/components/VDataTable/VDataTableHeaderDesktop.js.map +1 -1
  391. package/lib/components/VDataTable/VDataTableHeaderMobile.js +18 -25
  392. package/lib/components/VDataTable/VDataTableHeaderMobile.js.map +1 -1
  393. package/lib/components/VDataTable/VEditDialog.js +18 -18
  394. package/lib/components/VDataTable/VEditDialog.js.map +1 -1
  395. package/lib/components/VDataTable/VSimpleTable.js +1 -1
  396. package/lib/components/VDataTable/VSimpleTable.js.map +1 -1
  397. package/lib/components/VDataTable/VVirtualTable.js +2 -3
  398. package/lib/components/VDataTable/VVirtualTable.js.map +1 -1
  399. package/lib/components/VDataTable/mixins/header.js +3 -8
  400. package/lib/components/VDataTable/mixins/header.js.map +1 -1
  401. package/lib/components/VDatePicker/VDatePicker.js +38 -27
  402. package/lib/components/VDatePicker/VDatePicker.js.map +1 -1
  403. package/lib/components/VDatePicker/VDatePickerHeader.js +45 -21
  404. package/lib/components/VDatePicker/VDatePickerHeader.js.map +1 -1
  405. package/lib/components/VDatePicker/VDatePickerMonthTable.js +3 -1
  406. package/lib/components/VDatePicker/VDatePickerMonthTable.js.map +1 -1
  407. package/lib/components/VDatePicker/VDatePickerTitle.js +34 -11
  408. package/lib/components/VDatePicker/VDatePickerTitle.js.map +1 -1
  409. package/lib/components/VDatePicker/VDatePickerYears.js +17 -8
  410. package/lib/components/VDatePicker/VDatePickerYears.js.map +1 -1
  411. package/lib/components/VDatePicker/mixins/date-picker-table.js +31 -16
  412. package/lib/components/VDatePicker/mixins/date-picker-table.js.map +1 -1
  413. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.js +4 -0
  414. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.js.map +1 -1
  415. package/lib/components/VDatePicker/util/eventHelpers.js +26 -14
  416. package/lib/components/VDatePicker/util/eventHelpers.js.map +1 -1
  417. package/lib/components/VDialog/VDialog.js +13 -5
  418. package/lib/components/VDialog/VDialog.js.map +1 -1
  419. package/lib/components/VExpansionPanel/VExpansionPanel.js +1 -0
  420. package/lib/components/VExpansionPanel/VExpansionPanel.js.map +1 -1
  421. package/lib/components/VExpansionPanel/VExpansionPanelContent.js +2 -2
  422. package/lib/components/VExpansionPanel/VExpansionPanelContent.js.map +1 -1
  423. package/lib/components/VExpansionPanel/VExpansionPanelHeader.js +4 -7
  424. package/lib/components/VExpansionPanel/VExpansionPanelHeader.js.map +1 -1
  425. package/lib/components/VFileInput/VFileInput.js +43 -25
  426. package/lib/components/VFileInput/VFileInput.js.map +1 -1
  427. package/lib/components/VFooter/VFooter.js +2 -2
  428. package/lib/components/VFooter/VFooter.js.map +1 -1
  429. package/lib/components/VForm/VForm.js +41 -26
  430. package/lib/components/VForm/VForm.js.map +1 -1
  431. package/lib/components/VGrid/VCol.js +7 -5
  432. package/lib/components/VGrid/VCol.js.map +1 -1
  433. package/lib/components/VGrid/VContainer.js +14 -10
  434. package/lib/components/VGrid/VContainer.js.map +1 -1
  435. package/lib/components/VGrid/VRow.js +2 -2
  436. package/lib/components/VGrid/VRow.js.map +1 -1
  437. package/lib/components/VGrid/grid.js +16 -14
  438. package/lib/components/VGrid/grid.js.map +1 -1
  439. package/lib/components/VHover/VHover.js +24 -18
  440. package/lib/components/VHover/VHover.js.map +1 -1
  441. package/lib/components/VIcon/VIcon.js +79 -57
  442. package/lib/components/VIcon/VIcon.js.map +1 -1
  443. package/lib/components/VImg/VImg.js +5 -9
  444. package/lib/components/VImg/VImg.js.map +1 -1
  445. package/lib/components/VInput/VInput.js +32 -9
  446. package/lib/components/VInput/VInput.js.map +1 -1
  447. package/lib/components/VItemGroup/VItem.js +25 -21
  448. package/lib/components/VItemGroup/VItem.js.map +1 -1
  449. package/lib/components/VItemGroup/VItemGroup.js +13 -3
  450. package/lib/components/VItemGroup/VItemGroup.js.map +1 -1
  451. package/lib/components/VLabel/VLabel.js +3 -1
  452. package/lib/components/VLabel/VLabel.js.map +1 -1
  453. package/lib/components/VLazy/VLazy.js +9 -16
  454. package/lib/components/VLazy/VLazy.js.map +1 -1
  455. package/lib/components/VList/VList.js +3 -3
  456. package/lib/components/VList/VList.js.map +1 -1
  457. package/lib/components/VList/VListGroup.js +34 -32
  458. package/lib/components/VList/VListGroup.js.map +1 -1
  459. package/lib/components/VList/VListItem.js +41 -19
  460. package/lib/components/VList/VListItem.js.map +1 -1
  461. package/lib/components/VList/VListItemAction.js +15 -9
  462. package/lib/components/VList/VListItemAction.js.map +1 -1
  463. package/lib/components/VList/VListItemIcon.js +3 -1
  464. package/lib/components/VList/VListItemIcon.js.map +1 -1
  465. package/lib/components/VMain/VMain.js +2 -2
  466. package/lib/components/VMain/VMain.js.map +1 -1
  467. package/lib/components/VMenu/VMenu.js +18 -6
  468. package/lib/components/VMenu/VMenu.js.map +1 -1
  469. package/lib/components/VMessages/VMessages.js +13 -2
  470. package/lib/components/VMessages/VMessages.js.map +1 -1
  471. package/lib/components/VNavigationDrawer/VNavigationDrawer.js +17 -12
  472. package/lib/components/VNavigationDrawer/VNavigationDrawer.js.map +1 -1
  473. package/lib/components/VOtpInput/VOtpInput.js +103 -35
  474. package/lib/components/VOtpInput/VOtpInput.js.map +1 -1
  475. package/lib/components/VOverflowBtn/VOverflowBtn.js +16 -15
  476. package/lib/components/VOverflowBtn/VOverflowBtn.js.map +1 -1
  477. package/lib/components/VOverlay/VOverlay.js +13 -2
  478. package/lib/components/VOverlay/VOverlay.js.map +1 -1
  479. package/lib/components/VPagination/VPagination.js +28 -23
  480. package/lib/components/VPagination/VPagination.js.map +1 -1
  481. package/lib/components/VPicker/VPicker.js +4 -4
  482. package/lib/components/VPicker/VPicker.js.map +1 -1
  483. package/lib/components/VProgressCircular/VProgressCircular.js +6 -7
  484. package/lib/components/VProgressCircular/VProgressCircular.js.map +1 -1
  485. package/lib/components/VProgressLinear/VProgressLinear.js +45 -22
  486. package/lib/components/VProgressLinear/VProgressLinear.js.map +1 -1
  487. package/lib/components/VRadioGroup/VRadio.js +3 -2
  488. package/lib/components/VRadioGroup/VRadio.js.map +1 -1
  489. package/lib/components/VRadioGroup/VRadioGroup.js +14 -5
  490. package/lib/components/VRadioGroup/VRadioGroup.js.map +1 -1
  491. package/lib/components/VRangeSlider/VRangeSlider.js +17 -5
  492. package/lib/components/VRangeSlider/VRangeSlider.js.map +1 -1
  493. package/lib/components/VRating/VRating.js +11 -0
  494. package/lib/components/VRating/VRating.js.map +1 -1
  495. package/lib/components/VSelect/VSelect.js +104 -42
  496. package/lib/components/VSelect/VSelect.js.map +1 -1
  497. package/lib/components/VSelect/VSelectList.js +64 -29
  498. package/lib/components/VSelect/VSelectList.js.map +1 -1
  499. package/lib/components/VSheet/VSheet.js +3 -2
  500. package/lib/components/VSheet/VSheet.js.map +1 -1
  501. package/lib/components/VSlideGroup/VSlideGroup.js +23 -23
  502. package/lib/components/VSlideGroup/VSlideGroup.js.map +1 -1
  503. package/lib/components/VSlideGroup/VSlideItem.js +2 -1
  504. package/lib/components/VSlideGroup/VSlideItem.js.map +1 -1
  505. package/lib/components/VSlider/VSlider.js +37 -25
  506. package/lib/components/VSlider/VSlider.js.map +1 -1
  507. package/lib/components/VSnackbar/VSnackbar.js +2 -1
  508. package/lib/components/VSnackbar/VSnackbar.js.map +1 -1
  509. package/lib/components/VSparkline/VSparkline.js +48 -67
  510. package/lib/components/VSparkline/VSparkline.js.map +1 -1
  511. package/lib/components/VSpeedDial/VSpeedDial.js +9 -15
  512. package/lib/components/VSpeedDial/VSpeedDial.js.map +1 -1
  513. package/lib/components/VStepper/VStepper.js +4 -3
  514. package/lib/components/VStepper/VStepper.js.map +1 -1
  515. package/lib/components/VStepper/VStepperContent.js +7 -8
  516. package/lib/components/VStepper/VStepperContent.js.map +1 -1
  517. package/lib/components/VStepper/VStepperStep.js +8 -19
  518. package/lib/components/VStepper/VStepperStep.js.map +1 -1
  519. package/lib/components/VSubheader/VSubheader.js +1 -1
  520. package/lib/components/VSubheader/VSubheader.js.map +1 -1
  521. package/lib/components/VSwitch/VSwitch.js +2 -4
  522. package/lib/components/VSwitch/VSwitch.js.map +1 -1
  523. package/lib/components/VTabs/VTab.js +1 -0
  524. package/lib/components/VTabs/VTab.js.map +1 -1
  525. package/lib/components/VTabs/VTabs.js +34 -8
  526. package/lib/components/VTabs/VTabs.js.map +1 -1
  527. package/lib/components/VTabs/VTabsBar.js +3 -0
  528. package/lib/components/VTabs/VTabsBar.js.map +1 -1
  529. package/lib/components/VTabs/VTabsItems.js +1 -0
  530. package/lib/components/VTabs/VTabsItems.js.map +1 -1
  531. package/lib/components/VTextField/VTextField.js +15 -19
  532. package/lib/components/VTextField/VTextField.js.map +1 -1
  533. package/lib/components/VTextarea/VTextarea.js +1 -1
  534. package/lib/components/VTextarea/VTextarea.js.map +1 -1
  535. package/lib/components/VTimePicker/VTimePicker.js +65 -31
  536. package/lib/components/VTimePicker/VTimePicker.js.map +1 -1
  537. package/lib/components/VTimePicker/VTimePickerClock.js +24 -39
  538. package/lib/components/VTimePicker/VTimePickerClock.js.map +1 -1
  539. package/lib/components/VTimePicker/VTimePickerTitle.js +3 -2
  540. package/lib/components/VTimePicker/VTimePickerTitle.js.map +1 -1
  541. package/lib/components/VToolbar/VToolbar.js +6 -7
  542. package/lib/components/VToolbar/VToolbar.js.map +1 -1
  543. package/lib/components/VTooltip/VTooltip.js +11 -22
  544. package/lib/components/VTooltip/VTooltip.js.map +1 -1
  545. package/lib/components/VTreeview/VTreeview.js +15 -13
  546. package/lib/components/VTreeview/VTreeview.js.map +1 -1
  547. package/lib/components/VTreeview/VTreeviewNode.js +4 -6
  548. package/lib/components/VTreeview/VTreeviewNode.js.map +1 -1
  549. package/lib/components/VVirtualScroll/VVirtualScroll.js +8 -14
  550. package/lib/components/VVirtualScroll/VVirtualScroll.js.map +1 -1
  551. package/lib/components/VWindow/VWindow.js +7 -6
  552. package/lib/components/VWindow/VWindow.js.map +1 -1
  553. package/lib/components/VWindow/VWindowItem.js +5 -7
  554. package/lib/components/VWindow/VWindowItem.js.map +1 -1
  555. package/lib/components/transitions/createTransition.js +2 -2
  556. package/lib/components/transitions/createTransition.js.map +1 -1
  557. package/lib/components/transitions/expand-transition.js +1 -0
  558. package/lib/components/transitions/expand-transition.js.map +1 -1
  559. package/lib/directives/color/index.js +6 -3
  560. package/lib/directives/color/index.js.map +1 -1
  561. package/lib/directives/intersect/index.js +20 -7
  562. package/lib/directives/intersect/index.js.map +1 -1
  563. package/lib/directives/mutate/index.js +13 -13
  564. package/lib/directives/mutate/index.js.map +1 -1
  565. package/lib/directives/resize/index.js +8 -8
  566. package/lib/directives/resize/index.js.map +1 -1
  567. package/lib/directives/ripple/index.js +5 -3
  568. package/lib/directives/ripple/index.js.map +1 -1
  569. package/lib/directives/scroll/index.js +8 -8
  570. package/lib/directives/scroll/index.js.map +1 -1
  571. package/lib/directives/touch/index.js +11 -8
  572. package/lib/directives/touch/index.js.map +1 -1
  573. package/lib/framework.js +1 -1
  574. package/lib/install.js +5 -28
  575. package/lib/install.js.map +1 -1
  576. package/lib/mixins/activatable/index.js +13 -14
  577. package/lib/mixins/activatable/index.js.map +1 -1
  578. package/lib/mixins/applicationable/index.js +4 -4
  579. package/lib/mixins/applicationable/index.js.map +1 -1
  580. package/lib/mixins/binds-attrs/index.js +1 -1
  581. package/lib/mixins/binds-attrs/index.js.map +1 -1
  582. package/lib/mixins/bootable/index.js +2 -4
  583. package/lib/mixins/bootable/index.js.map +1 -1
  584. package/lib/mixins/detachable/index.js +14 -11
  585. package/lib/mixins/detachable/index.js.map +1 -1
  586. package/lib/mixins/groupable/index.js +4 -2
  587. package/lib/mixins/groupable/index.js.map +1 -1
  588. package/lib/mixins/intersectable/index.js +2 -2
  589. package/lib/mixins/intersectable/index.js.map +1 -1
  590. package/lib/mixins/menuable/index.js +1 -1
  591. package/lib/mixins/menuable/index.js.map +1 -1
  592. package/lib/mixins/mouse/index.js +9 -5
  593. package/lib/mixins/mouse/index.js.map +1 -1
  594. package/lib/mixins/overlayable/index.js +4 -2
  595. package/lib/mixins/overlayable/index.js.map +1 -1
  596. package/lib/mixins/picker/index.js +5 -3
  597. package/lib/mixins/picker/index.js.map +1 -1
  598. package/lib/mixins/positionable/index.js.map +1 -1
  599. package/lib/mixins/proxyable/index.js +5 -2
  600. package/lib/mixins/proxyable/index.js.map +1 -1
  601. package/lib/mixins/registrable/index.js.map +1 -1
  602. package/lib/mixins/routable/index.js +5 -2
  603. package/lib/mixins/routable/index.js.map +1 -1
  604. package/lib/mixins/selectable/index.js +15 -12
  605. package/lib/mixins/selectable/index.js.map +1 -1
  606. package/lib/mixins/toggleable/index.js.map +1 -1
  607. package/lib/mixins/translatable/index.js +1 -1
  608. package/lib/mixins/translatable/index.js.map +1 -1
  609. package/lib/mixins/validatable/index.js +17 -7
  610. package/lib/mixins/validatable/index.js.map +1 -1
  611. package/lib/services/goto/util.js +42 -3
  612. package/lib/services/goto/util.js.map +1 -1
  613. package/lib/services/theme/index.js +18 -64
  614. package/lib/services/theme/index.js.map +1 -1
  615. package/lib/util/console.js +47 -17
  616. package/lib/util/console.js.map +1 -1
  617. package/lib/util/helpers.js +52 -3
  618. package/lib/util/helpers.js.map +1 -1
  619. package/lib/util/legacyEventsMixin.js +37 -0
  620. package/lib/util/legacyEventsMixin.js.map +1 -0
  621. package/lib/util/mergeData.js +6 -5
  622. package/lib/util/mergeData.js.map +1 -1
  623. package/lib/util/mixins.js +3 -2
  624. package/lib/util/mixins.js.map +1 -1
  625. package/package.json +2 -2
  626. package/src/components/VAlert/VAlert.ts +19 -8
  627. package/src/components/VAlert/__tests__/VAlert.spec.ts +78 -50
  628. package/src/components/VAlert/__tests__/__snapshots__/VAlert.spec.ts.snap +18 -20
  629. package/src/components/VApp/__tests__/VApp.spec.ts +24 -18
  630. package/src/components/VApp/__tests__/__snapshots__/VApp.spec.ts.snap +4 -4
  631. package/src/components/VAppBar/VAppBar.ts +21 -14
  632. package/src/components/VAppBar/VAppBarNavIcon.ts +1 -1
  633. package/src/components/VAppBar/__tests__/VAppBar.spec.ts +256 -74
  634. package/src/components/VAppBar/__tests__/VAppBarNavIcon.spec.ts +2 -6
  635. package/src/components/VAppBar/__tests__/__snapshots__/VAppBar.spec.ts.snap +13 -4
  636. package/src/components/VAppBar/__tests__/__snapshots__/VAppBarNavIcon.spec.ts.snap +4 -5
  637. package/src/components/VAutocomplete/VAutocomplete.ts +35 -6
  638. package/src/components/VAutocomplete/__tests__/VAutocomplete.spec.ts +125 -72
  639. package/src/components/VAutocomplete/__tests__/VAutocomplete2.spec.ts +109 -82
  640. package/src/components/VAutocomplete/__tests__/VAutocomplete3.spec.ts +114 -52
  641. package/src/components/VAvatar/__tests__/VAvatar.spec.ts +72 -10
  642. package/src/components/VBadge/VBadge.ts +38 -26
  643. package/src/components/VBadge/__tests__/VBadge.spec.ts +47 -30
  644. package/src/components/VBadge/__tests__/__snapshots__/VBadge.spec.ts.snap +5 -5
  645. package/src/components/VBanner/VBanner.ts +30 -17
  646. package/src/components/VBanner/__tests__/VBanner.spec.ts +35 -36
  647. package/src/components/VBanner/__tests__/__snapshots__/VBanner.spec.ts.snap +3 -3
  648. package/src/components/VBottomNavigation/VBottomNavigation.ts +29 -17
  649. package/src/components/VBottomNavigation/__tests__/VBottomNavigation.spec.ts +43 -37
  650. package/src/components/VBottomNavigation/__tests__/__snapshots__/VBottomNavigation.spec.ts.snap +10 -10
  651. package/src/components/VBreadcrumbs/VBreadcrumbs.ts +8 -4
  652. package/src/components/VBreadcrumbs/VBreadcrumbsItem.ts +4 -0
  653. package/src/components/VBreadcrumbs/__tests__/VBreadcrumbs.spec.ts +125 -10
  654. package/src/components/VBreadcrumbs/__tests__/VBreadcrumbsItem.spec.ts +10 -6
  655. package/src/components/VBtn/VBtn.ts +25 -17
  656. package/src/components/VBtn/__tests__/VBtn.spec.ts +262 -242
  657. package/src/components/VBtn/__tests__/__snapshots__/VBtn.spec.ts.snap +13 -73
  658. package/src/components/VBtnToggle/__tests__/VBtnToggle.spec.ts +10 -6
  659. package/src/components/VCalendar/VCalendar.ts +29 -27
  660. package/src/components/VCalendar/VCalendarCategory.ts +9 -8
  661. package/src/components/VCalendar/VCalendarDaily.ts +18 -28
  662. package/src/components/VCalendar/VCalendarMonthly.ts +2 -1
  663. package/src/components/VCalendar/VCalendarWeekly.ts +30 -35
  664. package/src/components/VCalendar/__tests__/VCalendar.spec.ts +19 -35
  665. package/src/components/VCalendar/__tests__/VCalendarCategory.spec.ts +21 -19
  666. package/src/components/VCalendar/__tests__/VCalendarDaily.spec.ts +30 -28
  667. package/src/components/VCalendar/__tests__/__snapshots__/VCalendar.spec.ts.snap +38 -38
  668. package/src/components/VCalendar/__tests__/__snapshots__/VCalendarDaily.spec.ts.snap +122 -122
  669. package/src/components/VCalendar/mixins/__tests__/__snapshots__/calendar-with-events.spec.ts.snap +1 -56
  670. package/src/components/VCalendar/mixins/__tests__/calendar-base.spec.ts +24 -21
  671. package/src/components/VCalendar/mixins/__tests__/calendar-with-events.spec.ts +27 -34
  672. package/src/components/VCalendar/mixins/__tests__/calendar-with-intervals.spec.ts +31 -28
  673. package/src/components/VCalendar/mixins/__tests__/times.spec.ts +10 -9
  674. package/src/components/VCalendar/mixins/calendar-base.ts +8 -12
  675. package/src/components/VCalendar/mixins/calendar-with-events.ts +19 -38
  676. package/src/components/VCalendar/mixins/calendar-with-intervals.ts +1 -1
  677. package/src/components/VCalendar/mixins/times.ts +1 -1
  678. package/src/components/VCard/__tests__/VCard.spec.ts +46 -28
  679. package/src/components/VCard/__tests__/__snapshots__/VCard.spec.ts.snap +2 -2
  680. package/src/components/VCarousel/VCarousel.ts +42 -15
  681. package/src/components/VCarousel/VCarouselItem.ts +1 -1
  682. package/src/components/VCarousel/__tests__/VCarousel.spec.ts +74 -54
  683. package/src/components/VCarousel/__tests__/VCarouselItem.spec.ts +9 -5
  684. package/src/components/VCarousel/__tests__/__snapshots__/VCarousel.spec.ts.snap +1 -1
  685. package/src/components/VCheckbox/VCheckbox.ts +23 -10
  686. package/src/components/VCheckbox/VSimpleCheckbox.ts +97 -45
  687. package/src/components/VCheckbox/__tests__/VCheckbox.spec.ts +163 -152
  688. package/src/components/VCheckbox/__tests__/VSimpleCheckbox.spec.ts +46 -13
  689. package/src/components/VCheckbox/__tests__/__snapshots__/VCheckbox.spec.ts.snap +54 -50
  690. package/src/components/VChip/VChip.ts +19 -15
  691. package/src/components/VChip/__tests__/VChip.spec.ts +50 -50
  692. package/src/components/VChip/__tests__/__snapshots__/VChip.spec.ts.snap +4 -4
  693. package/src/components/VChipGroup/__tests__/VChipGroup.spec.ts +14 -21
  694. package/src/components/VColorPicker/VColorPicker.ts +51 -41
  695. package/src/components/VColorPicker/VColorPickerCanvas.ts +44 -37
  696. package/src/components/VColorPicker/VColorPickerEdit.ts +37 -35
  697. package/src/components/VColorPicker/VColorPickerPreview.ts +48 -28
  698. package/src/components/VColorPicker/VColorPickerSwatches.ts +23 -12
  699. package/src/components/VColorPicker/__tests__/VColorPicker.spec.ts +47 -47
  700. package/src/components/VColorPicker/__tests__/VColorPickerCanvas.spec.ts +15 -13
  701. package/src/components/VColorPicker/__tests__/VColorPickerEdit.spec.ts +52 -50
  702. package/src/components/VColorPicker/__tests__/VColorPickerPreview.spec.ts +101 -30
  703. package/src/components/VColorPicker/__tests__/__snapshots__/VColorPicker.spec.ts.snap +236 -193
  704. package/src/components/VColorPicker/__tests__/__snapshots__/VColorPickerEdit.spec.ts.snap +48 -31
  705. package/src/components/VCombobox/VCombobox.ts +23 -0
  706. package/src/components/VCombobox/__tests__/VCombobox-multiple.spec.ts +202 -174
  707. package/src/components/VCombobox/__tests__/VCombobox.spec.ts +126 -95
  708. package/src/components/VContent/VContent.ts +11 -3
  709. package/src/components/VCounter/VCounter.ts +1 -1
  710. package/src/components/VCounter/__tests__/VCounter.spec.ts +10 -25
  711. package/src/components/VData/VData.ts +14 -1
  712. package/src/components/VData/__tests__/VData.spec.ts +69 -90
  713. package/src/components/VDataIterator/VDataFooter.ts +16 -9
  714. package/src/components/VDataIterator/VDataIterator.ts +51 -35
  715. package/src/components/VDataIterator/__tests__/VDataFooter.spec.ts +38 -39
  716. package/src/components/VDataIterator/__tests__/VDataIterator.spec.ts +90 -122
  717. package/src/components/VDataIterator/__tests__/__snapshots__/VDataFooter.spec.ts.snap +113 -103
  718. package/src/components/VDataIterator/__tests__/__snapshots__/VDataIterator.spec.ts.snap +94 -84
  719. package/src/components/VDataTable/RowGroup.ts +33 -16
  720. package/src/components/VDataTable/VDataTable.ts +20 -29
  721. package/src/components/VDataTable/VDataTableHeader.ts +8 -9
  722. package/src/components/VDataTable/VDataTableHeaderDesktop.ts +10 -1
  723. package/src/components/VDataTable/VDataTableHeaderMobile.ts +18 -25
  724. package/src/components/VDataTable/VEditDialog.ts +23 -21
  725. package/src/components/VDataTable/VSimpleTable.ts +2 -3
  726. package/src/components/VDataTable/VVirtualTable.ts +2 -3
  727. package/src/components/VDataTable/__tests__/MobileRow.spec.ts +55 -66
  728. package/src/components/VDataTable/__tests__/Row.spec.ts +64 -73
  729. package/src/components/VDataTable/__tests__/RowGroup.spec.ts +7 -5
  730. package/src/components/VDataTable/__tests__/VDataTable.spec.ts +916 -998
  731. package/src/components/VDataTable/__tests__/VDataTableHeader.spec.ts +41 -35
  732. package/src/components/VDataTable/__tests__/VEditDialog.spec.ts +52 -40
  733. package/src/components/VDataTable/__tests__/VSimpleTable.spec.ts +55 -29
  734. package/src/components/VDataTable/__tests__/VVirtualTable.spec.ts +13 -15
  735. package/src/components/VDataTable/__tests__/__snapshots__/Row.spec.ts.snap +30 -0
  736. package/src/components/VDataTable/__tests__/__snapshots__/VDataTable.spec.ts.snap +3348 -2891
  737. package/src/components/VDataTable/__tests__/__snapshots__/VDataTableHeader.spec.ts.snap +157 -186
  738. package/src/components/VDataTable/__tests__/__snapshots__/VEditDialog.spec.ts.snap +6 -6
  739. package/src/components/VDataTable/__tests__/__snapshots__/VSimpleTable.spec.ts.snap +22 -18
  740. package/src/components/VDataTable/mixins/__tests__/__snapshots__/header.spec.ts.snap +14 -17
  741. package/src/components/VDataTable/mixins/__tests__/header.spec.ts +17 -17
  742. package/src/components/VDataTable/mixins/header.ts +6 -10
  743. package/src/components/VDatePicker/VDatePicker.ts +48 -27
  744. package/src/components/VDatePicker/VDatePickerHeader.ts +57 -32
  745. package/src/components/VDatePicker/VDatePickerMonthTable.ts +1 -1
  746. package/src/components/VDatePicker/VDatePickerTitle.ts +41 -15
  747. package/src/components/VDatePicker/VDatePickerYears.ts +19 -10
  748. package/src/components/VDatePicker/__tests__/VDatePicker.date.spec.ts +278 -260
  749. package/src/components/VDatePicker/__tests__/VDatePicker.month.spec.ts +157 -131
  750. package/src/components/VDatePicker/__tests__/VDatePickerDateTable.spec.ts +76 -90
  751. package/src/components/VDatePicker/__tests__/VDatePickerHeader.spec.ts +85 -75
  752. package/src/components/VDatePicker/__tests__/VDatePickerMonthTable.spec.ts +63 -77
  753. package/src/components/VDatePicker/__tests__/VDatePickerTitle.spec.ts +56 -32
  754. package/src/components/VDatePicker/__tests__/VDatePickerYears.spec.ts +29 -26
  755. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePicker.date.spec.ts.snap +628 -595
  756. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePicker.month.spec.ts.snap +248 -228
  757. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePickerDateTable.spec.ts.snap +615 -615
  758. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePickerHeader.spec.ts.snap +52 -52
  759. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePickerMonthTable.spec.ts.snap +144 -144
  760. package/src/components/VDatePicker/__tests__/__snapshots__/VDatePickerTitle.spec.ts.snap +18 -9
  761. package/src/components/VDatePicker/mixins/date-picker-table.ts +33 -15
  762. package/src/components/VDatePicker/util/__tests__/createNativeLocaleFormatter.spec.ts +7 -0
  763. package/src/components/VDatePicker/util/createNativeLocaleFormatter.ts +3 -0
  764. package/src/components/VDatePicker/util/eventHelpers.ts +33 -13
  765. package/src/components/VDialog/VDialog.ts +24 -12
  766. package/src/components/VDialog/__tests__/VDialog.spec.ts +105 -101
  767. package/src/components/VDialog/__tests__/__snapshots__/VDialog.spec.ts.snap +0 -15
  768. package/src/components/VDivider/__tests__/VDivider.spec.ts +11 -15
  769. package/src/components/VDivider/__tests__/__snapshots__/VDivider.spec.ts.snap +2 -2
  770. package/src/components/VExpansionPanel/VExpansionPanel.ts +5 -0
  771. package/src/components/VExpansionPanel/VExpansionPanelContent.ts +7 -10
  772. package/src/components/VExpansionPanel/VExpansionPanelHeader.ts +13 -18
  773. package/src/components/VExpansionPanel/__tests__/VExpansionPanel.spec.ts +45 -29
  774. package/src/components/VExpansionPanel/__tests__/VExpansionPanelHeader.spec.ts +6 -4
  775. package/src/components/VExpansionPanel/__tests__/VExpansionPanels.spec.ts +9 -5
  776. package/src/components/VExpansionPanel/__tests__/__snapshots__/VExpansionPanel.spec.ts.snap +12 -11
  777. package/src/components/VFileInput/VFileInput.ts +47 -32
  778. package/src/components/VFileInput/__tests__/VFileInput.spec.ts +84 -54
  779. package/src/components/VFileInput/__tests__/__snapshots__/VFileInput.spec.ts.snap +242 -146
  780. package/src/components/VFooter/VFooter.ts +2 -2
  781. package/src/components/VFooter/__tests__/VFooter.spec.ts +28 -21
  782. package/src/components/VForm/VForm.ts +63 -35
  783. package/src/components/VForm/__tests__/VForm.spec.ts +100 -80
  784. package/src/components/VGrid/VCol.ts +4 -4
  785. package/src/components/VGrid/VContainer.ts +16 -12
  786. package/src/components/VGrid/VRow.ts +2 -2
  787. package/src/components/VGrid/__tests__/VCol.spec.ts +20 -18
  788. package/src/components/VGrid/__tests__/VContainer.spec.ts +58 -3
  789. package/src/components/VGrid/__tests__/VFlex.spec.ts +3 -3
  790. package/src/components/VGrid/__tests__/VGrid.spec.ts +12 -11
  791. package/src/components/VGrid/__tests__/VLayout.spec.ts +3 -3
  792. package/src/components/VGrid/grid.ts +16 -17
  793. package/src/components/VHover/VHover.ts +23 -17
  794. package/src/components/VHover/__tests__/VHover.spec.ts +44 -28
  795. package/src/components/VIcon/VIcon.ts +72 -53
  796. package/src/components/VIcon/__tests__/VIcon.spec.ts +139 -123
  797. package/src/components/VIcon/__tests__/__snapshots__/VIcon.spec.ts.snap +19 -74
  798. package/src/components/VImg/VImg.ts +5 -4
  799. package/src/components/VImg/__tests__/VImg.spec.ts +21 -20
  800. package/src/components/VImg/__tests__/__snapshots__/VImg.spec.ts.snap +71 -66
  801. package/src/components/VInput/VInput.ts +33 -8
  802. package/src/components/VInput/__tests__/VInput.spec.ts +170 -234
  803. package/src/components/VInput/__tests__/__snapshots__/VInput.spec.ts.snap +50 -101
  804. package/src/components/VItemGroup/VItem.ts +30 -24
  805. package/src/components/VItemGroup/VItemGroup.ts +14 -3
  806. package/src/components/VItemGroup/__tests__/VItem.spec.ts +39 -46
  807. package/src/components/VItemGroup/__tests__/VItemGroup.spec.ts +96 -124
  808. package/src/components/VItemGroup/__tests__/__snapshots__/VItem.spec.ts.snap +2 -0
  809. package/src/components/VLabel/VLabel.ts +1 -1
  810. package/src/components/VLabel/__tests__/VLabel.spec.ts +240 -14
  811. package/src/components/VLazy/VLazy.ts +12 -14
  812. package/src/components/VLazy/__tests__/VLazy.spec.ts +5 -4
  813. package/src/components/VLazy/__tests__/__snapshots__/VLazy.spec.ts.snap +2 -1
  814. package/src/components/VList/VList.ts +3 -3
  815. package/src/components/VList/VListGroup.ts +43 -32
  816. package/src/components/VList/VListItem.ts +56 -24
  817. package/src/components/VList/VListItemAction.ts +11 -10
  818. package/src/components/VList/VListItemIcon.ts +1 -1
  819. package/src/components/VList/__tests__/VList.spec.ts +13 -12
  820. package/src/components/VList/__tests__/VListGroup.spec.ts +58 -50
  821. package/src/components/VList/__tests__/VListItem.spec.ts +142 -63
  822. package/src/components/VList/__tests__/VListItemAction.spec.ts +32 -31
  823. package/src/components/VList/__tests__/VListItemAvatar.spec.ts +5 -2
  824. package/src/components/VList/__tests__/VListItemGroup.spec.ts +5 -2
  825. package/src/components/VList/__tests__/__snapshots__/VList.spec.ts.snap +10 -10
  826. package/src/components/VList/__tests__/__snapshots__/VListGroup.spec.ts.snap +6 -7
  827. package/src/components/VList/__tests__/__snapshots__/VListItem.spec.ts.snap +1 -1
  828. package/src/components/VList/__tests__/__snapshots__/VListItemAction.spec.ts.snap +20 -6
  829. package/src/components/VMain/VMain.ts +2 -2
  830. package/src/components/VMain/__tests__/VMain.spec.ts +71 -17
  831. package/src/components/VMenu/VMenu.ts +28 -7
  832. package/src/components/VMenu/__tests__/VMenu.spec.ts +90 -69
  833. package/src/components/VMenu/__tests__/__snapshots__/VMenu.spec.ts.snap +3 -5
  834. package/src/components/VMessages/VMessages.ts +15 -4
  835. package/src/components/VMessages/__tests__/VMessages.spec.ts +55 -16
  836. package/src/components/VMessages/__tests__/__snapshots__/VMessages.spec.ts.snap +16 -25
  837. package/src/components/VNavigationDrawer/VNavigationDrawer.ts +27 -19
  838. package/src/components/VNavigationDrawer/__tests__/VNavigationDrawer.spec.ts +84 -71
  839. package/src/components/VOtpInput/VOtpInput.ts +92 -32
  840. package/src/components/VOtpInput/__tests__/VOtpInput.spec.ts +75 -78
  841. package/src/components/VOverflowBtn/VOverflowBtn.ts +16 -11
  842. package/src/components/VOverflowBtn/__tests__/VOverflowBtn.spec.ts +6 -6
  843. package/src/components/VOverflowBtn/__tests__/__snapshots__/VOverflowBtn.spec.ts.snap +38 -46
  844. package/src/components/VOverlay/VOverlay.ts +15 -1
  845. package/src/components/VOverlay/__tests__/VOverlay.spec.ts +6 -6
  846. package/src/components/VPagination/VPagination.ts +41 -29
  847. package/src/components/VPagination/__tests__/VPagination.spec.ts +85 -71
  848. package/src/components/VPagination/__tests__/__snapshots__/VPagination.spec.ts.snap +214 -459
  849. package/src/components/VParallax/__tests__/__snapshots__/VParallax.spec.ts.snap +8 -8
  850. package/src/components/VPicker/VPicker.ts +9 -11
  851. package/src/components/VPicker/__tests__/VPicker.spec.ts +14 -15
  852. package/src/components/VPicker/__tests__/__snapshots__/VPicker.spec.ts.snap +2 -2
  853. package/src/components/VProgressCircular/VProgressCircular.ts +6 -6
  854. package/src/components/VProgressCircular/__tests__/VProgressCircular.spec.ts +28 -21
  855. package/src/components/VProgressCircular/__tests__/__snapshots__/VProgressCircular.spec.ts.snap +62 -62
  856. package/src/components/VProgressLinear/VProgressLinear.ts +62 -33
  857. package/src/components/VProgressLinear/__tests__/VProgressLinear.spec.ts +386 -71
  858. package/src/components/VProgressLinear/__tests__/__snapshots__/VProgressLinear.spec.ts.snap +53 -79
  859. package/src/components/VRadioGroup/VRadio.ts +4 -2
  860. package/src/components/VRadioGroup/VRadioGroup.ts +20 -7
  861. package/src/components/VRadioGroup/__tests__/VRadio.spec.ts +57 -44
  862. package/src/components/VRadioGroup/__tests__/VRadioGroup.spec.ts +4 -4
  863. package/src/components/VRadioGroup/__tests__/__snapshots__/VRadio.spec.ts.snap +29 -33
  864. package/src/components/VRadioGroup/__tests__/__snapshots__/VRadioGroup.spec.ts.snap +10 -18
  865. package/src/components/VRangeSlider/VRangeSlider.ts +20 -5
  866. package/src/components/VRangeSlider/__tests__/VRangeSlider.spec.ts +40 -40
  867. package/src/components/VRangeSlider/__tests__/__snapshots__/VRangeSlider.spec.ts.snap +32 -38
  868. package/src/components/VRating/VRating.ts +13 -0
  869. package/src/components/VRating/__tests__/VRating.spec.ts +24 -29
  870. package/src/components/VResponsive/__tests__/VResponsive.spec.ts +10 -5
  871. package/src/components/VResponsive/__tests__/__snapshots__/VResponsive.spec.ts.snap +2 -2
  872. package/src/components/VSelect/VSelect.ts +110 -48
  873. package/src/components/VSelect/VSelectList.ts +62 -25
  874. package/src/components/VSelect/__tests__/VSelect.spec.ts +166 -125
  875. package/src/components/VSelect/__tests__/VSelect2.spec.ts +129 -113
  876. package/src/components/VSelect/__tests__/VSelect3.spec.ts +109 -91
  877. package/src/components/VSelect/__tests__/VSelect4.spec.ts +79 -68
  878. package/src/components/VSelect/__tests__/VSelectList.spec.ts +23 -31
  879. package/src/components/VSelect/__tests__/__snapshots__/VSelect.spec.ts.snap +58 -62
  880. package/src/components/VSelect/__tests__/__snapshots__/VSelect2.spec.ts.snap +48 -60
  881. package/src/components/VSelect/__tests__/__snapshots__/VSelect3.spec.ts.snap +9 -297
  882. package/src/components/VSelect/__tests__/__snapshots__/VSelectList.spec.ts.snap +30 -27
  883. package/src/components/VSheet/VSheet.ts +2 -1
  884. package/src/components/VSheet/__tests__/VSheet.spec.ts +5 -5
  885. package/src/components/VSkeletonLoader/__tests__/VSkeletonLoader.spec.ts +22 -15
  886. package/src/components/VSkeletonLoader/__tests__/__snapshots__/VSkeletonLoader.spec.ts.snap +60 -60
  887. package/src/components/VSlideGroup/VSlideGroup.ts +36 -24
  888. package/src/components/VSlideGroup/VSlideItem.ts +2 -0
  889. package/src/components/VSlideGroup/__tests__/VSlideGroup.spec.ts +70 -62
  890. package/src/components/VSlideGroup/__tests__/__snapshots__/VSlideGroup.spec.ts.snap +13 -34
  891. package/src/components/VSlider/VSlider.ts +58 -32
  892. package/src/components/VSlider/__tests__/VSlider.spec.ts +188 -286
  893. package/src/components/VSlider/__tests__/__snapshots__/VSlider.spec.ts.snap +157 -246
  894. package/src/components/VSnackbar/VSnackbar.ts +2 -2
  895. package/src/components/VSnackbar/__tests__/VSnackbar.spec.ts +46 -37
  896. package/src/components/VSparkline/VSparkline.ts +54 -92
  897. package/src/components/VSparkline/__tests__/VSparkline.spec.ts +33 -35
  898. package/src/components/VSpeedDial/VSpeedDial.ts +12 -15
  899. package/src/components/VSpeedDial/__tests__/VSpeedDial.spec.ts +21 -13
  900. package/src/components/VSpeedDial/__tests__/__snapshots__/VSpeedDial.spec.ts.snap +6 -6
  901. package/src/components/VStepper/VStepper.ts +7 -5
  902. package/src/components/VStepper/VStepperContent.ts +10 -16
  903. package/src/components/VStepper/VStepperStep.ts +9 -16
  904. package/src/components/VStepper/__tests__/VStepper.spec.ts +7 -4
  905. package/src/components/VStepper/__tests__/VStepperContent.spec.ts +120 -107
  906. package/src/components/VStepper/__tests__/VStepperStep.spec.ts +51 -44
  907. package/src/components/VStepper/__tests__/__snapshots__/VStepperStep.spec.ts.snap +10 -12
  908. package/src/components/VSubheader/VSubheader.ts +1 -1
  909. package/src/components/VSubheader/__tests__/VSubheader.spec.ts +12 -7
  910. package/src/components/VSubheader/__tests__/__snapshots__/VSubheader.spec.ts.snap +1 -1
  911. package/src/components/VSwitch/VSwitch.ts +5 -6
  912. package/src/components/VSwitch/__tests__/VSwitch.spec.ts +34 -44
  913. package/src/components/VSwitch/__tests__/__snapshots__/VSwitch.spec.ts.snap +11 -15
  914. package/src/components/VSystemBar/__tests__/VSystemBar.spec.ts +89 -17
  915. package/src/components/VTabs/VTab.ts +2 -0
  916. package/src/components/VTabs/VTabs.ts +39 -14
  917. package/src/components/VTabs/VTabsBar.ts +11 -5
  918. package/src/components/VTabs/VTabsItems.ts +2 -0
  919. package/src/components/VTabs/__tests__/VTab.spec.ts +49 -38
  920. package/src/components/VTabs/__tests__/VTabs.spec.ts +189 -76
  921. package/src/components/VTabs/__tests__/VTabsBar.spec.ts +68 -27
  922. package/src/components/VTabs/__tests__/VTabsSlider.spec.ts +7 -6
  923. package/src/components/VTabs/__tests__/__snapshots__/VTabs.spec.ts.snap +1 -3
  924. package/src/components/VTextField/VTextField.ts +22 -22
  925. package/src/components/VTextField/__tests__/VTextField.spec.ts +350 -257
  926. package/src/components/VTextField/__tests__/__snapshots__/VTextField.spec.ts.snap +49 -73
  927. package/src/components/VTextarea/VTextarea.ts +1 -1
  928. package/src/components/VTextarea/__tests__/VTextarea.spec.ts +163 -35
  929. package/src/components/VTextarea/__tests__/__snapshots__/VTextarea.spec.ts.snap +99 -4
  930. package/src/components/VThemeProvider/__tests__/VThemeProvider.spec.ts +49 -10
  931. package/src/components/VTimePicker/VTimePicker.ts +199 -89
  932. package/src/components/VTimePicker/VTimePickerClock.ts +40 -45
  933. package/src/components/VTimePicker/VTimePickerTitle.ts +5 -4
  934. package/src/components/VTimePicker/__tests__/VTimePicker.spec.ts +155 -142
  935. package/src/components/VTimePicker/__tests__/VTimePickerClock.spec.ts +78 -81
  936. package/src/components/VTimePicker/__tests__/VTimePickerTitle.spec.ts +49 -43
  937. package/src/components/VTimePicker/__tests__/__snapshots__/VTimePicker.spec.ts.snap +120 -40
  938. package/src/components/VTimeline/__tests__/VTimelineItem.spec.ts +25 -35
  939. package/src/components/VTimeline/__tests__/__snapshots__/VTimelineItem.spec.ts.snap +6 -7
  940. package/src/components/VToolbar/VToolbar.ts +6 -7
  941. package/src/components/VToolbar/__tests__/VToolbar.spec.ts +49 -25
  942. package/src/components/VTooltip/VTooltip.ts +26 -32
  943. package/src/components/VTooltip/__tests__/VTooltip.spec.ts +64 -78
  944. package/src/components/VTooltip/__tests__/__snapshots__/VTooltip.spec.ts.snap +34 -18
  945. package/src/components/VTreeview/VTreeview.ts +20 -17
  946. package/src/components/VTreeview/VTreeviewNode.ts +4 -6
  947. package/src/components/VTreeview/__tests__/VTreeview.spec.ts +168 -174
  948. package/src/components/VTreeview/__tests__/VTreeviewNode.spec.ts +74 -78
  949. package/src/components/VTreeview/__tests__/__snapshots__/VTreeview.spec.ts.snap +141 -141
  950. package/src/components/VTreeview/__tests__/__snapshots__/VTreeviewNode.spec.ts.snap +32 -26
  951. package/src/components/VVirtualScroll/VVirtualScroll.ts +14 -15
  952. package/src/components/VVirtualScroll/__tests__/VVirtualScroll.spec.ts +24 -20
  953. package/src/components/VWindow/VWindow.ts +9 -6
  954. package/src/components/VWindow/VWindowItem.ts +5 -4
  955. package/src/components/VWindow/__tests__/VWindow.spec.ts +304 -185
  956. package/src/components/VWindow/__tests__/VWindowItem.spec.ts +283 -126
  957. package/src/components/VWindow/__tests__/__snapshots__/VWindow.spec.ts.snap +59 -0
  958. package/src/components/VWindow/__tests__/__snapshots__/VWindowItem.spec.ts.snap +36 -0
  959. package/src/components/transitions/createTransition.ts +2 -2
  960. package/src/components/transitions/expand-transition.ts +2 -0
  961. package/src/directives/click-outside/__tests__/click-outside-shadow-dom.spec.ts +4 -4
  962. package/src/directives/click-outside/__tests__/click-outside.spec.ts +3 -3
  963. package/src/directives/color/__tests__/color.spec.ts +54 -34
  964. package/src/directives/color/index.ts +7 -3
  965. package/src/directives/intersect/__tests__/intersect.spec.ts +7 -7
  966. package/src/directives/intersect/index.ts +81 -42
  967. package/src/directives/mutate/__tests__/mutate.spec.ts +32 -26
  968. package/src/directives/mutate/index.ts +58 -49
  969. package/src/directives/resize/__tests__/resize.spec.ts +5 -5
  970. package/src/directives/resize/index.ts +33 -14
  971. package/src/directives/ripple/__tests__/ripple.spec.ts +34 -36
  972. package/src/directives/ripple/index.ts +3 -6
  973. package/src/directives/scroll/__tests__/scroll.spec.ts +13 -13
  974. package/src/directives/scroll/index.ts +35 -20
  975. package/src/directives/touch/__tests__/touch.spec.ts +23 -16
  976. package/src/directives/touch/index.ts +42 -30
  977. package/src/globals.d.ts +6 -6
  978. package/src/install.ts +10 -32
  979. package/src/mixins/activatable/__tests__/activatable.spec.ts +55 -55
  980. package/src/mixins/activatable/index.ts +10 -11
  981. package/src/mixins/applicationable/__tests__/applicationable.spec.ts +31 -27
  982. package/src/mixins/applicationable/index.ts +4 -4
  983. package/src/mixins/binds-attrs/index.ts +1 -1
  984. package/src/mixins/bootable/__tests__/bootable.spec.ts +17 -11
  985. package/src/mixins/bootable/index.ts +4 -3
  986. package/src/mixins/colorable/__tests__/colorable.spec.ts +9 -6
  987. package/src/mixins/dependent/__tests__/dependent.spec.ts +72 -33
  988. package/src/mixins/detachable/__tests__/detachable.spec.ts +45 -31
  989. package/src/mixins/detachable/index.ts +17 -10
  990. package/src/mixins/elevatable/__tests__/elevatable.spec.ts +14 -13
  991. package/src/mixins/groupable/index.ts +10 -8
  992. package/src/mixins/intersectable/__tests__/intersectable.spec.ts +35 -29
  993. package/src/mixins/intersectable/index.ts +2 -2
  994. package/src/mixins/menuable/__tests__/menuable.spec.ts +76 -33
  995. package/src/mixins/menuable/index.ts +1 -1
  996. package/src/mixins/mobile/__tests__/mobile.spec.ts +9 -6
  997. package/src/mixins/mouse/__tests__/mouse.spec.ts +54 -40
  998. package/src/mixins/mouse/index.ts +10 -6
  999. package/src/mixins/overlayable/__tests__/overlayable.spec.ts +32 -24
  1000. package/src/mixins/overlayable/index.ts +4 -3
  1001. package/src/mixins/picker/index.ts +4 -4
  1002. package/src/mixins/positionable/index.ts +2 -2
  1003. package/src/mixins/proxyable/__tests__/proxyable.spec.ts +18 -17
  1004. package/src/mixins/proxyable/index.ts +6 -3
  1005. package/src/mixins/registrable/__tests__/registrable.spec.ts +31 -0
  1006. package/src/mixins/registrable/index.ts +4 -4
  1007. package/src/mixins/rippleable/__tests__/rippleable.spec.ts +10 -9
  1008. package/src/mixins/roundable/__tests__/roundable.spec.ts +7 -5
  1009. package/src/mixins/routable/__tests__/routable.spec.ts +60 -52
  1010. package/src/mixins/routable/index.ts +6 -4
  1011. package/src/mixins/scrollable/__tests__/scrollable.spec.ts +56 -27
  1012. package/src/mixins/selectable/__tests__/selectable.spec.ts +22 -9
  1013. package/src/mixins/selectable/index.ts +17 -14
  1014. package/src/mixins/toggleable/index.ts +2 -2
  1015. package/src/mixins/translatable/index.ts +1 -1
  1016. package/src/mixins/validatable/__tests__/validatable.spec.ts +194 -158
  1017. package/src/mixins/validatable/index.ts +29 -21
  1018. package/src/services/goto/__tests__/goto.spec.ts +146 -1
  1019. package/src/services/goto/util.ts +44 -5
  1020. package/src/services/theme/__tests__/__snapshots__/theme.spec.ts.snap +0 -1128
  1021. package/src/services/theme/__tests__/theme.spec.ts +81 -83
  1022. package/src/services/theme/index.ts +22 -60
  1023. package/src/util/__tests__/console.spec.ts +124 -11
  1024. package/src/util/__tests__/dom.spec.ts +8 -5
  1025. package/src/util/__tests__/helpers.spec.ts +122 -33
  1026. package/src/util/__tests__/mergeData.spec.ts +8 -8
  1027. package/src/util/console.ts +43 -24
  1028. package/src/util/helpers.ts +57 -5
  1029. package/src/util/legacyEventsMixin.ts +34 -0
  1030. package/src/util/mergeData.ts +10 -5
  1031. package/src/util/mixins.ts +24 -7
  1032. package/types/alacarte.d.ts +14 -14
  1033. package/types/index.d.ts +8 -8
  1034. package/types/lib.d.ts +173 -173
@@ -1,4 +1,4 @@
1
- import { h } from 'vue'; // Styles
1
+ import { h, defineComponent } from 'vue'; // Styles
2
2
 
3
3
  import "../../../src/components/VColorPicker/VColorPicker.sass"; // Components
4
4
 
@@ -9,13 +9,14 @@ import VColorPickerEdit, { modes } from './VColorPickerEdit';
9
9
  import VColorPickerSwatches from './VColorPickerSwatches'; // Helpers
10
10
 
11
11
  import { parseColor, fromRGBA, extractColor, hasAlpha } from './util';
12
- import mixins from '../../util/mixins';
13
- import { deepEqual } from '../../util/helpers'; // Mixins
12
+ import { deepEqual } from '../../util/helpers';
13
+ import { breaking } from '../../util/console'; // Mixins
14
14
 
15
15
  import Elevatable from '../../mixins/elevatable';
16
16
  import Themeable from '../../mixins/themeable';
17
- export default mixins(Elevatable, Themeable).extend({
17
+ export default defineComponent({
18
18
  name: 'v-color-picker',
19
+ mixins: [Elevatable, Themeable],
19
20
  props: {
20
21
  canvasHeight: {
21
22
  type: [String, Number],
@@ -42,7 +43,7 @@ export default mixins(Elevatable, Themeable).extend({
42
43
  type: [Number, String],
43
44
  default: 150
44
45
  },
45
- value: {
46
+ modelValue: {
46
47
  type: [Object, String]
47
48
  },
48
49
  width: {
@@ -50,23 +51,38 @@ export default mixins(Elevatable, Themeable).extend({
50
51
  default: 300
51
52
  }
52
53
  },
53
- data: () => ({
54
- internalValue: fromRGBA({
55
- r: 255,
56
- g: 0,
57
- b: 0,
58
- a: 1
59
- })
60
- }),
54
+ emits: ['update:modelValue', 'update:color', 'update:mode'],
55
+
56
+ data() {
57
+ return {
58
+ internalValue: fromRGBA({
59
+ r: 255,
60
+ g: 0,
61
+ b: 0,
62
+ a: 1
63
+ })
64
+ };
65
+ },
66
+
61
67
  computed: {
62
68
  hideAlpha() {
63
- if (!this.value) return false;
64
- return !hasAlpha(this.value);
69
+ if (!this.modelValue) return false;
70
+ return !hasAlpha(this.modelValue);
65
71
  }
66
72
 
67
73
  },
74
+
75
+ created() {
76
+ const breakingProps = [['value', 'modelValue'], ['onInput', 'onUpdate:modelValue']];
77
+ /* istanbul ignore next */
78
+
79
+ breakingProps.forEach(([original, replacement]) => {
80
+ if (this.$attrs.hasOwnProperty(original)) breaking(original, replacement, this);
81
+ });
82
+ },
83
+
68
84
  watch: {
69
- value: {
85
+ modelValue: {
70
86
  handler(color) {
71
87
  this.updateColor(parseColor(color, this.internalValue));
72
88
  },
@@ -77,10 +93,10 @@ export default mixins(Elevatable, Themeable).extend({
77
93
  methods: {
78
94
  updateColor(color) {
79
95
  this.internalValue = color;
80
- const value = extractColor(this.internalValue, this.value);
96
+ const value = extractColor(this.internalValue, this.modelValue);
81
97
 
82
- if (!deepEqual(value, this.value)) {
83
- this.$emit('input', value);
98
+ if (!deepEqual(value, this.modelValue)) {
99
+ this.$emit('update:modelValue', value);
84
100
  this.$emit('update:color', this.internalValue);
85
101
  }
86
102
  },
@@ -116,30 +132,20 @@ export default mixins(Elevatable, Themeable).extend({
116
132
 
117
133
  genPreview() {
118
134
  return h(VColorPickerPreview, {
119
- props: {
120
- color: this.internalValue,
121
- disabled: this.disabled,
122
- hideAlpha: this.hideAlpha
123
- },
124
- on: {
125
- 'update:color': this.updateColor
126
- }
135
+ color: this.internalValue,
136
+ disabled: this.disabled,
137
+ hideAlpha: this.hideAlpha,
138
+ 'onUpdate:color': this.updateColor
127
139
  });
128
140
  },
129
141
 
130
142
  genSwatches() {
131
143
  return h(VColorPickerSwatches, {
132
- props: {
133
- dark: this.dark,
134
- light: this.light,
135
- disabled: this.disabled,
136
- swatches: this.swatches,
137
- color: this.internalValue,
138
- maxHeight: this.swatchesMaxHeight
139
- },
140
- on: {
141
- 'update:color': this.updateColor
142
- }
144
+ disabled: this.disabled,
145
+ swatches: this.swatches,
146
+ color: this.internalValue,
147
+ maxHeight: this.swatchesMaxHeight,
148
+ 'onUpdate:color': this.updateColor
143
149
  });
144
150
  }
145
151
 
@@ -147,15 +153,12 @@ export default mixins(Elevatable, Themeable).extend({
147
153
 
148
154
  render() {
149
155
  return h(VSheet, {
150
- class: 'v-color-picker',
151
- class: {
156
+ class: ['v-color-picker', {
152
157
  'v-color-picker--flat': this.flat,
153
158
  ...this.themeClasses,
154
159
  ...this.elevationClasses
155
- },
156
- props: {
157
- maxWidth: this.width
158
- }
160
+ }],
161
+ maxWidth: this.width
159
162
  }, [!this.hideCanvas && this.genCanvas(), (!this.hideSliders || !this.hideInputs) && this.genControls(), this.showSwatches && this.genSwatches()]);
160
163
  }
161
164
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VColorPicker/VColorPicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {h} from 'vue'\n// Styles\nimport './VColorPicker.sass'\n\n// Components\nimport VSheet from '../VSheet/VSheet'\nimport VColorPickerPreview from './VColorPickerPreview'\nimport VColorPickerCanvas from './VColorPickerCanvas'\nimport VColorPickerEdit, { Mode, modes } from './VColorPickerEdit'\nimport VColorPickerSwatches from './VColorPickerSwatches'\n\n// Helpers\nimport { VColorPickerColor, parseColor, fromRGBA, extractColor, hasAlpha } from './util'\nimport mixins from '../../util/mixins'\nimport { deepEqual } from '../../util/helpers'\n\n// Mixins\nimport Elevatable from '../../mixins/elevatable'\nimport Themeable from '../../mixins/themeable'\n\n// Types\nimport { VNode, PropType } from 'vue'\n\nexport default mixins(Elevatable, Themeable).extend({\n name: 'v-color-picker',\n\n props: {\n canvasHeight: {\n type: [String, Number],\n default: 150,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n flat: Boolean,\n hideCanvas: Boolean,\n hideSliders: Boolean,\n hideInputs: Boolean,\n hideModeSwitch: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n showSwatches: Boolean,\n swatches: Array as PropType<string[][]>,\n swatchesMaxHeight: {\n type: [Number, String],\n default: 150,\n },\n value: {\n type: [Object, String],\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n data: () => ({\n internalValue: fromRGBA({ r: 255, g: 0, b: 0, a: 1 }),\n }),\n\n computed: {\n hideAlpha (): boolean {\n if (!this.value) return false\n\n return !hasAlpha(this.value)\n },\n },\n\n watch: {\n value: {\n handler (color: any) {\n this.updateColor(parseColor(color, this.internalValue))\n },\n immediate: true,\n },\n },\n\n methods: {\n updateColor (color: VColorPickerColor) {\n this.internalValue = color\n const value = extractColor(this.internalValue, this.value)\n\n if (!deepEqual(value, this.value)) {\n this.$emit('input', value)\n this.$emit('update:color', this.internalValue)\n }\n },\n genCanvas (): VNode {\n return h(VColorPickerCanvas, {\n color: this.internalValue,\n disabled: this.disabled,\n dotSize: this.dotSize,\n width: this.width,\n height: this.canvasHeight,\n 'onUpdate:color': this.updateColor\n })\n },\n genControls (): VNode {\n return h('div', {\n class: 'v-color-picker__controls',\n }, [\n !this.hideSliders && this.genPreview(),\n !this.hideInputs && this.genEdit(),\n ])\n },\n genEdit (): VNode {\n return h(VColorPickerEdit, {\n color: this.internalValue,\n disabled: this.disabled,\n hideAlpha: this.hideAlpha,\n hideModeSwitch: this.hideModeSwitch,\n mode: this.mode,\n 'onUpdate:color': this.updateColor,\n 'onUpdate:mode': (v: Mode) => this.$emit('update:mode', v),\n })\n },\n genPreview (): VNode {\n return h(VColorPickerPreview, {\n props: {\n color: this.internalValue,\n disabled: this.disabled,\n hideAlpha: this.hideAlpha,\n },\n on: {\n 'update:color': this.updateColor,\n },\n })\n },\n genSwatches (): VNode {\n return h(VColorPickerSwatches, {\n props: {\n dark: this.dark,\n light: this.light,\n disabled: this.disabled,\n swatches: this.swatches,\n color: this.internalValue,\n maxHeight: this.swatchesMaxHeight,\n },\n on: {\n 'update:color': this.updateColor,\n },\n })\n },\n },\n\n render (): VNode {\n return h(VSheet, {\n class: 'v-color-picker',\n class: {\n 'v-color-picker--flat': this.flat,\n ...this.themeClasses,\n ...this.elevationClasses,\n },\n props: {\n maxWidth: this.width,\n },\n }, [\n !this.hideCanvas && this.genCanvas(),\n (!this.hideSliders || !this.hideInputs) && this.genControls(),\n this.showSwatches && this.genSwatches(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPicker.js"}
1
+ {"version":3,"sources":["../../../src/components/VColorPicker/VColorPicker.ts"],"names":[],"mappings":"AAAA,SAAS,CAAT,EAAY,eAAZ,QAAmC,KAAnC,C,CAEA;;AACA,OAAO,wDAAP,C,CAEA;;AACA,OAAO,MAAP,MAAmB,kBAAnB;AACA,OAAO,mBAAP,MAAgC,uBAAhC;AACA,OAAO,kBAAP,MAA+B,sBAA/B;AACA,OAAO,gBAAP,IAAiC,KAAjC,QAA8C,oBAA9C;AACA,OAAO,oBAAP,MAAiC,wBAAjC,C,CAEA;;AACA,SAA4B,UAA5B,EAAwC,QAAxC,EAAkD,YAAlD,EAAgE,QAAhE,QAAgF,QAAhF;AACA,SAAS,SAAT,QAA0B,oBAA1B;AACA,SAAS,QAAT,QAAyB,oBAAzB,C,CAEA;;AACA,OAAO,UAAP,MAAuB,yBAAvB;AACA,OAAO,SAAP,MAAsB,wBAAtB;AAKA,eAAe,eAAe,CAAC;AAC7B,EAAA,IAAI,EAAE,gBADuB;AAG7B,EAAA,MAAM,EAAE,CAAC,UAAD,EAAa,SAAb,CAHqB;AAK7B,EAAA,KAAK,EAAE;AACL,IAAA,YAAY,EAAE;AACZ,MAAA,IAAI,EAAE,CAAC,MAAD,EAAS,MAAT,CADM;AAEZ,MAAA,OAAO,EAAE;AAFG,KADT;AAKL,IAAA,QAAQ,EAAE,OALL;AAML,IAAA,OAAO,EAAE;AACP,MAAA,IAAI,EAAE,CAAC,MAAD,EAAS,MAAT,CADC;AAEP,MAAA,OAAO,EAAE;AAFF,KANJ;AAUL,IAAA,IAAI,EAAE,OAVD;AAWL,IAAA,UAAU,EAAE,OAXP;AAYL,IAAA,WAAW,EAAE,OAZR;AAaL,IAAA,UAAU,EAAE,OAbP;AAcL,IAAA,cAAc,EAAE,OAdX;AAeL,IAAA,IAAI,EAAE;AACJ,MAAA,IAAI,EAAE,MADF;AAEJ,MAAA,OAAO,EAAE,MAFL;AAGJ,MAAA,SAAS,EAAG,CAAD,IAAe,MAAM,CAAC,IAAP,CAAY,KAAZ,EAAmB,QAAnB,CAA4B,CAA5B;AAHtB,KAfD;AAoBL,IAAA,YAAY,EAAE,OApBT;AAqBL,IAAA,QAAQ,EAAE,KArBL;AAsBL,IAAA,iBAAiB,EAAE;AACjB,MAAA,IAAI,EAAE,CAAC,MAAD,EAAS,MAAT,CADW;AAEjB,MAAA,OAAO,EAAE;AAFQ,KAtBd;AA0BL,IAAA,UAAU,EAAE;AACV,MAAA,IAAI,EAAE,CAAC,MAAD,EAAS,MAAT;AADI,KA1BP;AA6BL,IAAA,KAAK,EAAE;AACL,MAAA,IAAI,EAAE,CAAC,MAAD,EAAS,MAAT,CADD;AAEL,MAAA,OAAO,EAAE;AAFJ;AA7BF,GALsB;AAwC7B,EAAA,KAAK,EAAE,CAAC,mBAAD,EAAsB,cAAtB,EAAsC,aAAtC,CAxCsB;;AA0C7B,EAAA,IAAI,GAAA;AACF,WAAO;AACL,MAAA,aAAa,EAAE,QAAQ,CAAC;AAAE,QAAA,CAAC,EAAE,GAAL;AAAU,QAAA,CAAC,EAAE,CAAb;AAAgB,QAAA,CAAC,EAAE,CAAnB;AAAsB,QAAA,CAAC,EAAE;AAAzB,OAAD;AADlB,KAAP;AAGD,GA9C4B;;AAgD7B,EAAA,QAAQ,EAAE;AACR,IAAA,SAAS,GAAA;AACP,UAAI,CAAC,KAAK,UAAV,EAAsB,OAAO,KAAP;AACtB,aAAO,CAAC,QAAQ,CAAC,KAAK,UAAN,CAAhB;AACD;;AAJO,GAhDmB;;AAuD7B,EAAA,OAAO,GAAA;AACL,UAAM,aAAa,GAAG,CACpB,CAAC,OAAD,EAAU,YAAV,CADoB,EAEpB,CAAC,SAAD,EAAY,qBAAZ,CAFoB,CAAtB;AAKA;;AACA,IAAA,aAAa,CAAC,OAAd,CAAsB,CAAC,CAAC,QAAD,EAAW,WAAX,CAAD,KAA4B;AAChD,UAAI,KAAK,MAAL,CAAY,cAAZ,CAA2B,QAA3B,CAAJ,EAA0C,QAAQ,CAAC,QAAD,EAAW,WAAX,EAAwB,IAAxB,CAAR;AAC3C,KAFD;AAGD,GAjE4B;;AAmE7B,EAAA,KAAK,EAAE;AACL,IAAA,UAAU,EAAE;AACV,MAAA,OAAO,CAAE,KAAF,EAAY;AACjB,aAAK,WAAL,CAAiB,UAAU,CAAC,KAAD,EAAQ,KAAK,aAAb,CAA3B;AACD,OAHS;;AAIV,MAAA,SAAS,EAAE;AAJD;AADP,GAnEsB;AA4E7B,EAAA,OAAO,EAAE;AACP,IAAA,WAAW,CAAE,KAAF,EAA0B;AACnC,WAAK,aAAL,GAAqB,KAArB;AACA,YAAM,KAAK,GAAG,YAAY,CAAC,KAAK,aAAN,EAAqB,KAAK,UAA1B,CAA1B;;AAEA,UAAI,CAAC,SAAS,CAAC,KAAD,EAAQ,KAAK,UAAb,CAAd,EAAwC;AACtC,aAAK,KAAL,CAAW,mBAAX,EAAgC,KAAhC;AACA,aAAK,KAAL,CAAW,cAAX,EAA2B,KAAK,aAAhC;AACD;AACF,KATM;;AAWP,IAAA,SAAS,GAAA;AACP,aAAO,CAAC,CAAC,kBAAD,EAAqB;AAC3B,QAAA,KAAK,EAAE,KAAK,aADe;AAE3B,QAAA,QAAQ,EAAE,KAAK,QAFY;AAG3B,QAAA,OAAO,EAAE,KAAK,OAHa;AAI3B,QAAA,KAAK,EAAE,KAAK,KAJe;AAK3B,QAAA,MAAM,EAAE,KAAK,YALc;AAM3B,0BAAkB,KAAK;AANI,OAArB,CAAR;AAQD,KApBM;;AAsBP,IAAA,WAAW,GAAA;AACT,aAAO,CAAC,CAAC,KAAD,EAAQ;AACd,QAAA,KAAK,EAAE;AADO,OAAR,EAEL,CACD,CAAC,KAAK,WAAN,IAAqB,KAAK,UAAL,EADpB,EAED,CAAC,KAAK,UAAN,IAAoB,KAAK,OAAL,EAFnB,CAFK,CAAR;AAMD,KA7BM;;AA+BP,IAAA,OAAO,GAAA;AACL,aAAO,CAAC,CAAC,gBAAD,EAAmB;AACzB,QAAA,KAAK,EAAE,KAAK,aADa;AAEzB,QAAA,QAAQ,EAAE,KAAK,QAFU;AAGzB,QAAA,SAAS,EAAE,KAAK,SAHS;AAIzB,QAAA,cAAc,EAAE,KAAK,cAJI;AAKzB,QAAA,IAAI,EAAE,KAAK,IALc;AAMzB,0BAAkB,KAAK,WANE;AAOzB,yBAAkB,CAAD,IAAe,KAAK,KAAL,CAAW,aAAX,EAA0B,CAA1B;AAPP,OAAnB,CAAR;AASD,KAzCM;;AA2CP,IAAA,UAAU,GAAA;AACR,aAAO,CAAC,CAAC,mBAAD,EAAsB;AAC5B,QAAA,KAAK,EAAE,KAAK,aADgB;AAE5B,QAAA,QAAQ,EAAE,KAAK,QAFa;AAG5B,QAAA,SAAS,EAAE,KAAK,SAHY;AAI5B,0BAAkB,KAAK;AAJK,OAAtB,CAAR;AAMD,KAlDM;;AAoDP,IAAA,WAAW,GAAA;AACT,aAAO,CAAC,CAAC,oBAAD,EAAuB;AAC7B,QAAA,QAAQ,EAAE,KAAK,QADc;AAE7B,QAAA,QAAQ,EAAE,KAAK,QAFc;AAG7B,QAAA,KAAK,EAAE,KAAK,aAHiB;AAI7B,QAAA,SAAS,EAAE,KAAK,iBAJa;AAK7B,0BAAkB,KAAK;AALM,OAAvB,CAAR;AAOD;;AA5DM,GA5EoB;;AA2I7B,EAAA,MAAM,GAAA;AACJ,WAAO,CAAC,CAAC,MAAD,EAAS;AACf,MAAA,KAAK,EAAE,CAAC,gBAAD,EAAmB;AACxB,gCAAwB,KAAK,IADL;AAExB,WAAG,KAAK,YAFgB;AAGxB,WAAG,KAAK;AAHgB,OAAnB,CADQ;AAMf,MAAA,QAAQ,EAAE,KAAK;AANA,KAAT,EAOL,CACD,CAAC,KAAK,UAAN,IAAoB,KAAK,SAAL,EADnB,EAED,CAAC,CAAC,KAAK,WAAN,IAAqB,CAAC,KAAK,UAA5B,KAA2C,KAAK,WAAL,EAF1C,EAGD,KAAK,YAAL,IAAqB,KAAK,WAAL,EAHpB,CAPK,CAAR;AAYD;;AAxJ4B,CAAD,CAA9B","sourcesContent":["import { h, defineComponent } from 'vue'\n\n// Styles\nimport './VColorPicker.sass'\n\n// Components\nimport VSheet from '../VSheet/VSheet'\nimport VColorPickerPreview from './VColorPickerPreview'\nimport VColorPickerCanvas from './VColorPickerCanvas'\nimport VColorPickerEdit, { Mode, modes } from './VColorPickerEdit'\nimport VColorPickerSwatches from './VColorPickerSwatches'\n\n// Helpers\nimport { VColorPickerColor, parseColor, fromRGBA, extractColor, hasAlpha } from './util'\nimport { deepEqual } from '../../util/helpers'\nimport { breaking } from '../../util/console'\n\n// Mixins\nimport Elevatable from '../../mixins/elevatable'\nimport Themeable from '../../mixins/themeable'\n\n// Types\nimport type { VNode, PropType } from 'vue'\n\nexport default defineComponent({\n name: 'v-color-picker',\n\n mixins: [Elevatable, Themeable],\n\n props: {\n canvasHeight: {\n type: [String, Number],\n default: 150,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n flat: Boolean,\n hideCanvas: Boolean,\n hideSliders: Boolean,\n hideInputs: Boolean,\n hideModeSwitch: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n showSwatches: Boolean,\n swatches: Array as PropType<string[][]>,\n swatchesMaxHeight: {\n type: [Number, String],\n default: 150,\n },\n modelValue: {\n type: [Object, String],\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n emits: ['update:modelValue', 'update:color', 'update:mode'],\n\n data () {\n return {\n internalValue: fromRGBA({ r: 255, g: 0, b: 0, a: 1 }),\n }\n },\n\n computed: {\n hideAlpha (): boolean {\n if (!this.modelValue) return false\n return !hasAlpha(this.modelValue)\n },\n },\n\n created () {\n const breakingProps = [\n ['value', 'modelValue'],\n ['onInput', 'onUpdate:modelValue'],\n ]\n\n /* istanbul ignore next */\n breakingProps.forEach(([original, replacement]) => {\n if (this.$attrs.hasOwnProperty(original)) breaking(original, replacement, this)\n })\n },\n\n watch: {\n modelValue: {\n handler (color: any) {\n this.updateColor(parseColor(color, this.internalValue))\n },\n immediate: true,\n },\n },\n\n methods: {\n updateColor (color: VColorPickerColor) {\n this.internalValue = color\n const value = extractColor(this.internalValue, this.modelValue)\n\n if (!deepEqual(value, this.modelValue)) {\n this.$emit('update:modelValue', value)\n this.$emit('update:color', this.internalValue)\n }\n },\n\n genCanvas (): VNode {\n return h(VColorPickerCanvas, {\n color: this.internalValue,\n disabled: this.disabled,\n dotSize: this.dotSize,\n width: this.width,\n height: this.canvasHeight,\n 'onUpdate:color': this.updateColor\n })\n },\n\n genControls (): VNode {\n return h('div', {\n class: 'v-color-picker__controls',\n }, [\n !this.hideSliders && this.genPreview(),\n !this.hideInputs && this.genEdit(),\n ])\n },\n\n genEdit (): VNode {\n return h(VColorPickerEdit, {\n color: this.internalValue,\n disabled: this.disabled,\n hideAlpha: this.hideAlpha,\n hideModeSwitch: this.hideModeSwitch,\n mode: this.mode,\n 'onUpdate:color': this.updateColor,\n 'onUpdate:mode': (v: string) => this.$emit('update:mode', v),\n })\n },\n\n genPreview (): VNode {\n return h(VColorPickerPreview, {\n color: this.internalValue,\n disabled: this.disabled,\n hideAlpha: this.hideAlpha,\n 'onUpdate:color': this.updateColor,\n })\n },\n\n genSwatches (): VNode {\n return h(VColorPickerSwatches, {\n disabled: this.disabled,\n swatches: this.swatches,\n color: this.internalValue,\n maxHeight: this.swatchesMaxHeight,\n 'onUpdate:color': this.updateColor,\n })\n },\n },\n\n render (): VNode {\n return h(VSheet, {\n class: ['v-color-picker', {\n 'v-color-picker--flat': this.flat,\n ...this.themeClasses,\n ...this.elevationClasses,\n }],\n maxWidth: this.width,\n }, [\n !this.hideCanvas && this.genCanvas(),\n (!this.hideSliders || !this.hideInputs) && this.genControls(),\n this.showSwatches && this.genSwatches(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPicker.js"}
@@ -1,11 +1,9 @@
1
- import { h } from 'vue'; // Styles
1
+ import { h, defineComponent } from 'vue'; // Styles
2
2
 
3
3
  import "../../../src/components/VColorPicker/VColorPickerCanvas.sass"; // Helpers
4
4
 
5
5
  import { clamp, convertToUnit } from '../../util/helpers';
6
- import { fromHSVA, fromRGBA } from './util'; // Types
7
-
8
- import { defineComponent } from 'vue';
6
+ import { fromHSVA, fromRGBA } from './util';
9
7
  export default defineComponent({
10
8
  name: 'v-color-picker-canvas',
11
9
  props: {
@@ -32,6 +30,7 @@ export default defineComponent({
32
30
  default: 300
33
31
  }
34
32
  },
33
+ emits: ['update:color'],
35
34
 
36
35
  data() {
37
36
  return {
@@ -51,14 +50,17 @@ export default defineComponent({
51
50
  y: 0
52
51
  };
53
52
  return {
54
- x: this.color.hsva.s * parseInt(this.width, 10),
55
- y: (1 - this.color.hsva.v) * parseInt(this.height, 10)
53
+ x: this.color.hsva.s * parseInt(String(this.width), 10),
54
+ y: (1 - this.color.hsva.v) * parseInt(String(this.height), 10)
56
55
  };
57
56
  }
58
57
 
59
58
  },
60
59
  watch: {
61
- 'color.hue': 'updateCanvas'
60
+ 'color.hue'() {
61
+ this.updateCanvas();
62
+ }
63
+
62
64
  },
63
65
 
64
66
  mounted() {
@@ -66,24 +68,10 @@ export default defineComponent({
66
68
  },
67
69
 
68
70
  methods: {
69
- emitColor(x, y) {
70
- const {
71
- left,
72
- top,
73
- width,
74
- height
75
- } = this.boundingRect;
76
- this.$emit('update:color', fromHSVA({
77
- h: this.color.hue,
78
- s: clamp(x - left, 0, width) / width,
79
- v: 1 - clamp(y - top, 0, height) / height,
80
- a: this.color.alpha
81
- }));
82
- },
83
-
84
71
  updateCanvas() {
85
72
  if (!this.color) return;
86
73
  const canvas = this.$refs.canvas;
74
+ if (!canvas) return;
87
75
  const ctx = canvas.getContext('2d');
88
76
  if (!ctx) return;
89
77
  const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0);
@@ -101,19 +89,25 @@ export default defineComponent({
101
89
  ctx.fillRect(0, 0, canvas.width, canvas.height);
102
90
  },
103
91
 
104
- handleClick(e) {
105
- if (this.disabled) return;
106
- this.boundingRect = this.$el.getBoundingClientRect();
107
- this.emitColor(e.clientX, e.clientY);
92
+ emitColor(x, y) {
93
+ const {
94
+ left,
95
+ top,
96
+ width,
97
+ height
98
+ } = this.boundingRect;
99
+ this.$emit('update:color', fromHSVA({
100
+ h: this.color.hue,
101
+ s: clamp(x - left, 0, width) / width,
102
+ v: 1 - clamp(y - top, 0, height) / height,
103
+ a: this.color.alpha
104
+ }));
108
105
  },
109
106
 
110
- handleMouseDown(e) {
111
- // To prevent selection while moving cursor
112
- e.preventDefault();
107
+ handleClick(e) {
113
108
  if (this.disabled) return;
114
109
  this.boundingRect = this.$el.getBoundingClientRect();
115
- window.addEventListener('mousemove', this.handleMouseMove);
116
- window.addEventListener('mouseup', this.handleMouseUp);
110
+ this.emitColor(e.clientX, e.clientY);
117
111
  },
118
112
 
119
113
  handleMouseMove(e) {
@@ -126,25 +120,31 @@ export default defineComponent({
126
120
  window.removeEventListener('mouseup', this.handleMouseUp);
127
121
  },
128
122
 
123
+ handleMouseDown(e) {
124
+ // To prevent selection while moving cursor
125
+ e.preventDefault();
126
+ if (this.disabled) return;
127
+ this.boundingRect = this.$el.getBoundingClientRect();
128
+ window.addEventListener('mousemove', this.handleMouseMove);
129
+ window.addEventListener('mouseup', this.handleMouseUp);
130
+ },
131
+
129
132
  genCanvas() {
130
133
  return h('canvas', {
131
134
  ref: 'canvas',
132
- attrs: {
133
- width: this.width,
134
- height: this.height
135
- }
135
+ width: this.width,
136
+ height: this.height
136
137
  });
137
138
  },
138
139
 
139
140
  genDot() {
140
- const radius = parseInt(this.dotSize, 10) / 2;
141
+ const radius = parseInt(String(this.dotSize), 10) / 2;
141
142
  const x = convertToUnit(this.dot.x - radius);
142
143
  const y = convertToUnit(this.dot.y - radius);
143
144
  return h('div', {
144
- class: 'v-color-picker__canvas-dot',
145
- class: {
145
+ class: ['v-color-picker__canvas-dot', {
146
146
  'v-color-picker__canvas-dot--disabled': this.disabled
147
- },
147
+ }],
148
148
  style: {
149
149
  width: convertToUnit(this.dotSize),
150
150
  height: convertToUnit(this.dotSize),
@@ -162,10 +162,8 @@ export default defineComponent({
162
162
  width: convertToUnit(this.width),
163
163
  height: convertToUnit(this.height)
164
164
  },
165
- on: {
166
- click: this.handleClick,
167
- mousedown: this.handleMouseDown
168
- }
165
+ onClick: this.handleClick,
166
+ onMousedown: this.handleMouseDown
169
167
  }, [this.genCanvas(), this.genDot()]);
170
168
  }
171
169
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {h} from 'vue'\n// Styles\nimport './VColorPickerCanvas.sass'\n\n// Helpers\nimport { clamp, convertToUnit } from '../../util/helpers'\nimport { fromHSVA, VColorPickerColor, fromRGBA } from './util'\n\n// Types\nimport { defineComponent, VNode, PropType } from 'vue'\n\nexport default defineComponent({\n name: 'v-color-picker-canvas',\n\n props: {\n color: {\n type: Object as PropType<VColorPickerColor>,\n default: () => fromRGBA({ r: 255, g: 0, b: 0, a: 1 }),\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n data () {\n return {\n boundingRect: {\n width: 0,\n height: 0,\n left: 0,\n top: 0,\n } as ClientRect,\n }\n },\n\n computed: {\n dot (): { x: number, y: number} {\n if (!this.color) return { x: 0, y: 0 }\n\n return {\n x: this.color.hsva.s * parseInt(this.width, 10),\n y: (1 - this.color.hsva.v) * parseInt(this.height, 10),\n }\n },\n },\n\n watch: {\n 'color.hue': 'updateCanvas',\n },\n\n mounted () {\n this.updateCanvas()\n },\n\n methods: {\n emitColor (x: number, y: number) {\n const { left, top, width, height } = this.boundingRect\n\n this.$emit('update:color', fromHSVA({\n h: this.color.hue,\n s: clamp(x - left, 0, width) / width,\n v: 1 - clamp(y - top, 0, height) / height,\n a: this.color.alpha,\n }))\n },\n updateCanvas () {\n if (!this.color) return\n\n const canvas = this.$refs.canvas as HTMLCanvasElement\n const ctx = canvas.getContext('2d')\n\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${this.color.hue}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n },\n handleClick (e: MouseEvent) {\n if (this.disabled) return\n\n this.boundingRect = this.$el.getBoundingClientRect()\n this.emitColor(e.clientX, e.clientY)\n },\n handleMouseDown (e: MouseEvent) {\n // To prevent selection while moving cursor\n e.preventDefault()\n\n if (this.disabled) return\n\n this.boundingRect = this.$el.getBoundingClientRect()\n\n window.addEventListener('mousemove', this.handleMouseMove)\n window.addEventListener('mouseup', this.handleMouseUp)\n },\n handleMouseMove (e: MouseEvent) {\n if (this.disabled) return\n\n this.emitColor(e.clientX, e.clientY)\n },\n handleMouseUp () {\n window.removeEventListener('mousemove', this.handleMouseMove)\n window.removeEventListener('mouseup', this.handleMouseUp)\n },\n genCanvas (): VNode {\n return h('canvas', {\n ref: 'canvas',\n attrs: {\n width: this.width,\n height: this.height,\n },\n })\n },\n genDot (): VNode {\n const radius = parseInt(this.dotSize, 10) / 2\n const x = convertToUnit(this.dot.x - radius)\n const y = convertToUnit(this.dot.y - radius)\n\n return h('div', {\n class: 'v-color-picker__canvas-dot',\n class: {\n 'v-color-picker__canvas-dot--disabled': this.disabled,\n },\n style: {\n width: convertToUnit(this.dotSize),\n height: convertToUnit(this.dotSize),\n transform: `translate(${x}, ${y})`,\n },\n })\n },\n },\n\n render (): VNode {\n return h('div', {\n class: 'v-color-picker__canvas',\n style: {\n width: convertToUnit(this.width),\n height: convertToUnit(this.height),\n },\n on: {\n click: this.handleClick,\n mousedown: this.handleMouseDown,\n },\n }, [\n this.genCanvas(),\n this.genDot(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPickerCanvas.js"}
1
+ {"version":3,"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.ts"],"names":[],"mappings":"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","sourcesContent":["import { h, defineComponent } from 'vue'\n\n// Styles\nimport './VColorPickerCanvas.sass'\n\n// Helpers\nimport { clamp, convertToUnit } from '../../util/helpers'\nimport { fromHSVA, VColorPickerColor, fromRGBA } from './util'\n\n// Types\nimport type { VNode, PropType } from 'vue'\n\nexport default defineComponent({\n name: 'v-color-picker-canvas',\n\n props: {\n color: {\n type: Object as PropType<VColorPickerColor>,\n default: () => fromRGBA({ r: 255, g: 0, b: 0, a: 1 }),\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n emits: ['update:color'],\n\n data () {\n return {\n boundingRect: {\n width: 0,\n height: 0,\n left: 0,\n top: 0,\n } as ClientRect,\n }\n },\n\n computed: {\n dot () {\n if (!this.color) return { x: 0, y: 0 }\n\n return {\n x: this.color.hsva.s * parseInt(String(this.width), 10),\n y: (1 - this.color.hsva.v) * parseInt(String(this.height), 10),\n }\n },\n },\n\n watch: {\n 'color.hue' () {\n this.updateCanvas()\n },\n },\n\n mounted () {\n this.updateCanvas()\n },\n\n methods: {\n updateCanvas () {\n if (!this.color) return\n\n const canvas = this.$refs.canvas as HTMLCanvasElement\n if (!canvas) return\n\n const ctx = canvas.getContext('2d')\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${this.color.hue}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n },\n\n emitColor (x: number, y: number) {\n const { left, top, width, height } = this.boundingRect\n\n this.$emit('update:color', fromHSVA({\n h: this.color!.hue,\n s: clamp(x - left, 0, width) / width,\n v: 1 - clamp(y - top, 0, height) / height,\n a: this.color!.alpha,\n }))\n },\n\n handleClick (e: MouseEvent) {\n if (this.disabled) return\n\n this.boundingRect = this.$el.getBoundingClientRect()\n this.emitColor(e.clientX, e.clientY)\n },\n\n handleMouseMove (e: MouseEvent) {\n if (this.disabled) return\n this.emitColor(e.clientX, e.clientY)\n },\n\n handleMouseUp () {\n window.removeEventListener('mousemove', this.handleMouseMove)\n window.removeEventListener('mouseup', this.handleMouseUp)\n },\n\n handleMouseDown (e: MouseEvent) {\n // To prevent selection while moving cursor\n e.preventDefault()\n\n if (this.disabled) return\n\n this.boundingRect = this.$el.getBoundingClientRect()\n\n window.addEventListener('mousemove', this.handleMouseMove)\n window.addEventListener('mouseup', this.handleMouseUp)\n },\n\n genCanvas (): VNode {\n return h('canvas', {\n ref: 'canvas',\n width: this.width,\n height: this.height,\n })\n },\n\n genDot (): VNode {\n const radius = parseInt(String(this.dotSize), 10) / 2\n const x = convertToUnit(this.dot.x - radius)\n const y = convertToUnit(this.dot.y - radius)\n\n return h('div', {\n class: ['v-color-picker__canvas-dot', {\n 'v-color-picker__canvas-dot--disabled': this.disabled,\n }],\n style: {\n width: convertToUnit(this.dotSize),\n height: convertToUnit(this.dotSize),\n transform: `translate(${x}, ${y})`,\n },\n })\n },\n },\n\n render (): VNode {\n return h('div', {\n class: 'v-color-picker__canvas',\n style: {\n width: convertToUnit(this.width),\n height: convertToUnit(this.height),\n },\n onClick: this.handleClick,\n onMousedown: this.handleMouseDown,\n }, [\n this.genCanvas(),\n this.genDot(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPickerCanvas.js"}
@@ -1,13 +1,11 @@
1
- import { h } from 'vue'; // Styles
1
+ import { h, defineComponent } from 'vue'; // Styles
2
2
 
3
3
  import "../../../src/components/VColorPicker/VColorPickerEdit.sass"; // Components
4
4
 
5
5
  import VBtn from '../VBtn';
6
6
  import VIcon from '../VIcon'; // Helpers
7
7
 
8
- import { parseHex } from '../../util/colorUtils'; // Types
9
-
10
- import { defineComponent } from 'vue';
8
+ import { parseHex } from '../../util/colorUtils';
11
9
  import { fromRGBA, fromHexa, fromHSLA } from './util';
12
10
  export const modes = {
13
11
  rgba: {
@@ -25,7 +23,10 @@ export const modes = {
25
23
  export default defineComponent({
26
24
  name: 'v-color-picker-edit',
27
25
  props: {
28
- color: Object,
26
+ color: {
27
+ type: Object,
28
+ required: true
29
+ },
29
30
  disabled: Boolean,
30
31
  hideAlpha: Boolean,
31
32
  hideModeSwitch: Boolean,
@@ -35,17 +36,17 @@ export default defineComponent({
35
36
  validator: v => Object.keys(modes).includes(v)
36
37
  }
37
38
  },
39
+ emits: ['update:color', 'update:mode'],
38
40
 
39
41
  data() {
40
42
  return {
41
- modes,
42
43
  internalMode: this.mode
43
44
  };
44
45
  },
45
46
 
46
47
  computed: {
47
48
  currentMode() {
48
- return this.modes[this.internalMode];
49
+ return modes[this.internalMode];
49
50
  }
50
51
 
51
52
  },
@@ -55,11 +56,6 @@ export default defineComponent({
55
56
  }
56
57
 
57
58
  },
58
-
59
- created() {
60
- this.internalMode = this.mode;
61
- },
62
-
63
59
  methods: {
64
60
  getValue(v, type) {
65
61
  if (type === 'float') return Math.round(v * 100) / 100;else if (type === 'int') return Math.round(v);else return 0;
@@ -70,21 +66,21 @@ export default defineComponent({
70
66
  },
71
67
 
72
68
  changeMode() {
73
- const modes = Object.keys(this.modes);
74
- const index = modes.indexOf(this.internalMode);
75
- const newMode = modes[(index + 1) % modes.length];
69
+ const modeKeys = Object.keys(modes);
70
+ const index = modeKeys.indexOf(this.internalMode);
71
+ const newMode = modeKeys[(index + 1) % modeKeys.length];
76
72
  this.internalMode = newMode;
77
73
  this.$emit('update:mode', newMode);
78
74
  },
79
75
 
80
- genInput(target, attrs, value, on) {
76
+ genInput(target, attrs, value, onChange) {
81
77
  return h('div', {
82
78
  class: 'v-color-picker__input'
83
79
  }, [h('input', {
84
80
  key: target,
85
81
  ...attrs,
86
82
  value,
87
- ...on
83
+ onChange
88
84
  }), h('span', target.toUpperCase())]);
89
85
  },
90
86
 
@@ -95,11 +91,9 @@ export default defineComponent({
95
91
  return this.genInput('hex', {
96
92
  maxlength: this.hideAlpha ? 7 : 9,
97
93
  disabled: this.disabled
98
- }, value, {
99
- change: e => {
100
- const el = e.target;
101
- this.$emit('update:color', this.currentMode.from(parseHex(el.value)));
102
- }
94
+ }, value, e => {
95
+ const el = e.target;
96
+ this.$emit('update:color', this.currentMode.from(parseHex(el.value)));
103
97
  });
104
98
  } else {
105
99
  const inputs = this.hideAlpha ? this.currentMode.inputs.slice(0, -1) : this.currentMode.inputs;
@@ -111,14 +105,12 @@ export default defineComponent({
111
105
  max,
112
106
  step: type === 'float' ? '0.01' : type === 'int' ? '1' : undefined,
113
107
  disabled: this.disabled
114
- }, this.getValue(value[target], type), {
115
- input: e => {
116
- const el = e.target;
117
- const newVal = this.parseValue(el.value || '0', type);
118
- this.$emit('update:color', this.currentMode.from(Object.assign({}, value, {
119
- [target]: newVal
120
- }), this.color.alpha));
121
- }
108
+ }, this.getValue(value[target], type), e => {
109
+ const el = e.target;
110
+ const newVal = this.parseValue(el.value || '0', type);
111
+ this.$emit('update:color', this.currentMode.from(Object.assign({}, value, {
112
+ [target]: newVal
113
+ }), this.color.alpha));
122
114
  });
123
115
  });
124
116
  }
@@ -130,7 +122,9 @@ export default defineComponent({
130
122
  icon: true,
131
123
  disabled: this.disabled,
132
124
  onClick: this.changeMode
133
- }, [h(VIcon, '$unfold')]);
125
+ }, {
126
+ default: () => [h(VIcon, {}, '$unfold')]
127
+ });
134
128
  }
135
129
 
136
130
  },
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VColorPicker/VColorPickerEdit.ts"],"names":[],"mappings":"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","sourcesContent":["import {h} from 'vue'\n// Styles\nimport './VColorPickerEdit.sass'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\n\n// Helpers\nimport { parseHex } from '../../util/colorUtils'\n\n// Types\nimport { defineComponent, VNode, PropType } from 'vue'\nimport { VColorPickerColor, fromRGBA, fromHexa, fromHSLA } from './util'\n\ntype Input = [string, number, string]\n\nexport type Mode = {\n inputs?: Input[]\n from: Function\n}\n\nexport const modes = {\n rgba: {\n inputs: [\n ['r', 255, 'int'],\n ['g', 255, 'int'],\n ['b', 255, 'int'],\n ['a', 1, 'float'],\n ],\n from: fromRGBA,\n },\n hsla: {\n inputs: [\n ['h', 360, 'int'],\n ['s', 1, 'float'],\n ['l', 1, 'float'],\n ['a', 1, 'float'],\n ],\n from: fromHSLA,\n },\n hexa: {\n from: fromHexa,\n },\n} as { [key: string]: Mode }\n\nexport default defineComponent({\n name: 'v-color-picker-edit',\n\n props: {\n color: Object as PropType<VColorPickerColor>,\n disabled: Boolean,\n hideAlpha: Boolean,\n hideModeSwitch: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n },\n\n data () {\n return {\n modes,\n internalMode: this.mode,\n }\n },\n\n computed: {\n currentMode (): Mode {\n return this.modes[this.internalMode]\n },\n },\n\n watch: {\n mode (mode) {\n this.internalMode = mode\n },\n },\n\n created () {\n this.internalMode = this.mode\n },\n\n methods: {\n getValue (v: any, type: string) {\n if (type === 'float') return Math.round(v * 100) / 100\n else if (type === 'int') return Math.round(v)\n else return 0\n },\n parseValue (v: string, type: string) {\n if (type === 'float') return parseFloat(v)\n else if (type === 'int') return parseInt(v, 10) || 0\n else return 0\n },\n changeMode () {\n const modes = Object.keys(this.modes)\n const index = modes.indexOf(this.internalMode)\n const newMode = modes[(index + 1) % modes.length]\n this.internalMode = newMode\n this.$emit('update:mode', newMode)\n },\n genInput (target: string, attrs: any, value: any, on: any): VNode {\n return h('div', {\n class: 'v-color-picker__input',\n }, [\n h('input', {\n key: target,\n ...attrs,\n value,\n ...on,\n }),\n h('span', target.toUpperCase()),\n ])\n },\n genInputs (): VNode[] | VNode {\n if (this.internalMode === 'hexa') {\n const hex = this.color.hexa\n const value = this.hideAlpha && hex.endsWith('FF') ? hex.substr(0, 7) : hex\n return this.genInput(\n 'hex',\n {\n maxlength: this.hideAlpha ? 7 : 9,\n disabled: this.disabled,\n },\n value,\n {\n change: (e: Event) => {\n const el = e.target as HTMLInputElement\n this.$emit('update:color', this.currentMode.from(parseHex(el.value)))\n },\n }\n )\n } else {\n const inputs = this.hideAlpha ? this.currentMode.inputs!.slice(0, -1) : this.currentMode.inputs!\n return inputs.map(([target, max, type]) => {\n const value = this.color[this.internalMode as keyof VColorPickerColor] as any\n return this.genInput(\n target,\n {\n type: 'number',\n min: 0,\n max,\n step: type === 'float' ? '0.01' : type === 'int' ? '1' : undefined,\n disabled: this.disabled,\n },\n this.getValue(value[target], type),\n {\n input: (e: Event) => {\n const el = e.target as HTMLInputElement\n const newVal = this.parseValue(el.value || '0', type)\n\n this.$emit('update:color', this.currentMode.from(\n Object.assign({}, value, { [target]: newVal }),\n this.color.alpha\n ))\n },\n }\n )\n })\n }\n },\n genSwitch (): VNode {\n return h(VBtn, {\n small: true,\n icon: true,\n disabled: this.disabled,\n onClick: this.changeMode,\n }, [\n h(VIcon, '$unfold'),\n ])\n },\n },\n\n render (): VNode {\n return h('div', {\n class: 'v-color-picker__edit',\n }, [\n this.genInputs(),\n !this.hideModeSwitch && this.genSwitch(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPickerEdit.js"}
1
+ {"version":3,"sources":["../../../src/components/VColorPicker/VColorPickerEdit.ts"],"names":[],"mappings":"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","sourcesContent":["import { h, defineComponent } from 'vue'\n\n// Styles\nimport './VColorPickerEdit.sass'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\n\n// Helpers\nimport { parseHex } from '../../util/colorUtils'\n\n// Types\nimport type { VNode, PropType } from 'vue'\nimport { VColorPickerColor, fromRGBA, fromHexa, fromHSLA } from './util'\n\ntype Input = [string, number, string]\n\nexport type Mode = {\n inputs?: Input[]\n from: Function\n}\n\nexport const modes = {\n rgba: {\n inputs: [\n ['r', 255, 'int'],\n ['g', 255, 'int'],\n ['b', 255, 'int'],\n ['a', 1, 'float'],\n ],\n from: fromRGBA,\n },\n hsla: {\n inputs: [\n ['h', 360, 'int'],\n ['s', 1, 'float'],\n ['l', 1, 'float'],\n ['a', 1, 'float'],\n ],\n from: fromHSLA,\n },\n hexa: {\n from: fromHexa,\n },\n} as { [key: string]: Mode }\n\nexport default defineComponent({\n name: 'v-color-picker-edit',\n\n props: {\n color: {\n type: Object as PropType<VColorPickerColor>,\n required: true,\n },\n disabled: Boolean,\n hideAlpha: Boolean,\n hideModeSwitch: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n },\n\n emits: ['update:color', 'update:mode'],\n\n data () {\n return {\n internalMode: this.mode,\n }\n },\n\n computed: {\n currentMode (): Mode {\n return modes[this.internalMode]\n },\n },\n\n watch: {\n mode (mode: string) {\n this.internalMode = mode\n },\n },\n\n methods: {\n getValue (v: any, type: string) {\n if (type === 'float') return Math.round(v * 100) / 100\n else if (type === 'int') return Math.round(v)\n else return 0\n },\n\n parseValue (v: string, type: string) {\n if (type === 'float') return parseFloat(v)\n else if (type === 'int') return parseInt(v, 10) || 0\n else return 0\n },\n\n changeMode () {\n const modeKeys = Object.keys(modes)\n const index = modeKeys.indexOf(this.internalMode)\n const newMode = modeKeys[(index + 1) % modeKeys.length]\n this.internalMode = newMode\n this.$emit('update:mode', newMode)\n },\n\n genInput (target: string, attrs: any, value: any, onChange: any): VNode {\n return h('div', {\n class: 'v-color-picker__input',\n }, [\n h('input', {\n key: target,\n ...attrs,\n value,\n onChange,\n }),\n h('span', target.toUpperCase()),\n ])\n },\n\n genInputs (): VNode[] | VNode {\n if (this.internalMode === 'hexa') {\n const hex = this.color!.hexa\n const value = this.hideAlpha && hex.endsWith('FF') ? hex.substr(0, 7) : hex\n return this.genInput(\n 'hex',\n {\n maxlength: this.hideAlpha ? 7 : 9,\n disabled: this.disabled,\n },\n value,\n (e: Event) => {\n const el = e.target as HTMLInputElement\n this.$emit('update:color', this.currentMode.from(parseHex(el.value)))\n }\n )\n } else {\n const inputs = this.hideAlpha ? this.currentMode.inputs!.slice(0, -1) : this.currentMode.inputs!\n return inputs.map(([target, max, type]) => {\n const value = this.color![this.internalMode as keyof VColorPickerColor] as any\n return this.genInput(\n target,\n {\n type: 'number',\n min: 0,\n max,\n step: type === 'float' ? '0.01' : type === 'int' ? '1' : undefined,\n disabled: this.disabled,\n },\n this.getValue(value[target], type),\n (e: Event) => {\n const el = e.target as HTMLInputElement\n const newVal = this.parseValue(el.value || '0', type)\n\n this.$emit('update:color', this.currentMode.from(\n Object.assign({}, value, { [target]: newVal }),\n this.color!.alpha\n ))\n }\n )\n })\n }\n },\n\n genSwitch (): VNode {\n return h(VBtn, {\n small: true,\n icon: true,\n disabled: this.disabled,\n onClick: this.changeMode,\n }, {\n default: () => [h(VIcon, {}, '$unfold')]\n })\n },\n },\n\n render (): VNode {\n return h('div', {\n class: 'v-color-picker__edit',\n }, [\n this.genInputs(),\n !this.hideModeSwitch && this.genSwitch(),\n ])\n },\n})\n"],"sourceRoot":"","file":"VColorPickerEdit.js"}