agy-superpowers 5.0.8 → 5.0.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 (204) hide show
  1. package/package.json +1 -1
  2. package/template/agent/rules/superpowers.md +54 -0
  3. package/template/agent/skills/frontend-developer/SKILL.md +39 -0
  4. package/template/agent/skills/frontend-developer/references/react-nextjs.md +343 -0
  5. package/template/agent/skills/frontend-developer/references/react-rules/_sections.md +46 -0
  6. package/template/agent/skills/frontend-developer/references/react-rules/_template.md +28 -0
  7. package/template/agent/skills/frontend-developer/references/react-rules/advanced-event-handler-refs.md +55 -0
  8. package/template/agent/skills/frontend-developer/references/react-rules/advanced-init-once.md +42 -0
  9. package/template/agent/skills/frontend-developer/references/react-rules/advanced-use-latest.md +39 -0
  10. package/template/agent/skills/frontend-developer/references/react-rules/async-api-routes.md +38 -0
  11. package/template/agent/skills/frontend-developer/references/react-rules/async-defer-await.md +80 -0
  12. package/template/agent/skills/frontend-developer/references/react-rules/async-dependencies.md +51 -0
  13. package/template/agent/skills/frontend-developer/references/react-rules/async-parallel.md +28 -0
  14. package/template/agent/skills/frontend-developer/references/react-rules/async-suspense-boundaries.md +99 -0
  15. package/template/agent/skills/frontend-developer/references/react-rules/bundle-barrel-imports.md +59 -0
  16. package/template/agent/skills/frontend-developer/references/react-rules/bundle-conditional.md +31 -0
  17. package/template/agent/skills/frontend-developer/references/react-rules/bundle-defer-third-party.md +49 -0
  18. package/template/agent/skills/frontend-developer/references/react-rules/bundle-dynamic-imports.md +35 -0
  19. package/template/agent/skills/frontend-developer/references/react-rules/bundle-preload.md +50 -0
  20. package/template/agent/skills/frontend-developer/references/react-rules/client-event-listeners.md +74 -0
  21. package/template/agent/skills/frontend-developer/references/react-rules/client-localstorage-schema.md +71 -0
  22. package/template/agent/skills/frontend-developer/references/react-rules/client-passive-event-listeners.md +48 -0
  23. package/template/agent/skills/frontend-developer/references/react-rules/client-swr-dedup.md +56 -0
  24. package/template/agent/skills/frontend-developer/references/react-rules/js-batch-dom-css.md +107 -0
  25. package/template/agent/skills/frontend-developer/references/react-rules/js-cache-function-results.md +80 -0
  26. package/template/agent/skills/frontend-developer/references/react-rules/js-cache-property-access.md +28 -0
  27. package/template/agent/skills/frontend-developer/references/react-rules/js-cache-storage.md +70 -0
  28. package/template/agent/skills/frontend-developer/references/react-rules/js-combine-iterations.md +32 -0
  29. package/template/agent/skills/frontend-developer/references/react-rules/js-early-exit.md +50 -0
  30. package/template/agent/skills/frontend-developer/references/react-rules/js-flatmap-filter.md +60 -0
  31. package/template/agent/skills/frontend-developer/references/react-rules/js-hoist-regexp.md +45 -0
  32. package/template/agent/skills/frontend-developer/references/react-rules/js-index-maps.md +37 -0
  33. package/template/agent/skills/frontend-developer/references/react-rules/js-length-check-first.md +49 -0
  34. package/template/agent/skills/frontend-developer/references/react-rules/js-min-max-loop.md +82 -0
  35. package/template/agent/skills/frontend-developer/references/react-rules/js-set-map-lookups.md +24 -0
  36. package/template/agent/skills/frontend-developer/references/react-rules/js-tosorted-immutable.md +57 -0
  37. package/template/agent/skills/frontend-developer/references/react-rules/rendering-activity.md +26 -0
  38. package/template/agent/skills/frontend-developer/references/react-rules/rendering-animate-svg-wrapper.md +47 -0
  39. package/template/agent/skills/frontend-developer/references/react-rules/rendering-conditional-render.md +40 -0
  40. package/template/agent/skills/frontend-developer/references/react-rules/rendering-content-visibility.md +38 -0
  41. package/template/agent/skills/frontend-developer/references/react-rules/rendering-hoist-jsx.md +46 -0
  42. package/template/agent/skills/frontend-developer/references/react-rules/rendering-hydration-no-flicker.md +82 -0
  43. package/template/agent/skills/frontend-developer/references/react-rules/rendering-hydration-suppress-warning.md +30 -0
  44. package/template/agent/skills/frontend-developer/references/react-rules/rendering-resource-hints.md +85 -0
  45. package/template/agent/skills/frontend-developer/references/react-rules/rendering-script-defer-async.md +68 -0
  46. package/template/agent/skills/frontend-developer/references/react-rules/rendering-svg-precision.md +28 -0
  47. package/template/agent/skills/frontend-developer/references/react-rules/rendering-usetransition-loading.md +75 -0
  48. package/template/agent/skills/frontend-developer/references/react-rules/rerender-defer-reads.md +39 -0
  49. package/template/agent/skills/frontend-developer/references/react-rules/rerender-dependencies.md +45 -0
  50. package/template/agent/skills/frontend-developer/references/react-rules/rerender-derived-state-no-effect.md +40 -0
  51. package/template/agent/skills/frontend-developer/references/react-rules/rerender-derived-state.md +29 -0
  52. package/template/agent/skills/frontend-developer/references/react-rules/rerender-functional-setstate.md +74 -0
  53. package/template/agent/skills/frontend-developer/references/react-rules/rerender-lazy-state-init.md +58 -0
  54. package/template/agent/skills/frontend-developer/references/react-rules/rerender-memo-with-default-value.md +38 -0
  55. package/template/agent/skills/frontend-developer/references/react-rules/rerender-memo.md +44 -0
  56. package/template/agent/skills/frontend-developer/references/react-rules/rerender-move-effect-to-event.md +45 -0
  57. package/template/agent/skills/frontend-developer/references/react-rules/rerender-no-inline-components.md +82 -0
  58. package/template/agent/skills/frontend-developer/references/react-rules/rerender-simple-expression-in-memo.md +35 -0
  59. package/template/agent/skills/frontend-developer/references/react-rules/rerender-split-combined-hooks.md +64 -0
  60. package/template/agent/skills/frontend-developer/references/react-rules/rerender-transitions.md +40 -0
  61. package/template/agent/skills/frontend-developer/references/react-rules/rerender-use-deferred-value.md +59 -0
  62. package/template/agent/skills/frontend-developer/references/react-rules/rerender-use-ref-transient-values.md +73 -0
  63. package/template/agent/skills/frontend-developer/references/react-rules/server-after-nonblocking.md +73 -0
  64. package/template/agent/skills/frontend-developer/references/react-rules/server-auth-actions.md +96 -0
  65. package/template/agent/skills/frontend-developer/references/react-rules/server-cache-lru.md +41 -0
  66. package/template/agent/skills/frontend-developer/references/react-rules/server-cache-react.md +76 -0
  67. package/template/agent/skills/frontend-developer/references/react-rules/server-dedup-props.md +65 -0
  68. package/template/agent/skills/frontend-developer/references/react-rules/server-hoist-static-io.md +142 -0
  69. package/template/agent/skills/frontend-developer/references/react-rules/server-parallel-fetching.md +83 -0
  70. package/template/agent/skills/frontend-developer/references/react-rules/server-serialization.md +38 -0
  71. package/template/agent/skills/frontend-developer/references/svelte-sveltekit.md +220 -0
  72. package/template/agent/skills/frontend-developer/references/vanilla.md +275 -0
  73. package/template/agent/skills/frontend-developer/references/vue-nuxt.md +289 -0
  74. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/_index.md +154 -0
  75. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/animation-class-based-technique.md +254 -0
  76. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/animation-state-driven-technique.md +291 -0
  77. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-async.md +97 -0
  78. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-data-flow.md +307 -0
  79. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-fallthrough-attrs.md +174 -0
  80. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-keep-alive.md +137 -0
  81. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-slots.md +216 -0
  82. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-suspense.md +228 -0
  83. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-teleport.md +108 -0
  84. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-transition-group.md +128 -0
  85. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/component-transition.md +125 -0
  86. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/composables.md +290 -0
  87. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/directives.md +162 -0
  88. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/perf-avoid-component-abstraction-in-lists.md +159 -0
  89. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/perf-v-once-v-memo-directives.md +182 -0
  90. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/perf-virtualize-large-lists.md +187 -0
  91. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/plugins.md +166 -0
  92. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/reactivity.md +344 -0
  93. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/render-functions.md +201 -0
  94. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/sfc.md +310 -0
  95. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/state-management.md +135 -0
  96. package/template/agent/skills/frontend-developer/references/vue-rules/best-practices/updated-hook-performance.md +187 -0
  97. package/template/agent/skills/frontend-developer/references/vue-rules/router/_index.md +23 -0
  98. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-beforeenter-no-param-trigger.md +167 -0
  99. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-beforerouteenter-no-this.md +176 -0
  100. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-guard-async-await-pattern.md +227 -0
  101. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-navigation-guard-infinite-loop.md +187 -0
  102. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-navigation-guard-next-deprecated.md +150 -0
  103. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-param-change-no-lifecycle.md +181 -0
  104. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-simple-routing-cleanup.md +209 -0
  105. package/template/agent/skills/frontend-developer/references/vue-rules/router/router-use-vue-router-for-production.md +183 -0
  106. package/template/agent/skills/frontend-developer/references/vue-rules/testing/_index.md +29 -0
  107. package/template/agent/skills/frontend-developer/references/vue-rules/testing/async-component-testing.md +163 -0
  108. package/template/agent/skills/frontend-developer/references/vue-rules/testing/teleport-testing-complexity.md +158 -0
  109. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-async-await-flushpromises.md +175 -0
  110. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-browser-vs-node-runners.md +208 -0
  111. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-component-blackbox-approach.md +144 -0
  112. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-composables-helper-wrapper.md +238 -0
  113. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-e2e-playwright-recommended.md +242 -0
  114. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-no-snapshot-only.md +197 -0
  115. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-pinia-store-setup.md +228 -0
  116. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-suspense-async-components.md +229 -0
  117. package/template/agent/skills/frontend-developer/references/vue-rules/testing/testing-vitest-recommended-for-vue.md +204 -0
  118. package/template/agent/skills/mobile-developer/SKILL.md +52 -0
  119. package/template/agent/skills/mobile-developer/references/android-native.md +396 -0
  120. package/template/agent/skills/mobile-developer/references/android-rules/android-accessibility.md +36 -0
  121. package/template/agent/skills/mobile-developer/references/android-rules/android-architecture.md +52 -0
  122. package/template/agent/skills/mobile-developer/references/android-rules/android-coroutines.md +139 -0
  123. package/template/agent/skills/mobile-developer/references/android-rules/android-data-layer.md +51 -0
  124. package/template/agent/skills/mobile-developer/references/android-rules/android-emulator-skill.md +108 -0
  125. package/template/agent/skills/mobile-developer/references/android-rules/android-gradle-logic.md +126 -0
  126. package/template/agent/skills/mobile-developer/references/android-rules/android-retrofit.md +142 -0
  127. package/template/agent/skills/mobile-developer/references/android-rules/android-testing.md +102 -0
  128. package/template/agent/skills/mobile-developer/references/android-rules/android-viewmodel.md +43 -0
  129. package/template/agent/skills/mobile-developer/references/android-rules/coil-compose.md +74 -0
  130. package/template/agent/skills/mobile-developer/references/android-rules/compose-navigation.md +422 -0
  131. package/template/agent/skills/mobile-developer/references/android-rules/compose-performance-audit.md +199 -0
  132. package/template/agent/skills/mobile-developer/references/android-rules/compose-ui.md +49 -0
  133. package/template/agent/skills/mobile-developer/references/android-rules/gradle-build-performance.md +346 -0
  134. package/template/agent/skills/mobile-developer/references/android-rules/kotlin-concurrency-expert.md +169 -0
  135. package/template/agent/skills/mobile-developer/references/android-rules/rxjava-to-coroutines-migration.md +101 -0
  136. package/template/agent/skills/mobile-developer/references/android-rules/xml-to-compose-migration.md +338 -0
  137. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-best-practices.md +52 -0
  138. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-checks-migration.md +134 -0
  139. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-cli-app-best-practices.md +123 -0
  140. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-doc-validation.md +45 -0
  141. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-matcher-best-practices.md +106 -0
  142. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-modern-features.md +241 -0
  143. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-package-maintenance.md +75 -0
  144. package/template/agent/skills/mobile-developer/references/flutter-rules/dart-test-fundamentals.md +124 -0
  145. package/template/agent/skills/mobile-developer/references/flutter.md +291 -0
  146. package/template/agent/skills/mobile-developer/references/ios-native.md +358 -0
  147. package/template/agent/skills/mobile-developer/references/ios-rules/accessibility-patterns.md +215 -0
  148. package/template/agent/skills/mobile-developer/references/ios-rules/animation-advanced.md +403 -0
  149. package/template/agent/skills/mobile-developer/references/ios-rules/animation-basics.md +284 -0
  150. package/template/agent/skills/mobile-developer/references/ios-rules/animation-transitions.md +326 -0
  151. package/template/agent/skills/mobile-developer/references/ios-rules/charts-accessibility.md +135 -0
  152. package/template/agent/skills/mobile-developer/references/ios-rules/charts.md +602 -0
  153. package/template/agent/skills/mobile-developer/references/ios-rules/image-optimization.md +203 -0
  154. package/template/agent/skills/mobile-developer/references/ios-rules/latest-apis.md +464 -0
  155. package/template/agent/skills/mobile-developer/references/ios-rules/layout-best-practices.md +266 -0
  156. package/template/agent/skills/mobile-developer/references/ios-rules/liquid-glass.md +416 -0
  157. package/template/agent/skills/mobile-developer/references/ios-rules/list-patterns.md +394 -0
  158. package/template/agent/skills/mobile-developer/references/ios-rules/macos-scenes.md +318 -0
  159. package/template/agent/skills/mobile-developer/references/ios-rules/macos-views.md +357 -0
  160. package/template/agent/skills/mobile-developer/references/ios-rules/macos-window-styling.md +303 -0
  161. package/template/agent/skills/mobile-developer/references/ios-rules/performance-patterns.md +403 -0
  162. package/template/agent/skills/mobile-developer/references/ios-rules/scroll-patterns.md +293 -0
  163. package/template/agent/skills/mobile-developer/references/ios-rules/sheet-navigation-patterns.md +363 -0
  164. package/template/agent/skills/mobile-developer/references/ios-rules/state-management.md +417 -0
  165. package/template/agent/skills/mobile-developer/references/ios-rules/view-structure.md +389 -0
  166. package/template/agent/skills/mobile-developer/references/react-native-rules/_sections.md +86 -0
  167. package/template/agent/skills/mobile-developer/references/react-native-rules/_template.md +28 -0
  168. package/template/agent/skills/mobile-developer/references/react-native-rules/animation-derived-value.md +53 -0
  169. package/template/agent/skills/mobile-developer/references/react-native-rules/animation-gesture-detector-press.md +95 -0
  170. package/template/agent/skills/mobile-developer/references/react-native-rules/animation-gpu-properties.md +65 -0
  171. package/template/agent/skills/mobile-developer/references/react-native-rules/design-system-compound-components.md +66 -0
  172. package/template/agent/skills/mobile-developer/references/react-native-rules/fonts-config-plugin.md +71 -0
  173. package/template/agent/skills/mobile-developer/references/react-native-rules/imports-design-system-folder.md +68 -0
  174. package/template/agent/skills/mobile-developer/references/react-native-rules/js-hoist-intl.md +61 -0
  175. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-callbacks.md +44 -0
  176. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-function-references.md +132 -0
  177. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-images.md +53 -0
  178. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-inline-objects.md +97 -0
  179. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-item-expensive.md +94 -0
  180. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-item-memo.md +82 -0
  181. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-item-types.md +104 -0
  182. package/template/agent/skills/mobile-developer/references/react-native-rules/list-performance-virtualize.md +67 -0
  183. package/template/agent/skills/mobile-developer/references/react-native-rules/monorepo-native-deps-in-app.md +46 -0
  184. package/template/agent/skills/mobile-developer/references/react-native-rules/monorepo-single-dependency-versions.md +63 -0
  185. package/template/agent/skills/mobile-developer/references/react-native-rules/navigation-native-navigators.md +188 -0
  186. package/template/agent/skills/mobile-developer/references/react-native-rules/react-compiler-destructure-functions.md +50 -0
  187. package/template/agent/skills/mobile-developer/references/react-native-rules/react-compiler-reanimated-shared-values.md +48 -0
  188. package/template/agent/skills/mobile-developer/references/react-native-rules/react-state-dispatcher.md +91 -0
  189. package/template/agent/skills/mobile-developer/references/react-native-rules/react-state-fallback.md +56 -0
  190. package/template/agent/skills/mobile-developer/references/react-native-rules/react-state-minimize.md +65 -0
  191. package/template/agent/skills/mobile-developer/references/react-native-rules/rendering-no-falsy-and.md +74 -0
  192. package/template/agent/skills/mobile-developer/references/react-native-rules/rendering-text-in-text-component.md +36 -0
  193. package/template/agent/skills/mobile-developer/references/react-native-rules/scroll-position-no-state.md +82 -0
  194. package/template/agent/skills/mobile-developer/references/react-native-rules/state-ground-truth.md +80 -0
  195. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-expo-image.md +66 -0
  196. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-image-gallery.md +104 -0
  197. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-measure-views.md +78 -0
  198. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-menus.md +174 -0
  199. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-native-modals.md +77 -0
  200. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-pressable.md +61 -0
  201. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-safe-area-scroll.md +65 -0
  202. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-scrollview-content-inset.md +45 -0
  203. package/template/agent/skills/mobile-developer/references/react-native-rules/ui-styling.md +87 -0
  204. package/template/agent/skills/mobile-developer/references/react-native.md +345 -0
@@ -0,0 +1,289 @@
1
+ # Vue 3 + Nuxt Reference
2
+
3
+ > **Philosophy:** Progressive framework. Reactivity-first. Convention over configuration.
4
+ > Vue makes the simple things simple and the complex things manageable.
5
+
6
+ ---
7
+
8
+ ## Project Setup & Detection
9
+
10
+ **Stack indicators:** `nuxt.config.ts` / `vue.config.js`, `package.json` with `vue` or `nuxt` dependency.
11
+
12
+ **Key config files:**
13
+
14
+ | File | Purpose |
15
+ |------|---------|
16
+ | `nuxt.config.ts` | Nuxt configuration (modules, plugins, runtime config) |
17
+ | `app.config.ts` | App-level configuration (reactive, client-side) |
18
+ | `tsconfig.json` | TypeScript configuration |
19
+ | `.env` | Environment variables |
20
+
21
+ **Recommended project structure (Nuxt 3):**
22
+
23
+ ```
24
+ app/
25
+ pages/
26
+ index.vue # Home (/), file-based routing
27
+ about.vue # /about
28
+ users/
29
+ [id].vue # /users/:id (dynamic route)
30
+ layouts/
31
+ default.vue # Default layout
32
+ dashboard.vue # Dashboard layout
33
+ components/
34
+ ui/ # Reusable UI components
35
+ forms/ # Form components
36
+ composables/ # Auto-imported composables (useAuth, etc.)
37
+ stores/ # Pinia stores
38
+ server/
39
+ api/ # Server API routes
40
+ middleware/ # Server middleware
41
+ plugins/ # Vue plugins
42
+ middleware/ # Route middleware (auth guards)
43
+ utils/ # Auto-imported utility functions
44
+ assets/ # Styles, images (processed by Vite)
45
+ public/ # Static files (served as-is)
46
+ ```
47
+
48
+ ---
49
+
50
+ ## Architecture Patterns
51
+
52
+ ### Composition API (Default)
53
+
54
+ ```vue
55
+ <script setup lang="ts">
56
+ import { ref, computed, onMounted } from 'vue'
57
+
58
+ const count = ref(0)
59
+ const doubled = computed(() => count.value * 2)
60
+
61
+ function increment() {
62
+ count.value++
63
+ }
64
+
65
+ onMounted(() => {
66
+ console.log('Component mounted')
67
+ })
68
+ </script>
69
+
70
+ <template>
71
+ <button @click="increment">{{ count }} ({{ doubled }})</button>
72
+ </template>
73
+ ```
74
+
75
+ ### State Management
76
+
77
+ | Approach | Use When |
78
+ |----------|----------|
79
+ | **Pinia** (recommended) | Global/shared state — devtools, SSR, TypeScript |
80
+ | **Composables** (`useState` in Nuxt) | SSR-safe state shared across components |
81
+ | **`ref`/`reactive`** | Component-local state |
82
+ | **URL state** (`useRoute().query`) | Filters, pagination, shareable state |
83
+
84
+ **Pinia store:**
85
+
86
+ ```ts
87
+ // stores/auth.ts
88
+ export const useAuthStore = defineStore('auth', () => {
89
+ const user = ref<User | null>(null)
90
+ const isLoggedIn = computed(() => !!user.value)
91
+
92
+ async function login(credentials: Credentials) {
93
+ user.value = await $fetch('/api/auth/login', { method: 'POST', body: credentials })
94
+ }
95
+
96
+ return { user, isLoggedIn, login }
97
+ })
98
+ ```
99
+
100
+ ### Data Fetching (Nuxt)
101
+
102
+ | Composable | Use When |
103
+ |------------|----------|
104
+ | **`useFetch`** | SSR + client — auto-deduplication, caching |
105
+ | **`useAsyncData`** | Custom async logic, multiple sources |
106
+ | **`$fetch`** | Client-only calls, server API routes, event handlers |
107
+ | **`useLazyFetch`** | Non-blocking fetch (shows page immediately) |
108
+
109
+ ```vue
110
+ <script setup>
111
+ const { data: posts, pending, error } = await useFetch('/api/posts')
112
+ </script>
113
+ ```
114
+
115
+ ---
116
+
117
+ ## Performance Optimization
118
+
119
+ ### Key Optimizations
120
+
121
+ 1. **Auto-imports** — Nuxt auto-imports composables, components, and utils. No manual imports needed.
122
+
123
+ 2. **`<Suspense>` and `<NuxtLoadingIndicator>`** — built-in loading states.
124
+
125
+ 3. **`defineAsyncComponent`** — lazy load heavy components.
126
+
127
+ ```ts
128
+ const HeavyChart = defineAsyncComponent(() => import('~/components/Chart.vue'))
129
+ ```
130
+
131
+ 4. **`v-once`** — render static content once, skip future updates.
132
+
133
+ 5. **`v-memo`** — memoize template sub-trees (Vue 3.2+).
134
+
135
+ 6. **`shallowRef`** — avoid deep reactivity for large objects.
136
+
137
+ 7. **Route-based code splitting** — Nuxt splits by page automatically.
138
+
139
+ 8. **Image optimization** — use `nuxt/image` module for `<NuxtImg>` and `<NuxtPicture>`.
140
+
141
+ ---
142
+
143
+ ## Common Libraries Ecosystem
144
+
145
+ | Category | Recommended | Alternative |
146
+ |----------|-------------|-------------|
147
+ | **UI** | `nuxt-ui` / `primevue` | `vuetify`, `quasar` |
148
+ | **Styling** | `tailwindcss` (via `@nuxtjs/tailwindcss`) | `unocss` |
149
+ | **State** | `pinia` (built-in Nuxt module) | `vuex` (legacy) |
150
+ | **Forms** | `vee-validate` + `zod` | `formkit` |
151
+ | **Auth** | `sidebase/nuxt-auth` | `nuxt-auth-utils` |
152
+ | **Database** | `prisma` / `drizzle` | `nuxt-mongoose` |
153
+ | **i18n** | `@nuxtjs/i18n` | — |
154
+ | **Testing** | `vitest` + `@vue/test-utils` | — |
155
+ | **E2E** | `playwright` | `cypress` |
156
+ | **Icons** | `nuxt-icon` | `unplugin-icons` |
157
+ | **SEO** | `nuxt-seo` module suite | manual `useHead()` |
158
+
159
+ ---
160
+
161
+ ## Anti-Patterns & Gotchas
162
+
163
+ | ❌ Don't | Why | ✅ Do Instead |
164
+ |----------|-----|---------------|
165
+ | Options API for new code | Less composable, worse TypeScript | `<script setup>` Composition API |
166
+ | `this.$store` (Vuex) | Legacy, replaced by Pinia | Use Pinia stores |
167
+ | Mutating props | One-way data flow violation, bugs | Emit events or use `v-model` |
168
+ | `watch` for derived state | Extra re-render cycle | Use `computed` |
169
+ | `$fetch` in `setup` for SSR data | Runs on both server AND client (duplicate) | `useFetch` or `useAsyncData` |
170
+ | `ref.value` in template | `.value` is auto-unwrapped in templates | Just `{{ count }}`, not `{{ count.value }}` |
171
+ | Missing `key` on `v-for` | Re-render bugs, broken state | Always `:key="item.id"` |
172
+ | Barrel exports in composables | Nuxt auto-imports from `composables/` | One composable per file |
173
+ | `process.env` in client | Only works in Node.js | `useRuntimeConfig()` |
174
+
175
+ ---
176
+
177
+ ## Testing
178
+
179
+ | Layer | Tool | Purpose |
180
+ |-------|------|---------|
181
+ | **Unit** | Vitest + `@vue/test-utils` | Components, composables |
182
+ | **Component** | `@nuxt/test-utils` | Full Nuxt component context |
183
+ | **E2E** | Playwright | Full user flows |
184
+
185
+ ```ts
186
+ import { mount } from '@vue/test-utils'
187
+ import Counter from '~/components/Counter.vue'
188
+
189
+ test('increments', async () => {
190
+ const wrapper = mount(Counter)
191
+ await wrapper.find('button').trigger('click')
192
+ expect(wrapper.text()).toContain('1')
193
+ })
194
+ ```
195
+
196
+ ---
197
+
198
+ ## Deployment & Distribution
199
+
200
+ ### Nitro Server (Nuxt 3)
201
+
202
+ Nuxt 3 uses Nitro — deploy anywhere:
203
+
204
+ ```bash
205
+ # Build
206
+ nuxt build # Server (SSR)
207
+ nuxt generate # Static (SSG)
208
+
209
+ # Preview
210
+ nuxt preview
211
+ ```
212
+
213
+ | Platform | Preset |
214
+ |----------|--------|
215
+ | **Vercel** | `vercel` (auto-detected) |
216
+ | **Netlify** | `netlify` |
217
+ | **Cloudflare** | `cloudflare-pages` |
218
+ | **Node.js** | `node-server` |
219
+ | **Docker** | `node-server` + Dockerfile |
220
+ | **Static** | `nuxt generate` → any CDN |
221
+
222
+ ---
223
+
224
+ ## Quick Reference — Granular Rules
225
+
226
+ Individual rule files in `vue-rules/` with detailed code examples and best
227
+ practices from the Vue ecosystem. Read the specific rule when working in that area.
228
+
229
+ > Source: [antfu/skills](https://github.com/antfu/skills) (from [vuejs-ai/skills](https://github.com/vuejs-ai/skills))
230
+
231
+ ### Best Practices — Components
232
+
233
+ - [sfc.md](vue-rules/best-practices/sfc.md) — Single File Component patterns
234
+ - [component-data-flow.md](vue-rules/best-practices/component-data-flow.md) — Props, events, v-model
235
+ - [component-slots.md](vue-rules/best-practices/component-slots.md) — Slot patterns
236
+ - [component-fallthrough-attrs.md](vue-rules/best-practices/component-fallthrough-attrs.md) — Fallthrough attributes
237
+ - [component-async.md](vue-rules/best-practices/component-async.md) — Async components
238
+ - [component-keep-alive.md](vue-rules/best-practices/component-keep-alive.md) — KeepAlive caching
239
+ - [component-suspense.md](vue-rules/best-practices/component-suspense.md) — Suspense for async
240
+ - [component-teleport.md](vue-rules/best-practices/component-teleport.md) — Teleport for portals
241
+ - [component-transition.md](vue-rules/best-practices/component-transition.md) — Transition animations
242
+ - [component-transition-group.md](vue-rules/best-practices/component-transition-group.md) — TransitionGroup for lists
243
+
244
+ ### Best Practices — Core
245
+
246
+ - [reactivity.md](vue-rules/best-practices/reactivity.md) — Reactivity system deep dive
247
+ - [composables.md](vue-rules/best-practices/composables.md) — Composable patterns
248
+ - [state-management.md](vue-rules/best-practices/state-management.md) — State management approaches
249
+ - [directives.md](vue-rules/best-practices/directives.md) — Custom directives
250
+ - [plugins.md](vue-rules/best-practices/plugins.md) — Plugin architecture
251
+ - [render-functions.md](vue-rules/best-practices/render-functions.md) — Render functions & JSX
252
+
253
+ ### Best Practices — Performance
254
+
255
+ - [perf-virtualize-large-lists.md](vue-rules/best-practices/perf-virtualize-large-lists.md) — Virtualize large lists
256
+ - [perf-avoid-component-abstraction-in-lists.md](vue-rules/best-practices/perf-avoid-component-abstraction-in-lists.md) — Avoid abstraction in lists
257
+ - [perf-v-once-v-memo-directives.md](vue-rules/best-practices/perf-v-once-v-memo-directives.md) — v-once and v-memo
258
+ - [updated-hook-performance.md](vue-rules/best-practices/updated-hook-performance.md) — Updated hook pitfalls
259
+
260
+ ### Best Practices — Animation
261
+
262
+ - [animation-class-based-technique.md](vue-rules/best-practices/animation-class-based-technique.md) — CSS class-based animations
263
+ - [animation-state-driven-technique.md](vue-rules/best-practices/animation-state-driven-technique.md) — State-driven animations
264
+
265
+ ### Router
266
+
267
+ - [router-guard-async-await-pattern.md](vue-rules/router/router-guard-async-await-pattern.md) — Async guard pattern
268
+ - [router-navigation-guard-next-deprecated.md](vue-rules/router/router-navigation-guard-next-deprecated.md) — next() is deprecated
269
+ - [router-navigation-guard-infinite-loop.md](vue-rules/router/router-navigation-guard-infinite-loop.md) — Avoid guard infinite loops
270
+ - [router-param-change-no-lifecycle.md](vue-rules/router/router-param-change-no-lifecycle.md) — Param changes skip lifecycle
271
+ - [router-beforerouteenter-no-this.md](vue-rules/router/router-beforerouteenter-no-this.md) — No `this` in beforeRouteEnter
272
+ - [router-beforeenter-no-param-trigger.md](vue-rules/router/router-beforeenter-no-param-trigger.md) — beforeEnter vs param changes
273
+ - [router-simple-routing-cleanup.md](vue-rules/router/router-simple-routing-cleanup.md) — Simple routing cleanup
274
+ - [router-use-vue-router-for-production.md](vue-rules/router/router-use-vue-router-for-production.md) — Use Vue Router in production
275
+
276
+ ### Testing
277
+
278
+ - [testing-vitest-recommended-for-vue.md](vue-rules/testing/testing-vitest-recommended-for-vue.md) — Vitest is recommended
279
+ - [testing-component-blackbox-approach.md](vue-rules/testing/testing-component-blackbox-approach.md) — Black-box testing
280
+ - [testing-composables-helper-wrapper.md](vue-rules/testing/testing-composables-helper-wrapper.md) — Test composables with wrapper
281
+ - [testing-pinia-store-setup.md](vue-rules/testing/testing-pinia-store-setup.md) — Pinia store testing setup
282
+ - [testing-async-await-flushpromises.md](vue-rules/testing/testing-async-await-flushpromises.md) — Async testing patterns
283
+ - [testing-suspense-async-components.md](vue-rules/testing/testing-suspense-async-components.md) — Suspense testing
284
+ - [async-component-testing.md](vue-rules/testing/async-component-testing.md) — Async component testing
285
+ - [teleport-testing-complexity.md](vue-rules/testing/teleport-testing-complexity.md) — Teleport testing
286
+ - [testing-no-snapshot-only.md](vue-rules/testing/testing-no-snapshot-only.md) — Don't rely on snapshots only
287
+ - [testing-browser-vs-node-runners.md](vue-rules/testing/testing-browser-vs-node-runners.md) — Browser vs Node runners
288
+ - [testing-e2e-playwright-recommended.md](vue-rules/testing/testing-e2e-playwright-recommended.md) — Playwright for E2E
289
+
@@ -0,0 +1,154 @@
1
+ ---
2
+ name: vue-best-practices
3
+ description: MUST be used for Vue.js tasks. Strongly recommends Composition API with `<script setup>` and TypeScript as the standard approach. Covers Vue 3, SSR, Volar, vue-tsc. Load for any Vue, .vue files, Vue Router, Pinia, or Vite with Vue work. ALWAYS use Composition API unless the project explicitly requires Options API.
4
+ license: MIT
5
+ metadata:
6
+ author: github.com/vuejs-ai
7
+ version: "18.0.0"
8
+ ---
9
+
10
+ # Vue Best Practices Workflow
11
+
12
+ Use this skill as an instruction set. Follow the workflow in order unless the user explicitly asks for a different order.
13
+
14
+ ## Core Principles
15
+ - **Keep state predictable:** one source of truth, derive everything else.
16
+ - **Make data flow explicit:** Props down, Events up for most cases.
17
+ - **Favor small, focused components:** easier to test, reuse, and maintain.
18
+ - **Avoid unnecessary re-renders:** use computed properties and watchers wisely.
19
+ - **Readability counts:** write clear, self-documenting code.
20
+
21
+ ## 1) Confirm architecture before coding (required)
22
+
23
+ - Default stack: Vue 3 + Composition API + `<script setup lang="ts">`.
24
+ - If the project explicitly uses Options API, load `vue-options-api-best-practices` skill if available.
25
+ - If the project explicitly uses JSX, load `vue-jsx-best-practices` skill if available.
26
+
27
+ ### 1.1 Must-read core references (required)
28
+
29
+ - Before implementing any Vue task, make sure to read and apply these core references:
30
+ - `references/reactivity.md`
31
+ - `references/sfc.md`
32
+ - `references/component-data-flow.md`
33
+ - `references/composables.md`
34
+ - Keep these references in active working context for the entire task, not only when a specific issue appears.
35
+
36
+ ### 1.2 Plan component boundaries before coding (required)
37
+
38
+ Create a brief component map before implementation for any non-trivial feature.
39
+
40
+ - Define each component's single responsibility in one sentence.
41
+ - Keep entry/root and route-level view components as composition surfaces by default.
42
+ - Move feature UI and feature logic out of entry/root/view components unless the task is intentionally a tiny single-file demo.
43
+ - Define props/emits contracts for each child component in the map.
44
+ - Prefer a feature folder layout (`components/<feature>/...`, `composables/use<Feature>.ts`) when adding more than one component.
45
+
46
+ ## 2) Apply essential Vue foundations (required)
47
+
48
+ These are essential, must-know foundations. Apply all of them in every Vue task using the core references already loaded in section `1.1`.
49
+
50
+ ### Reactivity
51
+
52
+ - Must-read reference from `1.1`: [reactivity](references/reactivity.md)
53
+ - Keep source state minimal (`ref`/`reactive`), derive everything possible with `computed`.
54
+ - Use watchers for side effects if needed.
55
+ - Avoid recomputing expensive logic in templates.
56
+
57
+ ### SFC structure and template safety
58
+
59
+ - Must-read reference from `1.1`: [sfc](references/sfc.md)
60
+ - Keep SFC sections in this order: `<script>` → `<template>` → `<style>`.
61
+ - Keep SFC responsibilities focused; split large components.
62
+ - Keep templates declarative; move branching/derivation to script.
63
+ - Apply Vue template safety rules (`v-html`, list rendering, conditional rendering choices).
64
+
65
+ ### Keep components focused
66
+
67
+ Split a component when it has **more than one clear responsibility** (e.g. data orchestration + UI, or multiple independent UI sections).
68
+
69
+ - Prefer **smaller components + composables** over one “mega component”
70
+ - Move **UI sections** into child components (props in, events out).
71
+ - Move **state/side effects** into composables (`useXxx()`).
72
+
73
+ Apply objective split triggers. Split the component if **any** condition is true:
74
+
75
+ - It owns both orchestration/state and substantial presentational markup for multiple sections.
76
+ - It has 3+ distinct UI sections (for example: form, filters, list, footer/status).
77
+ - A template block is repeated or could become reusable (item rows, cards, list entries).
78
+
79
+ Entry/root and route view rule:
80
+
81
+ - Keep entry/root and route view components thin: app shell/layout, provider wiring, and feature composition.
82
+ - Do not place full feature implementations in entry/root/view components when those features contain independent parts.
83
+ - For CRUD/list features (todo, table, catalog, inbox), split at least into:
84
+ - feature container component
85
+ - input/form component
86
+ - list (and/or item) component
87
+ - footer/actions or filter/status component
88
+ - Allow a single-file implementation only for very small throwaway demos; if chosen, explicitly justify why splitting is unnecessary.
89
+
90
+ ### Component data flow
91
+
92
+ - Must-read reference from `1.1`: [component-data-flow](references/component-data-flow.md)
93
+ - Use props down, events up as the primary model.
94
+ - Use `v-model` only for true two-way component contracts.
95
+ - Use provide/inject only for deep-tree dependencies or shared context.
96
+ - Keep contracts explicit and typed with `defineProps`, `defineEmits`, and `InjectionKey` as needed.
97
+
98
+ ### Composables
99
+
100
+ - Must-read reference from `1.1`: [composables](references/composables.md)
101
+ - Extract logic into composables when it is reused, stateful, or side-effect heavy.
102
+ - Keep composable APIs small, typed, and predictable.
103
+ - Separate feature logic from presentational components.
104
+
105
+ ## 3) Consider optional features only when requirements call for them
106
+
107
+ ### 3.1 Standard optional features
108
+
109
+ Do not add these by default. Load the matching reference only when the requirement exists.
110
+
111
+ - Slots: parent needs to control child content/layout -> [component-slots](references/component-slots.md)
112
+ - Fallthrough attributes: wrapper/base components must forward attrs/events safely -> [component-fallthrough-attrs](references/component-fallthrough-attrs.md)
113
+ - Built-in component `<KeepAlive>` for stateful view caching -> [component-keep-alive](references/component-keep-alive.md)
114
+ - Built-in component `<Teleport>` for overlays/portals -> [component-teleport](references/component-teleport.md)
115
+ - Built-in component `<Suspense>` for async subtree fallback boundaries -> [component-suspense](references/component-suspense.md)
116
+ - Animation-related features: pick the simplest approach that matches the required motion behavior.
117
+ - Built-in component `<Transition>` for enter/leave effects -> [transition](references/component-transition.md)
118
+ - Built-in component `<TransitionGroup>` for animated list mutations -> [transition-group](references/component-transition-group.md)
119
+ - Class-based animation for non-enter/leave effects -> [animation-class-based-technique](references/animation-class-based-technique.md)
120
+ - State-driven animation for user-input-driven animation -> [animation-state-driven-technique](references/animation-state-driven-technique.md)
121
+
122
+ ### 3.2 Less-common optional features
123
+
124
+ Use these only when there is explicit product or technical need.
125
+
126
+ - Directives: behavior is DOM-specific and not a good composable/component fit -> [directives](references/directives.md)
127
+ - Async components: heavy/rarely-used UI should be lazy loaded -> [component-async](references/component-async.md)
128
+ - Render functions only when templates cannot express the requirement -> [render-functions](references/render-functions.md)
129
+ - Plugins when behavior must be installed app-wide -> [plugins](references/plugins.md)
130
+ - State management patterns: app-wide shared state crosses feature boundaries -> [state-management](references/state-management.md)
131
+
132
+ ## 4) Run performance optimization after behavior is correct
133
+
134
+ Performance work is a post-functionality pass. Do not optimize before core behavior is implemented and verified.
135
+
136
+ - Large list rendering bottlenecks -> [perf-virtualize-large-lists](references/perf-virtualize-large-lists.md)
137
+ - Static subtrees re-rendering unnecessarily -> [perf-v-once-v-memo-directives](references/perf-v-once-v-memo-directives.md)
138
+ - Over-abstraction in hot list paths -> [perf-avoid-component-abstraction-in-lists](references/perf-avoid-component-abstraction-in-lists.md)
139
+ - Expensive updates triggered too often -> [updated-hook-performance](references/updated-hook-performance.md)
140
+
141
+ ## 5) Final self-check before finishing
142
+
143
+ - Core behavior works and matches requirements.
144
+ - All must-read references were read and applied.
145
+ - Reactivity model is minimal and predictable.
146
+ - SFC structure and template rules are followed.
147
+ - Components are focused and well-factored, splitting when needed.
148
+ - Entry/root and route view components remain composition surfaces unless there is an explicit small-demo exception.
149
+ - Component split decisions are explicit and defensible (responsibility boundaries are clear).
150
+ - Data flow contracts are explicit and typed.
151
+ - Composables are used where reuse/complexity justifies them.
152
+ - Moved state/side effects into composables if applicable
153
+ - Optional features are used only when requirements demand them.
154
+ - Performance changes were applied only after functionality was complete.
@@ -0,0 +1,254 @@
1
+ ---
2
+ title: Use Class-based Animations for Non-Enter/Leave Effects
3
+ impact: LOW
4
+ impactDescription: Class-based animations are simpler and more performant for elements that remain in the DOM
5
+ type: best-practice
6
+ tags: [vue3, animation, css, class-binding, state]
7
+ ---
8
+
9
+ # Use Class-based Animations for Non-Enter/Leave Effects
10
+
11
+ **Impact: LOW** - For animations on elements that are not entering or leaving the DOM, use CSS class-based animations triggered by Vue's reactive state. This is simpler than `<Transition>` and more appropriate for feedback animations like shake, pulse, or highlight effects.
12
+
13
+ ## Task List
14
+
15
+ - Use class-based animations for elements staying in the DOM
16
+ - Use `<Transition>` only for enter/leave animations
17
+ - Combine CSS animations with Vue's class bindings (`:class`)
18
+ - Consider using `setTimeout` to auto-remove animation classes
19
+
20
+ **When to Use Class-based Animations:**
21
+ - User feedback (shake on error, pulse on success)
22
+ - Attention-grabbing effects (highlight changes)
23
+ - Hover/focus states that need more than CSS transitions
24
+ - Any animation where the element stays mounted
25
+
26
+ **When to Use Transition Component:**
27
+ - Elements entering/leaving the DOM (v-if/v-show)
28
+ - Route transitions
29
+ - List item additions/removals
30
+
31
+ ## Basic Pattern
32
+
33
+ ```vue
34
+ <template>
35
+ <div :class="{ shake: showError }">
36
+ <button @click="submitForm">Submit</button>
37
+ <span v-if="showError">This feature is disabled!</span>
38
+ </div>
39
+ </template>
40
+
41
+ <script setup>
42
+ import { ref } from 'vue'
43
+
44
+ const showError = ref(false)
45
+
46
+ function submitForm() {
47
+ if (!isValid()) {
48
+ // Trigger shake animation
49
+ showError.value = true
50
+
51
+ // Auto-remove class after animation completes
52
+ setTimeout(() => {
53
+ showError.value = false
54
+ }, 820) // Match animation duration
55
+ }
56
+ }
57
+ </script>
58
+
59
+ <style>
60
+ .shake {
61
+ animation: shake 0.82s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
62
+ transform: translate3d(0, 0, 0); /* Enable GPU acceleration */
63
+ }
64
+
65
+ @keyframes shake {
66
+ 10%, 90% { transform: translate3d(-1px, 0, 0); }
67
+ 20%, 80% { transform: translate3d(2px, 0, 0); }
68
+ 30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
69
+ 40%, 60% { transform: translate3d(4px, 0, 0); }
70
+ }
71
+ </style>
72
+ ```
73
+
74
+ ## Common Animation Patterns
75
+
76
+ ### Pulse on Success
77
+
78
+ ```vue
79
+ <template>
80
+ <button
81
+ @click="save"
82
+ :class="{ pulse: saved }"
83
+ >
84
+ {{ saved ? 'Saved!' : 'Save' }}
85
+ </button>
86
+ </template>
87
+
88
+ <script setup>
89
+ import { ref } from 'vue'
90
+
91
+ const saved = ref(false)
92
+
93
+ async function save() {
94
+ await saveData()
95
+ saved.value = true
96
+ setTimeout(() => saved.value = false, 1000)
97
+ }
98
+ </script>
99
+
100
+ <style>
101
+ .pulse {
102
+ animation: pulse 0.5s ease-in-out;
103
+ }
104
+
105
+ @keyframes pulse {
106
+ 0%, 100% { transform: scale(1); }
107
+ 50% { transform: scale(1.05); }
108
+ }
109
+ </style>
110
+ ```
111
+
112
+ ### Highlight on Change
113
+
114
+ ```vue
115
+ <template>
116
+ <div
117
+ :class="{ highlight: justUpdated }"
118
+ >
119
+ Value: {{ value }}
120
+ </div>
121
+ </template>
122
+
123
+ <script setup>
124
+ import { ref, watch } from 'vue'
125
+
126
+ const value = ref(0)
127
+ const justUpdated = ref(false)
128
+
129
+ watch(value, () => {
130
+ justUpdated.value = true
131
+ setTimeout(() => justUpdated.value = false, 1000)
132
+ })
133
+ </script>
134
+
135
+ <style>
136
+ .highlight {
137
+ animation: highlight 1s ease-out;
138
+ }
139
+
140
+ @keyframes highlight {
141
+ 0% { background-color: yellow; }
142
+ 100% { background-color: transparent; }
143
+ }
144
+ </style>
145
+ ```
146
+
147
+ ### Bounce Attention
148
+
149
+ ```vue
150
+ <template>
151
+ <div
152
+ :class="{ bounce: needsAttention }"
153
+ @animationend="needsAttention = false"
154
+ >
155
+ <BellIcon />
156
+ </div>
157
+ </template>
158
+
159
+ <script setup>
160
+ import { ref } from 'vue'
161
+
162
+ const needsAttention = ref(false)
163
+
164
+ function notifyUser() {
165
+ needsAttention.value = true
166
+ // No setTimeout needed - using animationend event
167
+ }
168
+ </script>
169
+
170
+ <style>
171
+ .bounce {
172
+ animation: bounce 0.5s ease;
173
+ }
174
+
175
+ @keyframes bounce {
176
+ 0%, 100% { transform: translateY(0); }
177
+ 50% { transform: translateY(-10px); }
178
+ }
179
+ </style>
180
+ ```
181
+
182
+ ## Using animationend Event
183
+
184
+ Instead of `setTimeout`, use the `animationend` event for cleaner code:
185
+
186
+ ```vue
187
+ <template>
188
+ <div
189
+ :class="{ animate: isAnimating }"
190
+ @animationend="isAnimating = false"
191
+ >
192
+ Content
193
+ </div>
194
+ </template>
195
+
196
+ <script setup>
197
+ import { ref } from 'vue'
198
+
199
+ const isAnimating = ref(false)
200
+
201
+ function triggerAnimation() {
202
+ isAnimating.value = true
203
+ // Class is automatically removed when animation ends
204
+ }
205
+ </script>
206
+ ```
207
+
208
+ ## Composable for Reusable Animations
209
+
210
+ ```javascript
211
+ // composables/useAnimation.js
212
+ import { ref } from 'vue'
213
+
214
+ export function useAnimation(duration = 500) {
215
+ const isAnimating = ref(false)
216
+
217
+ function trigger() {
218
+ isAnimating.value = true
219
+ setTimeout(() => {
220
+ isAnimating.value = false
221
+ }, duration)
222
+ }
223
+
224
+ return {
225
+ isAnimating,
226
+ trigger
227
+ }
228
+ }
229
+ ```
230
+
231
+ ```vue
232
+ <script setup>
233
+ import { useAnimation } from '@/composables/useAnimation'
234
+
235
+ const shake = useAnimation(820)
236
+ const pulse = useAnimation(500)
237
+ </script>
238
+
239
+ <template>
240
+ <button
241
+ :class="{ shake: shake.isAnimating.value }"
242
+ @click="shake.trigger()"
243
+ >
244
+ Shake me
245
+ </button>
246
+
247
+ <button
248
+ :class="{ pulse: pulse.isAnimating.value }"
249
+ @click="pulse.trigger()"
250
+ >
251
+ Pulse me
252
+ </button>
253
+ </template>
254
+ ```