@vuetify/nightly 3.0.0-beta.6 → 3.0.0-beta.9

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 (174) hide show
  1. package/CHANGELOG.md +14 -39
  2. package/dist/json/attributes.json +98 -14
  3. package/dist/json/importMap.json +64 -64
  4. package/dist/json/tags.json +23 -2
  5. package/dist/json/web-types.json +253 -40
  6. package/dist/vuetify.css +1469 -1640
  7. package/dist/vuetify.d.ts +1701 -7588
  8. package/dist/vuetify.esm.js +694 -443
  9. package/dist/vuetify.esm.js.map +1 -1
  10. package/dist/vuetify.js +693 -441
  11. package/dist/vuetify.js.map +1 -1
  12. package/dist/vuetify.min.css +3 -3
  13. package/dist/vuetify.min.js +766 -742
  14. package/dist/vuetify.min.js.map +1 -1
  15. package/lib/components/VAlert/VAlert.css +0 -3
  16. package/lib/components/VAlert/VAlert.mjs +20 -10
  17. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  18. package/lib/components/VAlert/VAlert.sass +0 -3
  19. package/lib/components/VAutocomplete/VAutocomplete.css +10 -0
  20. package/lib/components/VAutocomplete/VAutocomplete.mjs +2 -3
  21. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  22. package/lib/components/VAutocomplete/VAutocomplete.sass +10 -0
  23. package/lib/components/VAutocomplete/_variables.scss +1 -0
  24. package/lib/components/VAvatar/VAvatar.css +2 -0
  25. package/lib/components/VAvatar/VAvatar.sass +3 -0
  26. package/lib/components/VBtn/VBtn.css +29 -5
  27. package/lib/components/VBtn/VBtn.sass +40 -10
  28. package/lib/components/VBtn/_variables.scss +4 -0
  29. package/lib/components/VBtnGroup/VBtnGroup.css +1 -0
  30. package/lib/components/VCard/VCard.mjs +12 -7
  31. package/lib/components/VCard/VCard.mjs.map +1 -1
  32. package/lib/components/VCombobox/VCombobox.css +10 -0
  33. package/lib/components/VCombobox/VCombobox.mjs +2 -2
  34. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  35. package/lib/components/VCombobox/VCombobox.sass +10 -0
  36. package/lib/components/VCombobox/_variables.scss +1 -0
  37. package/lib/components/VDialog/VDialog.mjs +3 -3
  38. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  39. package/lib/components/VField/VField.css +44 -25
  40. package/lib/components/VField/VField.mjs +1 -1
  41. package/lib/components/VField/VField.mjs.map +1 -1
  42. package/lib/components/VField/VField.sass +33 -19
  43. package/lib/components/VField/_variables.scss +3 -2
  44. package/lib/components/VFileInput/VFileInput.mjs +2 -2
  45. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  46. package/lib/components/VForm/VForm.mjs +2 -2
  47. package/lib/components/VForm/VForm.mjs.map +1 -1
  48. package/lib/components/VGrid/VCol.mjs +2 -1
  49. package/lib/components/VGrid/VCol.mjs.map +1 -1
  50. package/lib/components/VGrid/VRow.mjs +8 -3
  51. package/lib/components/VGrid/VRow.mjs.map +1 -1
  52. package/lib/components/VIcon/VIcon.css +0 -10
  53. package/lib/components/VIcon/VIcon.sass +0 -10
  54. package/lib/components/VIcon/_variables.scss +0 -1
  55. package/lib/components/VImg/VImg.mjs +1 -0
  56. package/lib/components/VImg/VImg.mjs.map +1 -1
  57. package/lib/components/VInput/VInput.css +2 -1
  58. package/lib/components/VInput/VInput.sass +2 -1
  59. package/lib/components/VInput/_variables.scss +0 -1
  60. package/lib/components/VLayout/VLayout.css +0 -2
  61. package/lib/components/VLayout/VLayout.sass +0 -2
  62. package/lib/components/VList/VList.css +4 -1
  63. package/lib/components/VList/VList.sass +5 -1
  64. package/lib/components/VList/VListChildren.mjs +19 -2
  65. package/lib/components/VList/VListChildren.mjs.map +1 -1
  66. package/lib/components/VList/VListItem.mjs +18 -11
  67. package/lib/components/VList/VListItem.mjs.map +1 -1
  68. package/lib/components/VList/_variables.scss +1 -0
  69. package/lib/components/VMain/VMain.css +21 -3
  70. package/lib/components/VMain/VMain.mjs +13 -8
  71. package/lib/components/VMain/VMain.mjs.map +1 -1
  72. package/lib/components/VMain/VMain.sass +18 -3
  73. package/lib/components/VMenu/VMenu.mjs +2 -2
  74. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  75. package/lib/components/VNavigationDrawer/VNavigationDrawer.css +12 -17
  76. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +52 -19
  77. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  78. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +15 -20
  79. package/lib/components/VNavigationDrawer/_variables.scss +1 -1
  80. package/lib/components/VNavigationDrawer/sticky.mjs +72 -0
  81. package/lib/components/VNavigationDrawer/sticky.mjs.map +1 -0
  82. package/lib/components/VOverlay/VOverlay.mjs +8 -6
  83. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  84. package/lib/components/VOverlay/_variables.scss +1 -1
  85. package/lib/components/VOverlay/useActivator.mjs +1 -1
  86. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  87. package/lib/components/VPagination/VPagination.mjs +1 -1
  88. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  89. package/lib/components/VRadio/VRadio.mjs +8 -17
  90. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  91. package/lib/components/VRadioGroup/VRadioGroup.mjs +20 -3
  92. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  93. package/lib/components/VSelect/VSelect.css +10 -0
  94. package/lib/components/VSelect/VSelect.mjs +3 -4
  95. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  96. package/lib/components/VSelect/VSelect.sass +10 -0
  97. package/lib/components/VSelect/_variables.scss +1 -0
  98. package/lib/components/VSelectionControl/VSelectionControl.mjs +9 -4
  99. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  100. package/lib/components/VSnackbar/VSnackbar.css +1 -1
  101. package/lib/components/VSnackbar/VSnackbar.mjs +4 -4
  102. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  103. package/lib/components/VSnackbar/_variables.scss +1 -3
  104. package/lib/components/VTable/VTable.mjs.map +1 -1
  105. package/lib/components/VTabs/VTab.css +0 -1
  106. package/lib/components/VTabs/VTab.sass +0 -1
  107. package/lib/components/VTextField/VTextField.css +2 -1
  108. package/lib/components/VTextField/VTextField.mjs +19 -21
  109. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  110. package/lib/components/VTextField/VTextField.sass +2 -1
  111. package/lib/components/VTextarea/VTextarea.css +6 -2
  112. package/lib/components/VTextarea/VTextarea.mjs +18 -11
  113. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  114. package/lib/components/VTextarea/VTextarea.sass +9 -2
  115. package/lib/components/VTextarea/_variables.scss +0 -1
  116. package/lib/components/VTimeline/VTimeline.css +123 -112
  117. package/lib/components/VTimeline/VTimeline.mjs +4 -4
  118. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  119. package/lib/components/VTimeline/VTimeline.sass +129 -111
  120. package/lib/components/VTimeline/VTimelineDivider.mjs +5 -2
  121. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  122. package/lib/components/VTimeline/VTimelineItem.mjs +3 -1
  123. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  124. package/lib/components/VToolbar/VToolbar.css +9 -33
  125. package/lib/components/VToolbar/VToolbar.mjs +3 -4
  126. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  127. package/lib/components/VToolbar/VToolbar.sass +5 -15
  128. package/lib/components/VToolbar/_variables.scss +3 -7
  129. package/lib/components/VTooltip/VTooltip.mjs +2 -2
  130. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  131. package/lib/components/index.d.ts +1696 -7583
  132. package/lib/composables/color.mjs +19 -26
  133. package/lib/composables/color.mjs.map +1 -1
  134. package/lib/composables/defaults.mjs +1 -1
  135. package/lib/composables/defaults.mjs.map +1 -1
  136. package/lib/composables/form.mjs +29 -9
  137. package/lib/composables/form.mjs.map +1 -1
  138. package/lib/composables/{forwardRef.mjs → forwardRefs.mjs} +29 -3
  139. package/lib/composables/forwardRefs.mjs.map +1 -0
  140. package/lib/composables/index.mjs +3 -2
  141. package/lib/composables/index.mjs.map +1 -1
  142. package/lib/composables/layout.mjs +12 -12
  143. package/lib/composables/layout.mjs.map +1 -1
  144. package/lib/composables/rtl.mjs +2 -2
  145. package/lib/composables/rtl.mjs.map +1 -1
  146. package/lib/composables/size.mjs +18 -14
  147. package/lib/composables/size.mjs.map +1 -1
  148. package/lib/composables/stack.mjs +22 -12
  149. package/lib/composables/stack.mjs.map +1 -1
  150. package/lib/composables/theme.mjs +9 -6
  151. package/lib/composables/theme.mjs.map +1 -1
  152. package/lib/composables/validation.mjs +13 -3
  153. package/lib/composables/validation.mjs.map +1 -1
  154. package/lib/entry-bundler.mjs +1 -1
  155. package/lib/index.d.ts +21 -21
  156. package/lib/styles/generic/_colors.scss +17 -9
  157. package/lib/styles/main.css +1135 -1371
  158. package/lib/styles/settings/_utilities.scss +16 -5
  159. package/lib/styles/utilities/_index.sass +0 -1
  160. package/lib/util/anchor.mjs +1 -3
  161. package/lib/util/anchor.mjs.map +1 -1
  162. package/lib/util/colorUtils.mjs +2 -2
  163. package/lib/util/colorUtils.mjs.map +1 -1
  164. package/lib/util/colors.mjs +1 -1
  165. package/lib/util/colors.mjs.map +1 -1
  166. package/lib/util/defineComponent.mjs +6 -3
  167. package/lib/util/defineComponent.mjs.map +1 -1
  168. package/lib/util/helpers.mjs +4 -1
  169. package/lib/util/helpers.mjs.map +1 -1
  170. package/lib/util/injectSelf.mjs +12 -0
  171. package/lib/util/injectSelf.mjs.map +1 -0
  172. package/package.json +3 -1
  173. package/lib/composables/forwardRef.mjs.map +0 -1
  174. package/lib/styles/utilities/_text.sass +0 -9
@@ -1 +1 @@
1
- {"version":3,"file":"VCard.mjs","names":["VCardActions","VCardItem","VCardText","VDefaultsProvider","VImg","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","LoaderSlot","makeLoaderProps","useLoader","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeTagProps","makeThemeProps","provideTheme","defineComponent","useRender","VCard","name","directives","props","appendAvatar","String","appendIcon","disabled","Boolean","flat","hover","image","link","prependAvatar","prependIcon","ripple","subtitle","text","title","variant","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","Tag","isLink","value","tag","hasTitle","hasSubtitle","hasHeader","hasAppend","append","hasPrepend","prepend","hasImage","hasCardItem","hasText","isClickable","href","navigate","cover","src","loading","undefined","default","loader","item","actions"],"sources":["../../../src/components/VCard/VCard.tsx"],"sourcesContent":["/* eslint-disable complexity */\n\n// Styles\nimport './VCard.sass'\n\n// Components\nimport { VCardActions } from './VCardActions'\nimport { VCardItem } from './VCardItem'\nimport { VCardText } from './VCardText'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VImg } from '@/components/VImg'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { LoaderSlot, makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { defineComponent, useRender } from '@/util'\n\nexport const VCard = defineComponent({\n name: 'VCard',\n\n directives: { Ripple },\n\n props: {\n appendAvatar: String,\n appendIcon: IconValue,\n disabled: Boolean,\n flat: Boolean,\n hover: Boolean,\n image: String,\n link: Boolean,\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: Boolean,\n subtitle: String,\n text: String,\n title: String,\n\n ...makeThemeProps(),\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeTagProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const link = useLink(props, attrs)\n\n useRender(() => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasTitle = !!(slots.title || props.title)\n const hasSubtitle = !!(slots.subtitle || props.subtitle)\n const hasHeader = hasTitle || hasSubtitle\n const hasAppend = !!(slots.append || props.appendAvatar || props.appendIcon)\n const hasPrepend = !!(slots.prepend || props.prependAvatar || props.prependIcon)\n const hasImage = !!(slots.image || props.image)\n const hasCardItem = hasHeader || hasPrepend || hasAppend\n const hasText = !!(slots.text || props.text)\n const isClickable = !props.disabled && (link.isClickable.value || props.link)\n\n return (\n <Tag\n class={[\n 'v-card',\n {\n 'v-card--disabled': props.disabled,\n 'v-card--flat': props.flat,\n 'v-card--hover': props.hover && !(props.disabled || props.flat),\n 'v-card--link': isClickable,\n },\n themeClasses.value,\n borderClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n href={ link.href.value }\n onClick={ isClickable && link.navigate }\n v-ripple={ isClickable }\n >\n { hasImage && (\n <VDefaultsProvider\n key=\"image\"\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n >\n <div class=\"v-card__image\">\n { slots.image?.() ?? <VImg /> }\n </div>\n </VDefaultsProvider>\n ) }\n\n <LoaderSlot\n name=\"v-card\"\n active={ !!props.loading }\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n v-slots={{ default: slots.loader }}\n />\n\n { hasCardItem && (\n <VCardItem\n key=\"item\"\n prependAvatar={ props.prependAvatar }\n prependIcon={ props.prependIcon }\n title={ props.title }\n subtitle={ props.subtitle }\n appendAvatar={ props.appendAvatar }\n appendIcon={ props.appendIcon }\n >\n {{\n default: slots.item,\n prepend: slots.prepend,\n title: slots.title,\n subtitle: slots.subtitle,\n append: slots.append,\n }}\n </VCardItem>\n ) }\n\n { hasText && (\n <VCardText key=\"text\">\n { slots.text?.() ?? props.text }\n </VCardText>\n ) }\n\n { slots.default?.() }\n\n { slots.actions && (\n <VCardActions v-slots={{ default: slots.actions }} />\n ) }\n\n { genOverlays(isClickable, 'v-card') }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VCard = InstanceType<typeof VCard>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VCard.mjs","names":["VCardActions","VCardItem","VCardText","VDefaultsProvider","VImg","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","LoaderSlot","makeLoaderProps","useLoader","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeTagProps","makeThemeProps","provideTheme","defineComponent","useRender","computed","VCard","name","directives","props","appendAvatar","String","appendIcon","disabled","Boolean","flat","hover","image","link","type","default","undefined","prependAvatar","prependIcon","ripple","subtitle","text","title","variant","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","isLink","value","isClickable","Tag","tag","hasTitle","hasSubtitle","hasHeader","hasAppend","append","hasPrepend","prepend","hasImage","hasCardItem","hasText","href","navigate","cover","src","loading","loader","item","actions"],"sources":["../../../src/components/VCard/VCard.tsx"],"sourcesContent":["/* eslint-disable complexity */\n\n// Styles\nimport './VCard.sass'\n\n// Components\nimport { VCardActions } from './VCardActions'\nimport { VCardItem } from './VCardItem'\nimport { VCardText } from './VCardText'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VImg } from '@/components/VImg'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { LoaderSlot, makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { defineComponent, useRender } from '@/util'\nimport { computed } from 'vue'\n\nexport const VCard = defineComponent({\n name: 'VCard',\n\n directives: { Ripple },\n\n props: {\n appendAvatar: String,\n appendIcon: IconValue,\n disabled: Boolean,\n flat: Boolean,\n hover: Boolean,\n image: String,\n link: {\n type: Boolean,\n default: undefined,\n },\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: Boolean,\n subtitle: String,\n text: String,\n title: String,\n\n ...makeThemeProps(),\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeTagProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const link = useLink(props, attrs)\n\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (props.link || link.isClickable.value)\n )\n\n useRender(() => {\n const Tag = isLink.value ? 'a' : props.tag\n const hasTitle = !!(slots.title || props.title)\n const hasSubtitle = !!(slots.subtitle || props.subtitle)\n const hasHeader = hasTitle || hasSubtitle\n const hasAppend = !!(slots.append || props.appendAvatar || props.appendIcon)\n const hasPrepend = !!(slots.prepend || props.prependAvatar || props.prependIcon)\n const hasImage = !!(slots.image || props.image)\n const hasCardItem = hasHeader || hasPrepend || hasAppend\n const hasText = !!(slots.text || props.text)\n\n return (\n <Tag\n class={[\n 'v-card',\n {\n 'v-card--disabled': props.disabled,\n 'v-card--flat': props.flat,\n 'v-card--hover': props.hover && !(props.disabled || props.flat),\n 'v-card--link': isClickable.value,\n },\n themeClasses.value,\n borderClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n href={ link.href.value }\n onClick={ isClickable.value && link.navigate }\n v-ripple={ isClickable.value }\n >\n { hasImage && (\n <VDefaultsProvider\n key=\"image\"\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n >\n <div class=\"v-card__image\">\n { slots.image?.() ?? <VImg /> }\n </div>\n </VDefaultsProvider>\n ) }\n\n <LoaderSlot\n name=\"v-card\"\n active={ !!props.loading }\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n v-slots={{ default: slots.loader }}\n />\n\n { hasCardItem && (\n <VCardItem\n key=\"item\"\n prependAvatar={ props.prependAvatar }\n prependIcon={ props.prependIcon }\n title={ props.title }\n subtitle={ props.subtitle }\n appendAvatar={ props.appendAvatar }\n appendIcon={ props.appendIcon }\n >\n {{\n default: slots.item,\n prepend: slots.prepend,\n title: slots.title,\n subtitle: slots.subtitle,\n append: slots.append,\n }}\n </VCardItem>\n ) }\n\n { hasText && (\n <VCardText key=\"text\">\n { slots.text?.() ?? props.text }\n </VCardText>\n ) }\n\n { slots.default?.() }\n\n { slots.actions && (\n <VCardActions v-slots={{ default: slots.actions }} />\n ) }\n\n { genOverlays(isClickable.value, 'v-card') }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VCard = InstanceType<typeof VCard>\n"],"mappings":";;AAAA;AAEA;AACA,qB,CAEA;;SACSA,Y;SACAC,S;SACAC,S;SACAC,iB;SACAC,I,6BAET;;SACSC,M,6CAET;;SACSC,W,EAAaC,gB,EAAkBC,U;SAC/BC,S;SACAC,U,EAAYC,e,EAAiBC,S;SAC7BC,e,EAAiBC,S;SACjBC,gB,EAAkBC,U;SAClBC,kB,EAAoBC,Y;SACpBC,kB,EAAoBC,Y;SACpBC,iB,EAAmBC,W;SACnBC,iB,EAAmBC,W;SACnBC,gB,EAAkBC,U;SAClBC,e,EAAiBC,O;SACjBC,Y;SACAC,c,EAAgBC,Y,uCAEzB;;SACSC,e,EAAiBC,S;AAC1B,SAASC,QAAT,QAAyB,KAAzB;AAEA,OAAO,MAAMC,KAAK,GAAGH,eAAe,CAAC;EACnCI,IAAI,EAAE,OAD6B;EAGnCC,UAAU,EAAE;IAAEhC;EAAF,CAHuB;EAKnCiC,KAAK,EAAE;IACLC,YAAY,EAAEC,MADT;IAELC,UAAU,EAAEhC,SAFP;IAGLiC,QAAQ,EAAEC,OAHL;IAILC,IAAI,EAAED,OAJD;IAKLE,KAAK,EAAEF,OALF;IAMLG,KAAK,EAAEN,MANF;IAOLO,IAAI,EAAE;MACJC,IAAI,EAAEL,OADF;MAEJM,OAAO,EAAEC;IAFL,CAPD;IAWLC,aAAa,EAAEX,MAXV;IAYLY,WAAW,EAAE3C,SAZR;IAaL4C,MAAM,EAAEV,OAbH;IAcLW,QAAQ,EAAEd,MAdL;IAeLe,IAAI,EAAEf,MAfD;IAgBLgB,KAAK,EAAEhB,MAhBF;IAkBL,GAAGV,cAAc,EAlBZ;IAmBL,GAAGjB,eAAe,EAnBb;IAoBL,GAAGE,gBAAgB,EApBd;IAqBL,GAAGE,kBAAkB,EArBhB;IAsBL,GAAGE,kBAAkB,EAtBhB;IAuBL,GAAGR,eAAe,EAvBb;IAwBL,GAAGU,iBAAiB,EAxBf;IAyBL,GAAGE,iBAAiB,EAzBf;IA0BL,GAAGE,gBAAgB,EA1Bd;IA2BL,GAAGE,eAAe,EA3Bb;IA4BL,GAAGE,YAAY,EA5BV;IA6BL,GAAGtB,gBAAgB,CAAC;MAAEkD,OAAO,EAAE;IAAX,CAAD;EA7Bd,CAL4B;;EAqCnCC,KAAK,CAAEpB,KAAF,QAA2B;IAAA,IAAlB;MAAEqB,KAAF;MAASC;IAAT,CAAkB;IAC9B,MAAM;MAAEC;IAAF,IAAmB9B,YAAY,CAACO,KAAD,CAArC;IACA,MAAM;MAAEwB;IAAF,IAAoBhD,SAAS,CAACwB,KAAD,CAAnC;IACA,MAAM;MAAEyB,YAAF;MAAgBC,WAAhB;MAA6BC;IAA7B,IAAgDzD,UAAU,CAAC8B,KAAD,CAAhE;IACA,MAAM;MAAE4B;IAAF,IAAqBlD,UAAU,CAACsB,KAAD,CAArC;IACA,MAAM;MAAE6B;IAAF,IAAsBjD,YAAY,CAACoB,KAAD,CAAxC;IACA,MAAM;MAAE8B;IAAF,IAAuBhD,YAAY,CAACkB,KAAD,CAAzC;IACA,MAAM;MAAE+B;IAAF,IAAoBzD,SAAS,CAAC0B,KAAD,CAAnC;IACA,MAAM;MAAEgC;IAAF,IAAqBhD,WAAW,CAACgB,KAAD,CAAtC;IACA,MAAM;MAAEiC;IAAF,IAAsB/C,WAAW,CAACc,KAAD,CAAvC;IACA,MAAM;MAAEkC;IAAF,IAAqB9C,UAAU,CAACY,KAAD,CAArC;IACA,MAAMS,IAAI,GAAGnB,OAAO,CAACU,KAAD,EAAQqB,KAAR,CAApB;IAEA,MAAMc,MAAM,GAAGvC,QAAQ,CAAC,MAAMI,KAAK,CAACS,IAAN,KAAe,KAAf,IAAwBA,IAAI,CAAC0B,MAAL,CAAYC,KAA3C,CAAvB;IACA,MAAMC,WAAW,GAAGzC,QAAQ,CAAC,MAC3B,CAACI,KAAK,CAACI,QAAP,IACAJ,KAAK,CAACS,IAAN,KAAe,KADf,KAECT,KAAK,CAACS,IAAN,IAAcA,IAAI,CAAC4B,WAAL,CAAiBD,KAFhC,CAD0B,CAA5B;IAMAzC,SAAS,CAAC,MAAM;MAAA;;MACd,MAAM2C,GAAG,GAAGH,MAAM,CAACC,KAAP,GAAe,GAAf,GAAqBpC,KAAK,CAACuC,GAAvC;MACA,MAAMC,QAAQ,GAAG,CAAC,EAAElB,KAAK,CAACJ,KAAN,IAAelB,KAAK,CAACkB,KAAvB,CAAlB;MACA,MAAMuB,WAAW,GAAG,CAAC,EAAEnB,KAAK,CAACN,QAAN,IAAkBhB,KAAK,CAACgB,QAA1B,CAArB;MACA,MAAM0B,SAAS,GAAGF,QAAQ,IAAIC,WAA9B;MACA,MAAME,SAAS,GAAG,CAAC,EAAErB,KAAK,CAACsB,MAAN,IAAgB5C,KAAK,CAACC,YAAtB,IAAsCD,KAAK,CAACG,UAA9C,CAAnB;MACA,MAAM0C,UAAU,GAAG,CAAC,EAAEvB,KAAK,CAACwB,OAAN,IAAiB9C,KAAK,CAACa,aAAvB,IAAwCb,KAAK,CAACc,WAAhD,CAApB;MACA,MAAMiC,QAAQ,GAAG,CAAC,EAAEzB,KAAK,CAACd,KAAN,IAAeR,KAAK,CAACQ,KAAvB,CAAlB;MACA,MAAMwC,WAAW,GAAGN,SAAS,IAAIG,UAAb,IAA2BF,SAA/C;MACA,MAAMM,OAAO,GAAG,CAAC,EAAE3B,KAAK,CAACL,IAAN,IAAcjB,KAAK,CAACiB,IAAtB,CAAjB;MAEA;QAAA,SAEW,CACL,QADK,EAEL;UACE,oBAAoBjB,KAAK,CAACI,QAD5B;UAEE,gBAAgBJ,KAAK,CAACM,IAFxB;UAGE,iBAAiBN,KAAK,CAACO,KAAN,IAAe,EAAEP,KAAK,CAACI,QAAN,IAAkBJ,KAAK,CAACM,IAA1B,CAHlC;UAIE,gBAAgB+B,WAAW,CAACD;QAJ9B,CAFK,EAQLb,YAAY,CAACa,KARR,EASLZ,aAAa,CAACY,KATT,EAULX,YAAY,CAACW,KAVR,EAWLR,cAAc,CAACQ,KAXV,EAYLN,gBAAgB,CAACM,KAZZ,EAaLL,aAAa,CAACK,KAbT,EAcLH,eAAe,CAACG,KAdX,EAeLF,cAAc,CAACE,KAfV,EAgBLT,cAAc,CAACS,KAhBV,CAFX;QAAA,SAoBW,CACLV,WAAW,CAACU,KADP,EAELP,eAAe,CAACO,KAFX,EAGLJ,cAAc,CAACI,KAHV,CApBX;QAAA,QAyBW3B,IAAI,CAACyC,IAAL,CAAUd,KAzBrB;QAAA,WA0BcC,WAAW,CAACD,KAAZ,IAAqB3B,IAAI,CAAC0C;MA1BxC;QAAA,gBA6BMJ,QAAQ;UAAA,OAEF,OAFE;UAAA,YAGI;YACRjF,IAAI,EAAE;cACJsF,KAAK,EAAE,IADH;cAEJC,GAAG,EAAErD,KAAK,CAACQ;YAFP;UADE;QAHJ;UAAA;YAAA,SAUK;UAVL,qCAWFc,KAAK,CAACd,KAXJ,qBAWF,mBAAAc,KAAK,CAXH;QAAA,EA7Bd;UAAA,QA8CW,QA9CX;UAAA,UA+Ce,CAAC,CAACtB,KAAK,CAACsD,OA/CvB;UAAA,SAgDc,OAAOtD,KAAK,CAACsD,OAAb,KAAyB,SAAzB,GAAqC1C,SAArC,GAAiDZ,KAAK,CAACsD;QAhDrE,GAiDe;UAAE3C,OAAO,EAAEW,KAAK,CAACiC;QAAjB,CAjDf,GAoDMP,WAAW;UAAA,OAEL,MAFK;UAAA,iBAGOhD,KAAK,CAACa,aAHb;UAAA,eAIKb,KAAK,CAACc,WAJX;UAAA,SAKDd,KAAK,CAACkB,KALL;UAAA,YAMElB,KAAK,CAACgB,QANR;UAAA,gBAOMhB,KAAK,CAACC,YAPZ;UAAA,cAQID,KAAK,CAACG;QARV;UAWPQ,OAAO,EAAEW,KAAK,CAACkC,IAXR;UAYPV,OAAO,EAAExB,KAAK,CAACwB,OAZR;UAaP5B,KAAK,EAAEI,KAAK,CAACJ,KAbN;UAcPF,QAAQ,EAAEM,KAAK,CAACN,QAdT;UAeP4B,MAAM,EAAEtB,KAAK,CAACsB;QAfP,EApDjB,EAwEMK,OAAO;UAAA,OACQ;QADR;UAAA,+CAEH3B,KAAK,CAACL,IAFH,qBAEH,kBAAAK,KAAK,CAFF,0BAEetB,KAAK,CAACiB,IAFrB;QAAA,EAxEb,oBA8EMK,KAAK,CAACX,OA9EZ,qBA8EM,oBAAAW,KAAK,CA9EX,EAgFMA,KAAK,CAACmC,OAAN,qCACuB;UAAE9C,OAAO,EAAEW,KAAK,CAACmC;QAAjB,CADvB,CAhFN,EAoFMzF,WAAW,CAACqE,WAAW,CAACD,KAAb,EAAoB,QAApB,CApFjB;MAAA,mCA2BeC,WAAW,CAACD,KA3B3B;IAuFD,CAlGQ,CAAT;IAoGA,OAAO,EAAP;EACD;;AA9JkC,CAAD,CAA7B"}
@@ -17,6 +17,11 @@
17
17
  .v-combobox .v-field--dirty .v-combobox__selection {
18
18
  margin-inline-end: 2px;
19
19
  }
20
+ .v-combobox .v-field--single-line .v-combobox__selection-text {
21
+ overflow: hidden;
22
+ text-overflow: ellipsis;
23
+ white-space: nowrap;
24
+ }
20
25
 
21
26
  .v-combobox__content {
22
27
  overflow: hidden;
@@ -30,11 +35,15 @@
30
35
  display: inline-flex;
31
36
  letter-spacing: inherit;
32
37
  line-height: inherit;
38
+ max-width: 100%;
33
39
  }
34
40
  .v-combobox--active-menu .v-field__append-inner > .v-icon {
35
41
  opacity: var(--v-high-emphasis-opacity);
36
42
  transform: rotate(180deg);
37
43
  }
44
+ .v-combobox--chips .v-combobox__selection {
45
+ margin-top: 2px;
46
+ }
38
47
  .v-combobox--chips .v-combobox__selection:first-child {
39
48
  margin-inline-start: 0;
40
49
  }
@@ -52,6 +61,7 @@
52
61
  position: absolute;
53
62
  left: 0;
54
63
  right: 0;
64
+ width: 100%;
55
65
  padding-inline-start: inherit;
56
66
  padding-inline-end: inherit;
57
67
  }
@@ -13,7 +13,7 @@ import { VTextField } from "../VTextField/index.mjs"; // Composables
13
13
  import { makeFilterProps, useFilter } from "../../composables/filter.mjs";
14
14
  import { makeTransitionProps } from "../../composables/transition.mjs";
15
15
  import { transformItem, useItems } from "../../composables/items.mjs";
16
- import { useForwardRef } from "../../composables/forwardRef.mjs";
16
+ import { forwardRefs } from "../../composables/forwardRefs.mjs";
17
17
  import { useLocale } from "../../composables/locale.mjs";
18
18
  import { useProxiedModel } from "../../composables/proxiedModel.mjs";
19
19
  import { useTextColor } from "../../composables/color.mjs"; // Utility
@@ -370,7 +370,7 @@ export const VCombobox = genericComponent()({
370
370
  }
371
371
  });
372
372
  });
373
- return useForwardRef({
373
+ return forwardRefs({
374
374
  isFocused,
375
375
  isPristine,
376
376
  menu,
@@ -1 +1 @@
1
- {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForwardRef","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","find","item","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","noDataText","onClick","prepend","isSelected","hideSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots } from '@/util'\nimport type { PropType } from 'vue'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n item: [{ item: T, index: number, props: Record<string, unknown> }]\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n return _search.value\n },\n set: val => {\n _search.value = val\n if (!props.multiple) {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n key={ index }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","forwardRefs","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","find","item","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","noDataText","onClick","prepend","isSelected","hideSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots } from '@/util'\nimport type { PropType } from 'vue'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: Omit<VInputSlots & VFieldSlots, 'default'> & MakeSlots<{\n item: [{ item: T, index: number, props: Record<string, unknown> }]\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n return _search.value\n },\n set: val => {\n _search.value = val\n if (!props.multiple) {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n key={ index }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
@@ -31,6 +31,12 @@
31
31
  .v-combobox__selection
32
32
  margin-inline-end: 2px
33
33
 
34
+ .v-field--single-line
35
+ .v-combobox__selection-text
36
+ overflow: hidden
37
+ text-overflow: ellipsis
38
+ white-space: nowrap
39
+
34
40
  .v-combobox
35
41
  &__content
36
42
  overflow: hidden
@@ -45,6 +51,7 @@
45
51
  display: inline-flex
46
52
  letter-spacing: inherit
47
53
  line-height: inherit
54
+ max-width: 100%
48
55
 
49
56
  &--active-menu
50
57
  .v-field__append-inner
@@ -54,6 +61,8 @@
54
61
 
55
62
  &--chips
56
63
  .v-combobox__selection
64
+ margin-top: $combobox-chips-margin-top
65
+
57
66
  &:first-child
58
67
  margin-inline-start: 0
59
68
 
@@ -73,6 +82,7 @@
73
82
  position: absolute
74
83
  left: 0
75
84
  right: 0
85
+ width: 100%
76
86
  padding-inline-start: inherit
77
87
  padding-inline-end: inherit
78
88
 
@@ -6,3 +6,4 @@ $combobox-content-elevation: 4 !default;
6
6
  $combobox-line-height: 1.75 !default;
7
7
  $combobox-transition: .2s settings.$standard-easing !default;
8
8
  $combobox-chips-control-min-height: 64px !default;
9
+ $combobox-chips-margin-top: 2px !default;
@@ -9,7 +9,7 @@ import { makeDimensionProps, useDimension } from "../../composables/dimensions.m
9
9
  import { makeTransitionProps } from "../../composables/transition.mjs";
10
10
  import { useProxiedModel } from "../../composables/proxiedModel.mjs";
11
11
  import { useScopeId } from "../../composables/scopeId.mjs";
12
- import { useForwardRef } from "../../composables/forwardRef.mjs"; // Utilities
12
+ import { forwardRefs } from "../../composables/forwardRefs.mjs"; // Utilities
13
13
 
14
14
  import { nextTick, ref, watch } from 'vue';
15
15
  import { genericComponent, IN_BROWSER, useRender } from "../../util/index.mjs"; // Types
@@ -63,7 +63,7 @@ export const VDialog = genericComponent()({
63
63
  const after = e.target;
64
64
 
65
65
  if (before !== after && (_overlay$value = overlay.value) != null && _overlay$value.contentEl && // We're the topmost dialog
66
- (_overlay$value2 = overlay.value) != null && _overlay$value2.isTop && // It isn't the document or the dialog body
66
+ (_overlay$value2 = overlay.value) != null && _overlay$value2.globalTop && // It isn't the document or the dialog body
67
67
  ![document, overlay.value.contentEl].includes(after) && // It isn't inside the dialog body
68
68
  !overlay.value.contentEl.contains(after)) {
69
69
  const focusable = [...overlay.value.contentEl.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])')].filter(el => !el.hasAttribute('disabled'));
@@ -125,7 +125,7 @@ export const VDialog = genericComponent()({
125
125
  default: slots.default,
126
126
  activator: slots.activator
127
127
  }));
128
- return useForwardRef({}, overlay);
128
+ return forwardRefs({}, overlay);
129
129
  }
130
130
 
131
131
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VOverlay","makeDimensionProps","useDimension","makeTransitionProps","useProxiedModel","useScopeId","useForwardRef","nextTick","ref","watch","genericComponent","IN_BROWSER","useRender","VDialog","name","inheritAttrs","props","fullscreen","Boolean","origin","type","String","default","retainFocus","scrollable","modelValue","width","transition","component","emits","value","setup","attrs","slots","isActive","dimensionStyles","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","isTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activator"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\nimport { useForwardRef } from '@/composables/forwardRef'\n\n// Utilities\nimport { nextTick, ref, watch } from 'vue'\nimport { genericComponent, IN_BROWSER, useRender } from '@/util'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<new () => {\n $slots: OverlaySlots\n}>()({\n name: 'VDialog',\n\n inheritAttrs: false,\n\n props: {\n fullscreen: Boolean,\n origin: {\n type: String,\n default: 'center center',\n },\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n modelValue: Boolean,\n\n ...makeDimensionProps({ width: 'auto' }),\n ...makeTransitionProps({\n transition: { component: VDialogTransition },\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { dimensionStyles } = useDimension(props)\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.isTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n useRender(() => (\n <VOverlay\n v-model={ isActive.value }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n style={ dimensionStyles.value }\n transition={ props.transition }\n ref={ overlay }\n aria-role=\"dialog\"\n aria-modal=\"true\"\n activatorProps={{\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }}\n z-index={ 2400 }\n { ...scopeId }\n { ...attrs }\n v-slots={{\n default: slots.default,\n activator: slots.activator,\n }}\n />\n ))\n\n return useForwardRef({}, overlay)\n },\n})\n\nexport type VDialog = InstanceType<typeof VDialog>\n"],"mappings":";AAAA;AACA,uB,CAEA;;SACSA,iB;SACAC,Q,iCAET;;SACSC,kB,EAAoBC,Y;SACpBC,mB;SACAC,e;SACAC,U;SACAC,a,4CAET;;AACA,SAASC,QAAT,EAAmBC,GAAnB,EAAwBC,KAAxB,QAAqC,KAArC;SACSC,gB,EAAkBC,U,EAAYC,S,gCAEvC;;AAGA,OAAO,MAAMC,OAAO,GAAGH,gBAAgB,GAElC;EACHI,IAAI,EAAE,SADH;EAGHC,YAAY,EAAE,KAHX;EAKHC,KAAK,EAAE;IACLC,UAAU,EAAEC,OADP;IAELC,MAAM,EAAE;MACNC,IAAI,EAAEC,MADA;MAENC,OAAO,EAAE;IAFH,CAFH;IAMLC,WAAW,EAAE;MACXH,IAAI,EAAEF,OADK;MAEXI,OAAO,EAAE;IAFE,CANR;IAULE,UAAU,EAAEN,OAVP;IAWLO,UAAU,EAAEP,OAXP;IAaL,GAAGjB,kBAAkB,CAAC;MAAEyB,KAAK,EAAE;IAAT,CAAD,CAbhB;IAcL,GAAGvB,mBAAmB,CAAC;MACrBwB,UAAU,EAAE;QAAEC,SAAS,EAAE7B;MAAb;IADS,CAAD;EAdjB,CALJ;EAwBH8B,KAAK,EAAE;IACL,qBAAsBC,KAAD,IAAoB;EADpC,CAxBJ;;EA4BHC,KAAK,CAAEf,KAAF,QAA2B;IAAA,IAAlB;MAAEgB,KAAF;MAASC;IAAT,CAAkB;IAC9B,MAAMC,QAAQ,GAAG9B,eAAe,CAACY,KAAD,EAAQ,YAAR,CAAhC;IACA,MAAM;MAAEmB;IAAF,IAAsBjC,YAAY,CAACc,KAAD,CAAxC;IACA,MAAM;MAAEoB;IAAF,IAAc/B,UAAU,EAA9B;IAEA,MAAMgC,OAAO,GAAG7B,GAAG,EAAnB;;IACA,SAAS8B,SAAT,CAAoBC,CAApB,EAAmC;MAAA;;MACjC,MAAMC,MAAM,GAAGD,CAAC,CAACE,aAAjB;MACA,MAAMC,KAAK,GAAGH,CAAC,CAACI,MAAhB;;MAEA,IACEH,MAAM,KAAKE,KAAX,sBACAL,OAAO,CAACP,KADR,aACA,eAAec,SADf,IAEA;MAFA,mBAGAP,OAAO,CAACP,KAHR,aAGA,gBAAee,KAHf,IAIA;MACA,CAAC,CAACC,QAAD,EAAWT,OAAO,CAACP,KAAR,CAAcc,SAAzB,EAAoCG,QAApC,CAA6CL,KAA7C,CALD,IAMA;MACA,CAACL,OAAO,CAACP,KAAR,CAAcc,SAAd,CAAwBI,QAAxB,CAAiCN,KAAjC,CARH,EASE;QACA,MAAMO,SAAS,GAAG,CAAC,GAAGZ,OAAO,CAACP,KAAR,CAAcc,SAAd,CAAwBM,gBAAxB,CACpB,0EADoB,CAAJ,EAEfC,MAFe,CAERC,EAAE,IAAI,CAACA,EAAE,CAACC,YAAH,CAAgB,UAAhB,CAFC,CAAlB;QAIA,IAAI,CAACJ,SAAS,CAACK,MAAf,EAAuB;QAEvB,MAAMC,YAAY,GAAGN,SAAS,CAAC,CAAD,CAA9B;QACA,MAAMO,WAAW,GAAGP,SAAS,CAACA,SAAS,CAACK,MAAV,GAAmB,CAApB,CAA7B;;QAEA,IAAId,MAAM,KAAKe,YAAf,EAA6B;UAC3BC,WAAW,CAACC,KAAZ;QACD,CAFD,MAEO;UACLF,YAAY,CAACE,KAAb;QACD;MACF;IACF;;IAED,IAAI9C,UAAJ,EAAgB;MACdF,KAAK,CAAC,MAAMyB,QAAQ,CAACJ,KAAT,IAAkBd,KAAK,CAACO,WAA/B,EAA4CmC,GAAG,IAAI;QACtDA,GAAG,GACCZ,QAAQ,CAACa,gBAAT,CAA0B,SAA1B,EAAqCrB,SAArC,CADD,GAECQ,QAAQ,CAACc,mBAAT,CAA6B,SAA7B,EAAwCtB,SAAxC,CAFJ;MAGD,CAJI,EAIF;QAAEuB,SAAS,EAAE;MAAb,CAJE,CAAL;IAKD;;IAEDpD,KAAK,CAACyB,QAAD,EAAW,MAAMwB,GAAN,IAAa;MAC3B,MAAMnD,QAAQ,EAAd;;MACA,IAAImD,GAAJ,EAAS;QAAA;;QACP,cAAArB,OAAO,CAACP,KAAR,CAAec,SAAf,gCAA0Ba,KAA1B,CAAgC;UAAEK,aAAa,EAAE;QAAjB,CAAhC;MACD,CAFD,MAEO;QAAA;;QACL,gBAAAzB,OAAO,CAACP,KAAR,CAAeiC,WAAf,kCAA4BN,KAA5B,CAAkC;UAAEK,aAAa,EAAE;QAAjB,CAAlC;MACD;IACF,CAPI,CAAL;IASAlD,SAAS,CAAC;MAAA,cAEIsB,QAAQ,CAACJ,KAFb;MAAA,iCAEII,QAAQ,CAACJ,KAFb;MAAA,SAGC,CACL,UADK,EAEL;QACE,wBAAwBd,KAAK,CAACC,UADhC;QAEE,wBAAwBD,KAAK,CAACQ;MAFhC,CAFK,CAHD;MAAA,SAUEW,eAAe,CAACL,KAVlB;MAAA,cAWOd,KAAK,CAACW,UAXb;MAAA,OAYAU,OAZA;MAAA,aAaI,QAbJ;MAAA,cAcK,MAdL;MAAA,kBAeU;QACd,iBAAiB,QADH;QAEd,iBAAiBhB,MAAM,CAACa,QAAQ,CAACJ,KAAV;MAFT,CAfV;MAAA,WAmBI;IAnBJ,GAoBDM,OApBC,EAqBDJ,KArBC,GAsBG;MACPV,OAAO,EAAEW,KAAK,CAACX,OADR;MAEP0C,SAAS,EAAE/B,KAAK,CAAC+B;IAFV,CAtBH,CAAD,CAAT;IA6BA,OAAO1D,aAAa,CAAC,EAAD,EAAK+B,OAAL,CAApB;EACD;;AAhHE,CAFkC,CAAhC"}
1
+ {"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VOverlay","makeDimensionProps","useDimension","makeTransitionProps","useProxiedModel","useScopeId","forwardRefs","nextTick","ref","watch","genericComponent","IN_BROWSER","useRender","VDialog","name","inheritAttrs","props","fullscreen","Boolean","origin","type","String","default","retainFocus","scrollable","modelValue","width","transition","component","emits","value","setup","attrs","slots","isActive","dimensionStyles","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","globalTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activator"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\nimport { forwardRefs } from '@/composables/forwardRefs'\n\n// Utilities\nimport { nextTick, ref, watch } from 'vue'\nimport { genericComponent, IN_BROWSER, useRender } from '@/util'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<new () => {\n $slots: OverlaySlots\n}>()({\n name: 'VDialog',\n\n inheritAttrs: false,\n\n props: {\n fullscreen: Boolean,\n origin: {\n type: String,\n default: 'center center',\n },\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n modelValue: Boolean,\n\n ...makeDimensionProps({ width: 'auto' }),\n ...makeTransitionProps({\n transition: { component: VDialogTransition },\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { dimensionStyles } = useDimension(props)\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.globalTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n useRender(() => (\n <VOverlay\n v-model={ isActive.value }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n style={ dimensionStyles.value }\n transition={ props.transition }\n ref={ overlay }\n aria-role=\"dialog\"\n aria-modal=\"true\"\n activatorProps={{\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }}\n z-index={ 2400 }\n { ...scopeId }\n { ...attrs }\n v-slots={{\n default: slots.default,\n activator: slots.activator,\n }}\n />\n ))\n\n return forwardRefs({}, overlay)\n },\n})\n\nexport type VDialog = InstanceType<typeof VDialog>\n"],"mappings":"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"}
@@ -13,7 +13,7 @@
13
13
  position: relative;
14
14
  --v-field-padding-start: 16px;
15
15
  --v-field-padding-end: 16px;
16
- --v-field-padding-top: 8px;
16
+ --v-field-padding-top: 10px;
17
17
  --v-field-padding-bottom: 6px;
18
18
  }
19
19
  .v-field--disabled {
@@ -25,8 +25,6 @@
25
25
  /* region MODIFIERS */
26
26
  .v-field--prepended {
27
27
  padding-inline-start: 12px;
28
- --v-field-padding-start: 6px;
29
- --v-field-padding-end: 6px;
30
28
  }
31
29
  .v-field--appended {
32
30
  padding-inline-end: 12px;
@@ -44,16 +42,26 @@
44
42
  .v-field--variant-plain, .v-field--variant-underlined {
45
43
  border-radius: 0;
46
44
  padding: 0;
47
- --v-field-padding-start: 0;
48
- --v-field-padding-end: 0;
49
- --v-field-padding-top: 0;
50
- }
51
- .v-field--variant-plain.v-field--single-line, .v-field--variant-underlined.v-field--single-line {
52
- --v-field-padding-top: 0;
45
+ --v-field-padding-start: 0px;
46
+ --v-field-padding-end: 0px;
47
+ --v-field-padding-top: 6px;
48
+ --v-field-padding-bottom: 2px;
53
49
  }
54
50
  .v-field--variant-outlined, .v-field--single-line {
55
- --v-field-padding-top: 0;
51
+ --v-field-padding-top: 0px;
56
52
  }
53
+ .v-input--density-default .v-field--variant-outlined, .v-input--density-default .v-field--single-line {
54
+ --v-field-padding-bottom: 16px;
55
+ }
56
+
57
+ .v-input--density-comfortable .v-field--variant-outlined, .v-input--density-comfortable .v-field--single-line {
58
+ --v-field-padding-bottom: 12px;
59
+ }
60
+
61
+ .v-input--density-compact .v-field--variant-outlined, .v-input--density-compact .v-field--single-line {
62
+ --v-field-padding-bottom: 8px;
63
+ }
64
+
57
65
  .v-input--density-default .v-field--variant-solo, .v-input--density-default .v-field--variant-filled {
58
66
  --v-input-control-height: 56px;
59
67
  --v-field-padding-bottom: 6px;
@@ -69,19 +77,23 @@
69
77
  --v-field-padding-bottom: -2px;
70
78
  }
71
79
 
72
- .v-input--density-default .v-field--variant-underlined {
80
+ .v-input--density-default .v-field--variant-plain, .v-input--density-default .v-field--variant-underlined {
81
+ --v-input-control-height: 48px;
82
+ }
83
+
84
+ .v-input--density-comfortable .v-field--variant-plain, .v-input--density-comfortable .v-field--variant-underlined {
73
85
  --v-input-control-height: 40px;
74
- --v-field-padding-bottom: 6px;
75
86
  }
76
87
 
77
- .v-input--density-comfortable .v-field--variant-underlined {
88
+ .v-input--density-compact .v-field--variant-plain, .v-input--density-compact .v-field--variant-underlined {
78
89
  --v-input-control-height: 32px;
79
- --v-field-padding-bottom: 4px;
80
90
  }
81
91
 
82
- .v-input--density-compact .v-field--variant-underlined {
83
- --v-input-control-height: 24px;
84
- --v-field-padding-bottom: 2px;
92
+ .v-field--prepended {
93
+ --v-field-padding-start: 6px;
94
+ }
95
+ .v-field--appended {
96
+ --v-field-padding-end: 6px;
85
97
  }
86
98
 
87
99
  /* endregion */
@@ -92,15 +104,22 @@
92
104
  flex-wrap: wrap;
93
105
  letter-spacing: 0.009375em;
94
106
  opacity: var(--v-high-emphasis-opacity);
107
+ min-height: var(--v-input-control-height, 56px);
95
108
  padding-inline-start: var(--v-field-padding-start);
96
109
  padding-inline-end: var(--v-field-padding-end);
97
- padding-top: var(--v-field-padding-top, 8px);
98
- flex: 1 0 0;
99
- min-width: 0;
110
+ padding-top: calc(var(--v-field-padding-top, 10px) + var(--v-input-padding-top, 0));
111
+ padding-bottom: var(--v-field-padding-bottom, 6px);
112
+ width: 100%;
100
113
  }
101
114
  .v-field__input input {
102
115
  letter-spacing: inherit;
103
116
  }
117
+ .v-field__input input::placeholder,
118
+ textarea.v-field__input::placeholder {
119
+ color: currentColor;
120
+ opacity: var(--v-disabled-opacity);
121
+ }
122
+
104
123
  .v-field__input:focus, .v-field__input:active {
105
124
  outline: none;
106
125
  }
@@ -110,10 +129,10 @@
110
129
 
111
130
  .v-field__field {
112
131
  flex: 1 0;
113
- min-height: var(--v-input-control-height, 56px);
114
132
  grid-area: field;
115
- padding-bottom: var(--v-field-padding-bottom, 6px);
116
133
  position: relative;
134
+ align-items: flex-start;
135
+ display: flex;
117
136
  }
118
137
 
119
138
  /* endregion */
@@ -132,13 +151,12 @@
132
151
  padding-inline-start: var(--v-field-padding-after);
133
152
  }
134
153
 
135
- .v-field__field,
136
154
  .v-field__prepend-inner,
137
155
  .v-field__append-inner,
138
156
  .v-field__clearable {
139
157
  align-items: flex-start;
140
158
  display: flex;
141
- padding-top: var(--v-input-padding-top, 8px);
159
+ padding-top: var(--v-input-padding-top, 10px);
142
160
  }
143
161
 
144
162
  .v-field--focused .v-field__prepend-inner,
@@ -190,6 +208,7 @@
190
208
  max-width: calc(100% - var(--v-field-padding-start) - var(--v-field-padding-end));
191
209
  pointer-events: none;
192
210
  position: absolute;
211
+ top: var(--v-input-padding-top, 10px);
193
212
  transform-origin: left center;
194
213
  transition: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
195
214
  transition-property: opacity, transform;
@@ -225,7 +244,7 @@
225
244
  }
226
245
 
227
246
  .v-field--variant-plain .v-label.v-field-label--floating, .v-field--variant-underlined .v-label.v-field-label--floating {
228
- transform: translateY(-6px);
247
+ transform: translateY(-16px);
229
248
  margin: 0;
230
249
  }
231
250
  .v-field--variant-outlined .v-label.v-field-label--floating {
@@ -104,7 +104,7 @@ export const VField = genericComponent()({
104
104
  const width = Math.abs(targetWidth - rect.width) > 1 ? {
105
105
  maxWidth: convertToUnit(targetWidth)
106
106
  } : undefined;
107
- const duration = parseFloat(getComputedStyle(el).transitionDuration) * 1000;
107
+ const duration = parseFloat(getComputedStyle(el).transitionDuration) * 1000 || 150;
108
108
  const scale = parseFloat(getComputedStyle(targetEl).getPropertyValue('--v-field-label-scale'));
109
109
  el.style.visibility = 'visible';
110
110
  targetEl.style.visibility = 'hidden';