From floating-ui-vue
Provides Vuetify docs, API references, breaking changes, issues, discussions, and best practices for Vue apps importing Vuetify. Use for code generation, debugging, upgrades.
npx claudepluginhub skilld-dev/vue-ecosystem-skills --plugin floating-ui-vueThis skill uses the workspace's default tool permissions.
> Vue Material Component Framework
references/discussions/_INDEX.mdreferences/discussions/discussion-21067.mdreferences/discussions/discussion-21070.mdreferences/discussions/discussion-21188.mdreferences/discussions/discussion-21216.mdreferences/discussions/discussion-21241.mdreferences/discussions/discussion-21276.mdreferences/discussions/discussion-21293.mdreferences/discussions/discussion-21396.mdreferences/discussions/discussion-21407.mdreferences/discussions/discussion-21511.mdreferences/discussions/discussion-21631.mdreferences/discussions/discussion-21710.mdreferences/discussions/discussion-21913.mdreferences/discussions/discussion-21921.mdreferences/discussions/discussion-22103.mdreferences/discussions/discussion-22113.mdreferences/discussions/discussion-22138.mdreferences/discussions/discussion-22178.mdreferences/discussions/discussion-22342.mdAdds shadcn-vue UI components to Vue apps with Tailwind. Tracks API changes, deprecations, new features for debugging, best practices, and modifications.
Guides Reka UI (headless Vue 3 primitives): component APIs, WAI-ARIA accessibility, asChild composition, controlled/uncontrolled state, virtualization, styling integration.
Guides Vant UI component usage in Vue 3 projects, covering installation, components like Button, Cell, Form, Dialog, Toast, Popup, ConfigProvider, and theme customization for mobile-first interfaces.
Share bugs, ideas, or general feedback.
vuetifyVue Material Component Framework
Version: 4.0.1 Tags: v1-stable: 1.5.24, v2-stable: 2.7.2, next: 4.0.1, dev: 4.0.1, v3-stable: 3.12.3, latest: 4.0.3
References: Docs — API reference, guides • GitHub Issues — bugs, workarounds, edge cases • GitHub Discussions — Q&A, patterns, recipes • Releases — changelog, breaking changes, new APIs
This section documents version-specific API changes — prioritize recent major/minor releases.
BREAKING: VRow / VCol Grid — complete overhaul using CSS gap instead of negative margins. dense prop removed (use density="compact"), align/justify on VRow and order/align-self on VCol removed in favor of utility classes source
BREAKING: MD3 Typography — variant names renamed for Material Design 3 compliance: h1-h3 -> display-*, h4-h6 -> headline-*, subtitle-1/body-1 -> body-large, button/subtitle-2 -> label-large source
BREAKING: MD3 Elevation — elevation levels reduced from 25 (0-24) to 6 (0-5) to align with MD3 density-independent pixel levels source
BREAKING: VBtn Defaults — text-transform: uppercase removed by default. $button-stacked-icon-margin Sass variable replaced by $button-stacked-gap source
BREAKING: VSelect / VAutocomplete / VCombobox — item slot prop renamed to internalItem. The item prop is now an alias for internalItem.raw source
BREAKING: VForm Slot — isValid, errors, and isDisabled slot variables are now unwrapped values instead of Ref objects source
NEW: VSnackbarQueue — rewritten in v4 to support showing multiple snackbars simultaneously; default slot renamed to item source
NEW: VRow gap prop — provides fine-grained control over grid spacing, accepting numbers, strings, or [x, y] arrays source
NEW: VAvatarGroup (experimental) — new labs component for grouping multiple avatars with overlapping support source
NEW: VCommandPalette (experimental) — new labs component providing a search and action interface for application commands source
Also changed: VCalendar promoted from labs · VHotkey promoted from labs · VToolbar location prop new · VAvatar badge prop new · VProgressCircular reveal prop new · VTreeview indent-lines props new · vuetify/styles/core new entry point · system default theme · VSnackbar multi-line removed · VContainer fill-height behavior changed
cmd modifier in the useHotkey composable for cross-platform compatibility — automatically resolves to Command on Mac and Control on PC source// Preferred: works on both Mac and PC
useHotkey('cmd+s', (e) => saveDocument(e))
// Avoid: hardcoding 'ctrl' may cause conflicts or feel non-idiomatic on Mac
useHotkey('ctrl+s', (e) => saveDocument(e))
class and style to specific component keys in the defaults configuration — these are not supported in the global defaults key source// Preferred
createVuetify({
defaults: {
VBtn: {
class: 'text-none',
style: { textTransform: 'none' }
}
}
})
// Avoid: class and style are ignored in global
createVuetify({
defaults: {
global: { class: 'text-none' }
}
})
/* main.css */
@layer theme, base, vuetify, components, utilities;
@import 'vuetify/styles' layer(vuetify);
@import 'tailwindcss';
Use v-text-field with decimal.js for high-precision decimal arithmetic — VNumberInput uses toFixed() internally and may suffer from standard JavaScript floating-point inaccuracies source
Centralize snackbar messages using global state (e.g., Pinia) with v-snackbar-queue — allows triggering notifications from any part of the application by pushing to a shared array source
<template>
<v-app>
<v-snackbar-queue v-model="messages.queue" />
</v-app>
</template>
order prop to explicitly control layout component priority — overrides the default behavior where priority is determined solely by markup order source
<v-navigation-drawer />
<v-app-bar :order="-1" />
Utilize useDate()'s parseISO and toISO methods for standardizing date strings — VDateInput and other date components internally expect and return native JS Date objects source
Use v-command-palette (experimental) for keyboard-driven power-user workflows — provides a pre-configured, accessible, and searchable dialog interface that implements ARIA best practices automatically source
Restore previous negative-margin/padding grid behavior during Vuetify 4 migration using the @layer vuetify-overrides block — necessary when existing layouts rely on the legacy system instead of the new CSS gap property source
@layer vuetify-overrides {
.v-row {
gap: unset;
margin: calc(var(--v-col-gap-y) * -.5) calc(var(--v-col-gap-x) * -.5);
}
}