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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (764) hide show
  1. package/CHANGELOG.md +13 -45
  2. package/dist/_component-variables.sass +61 -0
  3. package/dist/json/attributes.json +398 -370
  4. package/dist/json/importMap.json +207 -219
  5. package/dist/json/tags.json +99 -121
  6. package/dist/json/web-types.json +1246 -1055
  7. package/dist/vuetify.css +994 -858
  8. package/dist/vuetify.d.ts +8241 -5547
  9. package/dist/vuetify.esm.js +8872 -8039
  10. package/dist/vuetify.esm.js.map +1 -1
  11. package/dist/vuetify.js +8871 -8038
  12. package/dist/vuetify.js.map +1 -1
  13. package/dist/vuetify.min.css +2 -2
  14. package/dist/vuetify.min.js +1142 -1077
  15. package/dist/vuetify.min.js.map +1 -1
  16. package/lib/blueprints/index.mjs +4 -0
  17. package/lib/blueprints/index.mjs.map +1 -0
  18. package/lib/blueprints/md1.mjs +63 -0
  19. package/lib/blueprints/md1.mjs.map +1 -0
  20. package/lib/blueprints/md2.mjs +60 -0
  21. package/lib/blueprints/md2.mjs.map +1 -0
  22. package/lib/blueprints/md3.mjs +74 -0
  23. package/lib/blueprints/md3.mjs.map +1 -0
  24. package/lib/components/VAlert/VAlert.css +5 -5
  25. package/lib/components/VAlert/VAlert.mjs +19 -8
  26. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  27. package/lib/components/VAlert/VAlert.sass +0 -2
  28. package/lib/components/VAlert/VAlertTitle.mjs.map +1 -1
  29. package/lib/components/VAlert/index.mjs.map +1 -1
  30. package/lib/components/VApp/VApp.css +2 -5
  31. package/lib/components/VApp/VApp.mjs +3 -4
  32. package/lib/components/VApp/VApp.mjs.map +1 -1
  33. package/lib/components/VApp/VApp.sass +11 -12
  34. package/lib/components/VApp/index.mjs.map +1 -1
  35. package/lib/components/VApp/variables.scss +6 -0
  36. package/lib/components/VAppBar/VAppBar.mjs +8 -7
  37. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  38. package/lib/components/VAppBar/VAppBar.sass +0 -1
  39. package/lib/components/VAppBar/VAppBarNavIcon.mjs +11 -14
  40. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  41. package/lib/components/VAppBar/VAppBarTitle.mjs +7 -4
  42. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  43. package/lib/components/VAppBar/_variables.scss +2 -0
  44. package/lib/components/VAppBar/index.mjs.map +1 -1
  45. package/lib/components/VAutocomplete/VAutocomplete.mjs +76 -53
  46. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  47. package/lib/components/VAutocomplete/VAutocomplete.sass +0 -2
  48. package/lib/components/VAutocomplete/index.mjs.map +1 -1
  49. package/lib/components/VAvatar/VAvatar.css +1 -1
  50. package/lib/components/VAvatar/VAvatar.mjs +3 -2
  51. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  52. package/lib/components/VAvatar/VAvatar.sass +1 -2
  53. package/lib/components/VAvatar/_mixins.scss +0 -1
  54. package/lib/components/VAvatar/index.mjs.map +1 -1
  55. package/lib/components/VBadge/VBadge.css +3 -6
  56. package/lib/components/VBadge/VBadge.mjs +21 -48
  57. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  58. package/lib/components/VBadge/VBadge.sass +2 -5
  59. package/lib/components/VBadge/_variables.scss +3 -4
  60. package/lib/components/VBadge/index.mjs.map +1 -1
  61. package/lib/components/VBanner/VBanner.css +7 -7
  62. package/lib/components/VBanner/VBanner.mjs +34 -22
  63. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  64. package/lib/components/VBanner/VBanner.sass +6 -8
  65. package/lib/components/VBanner/VBannerActions.mjs +1 -1
  66. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  67. package/lib/components/VBanner/VBannerText.mjs.map +1 -1
  68. package/lib/components/VBanner/index.mjs +0 -2
  69. package/lib/components/VBanner/index.mjs.map +1 -1
  70. package/lib/components/VBottomNavigation/VBottomNavigation.css +5 -12
  71. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +5 -4
  72. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  73. package/lib/components/VBottomNavigation/VBottomNavigation.sass +6 -14
  74. package/lib/components/VBottomNavigation/_variables.scss +7 -8
  75. package/lib/components/VBottomNavigation/index.mjs.map +1 -1
  76. package/lib/components/VBottomSheet/VBottomSheet.mjs.map +1 -1
  77. package/lib/components/VBottomSheet/index.mjs.map +1 -1
  78. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +31 -15
  79. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  80. package/lib/components/VBreadcrumbs/VBreadcrumbs.sass +0 -1
  81. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  82. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +5 -8
  83. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  84. package/lib/components/VBreadcrumbs/index.mjs.map +1 -1
  85. package/lib/components/VBtn/VBtn.css +83 -24
  86. package/lib/components/VBtn/VBtn.mjs +80 -31
  87. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  88. package/lib/components/VBtn/VBtn.sass +57 -8
  89. package/lib/components/VBtn/_variables.scss +7 -4
  90. package/lib/components/VBtn/index.mjs.map +1 -1
  91. package/lib/components/VBtnGroup/VBtnGroup.css +1 -1
  92. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  93. package/lib/components/VBtnGroup/VBtnGroup.sass +0 -1
  94. package/lib/components/VBtnGroup/_variables.scss +2 -0
  95. package/lib/components/VBtnGroup/index.mjs.map +1 -1
  96. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  97. package/lib/components/VBtnToggle/VBtnToggle.sass +0 -1
  98. package/lib/components/VBtnToggle/_variables.scss +1 -0
  99. package/lib/components/VBtnToggle/index.mjs.map +1 -1
  100. package/lib/components/VCalendar/VCalendar.mjs.map +1 -1
  101. package/lib/components/VCalendar/VCalendarCategory.mjs.map +1 -1
  102. package/lib/components/VCalendar/VCalendarDaily.mjs.map +1 -1
  103. package/lib/components/VCalendar/VCalendarMonthly.mjs.map +1 -1
  104. package/lib/components/VCalendar/VCalendarWeekly.mjs.map +1 -1
  105. package/lib/components/VCalendar/index.mjs.map +1 -1
  106. package/lib/components/VCalendar/mixins/calendar-base.mjs.map +1 -1
  107. package/lib/components/VCalendar/mixins/calendar-with-events.mjs.map +1 -1
  108. package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs.map +1 -1
  109. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  110. package/lib/components/VCalendar/mixins/times.mjs.map +1 -1
  111. package/lib/components/VCalendar/modes/column.mjs.map +1 -1
  112. package/lib/components/VCalendar/modes/common.mjs.map +1 -1
  113. package/lib/components/VCalendar/modes/index.mjs.map +1 -1
  114. package/lib/components/VCalendar/modes/stack.mjs.map +1 -1
  115. package/lib/components/VCalendar/util/events.mjs.map +1 -1
  116. package/lib/components/VCalendar/util/parser.mjs.map +1 -1
  117. package/lib/components/VCalendar/util/props.mjs.map +1 -1
  118. package/lib/components/VCalendar/util/timestamp.mjs.map +1 -1
  119. package/lib/components/VCard/VCard.css +91 -73
  120. package/lib/components/VCard/VCard.mjs +61 -70
  121. package/lib/components/VCard/VCard.mjs.map +1 -1
  122. package/lib/components/VCard/VCard.sass +71 -59
  123. package/lib/components/VCard/VCardActions.mjs +1 -1
  124. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  125. package/lib/components/VCard/VCardItem.mjs +88 -0
  126. package/lib/components/VCard/VCardItem.mjs.map +1 -0
  127. package/lib/components/VCard/VCardSubtitle.mjs.map +1 -1
  128. package/lib/components/VCard/VCardText.mjs.map +1 -1
  129. package/lib/components/VCard/VCardTitle.mjs.map +1 -1
  130. package/lib/components/VCard/_variables.scss +39 -24
  131. package/lib/components/VCard/index.mjs +1 -5
  132. package/lib/components/VCard/index.mjs.map +1 -1
  133. package/lib/components/VCarousel/VCarousel.mjs +5 -3
  134. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  135. package/lib/components/VCarousel/VCarousel.sass +0 -1
  136. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  137. package/lib/components/VCarousel/_variables.scss +1 -0
  138. package/lib/components/VCarousel/index.mjs.map +1 -1
  139. package/lib/components/VCheckbox/VCheckbox.mjs +13 -45
  140. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  141. package/lib/components/VCheckbox/VCheckbox.sass +0 -1
  142. package/lib/components/VCheckbox/VCheckboxBtn.mjs +67 -0
  143. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -0
  144. package/lib/components/VCheckbox/index.mjs +1 -0
  145. package/lib/components/VCheckbox/index.mjs.map +1 -1
  146. package/lib/components/VChip/VChip.css +142 -65
  147. package/lib/components/VChip/VChip.mjs +80 -41
  148. package/lib/components/VChip/VChip.mjs.map +1 -1
  149. package/lib/components/VChip/VChip.sass +6 -1
  150. package/lib/components/VChip/_mixins.scss +26 -6
  151. package/lib/components/VChip/_variables.scss +1 -5
  152. package/lib/components/VChip/index.mjs.map +1 -1
  153. package/lib/components/VChipGroup/VChipGroup.mjs +5 -4
  154. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  155. package/lib/components/VChipGroup/VChipGroup.sass +1 -1
  156. package/lib/components/VChipGroup/_variables.scss +1 -1
  157. package/lib/components/VChipGroup/index.mjs.map +1 -1
  158. package/lib/components/VCode/VCode.sass +1 -2
  159. package/lib/components/VCode/_variables.scss +1 -1
  160. package/lib/components/VCode/index.mjs.map +1 -1
  161. package/lib/components/VColorPicker/VColorPicker.mjs +16 -10
  162. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  163. package/lib/components/VColorPicker/VColorPicker.sass +0 -1
  164. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +5 -4
  165. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  166. package/lib/components/VColorPicker/VColorPickerCanvas.sass +0 -1
  167. package/lib/components/VColorPicker/VColorPickerEdit.mjs +4 -3
  168. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  169. package/lib/components/VColorPicker/VColorPickerEdit.sass +0 -1
  170. package/lib/components/VColorPicker/VColorPickerPreview.mjs +4 -3
  171. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  172. package/lib/components/VColorPicker/VColorPickerPreview.sass +0 -1
  173. package/lib/components/VColorPicker/VColorPickerSwatches.mjs +6 -5
  174. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  175. package/lib/components/VColorPicker/VColorPickerSwatches.sass +0 -1
  176. package/lib/components/VColorPicker/_variables.scss +17 -10
  177. package/lib/components/VColorPicker/index.mjs.map +1 -1
  178. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  179. package/lib/components/VCombobox/VCombobox.mjs +82 -66
  180. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  181. package/lib/components/VCombobox/VCombobox.sass +0 -2
  182. package/lib/components/VCombobox/index.mjs.map +1 -1
  183. package/lib/components/VCounter/VCounter.mjs +16 -16
  184. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  185. package/lib/components/VCounter/VCounter.sass +1 -2
  186. package/lib/components/VCounter/_variables.scss +2 -1
  187. package/lib/components/VCounter/index.mjs.map +1 -1
  188. package/lib/components/VData/VData.mjs.map +1 -1
  189. package/lib/components/VData/index.mjs.map +1 -1
  190. package/lib/components/VDataIterator/VDataFooter.mjs.map +1 -1
  191. package/lib/components/VDataIterator/VDataIterator.mjs.map +1 -1
  192. package/lib/components/VDataIterator/index.mjs.map +1 -1
  193. package/lib/components/VDataTable/MobileRow.mjs.map +1 -1
  194. package/lib/components/VDataTable/Row.mjs.map +1 -1
  195. package/lib/components/VDataTable/RowGroup.mjs.map +1 -1
  196. package/lib/components/VDataTable/VDataTable.mjs.map +1 -1
  197. package/lib/components/VDataTable/VDataTableHeader.mjs.map +1 -1
  198. package/lib/components/VDataTable/VDataTableHeaderDesktop.mjs.map +1 -1
  199. package/lib/components/VDataTable/VDataTableHeaderMobile.mjs.map +1 -1
  200. package/lib/components/VDataTable/VEditDialog.mjs.map +1 -1
  201. package/lib/components/VDataTable/VVirtualTable.mjs.map +1 -1
  202. package/lib/components/VDataTable/index.mjs.map +1 -1
  203. package/lib/components/VDataTable/mixins/header.mjs.map +1 -1
  204. package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
  205. package/lib/components/VDatePicker/VDatePickerDateTable.mjs.map +1 -1
  206. package/lib/components/VDatePicker/VDatePickerHeader.mjs.map +1 -1
  207. package/lib/components/VDatePicker/VDatePickerMonthTable.mjs.map +1 -1
  208. package/lib/components/VDatePicker/VDatePickerTitle.mjs.map +1 -1
  209. package/lib/components/VDatePicker/VDatePickerYears.mjs.map +1 -1
  210. package/lib/components/VDatePicker/index.mjs.map +1 -1
  211. package/lib/components/VDatePicker/mixins/date-picker-table.mjs.map +1 -1
  212. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs.map +1 -1
  213. package/lib/components/VDatePicker/util/eventHelpers.mjs.map +1 -1
  214. package/lib/components/VDatePicker/util/index.mjs.map +1 -1
  215. package/lib/components/VDatePicker/util/isDateAllowed.mjs.map +1 -1
  216. package/lib/components/VDatePicker/util/monthChange.mjs.map +1 -1
  217. package/lib/components/VDatePicker/util/pad.mjs.map +1 -1
  218. package/lib/components/VDatePicker/util/sanitizeDateString.mjs.map +1 -1
  219. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  220. package/lib/components/VDefaultsProvider/index.mjs.map +1 -1
  221. package/lib/components/VDialog/VDialog.css +2 -6
  222. package/lib/components/VDialog/VDialog.mjs +29 -25
  223. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  224. package/lib/components/VDialog/VDialog.sass +1 -6
  225. package/lib/components/VDialog/_variables.scss +0 -2
  226. package/lib/components/VDialog/index.mjs.map +1 -1
  227. package/lib/components/VDivider/VDivider.mjs +16 -17
  228. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  229. package/lib/components/VDivider/VDivider.sass +0 -1
  230. package/lib/components/VDivider/_variables.scss +3 -1
  231. package/lib/components/VDivider/index.mjs.map +1 -1
  232. package/lib/components/VExpansionPanel/VExpansionPanel.css +8 -7
  233. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +6 -4
  234. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  235. package/lib/components/VExpansionPanel/VExpansionPanel.sass +0 -1
  236. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  237. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +7 -6
  238. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  239. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  240. package/lib/components/VExpansionPanel/_variables.scss +15 -10
  241. package/lib/components/VExpansionPanel/index.mjs.map +1 -1
  242. package/lib/components/VField/VField.css +9 -9
  243. package/lib/components/VField/VField.mjs +24 -15
  244. package/lib/components/VField/VField.mjs.map +1 -1
  245. package/lib/components/VField/VField.sass +6 -8
  246. package/lib/components/VField/VFieldLabel.mjs +8 -9
  247. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  248. package/lib/components/VField/_variables.scss +3 -3
  249. package/lib/components/VField/index.mjs.map +1 -1
  250. package/lib/components/VFileInput/VFileInput.mjs +3 -2
  251. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  252. package/lib/components/VFileInput/VFileInput.sass +0 -1
  253. package/lib/components/VFileInput/index.mjs.map +1 -1
  254. package/lib/components/VFooter/VFooter.mjs +5 -4
  255. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  256. package/lib/components/VFooter/VFooter.sass +0 -1
  257. package/lib/components/VFooter/_variables.scss +2 -1
  258. package/lib/components/VFooter/index.mjs.map +1 -1
  259. package/lib/components/VForm/VForm.mjs +3 -3
  260. package/lib/components/VForm/VForm.mjs.map +1 -1
  261. package/lib/components/VForm/index.mjs.map +1 -1
  262. package/lib/components/VGrid/VCol.mjs.map +1 -1
  263. package/lib/components/VGrid/VContainer.mjs +4 -3
  264. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  265. package/lib/components/VGrid/VRow.mjs.map +1 -1
  266. package/lib/components/VGrid/VSpacer.mjs.map +1 -1
  267. package/lib/components/VGrid/index.mjs.map +1 -1
  268. package/lib/components/VHover/VHover.mjs.map +1 -1
  269. package/lib/components/VHover/index.mjs.map +1 -1
  270. package/lib/components/VIcon/VIcon.css +0 -8
  271. package/lib/components/VIcon/VIcon.mjs +21 -24
  272. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  273. package/lib/components/VIcon/VIcon.sass +0 -9
  274. package/lib/components/VIcon/_variables.scss +2 -5
  275. package/lib/components/VIcon/index.mjs.map +1 -1
  276. package/lib/components/VImg/VImg.mjs.map +1 -1
  277. package/lib/components/VImg/VImg.sass +0 -1
  278. package/lib/components/VImg/index.mjs.map +1 -1
  279. package/lib/components/VInput/VInput.mjs +13 -8
  280. package/lib/components/VInput/VInput.mjs.map +1 -1
  281. package/lib/components/VInput/VInput.sass +0 -1
  282. package/lib/components/VInput/index.mjs.map +1 -1
  283. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  284. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  285. package/lib/components/VItemGroup/VItemGroup.sass +0 -1
  286. package/lib/components/VItemGroup/index.mjs.map +1 -1
  287. package/lib/components/VKbd/VKbd.sass +0 -1
  288. package/lib/components/VKbd/_variables.scss +1 -1
  289. package/lib/components/VKbd/index.mjs.map +1 -1
  290. package/lib/components/VLabel/VLabel.mjs +4 -3
  291. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  292. package/lib/components/VLabel/VLabel.sass +0 -1
  293. package/lib/components/VLabel/_variables.scss +1 -0
  294. package/lib/components/VLabel/index.mjs.map +1 -1
  295. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  296. package/lib/components/VLayout/VLayoutItem.mjs +1 -1
  297. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  298. package/lib/components/VLayout/index.mjs.map +1 -1
  299. package/lib/components/VLazy/VLazy.mjs +5 -3
  300. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  301. package/lib/components/VLazy/index.mjs.map +1 -1
  302. package/lib/components/VList/VList.css +0 -6
  303. package/lib/components/VList/VList.mjs +62 -48
  304. package/lib/components/VList/VList.mjs.map +1 -1
  305. package/lib/components/VList/VList.sass +0 -2
  306. package/lib/components/VList/VListChildren.mjs +43 -5
  307. package/lib/components/VList/VListChildren.mjs.map +1 -1
  308. package/lib/components/VList/VListGroup.mjs +18 -7
  309. package/lib/components/VList/VListGroup.mjs.map +1 -1
  310. package/lib/components/VList/VListImg.mjs.map +1 -1
  311. package/lib/components/VList/VListItem.css +14 -13
  312. package/lib/components/VList/VListItem.mjs +25 -19
  313. package/lib/components/VList/VListItem.mjs.map +1 -1
  314. package/lib/components/VList/VListItem.sass +1 -2
  315. package/lib/components/VList/VListItemAction.mjs +8 -9
  316. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  317. package/lib/components/VList/VListItemAvatar.mjs +4 -3
  318. package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
  319. package/lib/components/VList/VListItemHeader.mjs.map +1 -1
  320. package/lib/components/VList/VListItemIcon.mjs +4 -3
  321. package/lib/components/VList/VListItemIcon.mjs.map +1 -1
  322. package/lib/components/VList/VListItemMedia.mjs +4 -3
  323. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  324. package/lib/components/VList/VListItemSubtitle.mjs.map +1 -1
  325. package/lib/components/VList/VListItemTitle.mjs.map +1 -1
  326. package/lib/components/VList/VListSubheader.mjs +7 -6
  327. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  328. package/lib/components/VList/_variables.scss +0 -1
  329. package/lib/components/VList/index.mjs +2 -2
  330. package/lib/components/VList/index.mjs.map +1 -1
  331. package/lib/components/VList/list.mjs.map +1 -1
  332. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -3
  333. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  334. package/lib/components/VLocaleProvider/index.mjs.map +1 -1
  335. package/lib/components/VMain/VMain.mjs +4 -3
  336. package/lib/components/VMain/VMain.mjs.map +1 -1
  337. package/lib/components/VMain/VMain.sass +0 -1
  338. package/lib/components/VMain/_variables.scss +1 -1
  339. package/lib/components/VMain/index.mjs.map +1 -1
  340. package/lib/components/VMenu/VMenu.mjs +10 -6
  341. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  342. package/lib/components/VMenu/VMenu.sass +0 -1
  343. package/lib/components/VMenu/_variables.scss +0 -1
  344. package/lib/components/VMenu/index.mjs.map +1 -1
  345. package/lib/components/VMenu/shared.mjs.map +1 -1
  346. package/lib/components/VMessages/VMessages.mjs +5 -3
  347. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  348. package/lib/components/VMessages/VMessages.sass +0 -1
  349. package/lib/components/VMessages/_variables.scss +1 -1
  350. package/lib/components/VMessages/index.mjs.map +1 -1
  351. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +17 -11
  352. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  353. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +0 -1
  354. package/lib/components/VNavigationDrawer/_variables.scss +2 -1
  355. package/lib/components/VNavigationDrawer/index.mjs.map +1 -1
  356. package/lib/components/VNavigationDrawer/touch.mjs +5 -2
  357. package/lib/components/VNavigationDrawer/touch.mjs.map +1 -1
  358. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  359. package/lib/components/VNoSsr/index.mjs.map +1 -1
  360. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -1
  361. package/lib/components/VOtpInput/index.mjs.map +1 -1
  362. package/lib/components/VOverflowBtn/VOverflowBtn.mjs.map +1 -1
  363. package/lib/components/VOverflowBtn/index.mjs.map +1 -1
  364. package/lib/components/VOverlay/VOverlay.css +0 -1
  365. package/lib/components/VOverlay/VOverlay.mjs +54 -28
  366. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  367. package/lib/components/VOverlay/VOverlay.sass +0 -2
  368. package/lib/components/VOverlay/_variables.scss +0 -1
  369. package/lib/components/VOverlay/index.mjs.map +1 -1
  370. package/lib/components/VOverlay/locationStrategies.mjs +395 -0
  371. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -0
  372. package/lib/components/VOverlay/requestNewFrame.mjs.map +1 -1
  373. package/lib/components/VOverlay/scrollStrategies.mjs +2 -2
  374. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  375. package/lib/components/VOverlay/useActivator.mjs +11 -4
  376. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  377. package/lib/components/VOverlay/util/point.mjs +3 -3
  378. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  379. package/lib/components/VPagination/VPagination.mjs +22 -17
  380. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  381. package/lib/components/VPagination/VPagination.sass +0 -1
  382. package/lib/components/VPagination/index.mjs.map +1 -1
  383. package/lib/components/VParallax/VParallax.mjs +5 -5
  384. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  385. package/lib/components/VParallax/index.mjs.map +1 -1
  386. package/lib/components/VPicker/VPicker.mjs.map +1 -1
  387. package/lib/components/VPicker/index.mjs.map +1 -1
  388. package/lib/components/VProgressCircular/VProgressCircular.mjs +6 -5
  389. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  390. package/lib/components/VProgressCircular/VProgressCircular.sass +0 -1
  391. package/lib/components/VProgressCircular/_variables.scss +2 -0
  392. package/lib/components/VProgressCircular/index.mjs.map +1 -1
  393. package/lib/components/VProgressLinear/VProgressLinear.mjs +5 -3
  394. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  395. package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
  396. package/lib/components/VProgressLinear/_variables.scss +1 -0
  397. package/lib/components/VProgressLinear/index.mjs.map +1 -1
  398. package/lib/components/VRadio/VRadio.mjs +5 -3
  399. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  400. package/lib/components/VRadio/index.mjs.map +1 -1
  401. package/lib/components/VRadioGroup/VRadioGroup.mjs +10 -5
  402. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  403. package/lib/components/VRadioGroup/VRadioGroup.sass +5 -3
  404. package/lib/components/VRadioGroup/_variables.scss +3 -4
  405. package/lib/components/VRadioGroup/index.mjs.map +1 -1
  406. package/lib/components/VRangeSlider/VRangeSlider.mjs +12 -13
  407. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  408. package/lib/components/VRangeSlider/index.mjs.map +1 -1
  409. package/lib/components/VRating/VRating.mjs +9 -7
  410. package/lib/components/VRating/VRating.mjs.map +1 -1
  411. package/lib/components/VRating/VRating.sass +2 -1
  412. package/lib/components/VRating/index.mjs.map +1 -1
  413. package/lib/components/VResponsive/VResponsive.mjs +7 -6
  414. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  415. package/lib/components/VResponsive/index.mjs.map +1 -1
  416. package/lib/components/VSelect/VSelect.mjs +90 -38
  417. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  418. package/lib/components/VSelect/VSelect.sass +0 -2
  419. package/lib/components/VSelect/index.mjs.map +1 -1
  420. package/lib/components/VSelectionControl/VSelectionControl.css +1 -0
  421. package/lib/components/VSelectionControl/VSelectionControl.mjs +17 -14
  422. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  423. package/lib/components/VSelectionControl/VSelectionControl.sass +1 -1
  424. package/lib/components/VSelectionControl/_variables.scss +1 -0
  425. package/lib/components/VSelectionControl/index.mjs.map +1 -1
  426. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +5 -4
  427. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  428. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +1 -6
  429. package/lib/components/VSelectionControlGroup/_variables.scss +1 -4
  430. package/lib/components/VSelectionControlGroup/index.mjs.map +1 -1
  431. package/lib/components/VSheet/VSheet.mjs +10 -6
  432. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  433. package/lib/components/VSheet/VSheet.sass +0 -1
  434. package/lib/components/VSheet/_variables.scss +3 -2
  435. package/lib/components/VSheet/index.mjs.map +1 -1
  436. package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
  437. package/lib/components/VSkeletonLoader/index.mjs.map +1 -1
  438. package/lib/components/VSlideGroup/VSlideGroup.mjs +48 -49
  439. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  440. package/lib/components/VSlideGroup/VSlideGroup.sass +0 -1
  441. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +4 -3
  442. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  443. package/lib/components/VSlideGroup/_variables.scss +0 -5
  444. package/lib/components/VSlideGroup/helpers.mjs.map +1 -1
  445. package/lib/components/VSlideGroup/index.mjs +2 -2
  446. package/lib/components/VSlideGroup/index.mjs.map +1 -1
  447. package/lib/components/VSlider/VSlider.mjs +7 -9
  448. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  449. package/lib/components/VSlider/VSlider.sass +0 -2
  450. package/lib/components/VSlider/VSliderThumb.mjs +6 -5
  451. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  452. package/lib/components/VSlider/VSliderThumb.sass +0 -2
  453. package/lib/components/VSlider/VSliderTrack.mjs +13 -11
  454. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  455. package/lib/components/VSlider/VSliderTrack.sass +0 -2
  456. package/lib/components/VSlider/index.mjs.map +1 -1
  457. package/lib/components/VSlider/slider.mjs +4 -4
  458. package/lib/components/VSlider/slider.mjs.map +1 -1
  459. package/lib/components/VSnackbar/VSnackbar.css +5 -23
  460. package/lib/components/VSnackbar/VSnackbar.mjs +55 -52
  461. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  462. package/lib/components/VSnackbar/VSnackbar.sass +0 -19
  463. package/lib/components/VSnackbar/_variables.scss +2 -0
  464. package/lib/components/VSnackbar/index.mjs.map +1 -1
  465. package/lib/components/VSparkline/VSparkline.mjs.map +1 -1
  466. package/lib/components/VSparkline/helpers/core.mjs.map +1 -1
  467. package/lib/components/VSparkline/helpers/math.mjs.map +1 -1
  468. package/lib/components/VSparkline/helpers/path.mjs.map +1 -1
  469. package/lib/components/VSparkline/index.mjs.map +1 -1
  470. package/lib/components/VSpeedDial/VSpeedDial.mjs.map +1 -1
  471. package/lib/components/VSpeedDial/index.mjs.map +1 -1
  472. package/lib/components/VStepper/VStepper.mjs.map +1 -1
  473. package/lib/components/VStepper/VStepperContent.mjs.map +1 -1
  474. package/lib/components/VStepper/VStepperStep.mjs.map +1 -1
  475. package/lib/components/VStepper/index.mjs.map +1 -1
  476. package/lib/components/VSwitch/VSwitch.mjs +8 -2
  477. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  478. package/lib/components/VSwitch/VSwitch.sass +0 -1
  479. package/lib/components/VSwitch/_variables.scss +1 -0
  480. package/lib/components/VSwitch/index.mjs.map +1 -1
  481. package/lib/components/VSystemBar/VSystemBar.mjs +5 -13
  482. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  483. package/lib/components/VSystemBar/VSystemBar.sass +0 -1
  484. package/lib/components/VSystemBar/_variables.scss +2 -1
  485. package/lib/components/VSystemBar/index.mjs.map +1 -1
  486. package/lib/components/VTable/VTable.mjs +9 -8
  487. package/lib/components/VTable/VTable.mjs.map +1 -1
  488. package/lib/components/VTable/VTable.sass +0 -1
  489. package/lib/components/VTable/_variables.scss +2 -0
  490. package/lib/components/VTable/index.mjs.map +1 -1
  491. package/lib/components/VTabs/VTab.css +1 -1
  492. package/lib/components/VTabs/VTab.mjs +6 -5
  493. package/lib/components/VTabs/VTab.mjs.map +1 -1
  494. package/lib/components/VTabs/VTab.sass +1 -2
  495. package/lib/components/VTabs/VTabs.css +8 -9
  496. package/lib/components/VTabs/VTabs.mjs +9 -7
  497. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  498. package/lib/components/VTabs/VTabs.sass +4 -6
  499. package/lib/components/VTabs/_variables.scss +2 -0
  500. package/lib/components/VTabs/index.mjs.map +1 -1
  501. package/lib/components/VTabs/shared.mjs.map +1 -1
  502. package/lib/components/VTextField/VTextField.mjs +10 -7
  503. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  504. package/lib/components/VTextField/VTextField.sass +0 -1
  505. package/lib/components/VTextField/_variables.scss +1 -1
  506. package/lib/components/VTextField/index.mjs.map +1 -1
  507. package/lib/components/VTextarea/VTextarea.mjs +4 -4
  508. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  509. package/lib/components/VTextarea/VTextarea.sass +0 -2
  510. package/lib/components/VTextarea/_variables.scss +1 -0
  511. package/lib/components/VTextarea/index.mjs.map +1 -1
  512. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  513. package/lib/components/VThemeProvider/index.mjs.map +1 -1
  514. package/lib/components/VTimePicker/SelectingTimes.mjs.map +1 -1
  515. package/lib/components/VTimePicker/VTimePicker.mjs.map +1 -1
  516. package/lib/components/VTimePicker/VTimePickerClock.mjs.map +1 -1
  517. package/lib/components/VTimePicker/VTimePickerTitle.mjs.map +1 -1
  518. package/lib/components/VTimePicker/index.mjs.map +1 -1
  519. package/lib/components/VTimeline/VTimeline.mjs +24 -25
  520. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  521. package/lib/components/VTimeline/VTimeline.sass +3 -3
  522. package/lib/components/VTimeline/VTimelineDivider.mjs +42 -38
  523. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  524. package/lib/components/VTimeline/VTimelineItem.mjs +12 -12
  525. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  526. package/lib/components/VTimeline/_variables.scss +11 -6
  527. package/lib/components/VTimeline/index.mjs.map +1 -1
  528. package/lib/components/VToolbar/VToolbar.css +15 -6
  529. package/lib/components/VToolbar/VToolbar.mjs +25 -18
  530. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  531. package/lib/components/VToolbar/VToolbar.sass +15 -7
  532. package/lib/components/VToolbar/VToolbarItems.mjs +12 -8
  533. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  534. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  535. package/lib/components/VToolbar/_variables.scss +6 -2
  536. package/lib/components/VToolbar/index.mjs.map +1 -1
  537. package/lib/components/VTooltip/VTooltip.mjs +44 -40
  538. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  539. package/lib/components/VTooltip/VTooltip.sass +0 -1
  540. package/lib/components/VTooltip/_variables.scss +1 -0
  541. package/lib/components/VTooltip/index.mjs.map +1 -1
  542. package/lib/components/VTreeview/VTreeview.mjs.map +1 -1
  543. package/lib/components/VTreeview/VTreeviewNode.mjs.map +1 -1
  544. package/lib/components/VTreeview/index.mjs.map +1 -1
  545. package/lib/components/VTreeview/util/filterTreeItems.mjs.map +1 -1
  546. package/lib/components/VValidation/VValidation.mjs.map +1 -1
  547. package/lib/components/VValidation/index.mjs.map +1 -1
  548. package/lib/components/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  549. package/lib/components/VVirtualScroll/index.mjs.map +1 -1
  550. package/lib/components/VWindow/VWindow.mjs +6 -6
  551. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  552. package/lib/components/VWindow/VWindow.sass +0 -2
  553. package/lib/components/VWindow/VWindowItem.mjs +18 -11
  554. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  555. package/lib/components/VWindow/_variables.scss +1 -0
  556. package/lib/components/VWindow/index.mjs.map +1 -1
  557. package/lib/components/index.d.ts +6631 -3928
  558. package/lib/components/index.mjs.map +1 -1
  559. package/lib/components/transitions/createTransition.mjs.map +1 -1
  560. package/lib/components/transitions/dialog-transition.mjs +64 -8
  561. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  562. package/lib/components/transitions/expand-transition.mjs.map +1 -1
  563. package/lib/components/transitions/index.mjs.map +1 -1
  564. package/lib/composables/border.mjs +5 -6
  565. package/lib/composables/border.mjs.map +1 -1
  566. package/lib/composables/color.mjs.map +1 -1
  567. package/lib/composables/defaults.mjs.map +1 -1
  568. package/lib/composables/delay.mjs.map +1 -1
  569. package/lib/composables/density.mjs.map +1 -1
  570. package/lib/composables/dimensions.mjs.map +1 -1
  571. package/lib/composables/display.mjs +13 -11
  572. package/lib/composables/display.mjs.map +1 -1
  573. package/lib/composables/elevation.mjs.map +1 -1
  574. package/lib/composables/filter.mjs +33 -13
  575. package/lib/composables/filter.mjs.map +1 -1
  576. package/lib/composables/focus.mjs.map +1 -1
  577. package/lib/composables/form.mjs +6 -6
  578. package/lib/composables/form.mjs.map +1 -1
  579. package/lib/composables/forwardRef.mjs.map +1 -1
  580. package/lib/composables/group.mjs.map +1 -1
  581. package/lib/composables/hydration.mjs.map +1 -1
  582. package/lib/composables/icons.mjs +15 -3
  583. package/lib/composables/icons.mjs.map +1 -1
  584. package/lib/composables/index.mjs.map +1 -1
  585. package/lib/composables/intersectionObserver.mjs.map +1 -1
  586. package/lib/composables/items.mjs +39 -11
  587. package/lib/composables/items.mjs.map +1 -1
  588. package/lib/composables/layout.mjs +3 -3
  589. package/lib/composables/layout.mjs.map +1 -1
  590. package/lib/composables/lazy.mjs.map +1 -1
  591. package/lib/composables/loader.mjs.map +1 -1
  592. package/lib/composables/locale.mjs +11 -8
  593. package/lib/composables/locale.mjs.map +1 -1
  594. package/lib/composables/location.mjs +66 -0
  595. package/lib/composables/location.mjs.map +1 -0
  596. package/lib/composables/mutationObserver.mjs.map +1 -1
  597. package/lib/composables/nested/nested.mjs.map +1 -1
  598. package/lib/composables/nested/openStrategies.mjs.map +1 -1
  599. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  600. package/lib/composables/position.mjs +4 -25
  601. package/lib/composables/position.mjs.map +1 -1
  602. package/lib/composables/proxiedModel.mjs.map +1 -1
  603. package/lib/composables/refs.mjs.map +1 -1
  604. package/lib/composables/resizeObserver.mjs.map +1 -1
  605. package/lib/composables/rounded.mjs.map +1 -1
  606. package/lib/composables/router.mjs +25 -23
  607. package/lib/composables/router.mjs.map +1 -1
  608. package/lib/composables/rtl.mjs.map +1 -1
  609. package/lib/composables/scopeId.mjs +11 -0
  610. package/lib/composables/scopeId.mjs.map +1 -0
  611. package/lib/composables/scroll.mjs.map +1 -1
  612. package/lib/composables/selectLink.mjs.map +1 -1
  613. package/lib/composables/size.mjs +2 -2
  614. package/lib/composables/size.mjs.map +1 -1
  615. package/lib/composables/ssrBoot.mjs +3 -2
  616. package/lib/composables/ssrBoot.mjs.map +1 -1
  617. package/lib/composables/stack.mjs +23 -22
  618. package/lib/composables/stack.mjs.map +1 -1
  619. package/lib/composables/tag.mjs.map +1 -1
  620. package/lib/composables/teleport.mjs.map +1 -1
  621. package/lib/composables/theme.mjs +94 -93
  622. package/lib/composables/theme.mjs.map +1 -1
  623. package/lib/composables/toggleScope.mjs +18 -0
  624. package/lib/composables/toggleScope.mjs.map +1 -0
  625. package/lib/composables/touch.mjs.map +1 -1
  626. package/lib/composables/transition.mjs.map +1 -1
  627. package/lib/composables/validation.mjs +15 -7
  628. package/lib/composables/validation.mjs.map +1 -1
  629. package/lib/composables/variant.mjs +5 -3
  630. package/lib/composables/variant.mjs.map +1 -1
  631. package/lib/directives/click-outside/index.mjs.map +1 -1
  632. package/lib/directives/color/index.mjs.map +1 -1
  633. package/lib/directives/index.mjs.map +1 -1
  634. package/lib/directives/intersect/index.mjs.map +1 -1
  635. package/lib/directives/mutate/index.mjs.map +1 -1
  636. package/lib/directives/resize/index.mjs.map +1 -1
  637. package/lib/directives/ripple/VRipple.sass +0 -1
  638. package/lib/directives/ripple/index.mjs.map +1 -1
  639. package/lib/directives/scroll/index.mjs.map +1 -1
  640. package/lib/directives/touch/index.mjs.map +1 -1
  641. package/lib/entry-bundler.mjs +1 -1
  642. package/lib/entry-bundler.mjs.map +1 -1
  643. package/lib/framework.mjs +36 -26
  644. package/lib/framework.mjs.map +1 -1
  645. package/lib/iconsets/fa-svg.d.ts +2 -1
  646. package/lib/iconsets/fa-svg.mjs.map +1 -1
  647. package/lib/iconsets/fa.d.ts +2 -1
  648. package/lib/iconsets/fa.mjs.map +1 -1
  649. package/lib/iconsets/fa4.d.ts +2 -1
  650. package/lib/iconsets/fa4.mjs.map +1 -1
  651. package/lib/iconsets/md.d.ts +2 -1
  652. package/lib/iconsets/md.mjs.map +1 -1
  653. package/lib/iconsets/mdi-svg.d.ts +2 -1
  654. package/lib/iconsets/mdi-svg.mjs.map +1 -1
  655. package/lib/iconsets/mdi.d.ts +2 -1
  656. package/lib/iconsets/mdi.mjs.map +1 -1
  657. package/lib/index.d.ts +151 -145
  658. package/lib/locale/adapters/vue-i18n.mjs.map +1 -1
  659. package/lib/locale/adapters/vue-intl.mjs.map +1 -1
  660. package/lib/locale/af.mjs.map +1 -1
  661. package/lib/locale/ar.mjs.map +1 -1
  662. package/lib/locale/az.mjs.map +1 -1
  663. package/lib/locale/bg.mjs.map +1 -1
  664. package/lib/locale/ca.mjs.map +1 -1
  665. package/lib/locale/ckb.mjs.map +1 -1
  666. package/lib/locale/cs.mjs.map +1 -1
  667. package/lib/locale/da.mjs.map +1 -1
  668. package/lib/locale/de.mjs.map +1 -1
  669. package/lib/locale/el.mjs.map +1 -1
  670. package/lib/locale/en.mjs.map +1 -1
  671. package/lib/locale/es.mjs.map +1 -1
  672. package/lib/locale/et.mjs.map +1 -1
  673. package/lib/locale/fa.mjs.map +1 -1
  674. package/lib/locale/fi.mjs.map +1 -1
  675. package/lib/locale/fr.mjs.map +1 -1
  676. package/lib/locale/he.mjs.map +1 -1
  677. package/lib/locale/hr.mjs.map +1 -1
  678. package/lib/locale/hu.mjs.map +1 -1
  679. package/lib/locale/id.mjs.map +1 -1
  680. package/lib/locale/index.mjs.map +1 -1
  681. package/lib/locale/it.mjs.map +1 -1
  682. package/lib/locale/ja.mjs.map +1 -1
  683. package/lib/locale/ko.mjs.map +1 -1
  684. package/lib/locale/lt.mjs.map +1 -1
  685. package/lib/locale/lv.mjs.map +1 -1
  686. package/lib/locale/nl.mjs.map +1 -1
  687. package/lib/locale/no.mjs.map +1 -1
  688. package/lib/locale/pl.mjs.map +1 -1
  689. package/lib/locale/pt.mjs.map +1 -1
  690. package/lib/locale/ro.mjs.map +1 -1
  691. package/lib/locale/ru.mjs.map +1 -1
  692. package/lib/locale/sk.mjs.map +1 -1
  693. package/lib/locale/sl.mjs.map +1 -1
  694. package/lib/locale/sr-Cyrl.mjs.map +1 -1
  695. package/lib/locale/sr-Latn.mjs.map +1 -1
  696. package/lib/locale/sv.mjs.map +1 -1
  697. package/lib/locale/th.mjs.map +1 -1
  698. package/lib/locale/tr.mjs.map +1 -1
  699. package/lib/locale/uk.mjs.map +1 -1
  700. package/lib/locale/vi.mjs.map +1 -1
  701. package/lib/locale/zh-Hans.mjs.map +1 -1
  702. package/lib/locale/zh-Hant.mjs.map +1 -1
  703. package/lib/services/goto/easing-patterns.mjs.map +1 -1
  704. package/lib/services/goto/index.mjs.map +1 -1
  705. package/lib/services/goto/util.mjs.map +1 -1
  706. package/lib/styles/tools/_states.sass +9 -2
  707. package/lib/styles/tools/_utilities.sass +1 -1
  708. package/lib/styles/tools/_variant.sass +6 -6
  709. package/lib/util/anchor.mjs +58 -0
  710. package/lib/util/anchor.mjs.map +1 -0
  711. package/lib/util/animation.mjs +2 -2
  712. package/lib/util/animation.mjs.map +1 -1
  713. package/lib/util/box.mjs +12 -0
  714. package/lib/util/box.mjs.map +1 -1
  715. package/lib/util/color/APCA.mjs.map +1 -1
  716. package/lib/util/color/transformCIELAB.mjs.map +1 -1
  717. package/lib/util/color/transformSRGB.mjs.map +1 -1
  718. package/lib/util/colorUtils.mjs.map +1 -1
  719. package/lib/util/colors.mjs.map +1 -1
  720. package/lib/util/console.mjs.map +1 -1
  721. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  722. package/lib/util/dateTimeUtils.mjs.map +1 -1
  723. package/lib/util/defineComponent.mjs.map +1 -1
  724. package/lib/util/dom.mjs.map +1 -1
  725. package/lib/util/easing.mjs.map +1 -1
  726. package/lib/util/getCurrentInstance.mjs +19 -0
  727. package/lib/util/getCurrentInstance.mjs.map +1 -1
  728. package/lib/util/getScrollParent.mjs.map +1 -1
  729. package/lib/util/globals.mjs +0 -3
  730. package/lib/util/globals.mjs.map +1 -1
  731. package/lib/util/helpers.mjs +10 -6
  732. package/lib/util/helpers.mjs.map +1 -1
  733. package/lib/util/index.mjs +1 -0
  734. package/lib/util/index.mjs.map +1 -1
  735. package/lib/util/isFixedPosition.mjs.map +1 -1
  736. package/lib/util/propsFactory.mjs.map +1 -1
  737. package/lib/util/useRender.mjs.map +1 -1
  738. package/package.json +32 -26
  739. package/lib/components/VBanner/VBannerAvatar.mjs +0 -20
  740. package/lib/components/VBanner/VBannerAvatar.mjs.map +0 -1
  741. package/lib/components/VBanner/VBannerIcon.mjs +0 -20
  742. package/lib/components/VBanner/VBannerIcon.mjs.map +0 -1
  743. package/lib/components/VBreadcrumbs/shared.mjs +0 -2
  744. package/lib/components/VBreadcrumbs/shared.mjs.map +0 -1
  745. package/lib/components/VCard/VCardAvatar.mjs +0 -3
  746. package/lib/components/VCard/VCardAvatar.mjs.map +0 -1
  747. package/lib/components/VCard/VCardContent.mjs +0 -3
  748. package/lib/components/VCard/VCardContent.mjs.map +0 -1
  749. package/lib/components/VCard/VCardHeader.mjs +0 -3
  750. package/lib/components/VCard/VCardHeader.mjs.map +0 -1
  751. package/lib/components/VCard/VCardHeaderText.mjs +0 -3
  752. package/lib/components/VCard/VCardHeaderText.mjs.map +0 -1
  753. package/lib/components/VCard/VCardImg.mjs +0 -3
  754. package/lib/components/VCard/VCardImg.mjs.map +0 -1
  755. package/lib/components/VOverlay/positionStrategies.mjs +0 -207
  756. package/lib/components/VOverlay/positionStrategies.mjs.map +0 -1
  757. package/lib/components/VOverlay/util/anchor.mjs +0 -52
  758. package/lib/components/VOverlay/util/anchor.mjs.map +0 -1
  759. package/lib/components/VTimeline/shared.mjs +0 -2
  760. package/lib/components/VTimeline/shared.mjs.map +0 -1
  761. package/lib/composables/overlay.mjs +0 -34
  762. package/lib/composables/overlay.mjs.map +0 -1
  763. package/lib/presets/default/index.mjs +0 -71
  764. package/lib/presets/default/index.mjs.map +0 -1
@@ -1,5 +1,5 @@
1
1
  // Utilities
2
- import { computed, inject, provide, ref, watch, watchEffect } from 'vue';
2
+ import { computed, inject, provide, reactive, ref, watch, watchEffect } from 'vue';
3
3
  import { colorToInt, colorToRGB, createRange, darken, getCurrentInstance, getLuma, IN_BROWSER, intToHex, lighten, mergeDeep, propsFactory } from "../util/index.mjs";
4
4
  import { APCAcontrast } from "../util/color/APCA.mjs"; // Types
5
5
 
@@ -86,49 +86,54 @@ const defaultThemeOptions = {
86
86
  }
87
87
  };
88
88
 
89
- const parseThemeOptions = function () {
90
- var _options$themes;
91
-
89
+ function parseThemeOptions() {
92
90
  let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultThemeOptions;
93
91
  if (!options) return { ...defaultThemeOptions,
94
92
  isDisabled: true
95
93
  };
96
- const themes = Object.entries((_options$themes = options.themes) != null ? _options$themes : {}).reduce((obj, _ref) => {
97
- var _defaultThemeOptions$, _defaultThemeOptions$2;
94
+ const themes = {};
95
+
96
+ for (const [key, theme] of Object.entries((_options$themes = options.themes) != null ? _options$themes : {})) {
97
+ var _options$themes, _defaultThemeOptions$, _defaultThemeOptions$2;
98
98
 
99
- let [key, theme] = _ref;
100
99
  const defaultTheme = theme.dark ? (_defaultThemeOptions$ = defaultThemeOptions.themes) == null ? void 0 : _defaultThemeOptions$.dark : (_defaultThemeOptions$2 = defaultThemeOptions.themes) == null ? void 0 : _defaultThemeOptions$2.light;
101
- obj[key] = mergeDeep(defaultTheme, theme);
102
- return obj;
103
- }, {});
100
+ themes[key] = mergeDeep(defaultTheme, theme);
101
+ }
102
+
104
103
  return mergeDeep(defaultThemeOptions, { ...options,
105
104
  themes
106
105
  });
107
- }; // Composables
106
+ } // Composables
108
107
 
109
108
 
110
109
  export function createTheme(app, options) {
111
110
  const head = app._context.provides.usehead;
112
- const parsedOptions = parseThemeOptions(options);
113
- const styleEl = ref();
114
- const current = ref(parsedOptions.defaultTheme);
111
+ const parsedOptions = reactive(parseThemeOptions(options));
112
+ const name = ref(parsedOptions.defaultTheme);
115
113
  const themes = ref(parsedOptions.themes);
116
- const variations = ref(parsedOptions.variations);
117
114
  const computedThemes = computed(() => {
118
- return Object.entries(themes.value).reduce((obj, _ref2) => {
119
- var _parsedOptions$variat;
115
+ const acc = {};
120
116
 
121
- let [name, original] = _ref2;
122
- const theme = { ...original,
123
- colors: { ...original.colors,
124
- ...((_parsedOptions$variat = parsedOptions.variations.colors) != null ? _parsedOptions$variat : []).reduce((obj, color) => {
125
- return { ...obj,
126
- ...genColorVariations(color, original.colors[color])
127
- };
128
- }, {})
117
+ for (const [name, original] of Object.entries(themes.value)) {
118
+ const theme = acc[name] = { ...original,
119
+ colors: { ...original.colors
129
120
  }
130
121
  };
131
122
 
123
+ if (parsedOptions.variations) {
124
+ for (const name of parsedOptions.variations.colors) {
125
+ const color = theme.colors[name];
126
+
127
+ for (const variation of ['lighten', 'darken']) {
128
+ const fn = variation === 'lighten' ? lighten : darken;
129
+
130
+ for (const amount of createRange(parsedOptions.variations[variation], 1)) {
131
+ theme.colors[`${name}-${variation}-${amount}`] = intToHex(fn(colorToInt(color), amount));
132
+ }
133
+ }
134
+ }
135
+ }
136
+
132
137
  for (const color of Object.keys(theme.colors)) {
133
138
  if (/on-[a-z]/.test(color) || theme.colors[`on-${color}`]) continue;
134
139
  const onColor = `on-${color}`;
@@ -146,75 +151,46 @@ export function createTheme(app, options) {
146
151
 
147
152
  theme.colors[onColor] = whiteContrast > Math.min(blackContrast, 50) ? '#fff' : '#000';
148
153
  }
149
-
150
- obj[name] = theme;
151
- return obj;
152
- }, {});
153
- });
154
-
155
- function genColorVariations(name, color) {
156
- const obj = {};
157
-
158
- for (const variation of ['lighten', 'darken']) {
159
- const fn = variation === 'lighten' ? lighten : darken;
160
-
161
- for (const amount of createRange(variations.value[variation], 1)) {
162
- obj[`${name}-${variation}-${amount}`] = intToHex(fn(colorToInt(color), amount));
163
- }
164
154
  }
165
155
 
166
- return obj;
167
- }
168
-
156
+ return acc;
157
+ });
158
+ const current = computed(() => computedThemes.value[name.value]);
169
159
  const styles = computed(() => {
170
160
  const lines = [];
171
161
 
172
- for (const themeName of Object.keys(computedThemes.value)) {
173
- const variables = computedThemes.value[themeName].variables;
174
- lines.push(...createCssClass(`.v-theme--${themeName}`, [...genCssVariables(themeName), ...Object.keys(variables).map(key => {
162
+ if (current.value.dark) {
163
+ createCssClass(lines, ':root', ['color-scheme: dark']);
164
+ }
165
+
166
+ for (const [themeName, theme] of Object.entries(computedThemes.value)) {
167
+ const {
168
+ variables,
169
+ dark
170
+ } = theme;
171
+ createCssClass(lines, `.v-theme--${themeName}`, [`color-scheme: ${dark ? 'dark' : 'normal'}`, ...genCssVariables(theme), ...Object.keys(variables).map(key => {
175
172
  const value = variables[key];
176
173
  const color = typeof value === 'string' && value.startsWith('#') ? colorToRGB(value) : undefined;
177
174
  const rgb = color ? `${color.r}, ${color.g}, ${color.b}` : undefined;
178
175
  return `--v-${key}: ${rgb != null ? rgb : value}`;
179
- })]));
176
+ })]);
180
177
  }
181
178
 
182
179
  const colors = new Set(Object.values(computedThemes.value).flatMap(theme => Object.keys(theme.colors)));
183
180
 
184
181
  for (const key of colors) {
185
182
  if (/on-[a-z]/.test(key)) {
186
- lines.push(...createCssClass(`.${key}`, [`color: rgb(var(--v-theme-${key})) !important`]));
183
+ createCssClass(lines, `.${key}`, [`color: rgb(var(--v-theme-${key})) !important`]);
187
184
  } else {
188
- lines.push(...createCssClass(`.bg-${key}`, [`--v-theme-overlay-multiplier: var(--v-theme-${key}-overlay-multiplier)`, `background: rgb(var(--v-theme-${key})) !important`, `color: rgb(var(--v-theme-on-${key})) !important`]), ...createCssClass(`.text-${key}`, [`color: rgb(var(--v-theme-${key})) !important`]), ...createCssClass(`.border-${key}`, [`--v-border-color: var(--v-theme-${key})`]));
185
+ createCssClass(lines, `.bg-${key}`, [`--v-theme-overlay-multiplier: var(--v-theme-${key}-overlay-multiplier)`, `background: rgb(var(--v-theme-${key})) !important`, `color: rgb(var(--v-theme-on-${key})) !important`]);
186
+ createCssClass(lines, `.text-${key}`, [`color: rgb(var(--v-theme-${key})) !important`]);
187
+ createCssClass(lines, `.border-${key}`, [`--v-border-color: var(--v-theme-${key})`]);
189
188
  }
190
189
  }
191
190
 
192
191
  return lines.map((str, i) => i === 0 ? str : ` ${str}`).join('');
193
192
  });
194
193
 
195
- function genCssVariables(name) {
196
- const theme = computedThemes.value[name];
197
- if (!theme) throw new Error(`Could not find theme ${name}`);
198
- const lightOverlay = theme.dark ? 2 : 1;
199
- const darkOverlay = theme.dark ? 1 : 2;
200
- const variables = [];
201
-
202
- for (const [key, value] of Object.entries(theme.colors)) {
203
- const rgb = colorToRGB(value);
204
- variables.push(`--v-theme-${key}: ${rgb.r},${rgb.g},${rgb.b}`);
205
-
206
- if (!key.startsWith('on-')) {
207
- variables.push(`--v-theme-${key}-overlay-multiplier: ${getLuma(value) > 0.18 ? lightOverlay : darkOverlay}`);
208
- }
209
- }
210
-
211
- return variables;
212
- }
213
-
214
- function createCssClass(selector, content) {
215
- return [`${selector} {\n`, ...content.map(line => ` ${line};\n`), '}\n'];
216
- }
217
-
218
194
  if (head) {
219
195
  head.addHeadObjs(computed(() => ({
220
196
  style: [{
@@ -228,49 +204,53 @@ export function createTheme(app, options) {
228
204
  watchEffect(() => head.updateDOM());
229
205
  }
230
206
  } else {
231
- watch(themes, updateStyles, {
232
- deep: true,
207
+ let styleEl = IN_BROWSER ? document.getElementById('vuetify-theme-stylesheet') : null;
208
+ watch(styles, updateStyles, {
233
209
  immediate: true
234
210
  });
235
211
 
236
212
  function updateStyles() {
237
213
  if (parsedOptions.isDisabled) return;
238
- genStyleElement();
239
- if (styleEl.value) styleEl.value.innerHTML = styles.value;
240
- }
241
214
 
242
- function genStyleElement() {
243
- if (typeof document === 'undefined' || styleEl.value) return;
244
- const el = document.createElement('style');
245
- el.type = 'text/css';
246
- el.id = 'vuetify-theme-stylesheet';
247
- styleEl.value = el;
248
- document.head.appendChild(styleEl.value);
215
+ if (typeof document !== 'undefined' && !styleEl) {
216
+ const el = document.createElement('style');
217
+ el.type = 'text/css';
218
+ el.id = 'vuetify-theme-stylesheet';
219
+ styleEl = el;
220
+ document.head.appendChild(styleEl);
221
+ }
222
+
223
+ if (styleEl) styleEl.innerHTML = styles.value;
249
224
  }
250
225
  }
251
226
 
227
+ const themeClasses = computed(() => parsedOptions.isDisabled ? undefined : `v-theme--${name.value}`);
252
228
  return {
253
229
  isDisabled: parsedOptions.isDisabled,
254
- themes: computedThemes,
255
- setTheme: (key, theme) => themes.value[key] = theme,
256
- getTheme: key => computedThemes.value[key],
230
+ name,
231
+ themes,
257
232
  current,
258
- themeClasses: computed(() => parsedOptions.isDisabled ? undefined : `v-theme--${current.value}`),
259
- styles
233
+ computedThemes,
234
+ themeClasses,
235
+ styles,
236
+ global: {
237
+ name,
238
+ current
239
+ }
260
240
  };
261
241
  }
262
242
  export function provideTheme(props) {
263
243
  getCurrentInstance('provideTheme');
264
244
  const theme = inject(ThemeSymbol, null);
265
245
  if (!theme) throw new Error('Could not find Vuetify theme injection');
266
- const current = computed(() => {
246
+ const name = computed(() => {
267
247
  var _props$theme;
268
248
 
269
- return (_props$theme = props.theme) != null ? _props$theme : theme == null ? void 0 : theme.current.value;
249
+ return (_props$theme = props.theme) != null ? _props$theme : theme == null ? void 0 : theme.name.value;
270
250
  });
271
- const themeClasses = computed(() => theme.isDisabled ? undefined : `v-theme--${current.value}`);
251
+ const themeClasses = computed(() => theme.isDisabled ? undefined : `v-theme--${name.value}`);
272
252
  const newTheme = { ...theme,
273
- current,
253
+ name,
274
254
  themeClasses
275
255
  };
276
256
  provide(ThemeSymbol, newTheme);
@@ -282,4 +262,25 @@ export function useTheme() {
282
262
  if (!theme) throw new Error('Could not find Vuetify theme injection');
283
263
  return theme;
284
264
  }
265
+
266
+ function createCssClass(lines, selector, content) {
267
+ lines.push(`${selector} {\n`, ...content.map(line => ` ${line};\n`), '}\n');
268
+ }
269
+
270
+ function genCssVariables(theme) {
271
+ const lightOverlay = theme.dark ? 2 : 1;
272
+ const darkOverlay = theme.dark ? 1 : 2;
273
+ const variables = [];
274
+
275
+ for (const [key, value] of Object.entries(theme.colors)) {
276
+ const rgb = colorToRGB(value);
277
+ variables.push(`--v-theme-${key}: ${rgb.r},${rgb.g},${rgb.b}`);
278
+
279
+ if (!key.startsWith('on-')) {
280
+ variables.push(`--v-theme-${key}-overlay-multiplier: ${getLuma(value) > 0.18 ? lightOverlay : darkOverlay}`);
281
+ }
282
+ }
283
+
284
+ return variables;
285
+ }
285
286
  //# sourceMappingURL=theme.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/composables/theme.ts"],"names":["computed","inject","provide","ref","watch","watchEffect","colorToInt","colorToRGB","createRange","darken","getCurrentInstance","getLuma","IN_BROWSER","intToHex","lighten","mergeDeep","propsFactory","APCAcontrast","ThemeSymbol","Symbol","for","makeThemeProps","theme","String","defaultThemeOptions","defaultTheme","variations","colors","themes","light","dark","background","surface","primary","secondary","error","info","success","warning","variables","parseThemeOptions","options","isDisabled","Object","entries","reduce","obj","key","createTheme","app","head","_context","provides","usehead","parsedOptions","styleEl","current","computedThemes","value","name","original","color","genColorVariations","keys","test","onColor","colorVal","blackContrast","Math","abs","whiteContrast","min","variation","fn","amount","styles","lines","themeName","push","createCssClass","genCssVariables","map","startsWith","undefined","rgb","r","g","b","Set","values","flatMap","str","i","join","Error","lightOverlay","darkOverlay","selector","content","line","addHeadObjs","style","children","type","id","updateDOM","updateStyles","deep","immediate","genStyleElement","innerHTML","document","el","createElement","appendChild","setTheme","getTheme","themeClasses","provideTheme","props","newTheme","useTheme"],"mappings":"AAAA;AACA,SAASA,QAAT,EAAmBC,MAAnB,EAA2BC,OAA3B,EAAoCC,GAApC,EAAyCC,KAAzC,EAAgDC,WAAhD,QAAmE,KAAnE;SAEEC,U,EACAC,U,EACAC,W,EACAC,M,EACAC,kB,EACAC,O,EACAC,U,EACAC,Q,EACAC,O,EACAC,S,EACAC,Y;SAEOC,Y,kCAET;;AAqEA,OAAO,MAAMC,WAAwC,GAAGC,MAAM,CAACC,GAAP,CAAW,eAAX,CAAjD;AAEP,OAAO,MAAMC,cAAc,GAAGL,YAAY,CAAC;AACzCM,EAAAA,KAAK,EAAEC;AADkC,CAAD,EAEvC,OAFuC,CAAnC;AAIP,MAAMC,mBAAiC,GAAG;AACxCC,EAAAA,YAAY,EAAE,OAD0B;AAExCC,EAAAA,UAAU,EAAE;AAAEC,IAAAA,MAAM,EAAE,EAAV;AAAcb,IAAAA,OAAO,EAAE,CAAvB;AAA0BL,IAAAA,MAAM,EAAE;AAAlC,GAF4B;AAGxCmB,EAAAA,MAAM,EAAE;AACNC,IAAAA,KAAK,EAAE;AACLC,MAAAA,IAAI,EAAE,KADD;AAELH,MAAAA,MAAM,EAAE;AACNI,QAAAA,UAAU,EAAE,SADN;AAENC,QAAAA,OAAO,EAAE,SAFH;AAGN,2BAAmB,SAHb;AAIN,8BAAsB,SAJhB;AAKNC,QAAAA,OAAO,EAAE,SALH;AAMN,4BAAoB,SANd;AAONC,QAAAA,SAAS,EAAE,SAPL;AAQN,8BAAsB,SARhB;AASNC,QAAAA,KAAK,EAAE,SATD;AAUNC,QAAAA,IAAI,EAAE,SAVA;AAWNC,QAAAA,OAAO,EAAE,SAXH;AAYNC,QAAAA,OAAO,EAAE;AAZH,OAFH;AAgBLC,MAAAA,SAAS,EAAE;AACT,wBAAgB,SADP;AAET,0BAAkB,IAFT;AAGT,iCAAyB,IAHhB;AAIT,mCAA2B,IAJlB;AAKT,4BAAoB,IALX;AAMT,wBAAgB,IANP;AAOT,yBAAiB,IAPR;AAQT,yBAAiB,IARR;AAST,4BAAoB,IATX;AAUT,6BAAqB,IAVZ;AAWT,2BAAmB,IAXV;AAYT,2BAAmB,IAZV;AAaT,gCAAwB,SAbf;AAcT,qBAAa,SAdJ;AAeT,iCAAyB;AAfhB;AAhBN,KADD;AAmCNT,IAAAA,IAAI,EAAE;AACJA,MAAAA,IAAI,EAAE,IADF;AAEJH,MAAAA,MAAM,EAAE;AACNI,QAAAA,UAAU,EAAE,SADN;AAENC,QAAAA,OAAO,EAAE,SAFH;AAGN,2BAAmB,SAHb;AAIN,8BAAsB,SAJhB;AAKNC,QAAAA,OAAO,EAAE,SALH;AAMN,4BAAoB,SANd;AAONC,QAAAA,SAAS,EAAE,SAPL;AAQN,8BAAsB,SARhB;AASNC,QAAAA,KAAK,EAAE,SATD;AAUNC,QAAAA,IAAI,EAAE,SAVA;AAWNC,QAAAA,OAAO,EAAE,SAXH;AAYNC,QAAAA,OAAO,EAAE;AAZH,OAFJ;AAgBJC,MAAAA,SAAS,EAAE;AACT,wBAAgB,SADP;AAET,0BAAkB,IAFT;AAGT,iCAAyB,IAHhB;AAIT,mCAA2B,IAJlB;AAKT,4BAAoB,IALX;AAMT,wBAAgB,IANP;AAOT,yBAAiB,IAPR;AAQT,yBAAiB,IARR;AAST,4BAAoB,IATX;AAUT,6BAAqB,IAVZ;AAWT,2BAAmB,IAXV;AAYT,2BAAmB,IAZV;AAaT,gCAAwB,SAbf;AAcT,qBAAa,SAdJ;AAeT,iCAAyB;AAfhB;AAhBP;AAnCA;AAHgC,CAA1C;;AA2EA,MAAMC,iBAAiB,GAAG,YAAuE;AAAA;;AAAA,MAAtEC,OAAsE,uEAA9CjB,mBAA8C;AAC/F,MAAI,CAACiB,OAAL,EAAc,OAAO,EAAE,GAAGjB,mBAAL;AAA0BkB,IAAAA,UAAU,EAAE;AAAtC,GAAP;AAEd,QAAMd,MAAM,GAAGe,MAAM,CAACC,OAAP,oBAAeH,OAAO,CAACb,MAAvB,8BAAiC,EAAjC,EAAqCiB,MAArC,CAA4C,CAACC,GAAD,WAAuB;AAAA;;AAAA,QAAjB,CAACC,GAAD,EAAMzB,KAAN,CAAiB;AAChF,UAAMG,YAAY,GAAGH,KAAK,CAACQ,IAAN,4BAAaN,mBAAmB,CAACI,MAAjC,qBAAa,sBAA4BE,IAAzC,6BAAgDN,mBAAmB,CAACI,MAApE,qBAAgD,uBAA4BC,KAAjG;AACAiB,IAAAA,GAAG,CAACC,GAAD,CAAH,GAAWhC,SAAS,CAACU,YAAD,EAAeH,KAAf,CAApB;AACA,WAAOwB,GAAP;AACD,GAJc,EAIZ,EAJY,CAAf;AAMA,SAAO/B,SAAS,CACdS,mBADc,EAEd,EAAE,GAAGiB,OAAL;AAAcb,IAAAA;AAAd,GAFc,CAAhB;AAID,CAbD,C,CAeA;;;AACA,OAAO,SAASoB,WAAT,CAAsBC,GAAtB,EAAgCR,OAAhC,EAAuE;AAC5E,QAAMS,IAAI,GAAGD,GAAG,CAACE,QAAJ,CAAaC,QAAb,CAAsBC,OAAnC;AACA,QAAMC,aAAa,GAAGd,iBAAiB,CAACC,OAAD,CAAvC;AACA,QAAMc,OAAO,GAAGpD,GAAG,EAAnB;AACA,QAAMqD,OAAO,GAAGrD,GAAG,CAACmD,aAAa,CAAC7B,YAAf,CAAnB;AACA,QAAMG,MAAM,GAAGzB,GAAG,CAACmD,aAAa,CAAC1B,MAAf,CAAlB;AACA,QAAMF,UAAU,GAAGvB,GAAG,CAACmD,aAAa,CAAC5B,UAAf,CAAtB;AAEA,QAAM+B,cAAc,GAAGzD,QAAQ,CAAC,MAAM;AACpC,WAAO2C,MAAM,CAACC,OAAP,CAAehB,MAAM,CAAC8B,KAAtB,EAA6Bb,MAA7B,CAAoC,CAACC,GAAD,YAA2B;AAAA;;AAAA,UAArB,CAACa,IAAD,EAAOC,QAAP,CAAqB;AACpE,YAAMtC,KAA8B,GAAG,EACrC,GAAGsC,QADkC;AAErCjC,QAAAA,MAAM,EAAE,EACN,GAAGiC,QAAQ,CAACjC,MADN;AAEN,aAAG,0BAAC2B,aAAa,CAAC5B,UAAd,CAAyBC,MAA1B,oCAAoC,EAApC,EAAwCkB,MAAxC,CAA+C,CAACC,GAAD,EAAMe,KAAN,KAAgB;AAChE,mBAAO,EAAE,GAAGf,GAAL;AAAU,iBAAGgB,kBAAkB,CAACD,KAAD,EAAQD,QAAQ,CAACjC,MAAT,CAAgBkC,KAAhB,CAAR;AAA/B,aAAP;AACD,WAFE,EAEA,EAFA;AAFG;AAF6B,OAAvC;;AAUA,WAAK,MAAMA,KAAX,IAAoBlB,MAAM,CAACoB,IAAP,CAAYzC,KAAK,CAACK,MAAlB,CAApB,EAA+C;AAC7C,YAAI,WAAWqC,IAAX,CAAgBH,KAAhB,KAA0BvC,KAAK,CAACK,MAAN,CAAc,MAAKkC,KAAM,EAAzB,CAA9B,EAA2D;AAE3D,cAAMI,OAAO,GAAI,MAAKJ,KAAM,EAA5B;AACA,cAAMK,QAAQ,GAAG5D,UAAU,CAACgB,KAAK,CAACK,MAAN,CAAakC,KAAb,CAAD,CAA3B;AAEA,cAAMM,aAAa,GAAGC,IAAI,CAACC,GAAL,CAASpD,YAAY,CAAC,CAAD,EAAIiD,QAAJ,CAArB,CAAtB;AACA,cAAMI,aAAa,GAAGF,IAAI,CAACC,GAAL,CAASpD,YAAY,CAAC,QAAD,EAAWiD,QAAX,CAArB,CAAtB,CAP6C,CAS7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA5C,QAAAA,KAAK,CAACK,MAAN,CAAasC,OAAb,IAAwBK,aAAa,GAAGF,IAAI,CAACG,GAAL,CAASJ,aAAT,EAAwB,EAAxB,CAAhB,GAA8C,MAA9C,GAAuD,MAA/E;AACD;;AAEDrB,MAAAA,GAAG,CAACa,IAAD,CAAH,GAAYrC,KAAZ;AAEA,aAAOwB,GAAP;AACD,KApCM,EAoCJ,EApCI,CAAP;AAqCD,GAtC8B,CAA/B;;AAwCA,WAASgB,kBAAT,CAA6BH,IAA7B,EAA2CE,KAA3C,EAA0D;AACxD,UAAMf,GAA2B,GAAG,EAApC;;AACA,SAAK,MAAM0B,SAAX,IAAyB,CAAC,SAAD,EAAY,QAAZ,CAAzB,EAA0D;AACxD,YAAMC,EAAE,GAAGD,SAAS,KAAK,SAAd,GAA0B1D,OAA1B,GAAoCL,MAA/C;;AACA,WAAK,MAAMiE,MAAX,IAAqBlE,WAAW,CAACkB,UAAU,CAACgC,KAAX,CAAiBc,SAAjB,CAAD,EAA8B,CAA9B,CAAhC,EAAkE;AAChE1B,QAAAA,GAAG,CAAE,GAAEa,IAAK,IAAGa,SAAU,IAAGE,MAAO,EAAhC,CAAH,GAAwC7D,QAAQ,CAAC4D,EAAE,CAACnE,UAAU,CAACuD,KAAD,CAAX,EAAoBa,MAApB,CAAH,CAAhD;AACD;AACF;;AAED,WAAO5B,GAAP;AACD;;AAED,QAAM6B,MAAM,GAAG3E,QAAQ,CAAC,MAAM;AAC5B,UAAM4E,KAAK,GAAG,EAAd;;AAEA,SAAK,MAAMC,SAAX,IAAwBlC,MAAM,CAACoB,IAAP,CAAYN,cAAc,CAACC,KAA3B,CAAxB,EAA2D;AACzD,YAAMnB,SAAS,GAAGkB,cAAc,CAACC,KAAf,CAAqBmB,SAArB,EAAgCtC,SAAlD;AAEAqC,MAAAA,KAAK,CAACE,IAAN,CAAW,GAAGC,cAAc,CAAE,aAAYF,SAAU,EAAxB,EAA2B,CACrD,GAAGG,eAAe,CAACH,SAAD,CADmC,EAErD,GAAGlC,MAAM,CAACoB,IAAP,CAAYxB,SAAZ,EAAuB0C,GAAvB,CAA2BlC,GAAG,IAAI;AACnC,cAAMW,KAAK,GAAGnB,SAAS,CAACQ,GAAD,CAAvB;AACA,cAAMc,KAAK,GAAG,OAAOH,KAAP,KAAiB,QAAjB,IAA6BA,KAAK,CAACwB,UAAN,CAAiB,GAAjB,CAA7B,GAAqD3E,UAAU,CAACmD,KAAD,CAA/D,GAAyEyB,SAAvF;AACA,cAAMC,GAAG,GAAGvB,KAAK,GAAI,GAAEA,KAAK,CAACwB,CAAE,KAAIxB,KAAK,CAACyB,CAAE,KAAIzB,KAAK,CAAC0B,CAAE,EAAtC,GAA0CJ,SAA3D;AAEA,eAAQ,OAAMpC,GAAI,KAAIqC,GAAf,WAAeA,GAAf,GAAsB1B,KAAM,EAAnC;AACD,OANE,CAFkD,CAA3B,CAA5B;AAUD;;AAED,UAAM/B,MAAM,GAAG,IAAI6D,GAAJ,CAAQ7C,MAAM,CAAC8C,MAAP,CAAchC,cAAc,CAACC,KAA7B,EAAoCgC,OAApC,CAA4CpE,KAAK,IAAIqB,MAAM,CAACoB,IAAP,CAAYzC,KAAK,CAACK,MAAlB,CAArD,CAAR,CAAf;;AACA,SAAK,MAAMoB,GAAX,IAAkBpB,MAAlB,EAA0B;AACxB,UAAI,WAAWqC,IAAX,CAAgBjB,GAAhB,CAAJ,EAA0B;AACxB6B,QAAAA,KAAK,CAACE,IAAN,CAAW,GAAGC,cAAc,CAAE,IAAGhC,GAAI,EAAT,EAAY,CAAE,4BAA2BA,GAAI,eAAjC,CAAZ,CAA5B;AACD,OAFD,MAEO;AACL6B,QAAAA,KAAK,CAACE,IAAN,CACE,GAAGC,cAAc,CAAE,OAAMhC,GAAI,EAAZ,EAAe,CAC7B,+CAA8CA,GAAI,sBADrB,EAE7B,iCAAgCA,GAAI,eAFP,EAG7B,+BAA8BA,GAAI,eAHL,CAAf,CADnB,EAME,GAAGgC,cAAc,CAAE,SAAQhC,GAAI,EAAd,EAAiB,CAAE,4BAA2BA,GAAI,eAAjC,CAAjB,CANnB,EAOE,GAAGgC,cAAc,CAAE,WAAUhC,GAAI,EAAhB,EAAmB,CAAE,mCAAkCA,GAAI,GAAxC,CAAnB,CAPnB;AASD;AACF;;AAED,WAAO6B,KAAK,CAACK,GAAN,CAAU,CAACU,GAAD,EAAMC,CAAN,KAAYA,CAAC,KAAK,CAAN,GAAUD,GAAV,GAAiB,OAAMA,GAAI,EAAjD,EAAoDE,IAApD,CAAyD,EAAzD,CAAP;AACD,GApCsB,CAAvB;;AAsCA,WAASb,eAAT,CAA0BrB,IAA1B,EAAwC;AACtC,UAAMrC,KAAK,GAAGmC,cAAc,CAACC,KAAf,CAAqBC,IAArB,CAAd;AAEA,QAAI,CAACrC,KAAL,EAAY,MAAM,IAAIwE,KAAJ,CAAW,wBAAuBnC,IAAK,EAAvC,CAAN;AAEZ,UAAMoC,YAAY,GAAGzE,KAAK,CAACQ,IAAN,GAAa,CAAb,GAAiB,CAAtC;AACA,UAAMkE,WAAW,GAAG1E,KAAK,CAACQ,IAAN,GAAa,CAAb,GAAiB,CAArC;AAEA,UAAMS,SAAmB,GAAG,EAA5B;;AACA,SAAK,MAAM,CAACQ,GAAD,EAAMW,KAAN,CAAX,IAA2Bf,MAAM,CAACC,OAAP,CAAetB,KAAK,CAACK,MAArB,CAA3B,EAAyD;AACvD,YAAMyD,GAAG,GAAG7E,UAAU,CAACmD,KAAD,CAAtB;AACAnB,MAAAA,SAAS,CAACuC,IAAV,CAAgB,aAAY/B,GAAI,KAAIqC,GAAG,CAACC,CAAE,IAAGD,GAAG,CAACE,CAAE,IAAGF,GAAG,CAACG,CAAE,EAA5D;;AACA,UAAI,CAACxC,GAAG,CAACmC,UAAJ,CAAe,KAAf,CAAL,EAA4B;AAC1B3C,QAAAA,SAAS,CAACuC,IAAV,CAAgB,aAAY/B,GAAI,wBAAuBpC,OAAO,CAAC+C,KAAD,CAAP,GAAiB,IAAjB,GAAwBqC,YAAxB,GAAuCC,WAAY,EAA1G;AACD;AACF;;AAED,WAAOzD,SAAP;AACD;;AAED,WAASwC,cAAT,CAAyBkB,QAAzB,EAA2CC,OAA3C,EAA8D;AAC5D,WAAO,CACJ,GAAED,QAAS,MADP,EAEL,GAAGC,OAAO,CAACjB,GAAR,CAAYkB,IAAI,IAAK,KAAIA,IAAK,KAA9B,CAFE,EAGL,KAHK,CAAP;AAKD;;AAED,MAAIjD,IAAJ,EAAU;AACRA,IAAAA,IAAI,CAACkD,WAAL,CAAiBpG,QAAQ,CAAC,OAAO;AAC/BqG,MAAAA,KAAK,EAAE,CAAC;AACNC,QAAAA,QAAQ,EAAE3B,MAAM,CAACjB,KADX;AAEN6C,QAAAA,IAAI,EAAE,UAFA;AAGNC,QAAAA,EAAE,EAAE;AAHE,OAAD;AADwB,KAAP,CAAD,CAAzB;;AAQA,QAAI5F,UAAJ,EAAgB;AACdP,MAAAA,WAAW,CAAC,MAAM6C,IAAI,CAACuD,SAAL,EAAP,CAAX;AACD;AACF,GAZD,MAYO;AACLrG,IAAAA,KAAK,CAACwB,MAAD,EAAS8E,YAAT,EAAuB;AAAEC,MAAAA,IAAI,EAAE,IAAR;AAAcC,MAAAA,SAAS,EAAE;AAAzB,KAAvB,CAAL;;AAEA,aAASF,YAAT,GAAyB;AACvB,UAAIpD,aAAa,CAACZ,UAAlB,EAA8B;AAE9BmE,MAAAA,eAAe;AAEf,UAAItD,OAAO,CAACG,KAAZ,EAAmBH,OAAO,CAACG,KAAR,CAAcoD,SAAd,GAA0BnC,MAAM,CAACjB,KAAjC;AACpB;;AAED,aAASmD,eAAT,GAA4B;AAC1B,UAAI,OAAOE,QAAP,KAAoB,WAApB,IAAmCxD,OAAO,CAACG,KAA/C,EAAsD;AAEtD,YAAMsD,EAAE,GAAGD,QAAQ,CAACE,aAAT,CAAuB,OAAvB,CAAX;AACAD,MAAAA,EAAE,CAACT,IAAH,GAAU,UAAV;AACAS,MAAAA,EAAE,CAACR,EAAH,GAAQ,0BAAR;AAEAjD,MAAAA,OAAO,CAACG,KAAR,GAAgBsD,EAAhB;AACAD,MAAAA,QAAQ,CAAC7D,IAAT,CAAcgE,WAAd,CAA0B3D,OAAO,CAACG,KAAlC;AACD;AACF;;AAED,SAAO;AACLhB,IAAAA,UAAU,EAAEY,aAAa,CAACZ,UADrB;AAELd,IAAAA,MAAM,EAAE6B,cAFH;AAGL0D,IAAAA,QAAQ,EAAE,CAACpE,GAAD,EAAczB,KAAd,KAAiDM,MAAM,CAAC8B,KAAP,CAAaX,GAAb,IAAoBzB,KAH1E;AAIL8F,IAAAA,QAAQ,EAAGrE,GAAD,IAAiBU,cAAc,CAACC,KAAf,CAAqBX,GAArB,CAJtB;AAKLS,IAAAA,OALK;AAML6D,IAAAA,YAAY,EAAErH,QAAQ,CAAC,MAAMsD,aAAa,CAACZ,UAAd,GAA2ByC,SAA3B,GAAwC,YAAW3B,OAAO,CAACE,KAAM,EAAxE,CANjB;AAOLiB,IAAAA;AAPK,GAAP;AASD;AAED,OAAO,SAAS2C,YAAT,CAAuBC,KAAvB,EAAkD;AACvD7G,EAAAA,kBAAkB,CAAC,cAAD,CAAlB;AAEA,QAAMY,KAAK,GAAGrB,MAAM,CAACiB,WAAD,EAAc,IAAd,CAApB;AAEA,MAAI,CAACI,KAAL,EAAY,MAAM,IAAIwE,KAAJ,CAAU,wCAAV,CAAN;AAEZ,QAAMtC,OAAO,GAAGxD,QAAQ,CAAS,MAAM;AAAA;;AACrC,2BAAOuH,KAAK,CAACjG,KAAb,2BAAsBA,KAAtB,oBAAsBA,KAAK,CAAEkC,OAAP,CAAeE,KAArC;AACD,GAFuB,CAAxB;AAIA,QAAM2D,YAAY,GAAGrH,QAAQ,CAAC,MAAMsB,KAAK,CAACoB,UAAN,GAAmByC,SAAnB,GAAgC,YAAW3B,OAAO,CAACE,KAAM,EAAhE,CAA7B;AAEA,QAAM8D,QAAuB,GAAG,EAC9B,GAAGlG,KAD2B;AAE9BkC,IAAAA,OAF8B;AAG9B6D,IAAAA;AAH8B,GAAhC;AAMAnH,EAAAA,OAAO,CAACgB,WAAD,EAAcsG,QAAd,CAAP;AAEA,SAAOA,QAAP;AACD;AAED,OAAO,SAASC,QAAT,GAAqB;AAC1B/G,EAAAA,kBAAkB,CAAC,UAAD,CAAlB;AAEA,QAAMY,KAAK,GAAGrB,MAAM,CAACiB,WAAD,EAAc,IAAd,CAApB;AAEA,MAAI,CAACI,KAAL,EAAY,MAAM,IAAIwE,KAAJ,CAAU,wCAAV,CAAN;AAEZ,SAAOxE,KAAP;AACD","sourcesContent":["// Utilities\nimport { computed, inject, provide, ref, watch, watchEffect } from 'vue'\nimport {\n colorToInt,\n colorToRGB,\n createRange,\n darken,\n getCurrentInstance,\n getLuma,\n IN_BROWSER,\n intToHex,\n lighten,\n mergeDeep,\n propsFactory,\n} from '@/util'\nimport { APCAcontrast } from '@/util/color/APCA'\n\n// Types\nimport type { App, InjectionKey, Ref } from 'vue'\nimport type { HeadClient } from '@vueuse/head'\n\ntype DeepPartial<T> = T extends object ? { [P in keyof T]?: DeepPartial<T[P]> } : T\n\ninterface BaseColors {\n background: string\n surface: string\n primary: string\n secondary: string\n success: string\n warning: string\n error: string\n info: string\n}\n\ninterface OnColors {\n 'on-background': string\n 'on-surface': string\n 'on-primary': string\n 'on-secondary': string\n 'on-success': string\n 'on-warning': string\n 'on-error': string\n 'on-info': string\n}\n\nexport interface Colors extends BaseColors, OnColors {\n [key: string]: string\n}\n\ninterface InternalThemeDefinition {\n dark: boolean\n colors: Colors\n variables: Record<string, string | number>\n}\n\ninterface VariationsOptions {\n colors: string[]\n lighten: number\n darken: number\n}\n\ninterface InternalThemeOptions {\n isDisabled: boolean\n defaultTheme: string\n variations: VariationsOptions\n themes: Record<string, InternalThemeDefinition>\n}\n\nexport type ThemeDefinition = DeepPartial<InternalThemeDefinition>\n\nexport type ThemeOptions = false | {\n defaultTheme?: string\n variations?: false | VariationsOptions\n themes?: Record<string, ThemeDefinition>\n}\n\nexport interface ThemeInstance {\n isDisabled: boolean\n themes: Ref<Record<string, InternalThemeDefinition>>\n current: Ref<string>\n themeClasses: Ref<string | undefined>\n setTheme: (key: string, theme: InternalThemeDefinition) => void\n getTheme: (key: string) => InternalThemeDefinition\n styles: Ref<string>\n}\n\nexport const ThemeSymbol: InjectionKey<ThemeInstance> = Symbol.for('vuetify:theme')\n\nexport const makeThemeProps = propsFactory({\n theme: String,\n}, 'theme')\n\nconst defaultThemeOptions: ThemeOptions = {\n defaultTheme: 'light',\n variations: { colors: [], lighten: 0, darken: 0 },\n themes: {\n light: {\n dark: false,\n colors: {\n background: '#FFFFFF',\n surface: '#FFFFFF',\n 'surface-variant': '#424242',\n 'on-surface-variant': '#EEEEEE',\n primary: '#6200EE',\n 'primary-darken-1': '#3700B3',\n secondary: '#03DAC6',\n 'secondary-darken-1': '#018786',\n error: '#B00020',\n info: '#2196F3',\n success: '#4CAF50',\n warning: '#FB8C00',\n },\n variables: {\n 'border-color': '#000000',\n 'border-opacity': 0.12,\n 'high-emphasis-opacity': 0.87,\n 'medium-emphasis-opacity': 0.60,\n 'disabled-opacity': 0.38,\n 'idle-opacity': 0.04,\n 'hover-opacity': 0.04,\n 'focus-opacity': 0.12,\n 'selected-opacity': 0.08,\n 'activated-opacity': 0.12,\n 'pressed-opacity': 0.12,\n 'dragged-opacity': 0.08,\n 'kbd-background-color': '#212529',\n 'kbd-color': '#FFFFFF',\n 'code-background-color': '#C2C2C2',\n },\n },\n dark: {\n dark: true,\n colors: {\n background: '#121212',\n surface: '#212121',\n 'surface-variant': '#BDBDBD',\n 'on-surface-variant': '#424242',\n primary: '#BB86FC',\n 'primary-darken-1': '#3700B3',\n secondary: '#03DAC5',\n 'secondary-darken-1': '#03DAC5',\n error: '#CF6679',\n info: '#2196F3',\n success: '#4CAF50',\n warning: '#FB8C00',\n },\n variables: {\n 'border-color': '#FFFFFF',\n 'border-opacity': 0.12,\n 'high-emphasis-opacity': 0.87,\n 'medium-emphasis-opacity': 0.60,\n 'disabled-opacity': 0.38,\n 'idle-opacity': 0.10,\n 'hover-opacity': 0.04,\n 'focus-opacity': 0.12,\n 'selected-opacity': 0.08,\n 'activated-opacity': 0.12,\n 'pressed-opacity': 0.16,\n 'dragged-opacity': 0.08,\n 'kbd-background-color': '#212529',\n 'kbd-color': '#FFFFFF',\n 'code-background-color': '#B7B7B7',\n },\n },\n },\n}\n\nconst parseThemeOptions = (options: ThemeOptions = defaultThemeOptions): InternalThemeOptions => {\n if (!options) return { ...defaultThemeOptions, isDisabled: true } as InternalThemeOptions\n\n const themes = Object.entries(options.themes ?? {}).reduce((obj, [key, theme]) => {\n const defaultTheme = theme.dark ? defaultThemeOptions.themes?.dark : defaultThemeOptions.themes?.light\n obj[key] = mergeDeep(defaultTheme, theme)\n return obj\n }, {} as Record<string, ThemeDefinition>)\n\n return mergeDeep(\n defaultThemeOptions,\n { ...options, themes },\n ) as InternalThemeOptions\n}\n\n// Composables\nexport function createTheme (app: App, options?: ThemeOptions): ThemeInstance {\n const head = app._context.provides.usehead as HeadClient | undefined\n const parsedOptions = parseThemeOptions(options)\n const styleEl = ref<HTMLStyleElement>()\n const current = ref(parsedOptions.defaultTheme)\n const themes = ref(parsedOptions.themes)\n const variations = ref(parsedOptions.variations)\n\n const computedThemes = computed(() => {\n return Object.entries(themes.value).reduce((obj, [name, original]) => {\n const theme: InternalThemeDefinition = {\n ...original,\n colors: {\n ...original.colors,\n ...(parsedOptions.variations.colors ?? []).reduce((obj, color) => {\n return { ...obj, ...genColorVariations(color, original.colors[color]!) }\n }, {}),\n },\n }\n\n for (const color of Object.keys(theme.colors)) {\n if (/on-[a-z]/.test(color) || theme.colors[`on-${color}`]) continue\n\n const onColor = `on-${color}` as keyof OnColors\n const colorVal = colorToInt(theme.colors[color]!)\n\n const blackContrast = Math.abs(APCAcontrast(0, colorVal))\n const whiteContrast = Math.abs(APCAcontrast(0xffffff, colorVal))\n\n // TODO: warn about poor color selections\n // const contrastAsText = Math.abs(APCAcontrast(colorVal, colorToInt(theme.colors.background)))\n // const minContrast = Math.max(blackContrast, whiteContrast)\n // if (minContrast < 60) {\n // consoleInfo(`${key} theme color ${color} has poor contrast (${minContrast.toFixed()}%)`)\n // } else if (contrastAsText < 60 && !['background', 'surface'].includes(color)) {\n // consoleInfo(`${key} theme color ${color} has poor contrast as text (${contrastAsText.toFixed()}%)`)\n // }\n\n // Prefer white text if both have an acceptable contrast ratio\n theme.colors[onColor] = whiteContrast > Math.min(blackContrast, 50) ? '#fff' : '#000'\n }\n\n obj[name] = theme\n\n return obj\n }, {} as Record<string, InternalThemeDefinition>)\n })\n\n function genColorVariations (name: string, color: string) {\n const obj: Record<string, string> = {}\n for (const variation of (['lighten', 'darken'] as const)) {\n const fn = variation === 'lighten' ? lighten : darken\n for (const amount of createRange(variations.value[variation], 1)) {\n obj[`${name}-${variation}-${amount}`] = intToHex(fn(colorToInt(color), amount))\n }\n }\n\n return obj\n }\n\n const styles = computed(() => {\n const lines = []\n\n for (const themeName of Object.keys(computedThemes.value)) {\n const variables = computedThemes.value[themeName].variables\n\n lines.push(...createCssClass(`.v-theme--${themeName}`, [\n ...genCssVariables(themeName),\n ...Object.keys(variables).map(key => {\n const value = variables[key]\n const color = typeof value === 'string' && value.startsWith('#') ? colorToRGB(value) : undefined\n const rgb = color ? `${color.r}, ${color.g}, ${color.b}` : undefined\n\n return `--v-${key}: ${rgb ?? value}`\n }),\n ]))\n }\n\n const colors = new Set(Object.values(computedThemes.value).flatMap(theme => Object.keys(theme.colors)))\n for (const key of colors) {\n if (/on-[a-z]/.test(key)) {\n lines.push(...createCssClass(`.${key}`, [`color: rgb(var(--v-theme-${key})) !important`]))\n } else {\n lines.push(\n ...createCssClass(`.bg-${key}`, [\n `--v-theme-overlay-multiplier: var(--v-theme-${key}-overlay-multiplier)`,\n `background: rgb(var(--v-theme-${key})) !important`,\n `color: rgb(var(--v-theme-on-${key})) !important`,\n ]),\n ...createCssClass(`.text-${key}`, [`color: rgb(var(--v-theme-${key})) !important`]),\n ...createCssClass(`.border-${key}`, [`--v-border-color: var(--v-theme-${key})`]),\n )\n }\n }\n\n return lines.map((str, i) => i === 0 ? str : ` ${str}`).join('')\n })\n\n function genCssVariables (name: string) {\n const theme = computedThemes.value[name]\n\n if (!theme) throw new Error(`Could not find theme ${name}`)\n\n const lightOverlay = theme.dark ? 2 : 1\n const darkOverlay = theme.dark ? 1 : 2\n\n const variables: string[] = []\n for (const [key, value] of Object.entries(theme.colors)) {\n const rgb = colorToRGB(value!)\n variables.push(`--v-theme-${key}: ${rgb.r},${rgb.g},${rgb.b}`)\n if (!key.startsWith('on-')) {\n variables.push(`--v-theme-${key}-overlay-multiplier: ${getLuma(value) > 0.18 ? lightOverlay : darkOverlay}`)\n }\n }\n\n return variables\n }\n\n function createCssClass (selector: string, content: string[]) {\n return [\n `${selector} {\\n`,\n ...content.map(line => ` ${line};\\n`),\n '}\\n',\n ]\n }\n\n if (head) {\n head.addHeadObjs(computed(() => ({\n style: [{\n children: styles.value,\n type: 'text/css',\n id: 'vuetify-theme-stylesheet',\n }],\n })))\n\n if (IN_BROWSER) {\n watchEffect(() => head.updateDOM())\n }\n } else {\n watch(themes, updateStyles, { deep: true, immediate: true })\n\n function updateStyles () {\n if (parsedOptions.isDisabled) return\n\n genStyleElement()\n\n if (styleEl.value) styleEl.value.innerHTML = styles.value\n }\n\n function genStyleElement () {\n if (typeof document === 'undefined' || styleEl.value) return\n\n const el = document.createElement('style')\n el.type = 'text/css'\n el.id = 'vuetify-theme-stylesheet'\n\n styleEl.value = el\n document.head.appendChild(styleEl.value)\n }\n }\n\n return {\n isDisabled: parsedOptions.isDisabled,\n themes: computedThemes,\n setTheme: (key: string, theme: InternalThemeDefinition) => themes.value[key] = theme,\n getTheme: (key: string) => computedThemes.value[key],\n current,\n themeClasses: computed(() => parsedOptions.isDisabled ? undefined : `v-theme--${current.value}`),\n styles,\n }\n}\n\nexport function provideTheme (props: { theme?: string }) {\n getCurrentInstance('provideTheme')\n\n const theme = inject(ThemeSymbol, null)\n\n if (!theme) throw new Error('Could not find Vuetify theme injection')\n\n const current = computed<string>(() => {\n return props.theme ?? theme?.current.value\n })\n\n const themeClasses = computed(() => theme.isDisabled ? undefined : `v-theme--${current.value}`)\n\n const newTheme: ThemeInstance = {\n ...theme,\n current,\n themeClasses,\n }\n\n provide(ThemeSymbol, newTheme)\n\n return newTheme\n}\n\nexport function useTheme () {\n getCurrentInstance('useTheme')\n\n const theme = inject(ThemeSymbol, null)\n\n if (!theme) throw new Error('Could not find Vuetify theme injection')\n\n return theme\n}\n"],"file":"theme.mjs"}
1
+ {"version":3,"file":"theme.mjs","names":["computed","inject","provide","reactive","ref","watch","watchEffect","colorToInt","colorToRGB","createRange","darken","getCurrentInstance","getLuma","IN_BROWSER","intToHex","lighten","mergeDeep","propsFactory","APCAcontrast","ThemeSymbol","Symbol","for","makeThemeProps","theme","String","defaultThemeOptions","defaultTheme","variations","colors","themes","light","dark","background","surface","primary","secondary","error","info","success","warning","variables","parseThemeOptions","options","isDisabled","key","Object","entries","createTheme","app","head","_context","provides","usehead","parsedOptions","name","computedThemes","acc","original","value","color","variation","fn","amount","keys","test","onColor","colorVal","blackContrast","Math","abs","whiteContrast","min","current","styles","lines","createCssClass","themeName","genCssVariables","map","startsWith","undefined","rgb","r","g","b","Set","values","flatMap","str","i","join","addHeadObjs","style","children","type","id","updateDOM","styleEl","document","getElementById","updateStyles","immediate","el","createElement","appendChild","innerHTML","themeClasses","global","provideTheme","props","Error","newTheme","useTheme","selector","content","push","line","lightOverlay","darkOverlay"],"sources":["../../src/composables/theme.ts"],"sourcesContent":["// Utilities\nimport {\n computed,\n inject,\n provide,\n reactive,\n ref,\n watch,\n watchEffect,\n} from 'vue'\nimport {\n colorToInt,\n colorToRGB,\n createRange,\n darken,\n getCurrentInstance,\n getLuma,\n IN_BROWSER,\n intToHex,\n lighten,\n mergeDeep,\n propsFactory,\n} from '@/util'\nimport { APCAcontrast } from '@/util/color/APCA'\n\n// Types\nimport type { App, DeepReadonly, InjectionKey, Ref } from 'vue'\nimport type { HeadClient } from '@vueuse/head'\n\ntype DeepPartial<T> = T extends object ? { [P in keyof T]?: DeepPartial<T[P]> } : T\n\nexport type ThemeOptions = false | {\n defaultTheme?: string\n variations?: false | VariationsOptions\n themes?: Record<string, ThemeDefinition>\n}\nexport type ThemeDefinition = DeepPartial<InternalThemeDefinition>\n\ninterface InternalThemeOptions {\n isDisabled: boolean\n defaultTheme: string\n variations: false | VariationsOptions\n themes: Record<string, InternalThemeDefinition>\n}\n\ninterface VariationsOptions {\n colors: string[]\n lighten: number\n darken: number\n}\n\ninterface InternalThemeDefinition {\n dark: boolean\n colors: Colors\n variables: Record<string, string | number>\n}\n\nexport interface Colors extends BaseColors, OnColors {\n [key: string]: string\n}\n\ninterface BaseColors {\n background: string\n surface: string\n primary: string\n secondary: string\n success: string\n warning: string\n error: string\n info: string\n}\n\ninterface OnColors {\n 'on-background': string\n 'on-surface': string\n 'on-primary': string\n 'on-secondary': string\n 'on-success': string\n 'on-warning': string\n 'on-error': string\n 'on-info': string\n}\n\nexport interface ThemeInstance {\n readonly isDisabled: boolean\n readonly themes: Ref<Record<string, InternalThemeDefinition>>\n\n readonly name: Readonly<Ref<string>>\n readonly current: DeepReadonly<Ref<InternalThemeDefinition>>\n readonly computedThemes: DeepReadonly<Ref<Record<string, InternalThemeDefinition>>>\n\n readonly themeClasses: Readonly<Ref<string | undefined>>\n readonly styles: Readonly<Ref<string>>\n\n readonly global: {\n readonly name: Ref<string>\n readonly current: DeepReadonly<Ref<InternalThemeDefinition>>\n }\n}\n\nexport const ThemeSymbol: InjectionKey<ThemeInstance> = Symbol.for('vuetify:theme')\n\nexport const makeThemeProps = propsFactory({\n theme: String,\n}, 'theme')\n\nconst defaultThemeOptions: Exclude<ThemeOptions, false> = {\n defaultTheme: 'light',\n variations: { colors: [], lighten: 0, darken: 0 },\n themes: {\n light: {\n dark: false,\n colors: {\n background: '#FFFFFF',\n surface: '#FFFFFF',\n 'surface-variant': '#424242',\n 'on-surface-variant': '#EEEEEE',\n primary: '#6200EE',\n 'primary-darken-1': '#3700B3',\n secondary: '#03DAC6',\n 'secondary-darken-1': '#018786',\n error: '#B00020',\n info: '#2196F3',\n success: '#4CAF50',\n warning: '#FB8C00',\n },\n variables: {\n 'border-color': '#000000',\n 'border-opacity': 0.12,\n 'high-emphasis-opacity': 0.87,\n 'medium-emphasis-opacity': 0.60,\n 'disabled-opacity': 0.38,\n 'idle-opacity': 0.04,\n 'hover-opacity': 0.04,\n 'focus-opacity': 0.12,\n 'selected-opacity': 0.08,\n 'activated-opacity': 0.12,\n 'pressed-opacity': 0.12,\n 'dragged-opacity': 0.08,\n 'kbd-background-color': '#212529',\n 'kbd-color': '#FFFFFF',\n 'code-background-color': '#C2C2C2',\n },\n },\n dark: {\n dark: true,\n colors: {\n background: '#121212',\n surface: '#212121',\n 'surface-variant': '#BDBDBD',\n 'on-surface-variant': '#424242',\n primary: '#BB86FC',\n 'primary-darken-1': '#3700B3',\n secondary: '#03DAC5',\n 'secondary-darken-1': '#03DAC5',\n error: '#CF6679',\n info: '#2196F3',\n success: '#4CAF50',\n warning: '#FB8C00',\n },\n variables: {\n 'border-color': '#FFFFFF',\n 'border-opacity': 0.12,\n 'high-emphasis-opacity': 0.87,\n 'medium-emphasis-opacity': 0.60,\n 'disabled-opacity': 0.38,\n 'idle-opacity': 0.10,\n 'hover-opacity': 0.04,\n 'focus-opacity': 0.12,\n 'selected-opacity': 0.08,\n 'activated-opacity': 0.12,\n 'pressed-opacity': 0.16,\n 'dragged-opacity': 0.08,\n 'kbd-background-color': '#212529',\n 'kbd-color': '#FFFFFF',\n 'code-background-color': '#B7B7B7',\n },\n },\n },\n}\n\nfunction parseThemeOptions (options: ThemeOptions = defaultThemeOptions): InternalThemeOptions {\n if (!options) return { ...defaultThemeOptions, isDisabled: true } as InternalThemeOptions\n\n const themes: Record<string, InternalThemeDefinition> = {}\n for (const [key, theme] of Object.entries(options.themes ?? {})) {\n const defaultTheme = theme.dark\n ? defaultThemeOptions.themes?.dark\n : defaultThemeOptions.themes?.light\n themes[key] = mergeDeep(defaultTheme, theme) as InternalThemeDefinition\n }\n\n return mergeDeep(\n defaultThemeOptions,\n { ...options, themes },\n ) as InternalThemeOptions\n}\n\n// Composables\nexport function createTheme (app: App, options?: ThemeOptions): ThemeInstance {\n const head = app._context.provides.usehead as HeadClient | undefined\n const parsedOptions = reactive(parseThemeOptions(options))\n const name = ref(parsedOptions.defaultTheme)\n const themes = ref(parsedOptions.themes)\n\n const computedThemes = computed(() => {\n const acc: Record<string, InternalThemeDefinition> = {}\n for (const [name, original] of Object.entries(themes.value)) {\n const theme: InternalThemeDefinition = acc[name] = {\n ...original,\n colors: {\n ...original.colors,\n },\n }\n\n if (parsedOptions.variations) {\n for (const name of parsedOptions.variations.colors) {\n const color = theme.colors[name]\n for (const variation of (['lighten', 'darken'] as const)) {\n const fn = variation === 'lighten' ? lighten : darken\n for (const amount of createRange(parsedOptions.variations[variation], 1)) {\n theme.colors[`${name}-${variation}-${amount}`] = intToHex(fn(colorToInt(color), amount))\n }\n }\n }\n }\n\n for (const color of Object.keys(theme.colors)) {\n if (/on-[a-z]/.test(color) || theme.colors[`on-${color}`]) continue\n\n const onColor = `on-${color}` as keyof OnColors\n const colorVal = colorToInt(theme.colors[color]!)\n\n const blackContrast = Math.abs(APCAcontrast(0, colorVal))\n const whiteContrast = Math.abs(APCAcontrast(0xffffff, colorVal))\n\n // TODO: warn about poor color selections\n // const contrastAsText = Math.abs(APCAcontrast(colorVal, colorToInt(theme.colors.background)))\n // const minContrast = Math.max(blackContrast, whiteContrast)\n // if (minContrast < 60) {\n // consoleInfo(`${key} theme color ${color} has poor contrast (${minContrast.toFixed()}%)`)\n // } else if (contrastAsText < 60 && !['background', 'surface'].includes(color)) {\n // consoleInfo(`${key} theme color ${color} has poor contrast as text (${contrastAsText.toFixed()}%)`)\n // }\n\n // Prefer white text if both have an acceptable contrast ratio\n theme.colors[onColor] = whiteContrast > Math.min(blackContrast, 50) ? '#fff' : '#000'\n }\n }\n\n return acc\n })\n const current = computed(() => computedThemes.value[name.value])\n\n const styles = computed(() => {\n const lines: string[] = []\n\n if (current.value.dark) {\n createCssClass(lines, ':root', ['color-scheme: dark'])\n }\n\n for (const [themeName, theme] of Object.entries(computedThemes.value)) {\n const { variables, dark } = theme\n\n createCssClass(lines, `.v-theme--${themeName}`, [\n `color-scheme: ${dark ? 'dark' : 'normal'}`,\n ...genCssVariables(theme),\n ...Object.keys(variables).map(key => {\n const value = variables[key]\n const color = typeof value === 'string' && value.startsWith('#') ? colorToRGB(value) : undefined\n const rgb = color ? `${color.r}, ${color.g}, ${color.b}` : undefined\n\n return `--v-${key}: ${rgb ?? value}`\n }),\n ])\n }\n\n const colors = new Set(Object.values(computedThemes.value).flatMap(theme => Object.keys(theme.colors)))\n for (const key of colors) {\n if (/on-[a-z]/.test(key)) {\n createCssClass(lines, `.${key}`, [`color: rgb(var(--v-theme-${key})) !important`])\n } else {\n createCssClass(lines, `.bg-${key}`, [\n `--v-theme-overlay-multiplier: var(--v-theme-${key}-overlay-multiplier)`,\n `background: rgb(var(--v-theme-${key})) !important`,\n `color: rgb(var(--v-theme-on-${key})) !important`,\n ])\n createCssClass(lines, `.text-${key}`, [`color: rgb(var(--v-theme-${key})) !important`])\n createCssClass(lines, `.border-${key}`, [`--v-border-color: var(--v-theme-${key})`])\n }\n }\n\n return lines.map((str, i) => i === 0 ? str : ` ${str}`).join('')\n })\n\n if (head) {\n head.addHeadObjs(computed(() => ({\n style: [{\n children: styles.value,\n type: 'text/css',\n id: 'vuetify-theme-stylesheet',\n }],\n })))\n\n if (IN_BROWSER) {\n watchEffect(() => head.updateDOM())\n }\n } else {\n let styleEl = IN_BROWSER\n ? document.getElementById('vuetify-theme-stylesheet')\n : null\n\n watch(styles, updateStyles, { immediate: true })\n function updateStyles () {\n if (parsedOptions.isDisabled) return\n\n if (typeof document !== 'undefined' && !styleEl) {\n const el = document.createElement('style')\n el.type = 'text/css'\n el.id = 'vuetify-theme-stylesheet'\n\n styleEl = el\n document.head.appendChild(styleEl)\n }\n\n if (styleEl) styleEl.innerHTML = styles.value\n }\n }\n\n const themeClasses = computed(() => parsedOptions.isDisabled ? undefined : `v-theme--${name.value}`)\n\n return {\n isDisabled: parsedOptions.isDisabled,\n name,\n themes,\n current,\n computedThemes,\n themeClasses,\n styles,\n global: {\n name,\n current,\n },\n }\n}\n\nexport function provideTheme (props: { theme?: string }) {\n getCurrentInstance('provideTheme')\n\n const theme = inject(ThemeSymbol, null)\n\n if (!theme) throw new Error('Could not find Vuetify theme injection')\n\n const name = computed<string>(() => {\n return props.theme ?? theme?.name.value\n })\n\n const themeClasses = computed(() => theme.isDisabled ? undefined : `v-theme--${name.value}`)\n\n const newTheme: ThemeInstance = {\n ...theme,\n name,\n themeClasses,\n }\n\n provide(ThemeSymbol, newTheme)\n\n return newTheme\n}\n\nexport function useTheme () {\n getCurrentInstance('useTheme')\n\n const theme = inject(ThemeSymbol, null)\n\n if (!theme) throw new Error('Could not find Vuetify theme injection')\n\n return theme\n}\n\nfunction createCssClass (lines: string[], selector: string, content: string[]) {\n lines.push(\n `${selector} {\\n`,\n ...content.map(line => ` ${line};\\n`),\n '}\\n',\n )\n}\n\nfunction genCssVariables (theme: InternalThemeDefinition) {\n const lightOverlay = theme.dark ? 2 : 1\n const darkOverlay = theme.dark ? 1 : 2\n\n const variables: string[] = []\n for (const [key, value] of Object.entries(theme.colors)) {\n const rgb = colorToRGB(value)\n variables.push(`--v-theme-${key}: ${rgb.r},${rgb.g},${rgb.b}`)\n if (!key.startsWith('on-')) {\n variables.push(`--v-theme-${key}-overlay-multiplier: ${getLuma(value) > 0.18 ? lightOverlay : darkOverlay}`)\n }\n }\n\n return variables\n}\n"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { effectScope, watch } from 'vue';
2
+ export function useToggleScope(source, cb) {
3
+ let scope;
4
+ watch(source, active => {
5
+ if (active && !scope) {
6
+ scope = effectScope();
7
+ scope.run(cb);
8
+ } else {
9
+ var _scope;
10
+
11
+ (_scope = scope) == null ? void 0 : _scope.stop();
12
+ scope = undefined;
13
+ }
14
+ }, {
15
+ immediate: true
16
+ });
17
+ }
18
+ //# sourceMappingURL=toggleScope.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toggleScope.mjs","names":["effectScope","watch","useToggleScope","source","cb","scope","active","run","stop","undefined","immediate"],"sources":["../../src/composables/toggleScope.ts"],"sourcesContent":["import { effectScope, watch } from 'vue'\nimport type { EffectScope, WatchSource } from 'vue'\n\nexport function useToggleScope (source: WatchSource<boolean>, cb: () => void) {\n let scope: EffectScope | undefined\n watch(source, active => {\n if (active && !scope) {\n scope = effectScope()\n scope.run(cb)\n } else {\n scope?.stop()\n scope = undefined\n }\n }, { immediate: true })\n}\n"],"mappings":"AAAA,SAASA,WAAT,EAAsBC,KAAtB,QAAmC,KAAnC;AAGA,OAAO,SAASC,cAAT,CAAyBC,MAAzB,EAAuDC,EAAvD,EAAuE;EAC5E,IAAIC,KAAJ;EACAJ,KAAK,CAACE,MAAD,EAASG,MAAM,IAAI;IACtB,IAAIA,MAAM,IAAI,CAACD,KAAf,EAAsB;MACpBA,KAAK,GAAGL,WAAW,EAAnB;MACAK,KAAK,CAACE,GAAN,CAAUH,EAAV;IACD,CAHD,MAGO;MAAA;;MACL,UAAAC,KAAK,SAAL,mBAAOG,IAAP;MACAH,KAAK,GAAGI,SAAR;IACD;EACF,CARI,EAQF;IAAEC,SAAS,EAAE;EAAb,CARE,CAAL;AASD"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/composables/touch.ts"],"names":["CircularBuffer","HORIZON","HISTORY","kineticEnergyToVelocity","work","sqrt2","Math","sqrt","abs","calculateImpulseVelocity","samples","length","t","d","i","vprev","vcurr","useVelocity","touches","addMovement","e","Array","from","changedTouches","forEach","touch","identifier","push","timeStamp","endTouch","getVelocity","id","values","reverse","Error","newest","x","y","val","clientX","clientY","direction","absX","absY","oops"],"mappings":"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","sourcesContent":["import { CircularBuffer } from '@/util'\n\nconst HORIZON = 100 // ms\nconst HISTORY = 20 // number of samples to keep\n\nexport interface Sample {\n t: number\n d: number\n}\n\n/** @see https://android.googlesource.com/platform/frameworks/native/+/master/libs/input/VelocityTracker.cpp */\nfunction kineticEnergyToVelocity (work: number) {\n const sqrt2 = 1.41421356237\n return (work < 0 ? -1.0 : 1.0) * Math.sqrt(Math.abs(work)) * sqrt2\n}\n\n/**\n * Returns pointer velocity in px/s\n */\nexport function calculateImpulseVelocity (samples: Sample[]) {\n // The input should be in reversed time order (most recent sample at index i=0)\n if (samples.length < 2) {\n // if 0 or 1 points, velocity is zero\n return 0\n }\n // if (samples[1].t > samples[0].t) {\n // // Algorithm will still work, but not perfectly\n // consoleWarn('Samples provided to calculateImpulseVelocity in the wrong order')\n // }\n if (samples.length === 2) {\n // if 2 points, basic linear calculation\n if (samples[1].t === samples[0].t) {\n // consoleWarn(`Events have identical time stamps t=${samples[0].t}, setting velocity = 0`)\n return 0\n }\n return (samples[1].d - samples[0].d) / (samples[1].t - samples[0].t)\n }\n // Guaranteed to have at least 3 points here\n // start with the oldest sample and go forward in time\n let work = 0\n for (let i = samples.length - 1; i > 0; i--) {\n if (samples[i].t === samples[i - 1].t) {\n // consoleWarn(`Events have identical time stamps t=${samples[i].t}, skipping sample`)\n continue\n }\n const vprev = kineticEnergyToVelocity(work) // v[i-1]\n const vcurr = (samples[i].d - samples[i - 1].d) / (samples[i].t - samples[i - 1].t) // v[i]\n work += (vcurr - vprev) * Math.abs(vcurr)\n if (i === samples.length - 1) {\n work *= 0.5\n }\n }\n return kineticEnergyToVelocity(work) * 1000\n}\n\nexport function useVelocity () {\n const touches: Record<number, CircularBuffer<[number, Touch]> | undefined> = {}\n\n function addMovement (e: TouchEvent) {\n Array.from(e.changedTouches).forEach(touch => {\n const samples = touches[touch.identifier] ?? (touches[touch.identifier] = new CircularBuffer(HISTORY))\n samples.push([e.timeStamp, touch])\n })\n }\n\n function endTouch (e: TouchEvent) {\n Array.from(e.changedTouches).forEach(touch => {\n delete touches[touch.identifier]\n })\n }\n\n function getVelocity (id: number) {\n const samples = touches[id]?.values().reverse()\n\n if (!samples) {\n throw new Error(`No samples for touch id ${id}`)\n }\n\n const newest = samples[0]\n const x: Sample[] = []\n const y: Sample[] = []\n for (const val of samples) {\n if (newest[0] - val[0] > HORIZON) break\n\n x.push({ t: val[0], d: val[1].clientX })\n y.push({ t: val[0], d: val[1].clientY })\n }\n\n return {\n x: calculateImpulseVelocity(x),\n y: calculateImpulseVelocity(y),\n get direction () {\n const { x, y } = this\n const [absX, absY] = [Math.abs(x), Math.abs(y)]\n\n return absX > absY && x >= 0 ? 'right'\n : absX > absY && x <= 0 ? 'left'\n : absY > absX && y >= 0 ? 'down'\n : absY > absX && y <= 0 ? 'up'\n : oops()\n },\n }\n }\n\n return { addMovement, endTouch, getVelocity }\n}\n\nfunction oops (): never {\n throw new Error()\n}\n"],"file":"touch.mjs"}
1
+ {"version":3,"file":"touch.mjs","names":["CircularBuffer","HORIZON","HISTORY","kineticEnergyToVelocity","work","sqrt2","Math","sqrt","abs","calculateImpulseVelocity","samples","length","t","d","i","vprev","vcurr","useVelocity","touches","addMovement","e","Array","from","changedTouches","forEach","touch","identifier","push","timeStamp","endTouch","getVelocity","id","values","reverse","Error","newest","x","y","val","clientX","clientY","direction","absX","absY","oops"],"sources":["../../src/composables/touch.ts"],"sourcesContent":["import { CircularBuffer } from '@/util'\n\nconst HORIZON = 100 // ms\nconst HISTORY = 20 // number of samples to keep\n\nexport interface Sample {\n t: number\n d: number\n}\n\n/** @see https://android.googlesource.com/platform/frameworks/native/+/master/libs/input/VelocityTracker.cpp */\nfunction kineticEnergyToVelocity (work: number) {\n const sqrt2 = 1.41421356237\n return (work < 0 ? -1.0 : 1.0) * Math.sqrt(Math.abs(work)) * sqrt2\n}\n\n/**\n * Returns pointer velocity in px/s\n */\nexport function calculateImpulseVelocity (samples: Sample[]) {\n // The input should be in reversed time order (most recent sample at index i=0)\n if (samples.length < 2) {\n // if 0 or 1 points, velocity is zero\n return 0\n }\n // if (samples[1].t > samples[0].t) {\n // // Algorithm will still work, but not perfectly\n // consoleWarn('Samples provided to calculateImpulseVelocity in the wrong order')\n // }\n if (samples.length === 2) {\n // if 2 points, basic linear calculation\n if (samples[1].t === samples[0].t) {\n // consoleWarn(`Events have identical time stamps t=${samples[0].t}, setting velocity = 0`)\n return 0\n }\n return (samples[1].d - samples[0].d) / (samples[1].t - samples[0].t)\n }\n // Guaranteed to have at least 3 points here\n // start with the oldest sample and go forward in time\n let work = 0\n for (let i = samples.length - 1; i > 0; i--) {\n if (samples[i].t === samples[i - 1].t) {\n // consoleWarn(`Events have identical time stamps t=${samples[i].t}, skipping sample`)\n continue\n }\n const vprev = kineticEnergyToVelocity(work) // v[i-1]\n const vcurr = (samples[i].d - samples[i - 1].d) / (samples[i].t - samples[i - 1].t) // v[i]\n work += (vcurr - vprev) * Math.abs(vcurr)\n if (i === samples.length - 1) {\n work *= 0.5\n }\n }\n return kineticEnergyToVelocity(work) * 1000\n}\n\nexport function useVelocity () {\n const touches: Record<number, CircularBuffer<[number, Touch]> | undefined> = {}\n\n function addMovement (e: TouchEvent) {\n Array.from(e.changedTouches).forEach(touch => {\n const samples = touches[touch.identifier] ?? (touches[touch.identifier] = new CircularBuffer(HISTORY))\n samples.push([e.timeStamp, touch])\n })\n }\n\n function endTouch (e: TouchEvent) {\n Array.from(e.changedTouches).forEach(touch => {\n delete touches[touch.identifier]\n })\n }\n\n function getVelocity (id: number) {\n const samples = touches[id]?.values().reverse()\n\n if (!samples) {\n throw new Error(`No samples for touch id ${id}`)\n }\n\n const newest = samples[0]\n const x: Sample[] = []\n const y: Sample[] = []\n for (const val of samples) {\n if (newest[0] - val[0] > HORIZON) break\n\n x.push({ t: val[0], d: val[1].clientX })\n y.push({ t: val[0], d: val[1].clientY })\n }\n\n return {\n x: calculateImpulseVelocity(x),\n y: calculateImpulseVelocity(y),\n get direction () {\n const { x, y } = this\n const [absX, absY] = [Math.abs(x), Math.abs(y)]\n\n return absX > absY && x >= 0 ? 'right'\n : absX > absY && x <= 0 ? 'left'\n : absY > absX && y >= 0 ? 'down'\n : absY > absX && y <= 0 ? 'up'\n : oops()\n },\n }\n }\n\n return { addMovement, endTouch, getVelocity }\n}\n\nfunction oops (): never {\n throw new Error()\n}\n"],"mappings":"SAASA,c;AAET,MAAMC,OAAO,GAAG,GAAhB,C,CAAoB;;AACpB,MAAMC,OAAO,GAAG,EAAhB,C,CAAmB;;AAOnB;AACA,SAASC,uBAAT,CAAkCC,IAAlC,EAAgD;EAC9C,MAAMC,KAAK,GAAG,aAAd;EACA,OAAO,CAACD,IAAI,GAAG,CAAP,GAAW,CAAC,GAAZ,GAAkB,GAAnB,IAA0BE,IAAI,CAACC,IAAL,CAAUD,IAAI,CAACE,GAAL,CAASJ,IAAT,CAAV,CAA1B,GAAsDC,KAA7D;AACD;AAED;AACA;AACA;;;AACA,OAAO,SAASI,wBAAT,CAAmCC,OAAnC,EAAsD;EAC3D;EACA,IAAIA,OAAO,CAACC,MAAR,GAAiB,CAArB,EAAwB;IACtB;IACA,OAAO,CAAP;EACD,CAL0D,CAM3D;EACA;EACA;EACA;;;EACA,IAAID,OAAO,CAACC,MAAR,KAAmB,CAAvB,EAA0B;IACxB;IACA,IAAID,OAAO,CAAC,CAAD,CAAP,CAAWE,CAAX,KAAiBF,OAAO,CAAC,CAAD,CAAP,CAAWE,CAAhC,EAAmC;MACjC;MACA,OAAO,CAAP;IACD;;IACD,OAAO,CAACF,OAAO,CAAC,CAAD,CAAP,CAAWG,CAAX,GAAeH,OAAO,CAAC,CAAD,CAAP,CAAWG,CAA3B,KAAiCH,OAAO,CAAC,CAAD,CAAP,CAAWE,CAAX,GAAeF,OAAO,CAAC,CAAD,CAAP,CAAWE,CAA3D,CAAP;EACD,CAjB0D,CAkB3D;EACA;;;EACA,IAAIR,IAAI,GAAG,CAAX;;EACA,KAAK,IAAIU,CAAC,GAAGJ,OAAO,CAACC,MAAR,GAAiB,CAA9B,EAAiCG,CAAC,GAAG,CAArC,EAAwCA,CAAC,EAAzC,EAA6C;IAC3C,IAAIJ,OAAO,CAACI,CAAD,CAAP,CAAWF,CAAX,KAAiBF,OAAO,CAACI,CAAC,GAAG,CAAL,CAAP,CAAeF,CAApC,EAAuC;MACrC;MACA;IACD;;IACD,MAAMG,KAAK,GAAGZ,uBAAuB,CAACC,IAAD,CAArC,CAL2C,CAKC;;IAC5C,MAAMY,KAAK,GAAG,CAACN,OAAO,CAACI,CAAD,CAAP,CAAWD,CAAX,GAAeH,OAAO,CAACI,CAAC,GAAG,CAAL,CAAP,CAAeD,CAA/B,KAAqCH,OAAO,CAACI,CAAD,CAAP,CAAWF,CAAX,GAAeF,OAAO,CAACI,CAAC,GAAG,CAAL,CAAP,CAAeF,CAAnE,CAAd,CAN2C,CAMyC;;IACpFR,IAAI,IAAI,CAACY,KAAK,GAAGD,KAAT,IAAkBT,IAAI,CAACE,GAAL,CAASQ,KAAT,CAA1B;;IACA,IAAIF,CAAC,KAAKJ,OAAO,CAACC,MAAR,GAAiB,CAA3B,EAA8B;MAC5BP,IAAI,IAAI,GAAR;IACD;EACF;;EACD,OAAOD,uBAAuB,CAACC,IAAD,CAAvB,GAAgC,IAAvC;AACD;AAED,OAAO,SAASa,WAAT,GAAwB;EAC7B,MAAMC,OAAoE,GAAG,EAA7E;;EAEA,SAASC,WAAT,CAAsBC,CAAtB,EAAqC;IACnCC,KAAK,CAACC,IAAN,CAAWF,CAAC,CAACG,cAAb,EAA6BC,OAA7B,CAAqCC,KAAK,IAAI;MAAA;;MAC5C,MAAMf,OAAO,4BAAGQ,OAAO,CAACO,KAAK,CAACC,UAAP,CAAV,oCAAiCR,OAAO,CAACO,KAAK,CAACC,UAAP,CAAP,GAA4B,IAAI1B,cAAJ,CAAmBE,OAAnB,CAA1E;MACAQ,OAAO,CAACiB,IAAR,CAAa,CAACP,CAAC,CAACQ,SAAH,EAAcH,KAAd,CAAb;IACD,CAHD;EAID;;EAED,SAASI,QAAT,CAAmBT,CAAnB,EAAkC;IAChCC,KAAK,CAACC,IAAN,CAAWF,CAAC,CAACG,cAAb,EAA6BC,OAA7B,CAAqCC,KAAK,IAAI;MAC5C,OAAOP,OAAO,CAACO,KAAK,CAACC,UAAP,CAAd;IACD,CAFD;EAGD;;EAED,SAASI,WAAT,CAAsBC,EAAtB,EAAkC;IAAA;;IAChC,MAAMrB,OAAO,kBAAGQ,OAAO,CAACa,EAAD,CAAV,qBAAG,YAAaC,MAAb,GAAsBC,OAAtB,EAAhB;;IAEA,IAAI,CAACvB,OAAL,EAAc;MACZ,MAAM,IAAIwB,KAAJ,CAAW,2BAA0BH,EAAG,EAAxC,CAAN;IACD;;IAED,MAAMI,MAAM,GAAGzB,OAAO,CAAC,CAAD,CAAtB;IACA,MAAM0B,CAAW,GAAG,EAApB;IACA,MAAMC,CAAW,GAAG,EAApB;;IACA,KAAK,MAAMC,GAAX,IAAkB5B,OAAlB,EAA2B;MACzB,IAAIyB,MAAM,CAAC,CAAD,CAAN,GAAYG,GAAG,CAAC,CAAD,CAAf,GAAqBrC,OAAzB,EAAkC;MAElCmC,CAAC,CAACT,IAAF,CAAO;QAAEf,CAAC,EAAE0B,GAAG,CAAC,CAAD,CAAR;QAAazB,CAAC,EAAEyB,GAAG,CAAC,CAAD,CAAH,CAAOC;MAAvB,CAAP;MACAF,CAAC,CAACV,IAAF,CAAO;QAAEf,CAAC,EAAE0B,GAAG,CAAC,CAAD,CAAR;QAAazB,CAAC,EAAEyB,GAAG,CAAC,CAAD,CAAH,CAAOE;MAAvB,CAAP;IACD;;IAED,OAAO;MACLJ,CAAC,EAAE3B,wBAAwB,CAAC2B,CAAD,CADtB;MAELC,CAAC,EAAE5B,wBAAwB,CAAC4B,CAAD,CAFtB;;MAGL,IAAII,SAAJ,GAAiB;QACf,MAAM;UAAEL,CAAF;UAAKC;QAAL,IAAW,IAAjB;QACA,MAAM,CAACK,IAAD,EAAOC,IAAP,IAAe,CAACrC,IAAI,CAACE,GAAL,CAAS4B,CAAT,CAAD,EAAc9B,IAAI,CAACE,GAAL,CAAS6B,CAAT,CAAd,CAArB;QAEA,OAAOK,IAAI,GAAGC,IAAP,IAAeP,CAAC,IAAI,CAApB,GAAwB,OAAxB,GACHM,IAAI,GAAGC,IAAP,IAAeP,CAAC,IAAI,CAApB,GAAwB,MAAxB,GACAO,IAAI,GAAGD,IAAP,IAAeL,CAAC,IAAI,CAApB,GAAwB,MAAxB,GACAM,IAAI,GAAGD,IAAP,IAAeL,CAAC,IAAI,CAApB,GAAwB,IAAxB,GACAO,IAAI,EAJR;MAKD;;IAZI,CAAP;EAcD;;EAED,OAAO;IAAEzB,WAAF;IAAeU,QAAf;IAAyBC;EAAzB,CAAP;AACD;;AAED,SAASc,IAAT,GAAwB;EACtB,MAAM,IAAIV,KAAJ,EAAN;AACD"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/composables/transition.ts"],"names":["h","mergeProps","Transition","propsFactory","makeTransitionProps","transition","type","Boolean","String","Object","default","validator","val","MaybeTransition","props","slots","rest","component","customProps","name"],"mappings":"AAAA;AACA,SAASA,CAAT,EAAYC,UAAZ,EAAwBC,UAAxB,QAA0C,KAA1C;SACSC,Y,6BAET;;AAGA,OAAO,MAAMC,mBAAmB,GAAGD,YAAY,CAAC;AAC9CE,EAAAA,UAAU,EAAE;AACVC,IAAAA,IAAI,EAAE,CAACC,OAAD,EAAUC,MAAV,EAAkBC,MAAlB,CADI;AAEVC,IAAAA,OAAO,EAAE,iBAFC;AAGVC,IAAAA,SAAS,EAAEC,GAAG,IAAIA,GAAG,KAAK;AAHhB;AADkC,CAAD,EAM5C,YAN4C,CAAxC;AAYP,OAAO,MAAMC,eAA0D,GAAG,CAACC,KAAD,WAAsB;AAAA;;AAAA,MAAd;AAAEC,IAAAA;AAAF,GAAc;AAC9F,QAAM;AAAEV,IAAAA,UAAF;AAAc,OAAGW;AAAjB,MAA0BF,KAAhC;AAEA,MAAI,CAACT,UAAD,IAAe,OAAOA,UAAP,KAAsB,SAAzC,EAAoD,yBAAOU,KAAK,CAACL,OAAb,qBAAO,oBAAAK,KAAK,CAAZ;AAEpD,QAAM;AAAEE,IAAAA,SAAS,GAAGf,UAAd;AAA0B,OAAGgB;AAA7B,MAA6C,OAAOb,UAAP,KAAsB,QAAtB,GAAiCA,UAAjC,GAA8C,EAAjG;AAEA,SAAOL,CAAC,CACNiB,SADM,EAENhB,UAAU,CAAC,OAAOI,UAAP,KAAsB,QAAtB,GAAiC;AAAEc,IAAAA,IAAI,EAAEd;AAAR,GAAjC,GAAwDa,WAAzD,EAA6EF,IAA7E,CAFJ,EAGND,KAHM,CAAR;AAKD,CAZM","sourcesContent":["// Utilities\nimport { h, mergeProps, Transition } from 'vue'\nimport { propsFactory } from '@/util'\n\n// Types\nimport type { Component, FunctionalComponent, PropType, TransitionProps } from 'vue'\n\nexport const makeTransitionProps = propsFactory({\n transition: {\n type: [Boolean, String, Object] as PropType<string | boolean | TransitionProps & { component?: Component }>,\n default: 'fade-transition',\n validator: val => val !== true,\n },\n}, 'transition')\n\ninterface MaybeTransitionProps extends TransitionProps {\n transition?: string | boolean | TransitionProps & { component?: any }\n}\n\nexport const MaybeTransition: FunctionalComponent<MaybeTransitionProps> = (props, { slots }) => {\n const { transition, ...rest } = props\n\n if (!transition || typeof transition === 'boolean') return slots.default?.()\n\n const { component = Transition, ...customProps } = typeof transition === 'object' ? transition : {}\n\n return h(\n component,\n mergeProps(typeof transition === 'string' ? { name: transition } : customProps as any, rest as any),\n slots\n )\n}\n"],"file":"transition.mjs"}
1
+ {"version":3,"file":"transition.mjs","names":["h","mergeProps","Transition","propsFactory","makeTransitionProps","transition","type","Boolean","String","Object","default","validator","val","MaybeTransition","props","slots","rest","component","customProps","name"],"sources":["../../src/composables/transition.ts"],"sourcesContent":["// Utilities\nimport { h, mergeProps, Transition } from 'vue'\nimport { propsFactory } from '@/util'\n\n// Types\nimport type { Component, FunctionalComponent, PropType, TransitionProps } from 'vue'\n\nexport const makeTransitionProps = propsFactory({\n transition: {\n type: [Boolean, String, Object] as PropType<string | boolean | TransitionProps & { component?: Component }>,\n default: 'fade-transition',\n validator: val => val !== true,\n },\n}, 'transition')\n\ninterface MaybeTransitionProps extends TransitionProps {\n transition?: string | boolean | TransitionProps & { component?: any }\n}\n\nexport const MaybeTransition: FunctionalComponent<MaybeTransitionProps> = (props, { slots }) => {\n const { transition, ...rest } = props\n\n if (!transition || typeof transition === 'boolean') return slots.default?.()\n\n const { component = Transition, ...customProps } = typeof transition === 'object' ? transition : {}\n\n return h(\n component,\n mergeProps(typeof transition === 'string' ? { name: transition } : customProps as any, rest as any),\n slots\n )\n}\n"],"mappings":"AAAA;AACA,SAASA,CAAT,EAAYC,UAAZ,EAAwBC,UAAxB,QAA0C,KAA1C;SACSC,Y,6BAET;;AAGA,OAAO,MAAMC,mBAAmB,GAAGD,YAAY,CAAC;EAC9CE,UAAU,EAAE;IACVC,IAAI,EAAE,CAACC,OAAD,EAAUC,MAAV,EAAkBC,MAAlB,CADI;IAEVC,OAAO,EAAE,iBAFC;IAGVC,SAAS,EAAEC,GAAG,IAAIA,GAAG,KAAK;EAHhB;AADkC,CAAD,EAM5C,YAN4C,CAAxC;AAYP,OAAO,MAAMC,eAA0D,GAAG,CAACC,KAAD,WAAsB;EAAA;;EAAA,IAAd;IAAEC;EAAF,CAAc;EAC9F,MAAM;IAAEV,UAAF;IAAc,GAAGW;EAAjB,IAA0BF,KAAhC;EAEA,IAAI,CAACT,UAAD,IAAe,OAAOA,UAAP,KAAsB,SAAzC,EAAoD,yBAAOU,KAAK,CAACL,OAAb,qBAAO,oBAAAK,KAAK,CAAZ;EAEpD,MAAM;IAAEE,SAAS,GAAGf,UAAd;IAA0B,GAAGgB;EAA7B,IAA6C,OAAOb,UAAP,KAAsB,QAAtB,GAAiCA,UAAjC,GAA8C,EAAjG;EAEA,OAAOL,CAAC,CACNiB,SADM,EAENhB,UAAU,CAAC,OAAOI,UAAP,KAAsB,QAAtB,GAAiC;IAAEc,IAAI,EAAEd;EAAR,CAAjC,GAAwDa,WAAzD,EAA6EF,IAA7E,CAFJ,EAGND,KAHM,CAAR;AAKD,CAZM"}
@@ -2,7 +2,7 @@
2
2
  import { useForm } from "./form.mjs";
3
3
  import { useProxiedModel } from "./proxiedModel.mjs"; // Utilities
4
4
 
5
- import { computed, onBeforeMount, onBeforeUnmount, ref, watch } from 'vue';
5
+ import { computed, onBeforeMount, onBeforeUnmount, ref, unref, watch } from 'vue';
6
6
  import { getCurrentInstanceName, getUid, propsFactory, wrapInArray } from "../util/index.mjs"; // Types
7
7
 
8
8
  export const makeValidationProps = propsFactory({
@@ -22,15 +22,22 @@ export const makeValidationProps = propsFactory({
22
22
  type: Array,
23
23
  default: () => []
24
24
  },
25
- modelValue: null
25
+ modelValue: null,
26
+ validationValue: null
26
27
  });
27
28
  export function useValidation(props) {
28
29
  let name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : getCurrentInstanceName();
30
+ let id = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : getUid();
29
31
  const model = useProxiedModel(props, 'modelValue');
32
+ const validationModel = computed(() => {
33
+ var _props$validationValu;
34
+
35
+ return (_props$validationValu = props.validationValue) != null ? _props$validationValu : model.value;
36
+ });
30
37
  const form = useForm();
31
38
  const internalErrorMessages = ref([]);
32
39
  const isPristine = ref(true);
33
- const isDirty = computed(() => wrapInArray(model.value === '' ? null : model.value).length > 0);
40
+ const isDirty = computed(() => !!(wrapInArray(model.value === '' ? null : model.value).length || wrapInArray(validationModel.value === '' ? null : validationModel.value).length));
34
41
  const isDisabled = computed(() => !!(props.disabled || form != null && form.isDisabled.value));
35
42
  const isReadonly = computed(() => !!(props.readonly || form != null && form.isReadonly.value));
36
43
  const errorMessages = computed(() => {
@@ -38,6 +45,7 @@ export function useValidation(props) {
38
45
  });
39
46
  const isValid = computed(() => {
40
47
  if (props.error || errorMessages.value.length) return false;
48
+ if (!props.rules.length) return true;
41
49
  return isPristine.value ? null : true;
42
50
  });
43
51
  const isValidating = ref(false);
@@ -52,7 +60,7 @@ export function useValidation(props) {
52
60
  const uid = computed(() => {
53
61
  var _props$name;
54
62
 
55
- return (_props$name = props.name) != null ? _props$name : getUid();
63
+ return (_props$name = props.name) != null ? _props$name : unref(id);
56
64
  });
57
65
  onBeforeMount(() => {
58
66
  form == null ? void 0 : form.register(uid.value, validate, reset, resetValidation, isValid);
@@ -60,8 +68,8 @@ export function useValidation(props) {
60
68
  onBeforeUnmount(() => {
61
69
  form == null ? void 0 : form.unregister(uid.value);
62
70
  });
63
- watch(model, () => {
64
- if (model.value != null) validate();
71
+ watch(validationModel, () => {
72
+ if (validationModel.value != null) validate();
65
73
  });
66
74
 
67
75
  function reset() {
@@ -84,7 +92,7 @@ export function useValidation(props) {
84
92
  }
85
93
 
86
94
  const handler = typeof rule === 'function' ? rule : () => rule;
87
- const result = await handler(model.value);
95
+ const result = await handler(validationModel.value);
88
96
  if (result === true) continue;
89
97
 
90
98
  if (typeof result !== 'string') {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/composables/validation.ts"],"names":["useForm","useProxiedModel","computed","onBeforeMount","onBeforeUnmount","ref","watch","getCurrentInstanceName","getUid","propsFactory","wrapInArray","makeValidationProps","disabled","Boolean","error","errorMessages","type","Array","String","default","maxErrors","Number","name","readonly","rules","modelValue","useValidation","props","model","form","internalErrorMessages","isPristine","isDirty","value","length","isDisabled","isReadonly","isValid","isValidating","validationClasses","uid","register","validate","reset","resetValidation","unregister","results","rule","handler","result","console","warn","push"],"mappings":"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","sourcesContent":["// Composables\nimport { useForm } from '@/composables/form'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, onBeforeMount, onBeforeUnmount, ref, watch } from 'vue'\nimport { getCurrentInstanceName, getUid, propsFactory, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport type ValidationResult = string | true\nexport type ValidationRule =\n | ValidationResult\n | PromiseLike<ValidationResult>\n | ((value: any) => ValidationResult)\n | ((value: any) => PromiseLike<ValidationResult>)\n\nexport interface ValidationProps {\n disabled: boolean\n error: boolean\n errorMessages: string | string[]\n maxErrors: string | number\n name: string | undefined\n readonly: boolean\n rules: ValidationRule[]\n modelValue: any\n 'onUpdate:modelValue': ((val: any) => void) | undefined\n}\n\nexport const makeValidationProps = propsFactory({\n disabled: Boolean,\n error: Boolean,\n errorMessages: {\n type: [Array, String] as PropType<string | string[]>,\n default: () => ([]),\n },\n maxErrors: {\n type: [Number, String],\n default: 1,\n },\n name: String,\n readonly: Boolean,\n rules: {\n type: Array as PropType<ValidationRule[]>,\n default: () => ([]),\n },\n modelValue: null,\n})\n\nexport function useValidation (\n props: ValidationProps,\n name = getCurrentInstanceName(),\n) {\n const model = useProxiedModel(props, 'modelValue')\n const form = useForm()\n const internalErrorMessages = ref<string[]>([])\n const isPristine = ref(true)\n const isDirty = computed(() => wrapInArray(model.value === '' ? null : model.value).length > 0)\n const isDisabled = computed(() => !!(props.disabled || form?.isDisabled.value))\n const isReadonly = computed(() => !!(props.readonly || form?.isReadonly.value))\n const errorMessages = computed(() => {\n return props.errorMessages.length\n ? wrapInArray(props.errorMessages)\n : internalErrorMessages.value\n })\n const isValid = computed(() => {\n if (props.error || errorMessages.value.length) return false\n\n return isPristine.value ? null : true\n })\n const isValidating = ref(false)\n const validationClasses = computed(() => {\n return {\n [`${name}--error`]: isValid.value === false,\n [`${name}--dirty`]: isDirty.value,\n [`${name}--disabled`]: isDisabled.value,\n [`${name}--readonly`]: isReadonly.value,\n }\n })\n\n const uid = computed(() => props.name ?? getUid())\n\n onBeforeMount(() => {\n form?.register(uid.value, validate, reset, resetValidation, isValid)\n })\n\n onBeforeUnmount(() => {\n form?.unregister(uid.value)\n })\n\n watch(model, () => {\n if (model.value != null) validate()\n })\n\n function reset () {\n resetValidation()\n model.value = null\n }\n\n function resetValidation () {\n isPristine.value = true\n internalErrorMessages.value = []\n }\n\n async function validate () {\n const results = []\n\n isValidating.value = true\n\n for (const rule of props.rules) {\n if (results.length >= (props.maxErrors || 1)) {\n break\n }\n\n const handler = typeof rule === 'function' ? rule : () => rule\n const result = await handler(model.value)\n\n if (result === true) continue\n\n if (typeof result !== 'string') {\n // eslint-disable-next-line no-console\n console.warn(`${result} is not a valid value. Rule functions must return boolean true or a string.`)\n\n continue\n }\n\n results.push(result)\n }\n\n internalErrorMessages.value = results\n isValidating.value = false\n isPristine.value = false\n\n return internalErrorMessages.value\n }\n\n return {\n errorMessages,\n isDirty,\n isDisabled,\n isReadonly,\n isPristine,\n isValid,\n isValidating,\n reset,\n resetValidation,\n validate,\n validationClasses,\n }\n}\n"],"file":"validation.mjs"}
1
+ {"version":3,"file":"validation.mjs","names":["useForm","useProxiedModel","computed","onBeforeMount","onBeforeUnmount","ref","unref","watch","getCurrentInstanceName","getUid","propsFactory","wrapInArray","makeValidationProps","disabled","Boolean","error","errorMessages","type","Array","String","default","maxErrors","Number","name","readonly","rules","modelValue","validationValue","useValidation","props","id","model","validationModel","value","form","internalErrorMessages","isPristine","isDirty","length","isDisabled","isReadonly","isValid","isValidating","validationClasses","uid","register","validate","reset","resetValidation","unregister","results","rule","handler","result","console","warn","push"],"sources":["../../src/composables/validation.ts"],"sourcesContent":["// Composables\nimport { useForm } from '@/composables/form'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, onBeforeMount, onBeforeUnmount, ref, unref, watch } from 'vue'\nimport type { MaybeRef } from '@/util'\nimport { getCurrentInstanceName, getUid, propsFactory, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport type ValidationResult = string | true\nexport type ValidationRule =\n | ValidationResult\n | PromiseLike<ValidationResult>\n | ((value: any) => ValidationResult)\n | ((value: any) => PromiseLike<ValidationResult>)\n\nexport interface ValidationProps {\n disabled: boolean\n error: boolean\n errorMessages: string | string[]\n maxErrors: string | number\n name: string | undefined\n readonly: boolean\n rules: ValidationRule[]\n modelValue: any\n 'onUpdate:modelValue': ((val: any) => void) | undefined\n validationValue: any\n}\n\nexport const makeValidationProps = propsFactory({\n disabled: Boolean,\n error: Boolean,\n errorMessages: {\n type: [Array, String] as PropType<string | string[]>,\n default: () => ([]),\n },\n maxErrors: {\n type: [Number, String],\n default: 1,\n },\n name: String,\n readonly: Boolean,\n rules: {\n type: Array as PropType<ValidationRule[]>,\n default: () => ([]),\n },\n modelValue: null,\n validationValue: null,\n})\n\nexport function useValidation (\n props: ValidationProps,\n name = getCurrentInstanceName(),\n id: MaybeRef<string | number> = getUid(),\n) {\n const model = useProxiedModel(props, 'modelValue')\n const validationModel = computed(() => props.validationValue ?? model.value)\n const form = useForm()\n const internalErrorMessages = ref<string[]>([])\n const isPristine = ref(true)\n const isDirty = computed(() => !!(\n wrapInArray(model.value === '' ? null : model.value).length ||\n wrapInArray(validationModel.value === '' ? null : validationModel.value).length\n ))\n const isDisabled = computed(() => !!(props.disabled || form?.isDisabled.value))\n const isReadonly = computed(() => !!(props.readonly || form?.isReadonly.value))\n const errorMessages = computed(() => {\n return props.errorMessages.length\n ? wrapInArray(props.errorMessages)\n : internalErrorMessages.value\n })\n const isValid = computed(() => {\n if (props.error || errorMessages.value.length) return false\n if (!props.rules.length) return true\n\n return isPristine.value ? null : true\n })\n const isValidating = ref(false)\n const validationClasses = computed(() => {\n return {\n [`${name}--error`]: isValid.value === false,\n [`${name}--dirty`]: isDirty.value,\n [`${name}--disabled`]: isDisabled.value,\n [`${name}--readonly`]: isReadonly.value,\n }\n })\n\n const uid = computed(() => props.name ?? unref(id))\n\n onBeforeMount(() => {\n form?.register(uid.value, validate, reset, resetValidation, isValid)\n })\n\n onBeforeUnmount(() => {\n form?.unregister(uid.value)\n })\n\n watch(validationModel, () => {\n if (validationModel.value != null) validate()\n })\n\n function reset () {\n resetValidation()\n model.value = null\n }\n\n function resetValidation () {\n isPristine.value = true\n internalErrorMessages.value = []\n }\n\n async function validate () {\n const results = []\n\n isValidating.value = true\n\n for (const rule of props.rules) {\n if (results.length >= (props.maxErrors || 1)) {\n break\n }\n\n const handler = typeof rule === 'function' ? rule : () => rule\n const result = await handler(validationModel.value)\n\n if (result === true) continue\n\n if (typeof result !== 'string') {\n // eslint-disable-next-line no-console\n console.warn(`${result} is not a valid value. Rule functions must return boolean true or a string.`)\n\n continue\n }\n\n results.push(result)\n }\n\n internalErrorMessages.value = results\n isValidating.value = false\n isPristine.value = false\n\n return internalErrorMessages.value\n }\n\n return {\n errorMessages,\n isDirty,\n isDisabled,\n isReadonly,\n isPristine,\n isValid,\n isValidating,\n reset,\n resetValidation,\n validate,\n validationClasses,\n }\n}\n"],"mappings":"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"}
@@ -5,11 +5,13 @@ import { useColor } from "./color.mjs"; // Utilities
5
5
  import { computed, unref } from 'vue';
6
6
  import { getCurrentInstanceName, propsFactory } from "../util/index.mjs"; // Types
7
7
 
8
- export const allowedVariants = ['outlined', 'plain', 'text', 'contained', 'contained-flat', 'contained-text'];
8
+ export const allowedVariants = ['elevated', 'flat', 'tonal', 'outlined', 'text', 'plain'];
9
9
  export function genOverlays(isClickable, name) {
10
10
  return _createVNode(_Fragment, null, [isClickable && _createVNode("div", {
11
+ "key": "overlay",
11
12
  "class": `${name}__overlay`
12
13
  }, null), _createVNode("div", {
14
+ "key": "underlay",
13
15
  "class": `${name}__underlay`
14
16
  }, null)]);
15
17
  }
@@ -17,7 +19,7 @@ export const makeVariantProps = propsFactory({
17
19
  color: String,
18
20
  variant: {
19
21
  type: String,
20
- default: 'contained',
22
+ default: 'elevated',
21
23
  validator: v => allowedVariants.includes(v)
22
24
  }
23
25
  }, 'variant');
@@ -38,7 +40,7 @@ export function useVariant(props) {
38
40
  color
39
41
  } = unref(props);
40
42
  return {
41
- [['contained', 'contained-flat'].includes(variant) ? 'background' : 'text']: color
43
+ [['elevated', 'flat'].includes(variant) ? 'background' : 'text']: color
42
44
  };
43
45
  }));
44
46
  return {