devskill 2.0.2

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 (654) hide show
  1. package/README.md +123 -0
  2. package/README.vn.md +104 -0
  3. package/SKILL_GUIDE.vn.md +252 -0
  4. package/bin/devskill.js +11 -0
  5. package/meta.ts +123 -0
  6. package/package.json +21 -0
  7. package/publish.sh +50 -0
  8. package/scripts/cli.ts +556 -0
  9. package/skills/builderx_api-contexts/SKILL.md +63 -0
  10. package/skills/builderx_api-contexts/references/core-multi-outbox.md +57 -0
  11. package/skills/builderx_api-controllers/SKILL.md +49 -0
  12. package/skills/builderx_api-controllers/references/core-fallback.md +62 -0
  13. package/skills/builderx_api-schemas/SKILL.md +76 -0
  14. package/skills/builderx_api-schemas/references/core-schema.md +78 -0
  15. package/skills/builderx_spa-api/SKILL.md +67 -0
  16. package/skills/builderx_spa-api/references/base-api.md +97 -0
  17. package/skills/builderx_spa-api/references/fetch.md +70 -0
  18. package/skills/builderx_spa-design/SKILL.md +82 -0
  19. package/skills/builderx_spa-design/references/core-text-design.md +64 -0
  20. package/skills/builderx_spa-design/references/features-feedback-actions.md +76 -0
  21. package/skills/builderx_spa-design/references/features-forms.md +91 -0
  22. package/skills/builderx_spa-design/references/features-layout-navigation.md +121 -0
  23. package/skills/builderx_spa-permission/SKILL.md +38 -0
  24. package/skills/builderx_spa-permission/references/has-permission.md +34 -0
  25. package/skills/composition-patterns/AGENTS.md +946 -0
  26. package/skills/composition-patterns/README.md +60 -0
  27. package/skills/composition-patterns/SKILL.md +89 -0
  28. package/skills/composition-patterns/SYNC.md +5 -0
  29. package/skills/composition-patterns/metadata.json +11 -0
  30. package/skills/composition-patterns/rules/_sections.md +29 -0
  31. package/skills/composition-patterns/rules/_template.md +24 -0
  32. package/skills/composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
  33. package/skills/composition-patterns/rules/architecture-compound-components.md +112 -0
  34. package/skills/composition-patterns/rules/patterns-children-over-render-props.md +87 -0
  35. package/skills/composition-patterns/rules/patterns-explicit-variants.md +100 -0
  36. package/skills/composition-patterns/rules/react19-no-forwardref.md +42 -0
  37. package/skills/composition-patterns/rules/state-context-interface.md +191 -0
  38. package/skills/composition-patterns/rules/state-decouple-implementation.md +113 -0
  39. package/skills/composition-patterns/rules/state-lift-state.md +125 -0
  40. package/skills/deploy-to-vercel/Archive.zip +0 -0
  41. package/skills/deploy-to-vercel/SKILL.md +296 -0
  42. package/skills/deploy-to-vercel/SYNC.md +5 -0
  43. package/skills/deploy-to-vercel/resources/deploy-codex.sh +301 -0
  44. package/skills/deploy-to-vercel/resources/deploy.sh +301 -0
  45. package/skills/pinia/SKILL.md +105 -0
  46. package/skills/pinia/references/api-in-composables.md +139 -0
  47. package/skills/pinia/references/setup-stores.md +105 -0
  48. package/skills/pinia/references/using-in-components.md +91 -0
  49. package/skills/pinia-options/SKILL.md +72 -0
  50. package/skills/pinia-options/references/core-option-stores.md +149 -0
  51. package/skills/pinia-options/references/using-in-options-api.md +105 -0
  52. package/skills/react-best-practices/AGENTS.md +3373 -0
  53. package/skills/react-best-practices/README.md +123 -0
  54. package/skills/react-best-practices/SKILL.md +143 -0
  55. package/skills/react-best-practices/SYNC.md +5 -0
  56. package/skills/react-best-practices/metadata.json +15 -0
  57. package/skills/react-best-practices/rules/_sections.md +46 -0
  58. package/skills/react-best-practices/rules/_template.md +28 -0
  59. package/skills/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  60. package/skills/react-best-practices/rules/advanced-init-once.md +42 -0
  61. package/skills/react-best-practices/rules/advanced-use-latest.md +39 -0
  62. package/skills/react-best-practices/rules/async-api-routes.md +38 -0
  63. package/skills/react-best-practices/rules/async-defer-await.md +80 -0
  64. package/skills/react-best-practices/rules/async-dependencies.md +51 -0
  65. package/skills/react-best-practices/rules/async-parallel.md +28 -0
  66. package/skills/react-best-practices/rules/async-suspense-boundaries.md +99 -0
  67. package/skills/react-best-practices/rules/bundle-barrel-imports.md +59 -0
  68. package/skills/react-best-practices/rules/bundle-conditional.md +31 -0
  69. package/skills/react-best-practices/rules/bundle-defer-third-party.md +49 -0
  70. package/skills/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  71. package/skills/react-best-practices/rules/bundle-preload.md +50 -0
  72. package/skills/react-best-practices/rules/client-event-listeners.md +74 -0
  73. package/skills/react-best-practices/rules/client-localstorage-schema.md +71 -0
  74. package/skills/react-best-practices/rules/client-passive-event-listeners.md +48 -0
  75. package/skills/react-best-practices/rules/client-swr-dedup.md +56 -0
  76. package/skills/react-best-practices/rules/js-batch-dom-css.md +107 -0
  77. package/skills/react-best-practices/rules/js-cache-function-results.md +80 -0
  78. package/skills/react-best-practices/rules/js-cache-property-access.md +28 -0
  79. package/skills/react-best-practices/rules/js-cache-storage.md +70 -0
  80. package/skills/react-best-practices/rules/js-combine-iterations.md +32 -0
  81. package/skills/react-best-practices/rules/js-early-exit.md +50 -0
  82. package/skills/react-best-practices/rules/js-flatmap-filter.md +60 -0
  83. package/skills/react-best-practices/rules/js-hoist-regexp.md +45 -0
  84. package/skills/react-best-practices/rules/js-index-maps.md +37 -0
  85. package/skills/react-best-practices/rules/js-length-check-first.md +49 -0
  86. package/skills/react-best-practices/rules/js-min-max-loop.md +82 -0
  87. package/skills/react-best-practices/rules/js-set-map-lookups.md +24 -0
  88. package/skills/react-best-practices/rules/js-tosorted-immutable.md +57 -0
  89. package/skills/react-best-practices/rules/rendering-activity.md +26 -0
  90. package/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  91. package/skills/react-best-practices/rules/rendering-conditional-render.md +40 -0
  92. package/skills/react-best-practices/rules/rendering-content-visibility.md +38 -0
  93. package/skills/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  94. package/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  95. package/skills/react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  96. package/skills/react-best-practices/rules/rendering-resource-hints.md +85 -0
  97. package/skills/react-best-practices/rules/rendering-script-defer-async.md +68 -0
  98. package/skills/react-best-practices/rules/rendering-svg-precision.md +28 -0
  99. package/skills/react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  100. package/skills/react-best-practices/rules/rerender-defer-reads.md +39 -0
  101. package/skills/react-best-practices/rules/rerender-dependencies.md +45 -0
  102. package/skills/react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  103. package/skills/react-best-practices/rules/rerender-derived-state.md +29 -0
  104. package/skills/react-best-practices/rules/rerender-functional-setstate.md +74 -0
  105. package/skills/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  106. package/skills/react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  107. package/skills/react-best-practices/rules/rerender-memo.md +44 -0
  108. package/skills/react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  109. package/skills/react-best-practices/rules/rerender-no-inline-components.md +82 -0
  110. package/skills/react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  111. package/skills/react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
  112. package/skills/react-best-practices/rules/rerender-transitions.md +40 -0
  113. package/skills/react-best-practices/rules/rerender-use-deferred-value.md +59 -0
  114. package/skills/react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  115. package/skills/react-best-practices/rules/server-after-nonblocking.md +73 -0
  116. package/skills/react-best-practices/rules/server-auth-actions.md +96 -0
  117. package/skills/react-best-practices/rules/server-cache-lru.md +41 -0
  118. package/skills/react-best-practices/rules/server-cache-react.md +76 -0
  119. package/skills/react-best-practices/rules/server-dedup-props.md +65 -0
  120. package/skills/react-best-practices/rules/server-hoist-static-io.md +142 -0
  121. package/skills/react-best-practices/rules/server-parallel-fetching.md +83 -0
  122. package/skills/react-best-practices/rules/server-serialization.md +38 -0
  123. package/skills/react-native-skills/AGENTS.md +2897 -0
  124. package/skills/react-native-skills/README.md +165 -0
  125. package/skills/react-native-skills/SKILL.md +121 -0
  126. package/skills/react-native-skills/SYNC.md +5 -0
  127. package/skills/react-native-skills/metadata.json +16 -0
  128. package/skills/react-native-skills/rules/_sections.md +86 -0
  129. package/skills/react-native-skills/rules/_template.md +28 -0
  130. package/skills/react-native-skills/rules/animation-derived-value.md +53 -0
  131. package/skills/react-native-skills/rules/animation-gesture-detector-press.md +95 -0
  132. package/skills/react-native-skills/rules/animation-gpu-properties.md +65 -0
  133. package/skills/react-native-skills/rules/design-system-compound-components.md +66 -0
  134. package/skills/react-native-skills/rules/fonts-config-plugin.md +71 -0
  135. package/skills/react-native-skills/rules/imports-design-system-folder.md +68 -0
  136. package/skills/react-native-skills/rules/js-hoist-intl.md +61 -0
  137. package/skills/react-native-skills/rules/list-performance-callbacks.md +44 -0
  138. package/skills/react-native-skills/rules/list-performance-function-references.md +132 -0
  139. package/skills/react-native-skills/rules/list-performance-images.md +53 -0
  140. package/skills/react-native-skills/rules/list-performance-inline-objects.md +97 -0
  141. package/skills/react-native-skills/rules/list-performance-item-expensive.md +94 -0
  142. package/skills/react-native-skills/rules/list-performance-item-memo.md +82 -0
  143. package/skills/react-native-skills/rules/list-performance-item-types.md +104 -0
  144. package/skills/react-native-skills/rules/list-performance-virtualize.md +67 -0
  145. package/skills/react-native-skills/rules/monorepo-native-deps-in-app.md +46 -0
  146. package/skills/react-native-skills/rules/monorepo-single-dependency-versions.md +63 -0
  147. package/skills/react-native-skills/rules/navigation-native-navigators.md +188 -0
  148. package/skills/react-native-skills/rules/react-compiler-destructure-functions.md +50 -0
  149. package/skills/react-native-skills/rules/react-compiler-reanimated-shared-values.md +48 -0
  150. package/skills/react-native-skills/rules/react-state-dispatcher.md +91 -0
  151. package/skills/react-native-skills/rules/react-state-fallback.md +56 -0
  152. package/skills/react-native-skills/rules/react-state-minimize.md +65 -0
  153. package/skills/react-native-skills/rules/rendering-no-falsy-and.md +74 -0
  154. package/skills/react-native-skills/rules/rendering-text-in-text-component.md +36 -0
  155. package/skills/react-native-skills/rules/scroll-position-no-state.md +82 -0
  156. package/skills/react-native-skills/rules/state-ground-truth.md +80 -0
  157. package/skills/react-native-skills/rules/ui-expo-image.md +66 -0
  158. package/skills/react-native-skills/rules/ui-image-gallery.md +104 -0
  159. package/skills/react-native-skills/rules/ui-measure-views.md +78 -0
  160. package/skills/react-native-skills/rules/ui-menus.md +174 -0
  161. package/skills/react-native-skills/rules/ui-native-modals.md +77 -0
  162. package/skills/react-native-skills/rules/ui-pressable.md +61 -0
  163. package/skills/react-native-skills/rules/ui-safe-area-scroll.md +65 -0
  164. package/skills/react-native-skills/rules/ui-scrollview-content-inset.md +45 -0
  165. package/skills/react-native-skills/rules/ui-styling.md +87 -0
  166. package/skills/slidev/LICENSE.md +21 -0
  167. package/skills/slidev/README.md +61 -0
  168. package/skills/slidev/SKILL.md +189 -0
  169. package/skills/slidev/SYNC.md +5 -0
  170. package/skills/slidev/references/animation-click-marker.md +37 -0
  171. package/skills/slidev/references/animation-drawing.md +68 -0
  172. package/skills/slidev/references/animation-rough-marker.md +53 -0
  173. package/skills/slidev/references/api-slide-hooks.md +37 -0
  174. package/skills/slidev/references/build-og-image.md +36 -0
  175. package/skills/slidev/references/build-pdf.md +40 -0
  176. package/skills/slidev/references/build-remote-assets.md +34 -0
  177. package/skills/slidev/references/build-seo-meta.md +43 -0
  178. package/skills/slidev/references/code-groups.md +64 -0
  179. package/skills/slidev/references/code-import-snippet.md +55 -0
  180. package/skills/slidev/references/code-line-highlighting.md +50 -0
  181. package/skills/slidev/references/code-line-numbers.md +46 -0
  182. package/skills/slidev/references/code-magic-move.md +57 -0
  183. package/skills/slidev/references/code-max-height.md +37 -0
  184. package/skills/slidev/references/code-twoslash.md +42 -0
  185. package/skills/slidev/references/core-animations.md +196 -0
  186. package/skills/slidev/references/core-cli.md +140 -0
  187. package/skills/slidev/references/core-components.md +197 -0
  188. package/skills/slidev/references/core-exporting.md +148 -0
  189. package/skills/slidev/references/core-frontmatter.md +195 -0
  190. package/skills/slidev/references/core-global-context.md +155 -0
  191. package/skills/slidev/references/core-headmatter.md +188 -0
  192. package/skills/slidev/references/core-hosting.md +152 -0
  193. package/skills/slidev/references/core-layouts.md +286 -0
  194. package/skills/slidev/references/core-syntax.md +155 -0
  195. package/skills/slidev/references/diagram-latex.md +55 -0
  196. package/skills/slidev/references/diagram-mermaid.md +44 -0
  197. package/skills/slidev/references/diagram-plantuml.md +45 -0
  198. package/skills/slidev/references/editor-monaco-run.md +44 -0
  199. package/skills/slidev/references/editor-monaco-write.md +24 -0
  200. package/skills/slidev/references/editor-monaco.md +50 -0
  201. package/skills/slidev/references/editor-prettier.md +40 -0
  202. package/skills/slidev/references/editor-side.md +23 -0
  203. package/skills/slidev/references/editor-vscode.md +55 -0
  204. package/skills/slidev/references/layout-canvas-size.md +25 -0
  205. package/skills/slidev/references/layout-draggable.md +57 -0
  206. package/skills/slidev/references/layout-global-layers.md +50 -0
  207. package/skills/slidev/references/layout-slots.md +75 -0
  208. package/skills/slidev/references/layout-transform.md +33 -0
  209. package/skills/slidev/references/layout-zoom.md +39 -0
  210. package/skills/slidev/references/presenter-notes-ruby.md +35 -0
  211. package/skills/slidev/references/presenter-recording.md +30 -0
  212. package/skills/slidev/references/presenter-remote.md +40 -0
  213. package/skills/slidev/references/presenter-timer.md +34 -0
  214. package/skills/slidev/references/style-direction.md +34 -0
  215. package/skills/slidev/references/style-icons.md +46 -0
  216. package/skills/slidev/references/style-scoped.md +50 -0
  217. package/skills/slidev/references/syntax-block-frontmatter.md +39 -0
  218. package/skills/slidev/references/syntax-frontmatter-merging.md +49 -0
  219. package/skills/slidev/references/syntax-importing-slides.md +60 -0
  220. package/skills/slidev/references/syntax-mdc.md +51 -0
  221. package/skills/slidev/references/tool-eject-theme.md +27 -0
  222. package/skills/tsdown/LICENSE.md +22 -0
  223. package/skills/tsdown/README.md +77 -0
  224. package/skills/tsdown/SKILL.md +407 -0
  225. package/skills/tsdown/SYNC.md +5 -0
  226. package/skills/tsdown/references/README.md +139 -0
  227. package/skills/tsdown/references/advanced-benchmark.md +8 -0
  228. package/skills/tsdown/references/advanced-ci.md +89 -0
  229. package/skills/tsdown/references/advanced-hooks.md +363 -0
  230. package/skills/tsdown/references/advanced-plugins.md +381 -0
  231. package/skills/tsdown/references/advanced-programmatic.md +378 -0
  232. package/skills/tsdown/references/advanced-rolldown-options.md +117 -0
  233. package/skills/tsdown/references/guide-getting-started.md +178 -0
  234. package/skills/tsdown/references/guide-introduction.md +42 -0
  235. package/skills/tsdown/references/guide-migrate-from-tsup.md +189 -0
  236. package/skills/tsdown/references/option-cjs-default.md +98 -0
  237. package/skills/tsdown/references/option-cleaning.md +275 -0
  238. package/skills/tsdown/references/option-config-file.md +281 -0
  239. package/skills/tsdown/references/option-css.md +301 -0
  240. package/skills/tsdown/references/option-dependencies.md +385 -0
  241. package/skills/tsdown/references/option-dts.md +251 -0
  242. package/skills/tsdown/references/option-entry.md +211 -0
  243. package/skills/tsdown/references/option-exe.md +120 -0
  244. package/skills/tsdown/references/option-lint.md +127 -0
  245. package/skills/tsdown/references/option-log-level.md +91 -0
  246. package/skills/tsdown/references/option-minification.md +177 -0
  247. package/skills/tsdown/references/option-output-directory.md +270 -0
  248. package/skills/tsdown/references/option-output-format.md +181 -0
  249. package/skills/tsdown/references/option-package-exports.md +320 -0
  250. package/skills/tsdown/references/option-platform.md +256 -0
  251. package/skills/tsdown/references/option-root.md +88 -0
  252. package/skills/tsdown/references/option-shims.md +299 -0
  253. package/skills/tsdown/references/option-sourcemap.md +301 -0
  254. package/skills/tsdown/references/option-target.md +222 -0
  255. package/skills/tsdown/references/option-tree-shaking.md +335 -0
  256. package/skills/tsdown/references/option-unbundle.md +310 -0
  257. package/skills/tsdown/references/option-watch-mode.md +261 -0
  258. package/skills/tsdown/references/recipe-react.md +338 -0
  259. package/skills/tsdown/references/recipe-solid.md +46 -0
  260. package/skills/tsdown/references/recipe-svelte.md +54 -0
  261. package/skills/tsdown/references/recipe-vue.md +387 -0
  262. package/skills/tsdown/references/recipe-wasm.md +125 -0
  263. package/skills/tsdown/references/reference-cli.md +472 -0
  264. package/skills/turborepo/LICENSE.md +7 -0
  265. package/skills/turborepo/SKILL.md +951 -0
  266. package/skills/turborepo/SYNC.md +5 -0
  267. package/skills/turborepo/command/turborepo.md +70 -0
  268. package/skills/turborepo/references/best-practices/RULE.md +241 -0
  269. package/skills/turborepo/references/best-practices/dependencies.md +246 -0
  270. package/skills/turborepo/references/best-practices/packages.md +335 -0
  271. package/skills/turborepo/references/best-practices/structure.md +297 -0
  272. package/skills/turborepo/references/boundaries/RULE.md +126 -0
  273. package/skills/turborepo/references/caching/RULE.md +153 -0
  274. package/skills/turborepo/references/caching/gotchas.md +190 -0
  275. package/skills/turborepo/references/caching/remote-cache.md +127 -0
  276. package/skills/turborepo/references/ci/RULE.md +79 -0
  277. package/skills/turborepo/references/ci/github-actions.md +162 -0
  278. package/skills/turborepo/references/ci/patterns.md +145 -0
  279. package/skills/turborepo/references/ci/vercel.md +103 -0
  280. package/skills/turborepo/references/cli/RULE.md +100 -0
  281. package/skills/turborepo/references/cli/commands.md +297 -0
  282. package/skills/turborepo/references/configuration/RULE.md +235 -0
  283. package/skills/turborepo/references/configuration/global-options.md +239 -0
  284. package/skills/turborepo/references/configuration/gotchas.md +368 -0
  285. package/skills/turborepo/references/configuration/tasks.md +325 -0
  286. package/skills/turborepo/references/environment/RULE.md +123 -0
  287. package/skills/turborepo/references/environment/gotchas.md +175 -0
  288. package/skills/turborepo/references/environment/modes.md +101 -0
  289. package/skills/turborepo/references/filtering/RULE.md +148 -0
  290. package/skills/turborepo/references/filtering/patterns.md +152 -0
  291. package/skills/turborepo/references/watch/RULE.md +99 -0
  292. package/skills/vercel-cli-with-tokens/SKILL.md +328 -0
  293. package/skills/vercel-cli-with-tokens/SYNC.md +5 -0
  294. package/skills/vue/SKILL.md +90 -0
  295. package/skills/vue/references/composables.md +54 -0
  296. package/skills/vue/references/lifecycle.md +31 -0
  297. package/skills/vue/references/props-emits.md +62 -0
  298. package/skills/vue/references/provide-inject.md +47 -0
  299. package/skills/vue/references/state.md +65 -0
  300. package/skills/vue-antdv-tailwind/SKILL.md +33 -0
  301. package/skills/vue-antdv-tailwind/references/styling-rules.md +61 -0
  302. package/skills/vue-best-practices/LICENSE.md +21 -0
  303. package/skills/vue-best-practices/SKILL.md +154 -0
  304. package/skills/vue-best-practices/SYNC.md +5 -0
  305. package/skills/vue-best-practices/references/animation-class-based-technique.md +254 -0
  306. package/skills/vue-best-practices/references/animation-state-driven-technique.md +291 -0
  307. package/skills/vue-best-practices/references/component-async.md +97 -0
  308. package/skills/vue-best-practices/references/component-data-flow.md +307 -0
  309. package/skills/vue-best-practices/references/component-fallthrough-attrs.md +174 -0
  310. package/skills/vue-best-practices/references/component-keep-alive.md +137 -0
  311. package/skills/vue-best-practices/references/component-slots.md +216 -0
  312. package/skills/vue-best-practices/references/component-suspense.md +228 -0
  313. package/skills/vue-best-practices/references/component-teleport.md +108 -0
  314. package/skills/vue-best-practices/references/component-transition-group.md +128 -0
  315. package/skills/vue-best-practices/references/component-transition.md +125 -0
  316. package/skills/vue-best-practices/references/composables.md +290 -0
  317. package/skills/vue-best-practices/references/directives.md +162 -0
  318. package/skills/vue-best-practices/references/perf-avoid-component-abstraction-in-lists.md +159 -0
  319. package/skills/vue-best-practices/references/perf-v-once-v-memo-directives.md +182 -0
  320. package/skills/vue-best-practices/references/perf-virtualize-large-lists.md +187 -0
  321. package/skills/vue-best-practices/references/plugins.md +166 -0
  322. package/skills/vue-best-practices/references/reactivity.md +344 -0
  323. package/skills/vue-best-practices/references/render-functions.md +201 -0
  324. package/skills/vue-best-practices/references/sfc.md +310 -0
  325. package/skills/vue-best-practices/references/state-management.md +135 -0
  326. package/skills/vue-best-practices/references/updated-hook-performance.md +187 -0
  327. package/skills/vue-jsx-best-practices/LICENSE.md +21 -0
  328. package/skills/vue-jsx-best-practices/SKILL.md +12 -0
  329. package/skills/vue-jsx-best-practices/SYNC.md +5 -0
  330. package/skills/vue-jsx-best-practices/reference/render-function-jsx-vue-vs-react.md +141 -0
  331. package/skills/vue-options/SKILL.md +98 -0
  332. package/skills/vue-options/references/lifecycle.md +107 -0
  333. package/skills/vue-options/references/mixins.md +96 -0
  334. package/skills/vue-options/references/props-emits.md +106 -0
  335. package/skills/vue-options/references/provide-inject.md +92 -0
  336. package/skills/vue-options/references/state.md +115 -0
  337. package/skills/vue-options-api-best-practices/LICENSE.md +21 -0
  338. package/skills/vue-options-api-best-practices/SKILL.md +23 -0
  339. package/skills/vue-options-api-best-practices/SYNC.md +5 -0
  340. package/skills/vue-options-api-best-practices/reference/no-arrow-functions-in-lifecycle-hooks.md +95 -0
  341. package/skills/vue-options-api-best-practices/reference/no-arrow-functions-in-methods.md +68 -0
  342. package/skills/vue-options-api-best-practices/reference/stateful-methods-lifecycle.md +61 -0
  343. package/skills/vue-options-api-best-practices/reference/ts-options-api-arrow-functions-validators.md +141 -0
  344. package/skills/vue-options-api-best-practices/reference/ts-options-api-computed-return-types.md +192 -0
  345. package/skills/vue-options-api-best-practices/reference/ts-options-api-proptype-complex-types.md +212 -0
  346. package/skills/vue-options-api-best-practices/reference/ts-options-api-provide-inject-limitations.md +135 -0
  347. package/skills/vue-options-api-best-practices/reference/ts-options-api-type-event-handlers.md +202 -0
  348. package/skills/vue-options-api-best-practices/reference/ts-options-api-use-definecomponent.md +172 -0
  349. package/skills/vue-options-api-best-practices/reference/ts-strict-mode-options-api.md +197 -0
  350. package/skills/vue-pinia-best-practices/LICENSE.md +21 -0
  351. package/skills/vue-pinia-best-practices/SKILL.md +21 -0
  352. package/skills/vue-pinia-best-practices/SYNC.md +5 -0
  353. package/skills/vue-pinia-best-practices/reference/pinia-no-active-pinia-error.md +248 -0
  354. package/skills/vue-pinia-best-practices/reference/pinia-setup-store-return-all-state.md +227 -0
  355. package/skills/vue-pinia-best-practices/reference/pinia-store-destructuring-breaks-reactivity.md +193 -0
  356. package/skills/vue-pinia-best-practices/reference/state-url-for-ephemeral-filters.md +238 -0
  357. package/skills/vue-pinia-best-practices/reference/state-use-pinia-for-large-apps.md +262 -0
  358. package/skills/vue-pinia-best-practices/reference/store-method-binding-parentheses.md +191 -0
  359. package/skills/vue-router-best-practices/LICENSE.md +21 -0
  360. package/skills/vue-router-best-practices/SKILL.md +23 -0
  361. package/skills/vue-router-best-practices/SYNC.md +5 -0
  362. package/skills/vue-router-best-practices/reference/router-beforeenter-no-param-trigger.md +167 -0
  363. package/skills/vue-router-best-practices/reference/router-beforerouteenter-no-this.md +176 -0
  364. package/skills/vue-router-best-practices/reference/router-guard-async-await-pattern.md +227 -0
  365. package/skills/vue-router-best-practices/reference/router-navigation-guard-infinite-loop.md +187 -0
  366. package/skills/vue-router-best-practices/reference/router-navigation-guard-next-deprecated.md +150 -0
  367. package/skills/vue-router-best-practices/reference/router-param-change-no-lifecycle.md +181 -0
  368. package/skills/vue-router-best-practices/reference/router-simple-routing-cleanup.md +209 -0
  369. package/skills/vue-router-best-practices/reference/router-use-vue-router-for-production.md +183 -0
  370. package/skills/vue-testing-best-practices/LICENSE.md +21 -0
  371. package/skills/vue-testing-best-practices/SKILL.md +29 -0
  372. package/skills/vue-testing-best-practices/SYNC.md +5 -0
  373. package/skills/vue-testing-best-practices/reference/async-component-testing.md +163 -0
  374. package/skills/vue-testing-best-practices/reference/teleport-testing-complexity.md +158 -0
  375. package/skills/vue-testing-best-practices/reference/testing-async-await-flushpromises.md +175 -0
  376. package/skills/vue-testing-best-practices/reference/testing-browser-vs-node-runners.md +208 -0
  377. package/skills/vue-testing-best-practices/reference/testing-component-blackbox-approach.md +144 -0
  378. package/skills/vue-testing-best-practices/reference/testing-composables-helper-wrapper.md +238 -0
  379. package/skills/vue-testing-best-practices/reference/testing-e2e-playwright-recommended.md +242 -0
  380. package/skills/vue-testing-best-practices/reference/testing-no-snapshot-only.md +197 -0
  381. package/skills/vue-testing-best-practices/reference/testing-pinia-store-setup.md +228 -0
  382. package/skills/vue-testing-best-practices/reference/testing-suspense-async-components.md +229 -0
  383. package/skills/vue-testing-best-practices/reference/testing-vitest-recommended-for-vue.md +204 -0
  384. package/skills/vueuse-functions/LICENSE.md +21 -0
  385. package/skills/vueuse-functions/SKILL.md +419 -0
  386. package/skills/vueuse-functions/SYNC.md +5 -0
  387. package/skills/vueuse-functions/references/computedAsync.md +195 -0
  388. package/skills/vueuse-functions/references/computedEager.md +62 -0
  389. package/skills/vueuse-functions/references/computedInject.md +137 -0
  390. package/skills/vueuse-functions/references/computedWithControl.md +98 -0
  391. package/skills/vueuse-functions/references/createEventHook.md +86 -0
  392. package/skills/vueuse-functions/references/createGenericProjection.md +25 -0
  393. package/skills/vueuse-functions/references/createGlobalState.md +95 -0
  394. package/skills/vueuse-functions/references/createInjectionState.md +215 -0
  395. package/skills/vueuse-functions/references/createProjection.md +31 -0
  396. package/skills/vueuse-functions/references/createRef.md +54 -0
  397. package/skills/vueuse-functions/references/createReusableTemplate.md +357 -0
  398. package/skills/vueuse-functions/references/createSharedComposable.md +42 -0
  399. package/skills/vueuse-functions/references/createTemplatePromise.md +306 -0
  400. package/skills/vueuse-functions/references/createUnrefFn.md +51 -0
  401. package/skills/vueuse-functions/references/extendRef.md +76 -0
  402. package/skills/vueuse-functions/references/from.md +80 -0
  403. package/skills/vueuse-functions/references/get.md +30 -0
  404. package/skills/vueuse-functions/references/injectLocal.md +35 -0
  405. package/skills/vueuse-functions/references/isDefined.md +31 -0
  406. package/skills/vueuse-functions/references/logicAnd.md +40 -0
  407. package/skills/vueuse-functions/references/logicNot.md +36 -0
  408. package/skills/vueuse-functions/references/logicOr.md +40 -0
  409. package/skills/vueuse-functions/references/makeDestructurable.md +41 -0
  410. package/skills/vueuse-functions/references/onClickOutside.md +221 -0
  411. package/skills/vueuse-functions/references/onElementRemoval.md +88 -0
  412. package/skills/vueuse-functions/references/onKeyStroke.md +211 -0
  413. package/skills/vueuse-functions/references/onLongPress.md +227 -0
  414. package/skills/vueuse-functions/references/onStartTyping.md +53 -0
  415. package/skills/vueuse-functions/references/provideLocal.md +37 -0
  416. package/skills/vueuse-functions/references/reactify.md +144 -0
  417. package/skills/vueuse-functions/references/reactifyObject.md +62 -0
  418. package/skills/vueuse-functions/references/reactiveComputed.md +34 -0
  419. package/skills/vueuse-functions/references/reactiveOmit.md +86 -0
  420. package/skills/vueuse-functions/references/reactivePick.md +106 -0
  421. package/skills/vueuse-functions/references/refAutoReset.md +46 -0
  422. package/skills/vueuse-functions/references/refDebounced.md +81 -0
  423. package/skills/vueuse-functions/references/refDefault.md +36 -0
  424. package/skills/vueuse-functions/references/refManualReset.md +44 -0
  425. package/skills/vueuse-functions/references/refThrottled.md +99 -0
  426. package/skills/vueuse-functions/references/refWithControl.md +146 -0
  427. package/skills/vueuse-functions/references/set.md +30 -0
  428. package/skills/vueuse-functions/references/syncRef.md +195 -0
  429. package/skills/vueuse-functions/references/syncRefs.md +128 -0
  430. package/skills/vueuse-functions/references/templateRef.md +86 -0
  431. package/skills/vueuse-functions/references/toObserver.md +38 -0
  432. package/skills/vueuse-functions/references/toReactive.md +41 -0
  433. package/skills/vueuse-functions/references/toRef.md +75 -0
  434. package/skills/vueuse-functions/references/toRefs.md +81 -0
  435. package/skills/vueuse-functions/references/tryOnBeforeMount.md +34 -0
  436. package/skills/vueuse-functions/references/tryOnBeforeUnmount.md +32 -0
  437. package/skills/vueuse-functions/references/tryOnMounted.md +34 -0
  438. package/skills/vueuse-functions/references/tryOnScopeDispose.md +31 -0
  439. package/skills/vueuse-functions/references/tryOnUnmounted.md +32 -0
  440. package/skills/vueuse-functions/references/unrefElement.md +54 -0
  441. package/skills/vueuse-functions/references/until.md +161 -0
  442. package/skills/vueuse-functions/references/useAbs.md +31 -0
  443. package/skills/vueuse-functions/references/useActiveElement.md +85 -0
  444. package/skills/vueuse-functions/references/useAnimate.md +181 -0
  445. package/skills/vueuse-functions/references/useArrayDifference.md +84 -0
  446. package/skills/vueuse-functions/references/useArrayEvery.md +59 -0
  447. package/skills/vueuse-functions/references/useArrayFilter.md +63 -0
  448. package/skills/vueuse-functions/references/useArrayFind.md +50 -0
  449. package/skills/vueuse-functions/references/useArrayFindIndex.md +59 -0
  450. package/skills/vueuse-functions/references/useArrayFindLast.md +52 -0
  451. package/skills/vueuse-functions/references/useArrayIncludes.md +63 -0
  452. package/skills/vueuse-functions/references/useArrayJoin.md +74 -0
  453. package/skills/vueuse-functions/references/useArrayMap.md +59 -0
  454. package/skills/vueuse-functions/references/useArrayReduce.md +81 -0
  455. package/skills/vueuse-functions/references/useArraySome.md +59 -0
  456. package/skills/vueuse-functions/references/useArrayUnique.md +76 -0
  457. package/skills/vueuse-functions/references/useAsyncQueue.md +136 -0
  458. package/skills/vueuse-functions/references/useAsyncState.md +185 -0
  459. package/skills/vueuse-functions/references/useAsyncValidator.md +70 -0
  460. package/skills/vueuse-functions/references/useAuth.md +123 -0
  461. package/skills/vueuse-functions/references/useAverage.md +36 -0
  462. package/skills/vueuse-functions/references/useAxios.md +325 -0
  463. package/skills/vueuse-functions/references/useBase64.md +136 -0
  464. package/skills/vueuse-functions/references/useBattery.md +78 -0
  465. package/skills/vueuse-functions/references/useBluetooth.md +175 -0
  466. package/skills/vueuse-functions/references/useBreakpoints.md +172 -0
  467. package/skills/vueuse-functions/references/useBroadcastChannel.md +74 -0
  468. package/skills/vueuse-functions/references/useBrowserLocation.md +83 -0
  469. package/skills/vueuse-functions/references/useCached.md +52 -0
  470. package/skills/vueuse-functions/references/useCeil.md +31 -0
  471. package/skills/vueuse-functions/references/useChangeCase.md +79 -0
  472. package/skills/vueuse-functions/references/useClamp.md +85 -0
  473. package/skills/vueuse-functions/references/useClipboard.md +123 -0
  474. package/skills/vueuse-functions/references/useClipboardItems.md +94 -0
  475. package/skills/vueuse-functions/references/useCloned.md +91 -0
  476. package/skills/vueuse-functions/references/useColorMode.md +172 -0
  477. package/skills/vueuse-functions/references/useConfirmDialog.md +159 -0
  478. package/skills/vueuse-functions/references/useCookies.md +162 -0
  479. package/skills/vueuse-functions/references/useCountdown.md +105 -0
  480. package/skills/vueuse-functions/references/useCounter.md +86 -0
  481. package/skills/vueuse-functions/references/useCssSupports.md +35 -0
  482. package/skills/vueuse-functions/references/useCssVar.md +50 -0
  483. package/skills/vueuse-functions/references/useCurrentElement.md +61 -0
  484. package/skills/vueuse-functions/references/useCycleList.md +75 -0
  485. package/skills/vueuse-functions/references/useDark.md +144 -0
  486. package/skills/vueuse-functions/references/useDateFormat.md +145 -0
  487. package/skills/vueuse-functions/references/useDebounceFn.md +100 -0
  488. package/skills/vueuse-functions/references/useDebouncedRefHistory.md +40 -0
  489. package/skills/vueuse-functions/references/useDeviceMotion.md +86 -0
  490. package/skills/vueuse-functions/references/useDeviceOrientation.md +62 -0
  491. package/skills/vueuse-functions/references/useDevicePixelRatio.md +44 -0
  492. package/skills/vueuse-functions/references/useDevicesList.md +90 -0
  493. package/skills/vueuse-functions/references/useDisplayMedia.md +71 -0
  494. package/skills/vueuse-functions/references/useDocumentVisibility.md +45 -0
  495. package/skills/vueuse-functions/references/useDraggable.md +317 -0
  496. package/skills/vueuse-functions/references/useDrauu.md +65 -0
  497. package/skills/vueuse-functions/references/useDropZone.md +83 -0
  498. package/skills/vueuse-functions/references/useElementBounding.md +131 -0
  499. package/skills/vueuse-functions/references/useElementByPoint.md +48 -0
  500. package/skills/vueuse-functions/references/useElementHover.md +79 -0
  501. package/skills/vueuse-functions/references/useElementSize.md +78 -0
  502. package/skills/vueuse-functions/references/useElementVisibility.md +123 -0
  503. package/skills/vueuse-functions/references/useEventBus.md +101 -0
  504. package/skills/vueuse-functions/references/useEventListener.md +226 -0
  505. package/skills/vueuse-functions/references/useEventSource.md +204 -0
  506. package/skills/vueuse-functions/references/useExtractedObservable.md +198 -0
  507. package/skills/vueuse-functions/references/useEyeDropper.md +71 -0
  508. package/skills/vueuse-functions/references/useFavicon.md +67 -0
  509. package/skills/vueuse-functions/references/useFetch.md +546 -0
  510. package/skills/vueuse-functions/references/useFileDialog.md +91 -0
  511. package/skills/vueuse-functions/references/useFileSystemAccess.md +162 -0
  512. package/skills/vueuse-functions/references/useFirestore.md +129 -0
  513. package/skills/vueuse-functions/references/useFloor.md +31 -0
  514. package/skills/vueuse-functions/references/useFocus.md +99 -0
  515. package/skills/vueuse-functions/references/useFocusTrap.md +245 -0
  516. package/skills/vueuse-functions/references/useFocusWithin.md +57 -0
  517. package/skills/vueuse-functions/references/useFps.md +28 -0
  518. package/skills/vueuse-functions/references/useFullscreen.md +75 -0
  519. package/skills/vueuse-functions/references/useFuse.md +107 -0
  520. package/skills/vueuse-functions/references/useGamepad.md +222 -0
  521. package/skills/vueuse-functions/references/useGeolocation.md +85 -0
  522. package/skills/vueuse-functions/references/useIDBKeyval.md +93 -0
  523. package/skills/vueuse-functions/references/useIdle.md +88 -0
  524. package/skills/vueuse-functions/references/useImage.md +86 -0
  525. package/skills/vueuse-functions/references/useInfiniteScroll.md +157 -0
  526. package/skills/vueuse-functions/references/useIntersectionObserver.md +118 -0
  527. package/skills/vueuse-functions/references/useInterval.md +112 -0
  528. package/skills/vueuse-functions/references/useIntervalFn.md +50 -0
  529. package/skills/vueuse-functions/references/useIpcRenderer.md +144 -0
  530. package/skills/vueuse-functions/references/useIpcRendererInvoke.md +58 -0
  531. package/skills/vueuse-functions/references/useIpcRendererOn.md +52 -0
  532. package/skills/vueuse-functions/references/useJwt.md +57 -0
  533. package/skills/vueuse-functions/references/useKeyModifier.md +87 -0
  534. package/skills/vueuse-functions/references/useLastChanged.md +63 -0
  535. package/skills/vueuse-functions/references/useLocalStorage.md +41 -0
  536. package/skills/vueuse-functions/references/useMagicKeys.md +245 -0
  537. package/skills/vueuse-functions/references/useManualRefHistory.md +204 -0
  538. package/skills/vueuse-functions/references/useMath.md +47 -0
  539. package/skills/vueuse-functions/references/useMax.md +36 -0
  540. package/skills/vueuse-functions/references/useMediaControls.md +571 -0
  541. package/skills/vueuse-functions/references/useMediaQuery.md +53 -0
  542. package/skills/vueuse-functions/references/useMemoize.md +175 -0
  543. package/skills/vueuse-functions/references/useMemory.md +71 -0
  544. package/skills/vueuse-functions/references/useMin.md +36 -0
  545. package/skills/vueuse-functions/references/useMounted.md +38 -0
  546. package/skills/vueuse-functions/references/useMouse.md +113 -0
  547. package/skills/vueuse-functions/references/useMouseInElement.md +123 -0
  548. package/skills/vueuse-functions/references/useMousePressed.md +112 -0
  549. package/skills/vueuse-functions/references/useMutationObserver.md +61 -0
  550. package/skills/vueuse-functions/references/useNProgress.md +78 -0
  551. package/skills/vueuse-functions/references/useNavigatorLanguage.md +57 -0
  552. package/skills/vueuse-functions/references/useNetwork.md +106 -0
  553. package/skills/vueuse-functions/references/useNow.md +79 -0
  554. package/skills/vueuse-functions/references/useObjectUrl.md +55 -0
  555. package/skills/vueuse-functions/references/useObservable.md +91 -0
  556. package/skills/vueuse-functions/references/useOffsetPagination.md +199 -0
  557. package/skills/vueuse-functions/references/useOnline.md +41 -0
  558. package/skills/vueuse-functions/references/usePageLeave.md +42 -0
  559. package/skills/vueuse-functions/references/useParallax.md +58 -0
  560. package/skills/vueuse-functions/references/useParentElement.md +54 -0
  561. package/skills/vueuse-functions/references/usePerformanceObserver.md +48 -0
  562. package/skills/vueuse-functions/references/usePermission.md +79 -0
  563. package/skills/vueuse-functions/references/usePointer.md +89 -0
  564. package/skills/vueuse-functions/references/usePointerLock.md +60 -0
  565. package/skills/vueuse-functions/references/usePointerSwipe.md +80 -0
  566. package/skills/vueuse-functions/references/usePrecision.md +49 -0
  567. package/skills/vueuse-functions/references/usePreferredColorScheme.md +42 -0
  568. package/skills/vueuse-functions/references/usePreferredContrast.md +42 -0
  569. package/skills/vueuse-functions/references/usePreferredDark.md +41 -0
  570. package/skills/vueuse-functions/references/usePreferredLanguages.md +41 -0
  571. package/skills/vueuse-functions/references/usePreferredReducedMotion.md +42 -0
  572. package/skills/vueuse-functions/references/usePreferredReducedTransparency.md +42 -0
  573. package/skills/vueuse-functions/references/usePrevious.md +40 -0
  574. package/skills/vueuse-functions/references/useProjection.md +38 -0
  575. package/skills/vueuse-functions/references/useQRCode.md +53 -0
  576. package/skills/vueuse-functions/references/useRTDB.md +83 -0
  577. package/skills/vueuse-functions/references/useRafFn.md +68 -0
  578. package/skills/vueuse-functions/references/useRefHistory.md +285 -0
  579. package/skills/vueuse-functions/references/useResizeObserver.md +109 -0
  580. package/skills/vueuse-functions/references/useRound.md +31 -0
  581. package/skills/vueuse-functions/references/useRouteHash.md +27 -0
  582. package/skills/vueuse-functions/references/useRouteParams.md +38 -0
  583. package/skills/vueuse-functions/references/useRouteQuery.md +79 -0
  584. package/skills/vueuse-functions/references/useSSRWidth.md +47 -0
  585. package/skills/vueuse-functions/references/useScreenOrientation.md +96 -0
  586. package/skills/vueuse-functions/references/useScreenSafeArea.md +60 -0
  587. package/skills/vueuse-functions/references/useScriptTag.md +116 -0
  588. package/skills/vueuse-functions/references/useScroll.md +238 -0
  589. package/skills/vueuse-functions/references/useScrollLock.md +66 -0
  590. package/skills/vueuse-functions/references/useSessionStorage.md +41 -0
  591. package/skills/vueuse-functions/references/useShare.md +68 -0
  592. package/skills/vueuse-functions/references/useSortable.md +235 -0
  593. package/skills/vueuse-functions/references/useSorted.md +90 -0
  594. package/skills/vueuse-functions/references/useSpeechRecognition.md +94 -0
  595. package/skills/vueuse-functions/references/useSpeechSynthesis.md +105 -0
  596. package/skills/vueuse-functions/references/useStepper.md +137 -0
  597. package/skills/vueuse-functions/references/useStorage.md +278 -0
  598. package/skills/vueuse-functions/references/useStorageAsync.md +136 -0
  599. package/skills/vueuse-functions/references/useStyleTag.md +131 -0
  600. package/skills/vueuse-functions/references/useSubject.md +77 -0
  601. package/skills/vueuse-functions/references/useSubscription.md +33 -0
  602. package/skills/vueuse-functions/references/useSum.md +36 -0
  603. package/skills/vueuse-functions/references/useSupported.md +29 -0
  604. package/skills/vueuse-functions/references/useSwipe.md +75 -0
  605. package/skills/vueuse-functions/references/useTemplateRefsList.md +37 -0
  606. package/skills/vueuse-functions/references/useTextDirection.md +75 -0
  607. package/skills/vueuse-functions/references/useTextSelection.md +40 -0
  608. package/skills/vueuse-functions/references/useTextareaAutosize.md +97 -0
  609. package/skills/vueuse-functions/references/useThrottleFn.md +57 -0
  610. package/skills/vueuse-functions/references/useThrottledRefHistory.md +47 -0
  611. package/skills/vueuse-functions/references/useTimeAgo.md +154 -0
  612. package/skills/vueuse-functions/references/useTimeAgoIntl.md +117 -0
  613. package/skills/vueuse-functions/references/useTimeout.md +113 -0
  614. package/skills/vueuse-functions/references/useTimeoutFn.md +51 -0
  615. package/skills/vueuse-functions/references/useTimeoutPoll.md +47 -0
  616. package/skills/vueuse-functions/references/useTimestamp.md +89 -0
  617. package/skills/vueuse-functions/references/useTitle.md +113 -0
  618. package/skills/vueuse-functions/references/useToNumber.md +54 -0
  619. package/skills/vueuse-functions/references/useToString.md +34 -0
  620. package/skills/vueuse-functions/references/useToggle.md +103 -0
  621. package/skills/vueuse-functions/references/useTransition.md +265 -0
  622. package/skills/vueuse-functions/references/useTrunc.md +33 -0
  623. package/skills/vueuse-functions/references/useUrlSearchParams.md +121 -0
  624. package/skills/vueuse-functions/references/useUserMedia.md +1138 -0
  625. package/skills/vueuse-functions/references/useVModel.md +182 -0
  626. package/skills/vueuse-functions/references/useVModels.md +67 -0
  627. package/skills/vueuse-functions/references/useVibrate.md +87 -0
  628. package/skills/vueuse-functions/references/useVirtualList.md +182 -0
  629. package/skills/vueuse-functions/references/useWakeLock.md +50 -0
  630. package/skills/vueuse-functions/references/useWebNotification.md +176 -0
  631. package/skills/vueuse-functions/references/useWebSocket.md +299 -0
  632. package/skills/vueuse-functions/references/useWebWorker.md +60 -0
  633. package/skills/vueuse-functions/references/useWebWorkerFn.md +102 -0
  634. package/skills/vueuse-functions/references/useWindowFocus.md +46 -0
  635. package/skills/vueuse-functions/references/useWindowScroll.md +61 -0
  636. package/skills/vueuse-functions/references/useWindowSize.md +76 -0
  637. package/skills/vueuse-functions/references/useZoomFactor.md +53 -0
  638. package/skills/vueuse-functions/references/useZoomLevel.md +53 -0
  639. package/skills/vueuse-functions/references/watchArray.md +53 -0
  640. package/skills/vueuse-functions/references/watchAtMost.md +55 -0
  641. package/skills/vueuse-functions/references/watchDebounced.md +101 -0
  642. package/skills/vueuse-functions/references/watchDeep.md +54 -0
  643. package/skills/vueuse-functions/references/watchExtractedObservable.md +192 -0
  644. package/skills/vueuse-functions/references/watchIgnorable.md +120 -0
  645. package/skills/vueuse-functions/references/watchImmediate.md +44 -0
  646. package/skills/vueuse-functions/references/watchOnce.md +41 -0
  647. package/skills/vueuse-functions/references/watchPausable.md +86 -0
  648. package/skills/vueuse-functions/references/watchThrottled.md +108 -0
  649. package/skills/vueuse-functions/references/watchTriggerable.md +98 -0
  650. package/skills/vueuse-functions/references/watchWithFilter.md +54 -0
  651. package/skills/vueuse-functions/references/whenever.md +100 -0
  652. package/skills/web-design-guidelines/SKILL.md +39 -0
  653. package/skills/web-design-guidelines/SYNC.md +5 -0
  654. package/tsconfig.json +17 -0
@@ -0,0 +1,5 @@
1
+ # Sync Info
2
+
3
+ - **Source:** `vendor/web-design-guidelines/skills/vercel-cli-with-tokens`
4
+ - **Git SHA:** `9aec8ee6aaf702e49312a071e672f1c1b7b7e948`
5
+ - **Synced:** 2026-03-24
@@ -0,0 +1,90 @@
1
+ ---
2
+ name: vue
3
+ description: Vue 3 Composition API — <script setup>, reactivity (shallowRef/ref), props without destructure, computed, watch, provide/inject, and composables. Use when the project uses modern Vue 3 Composition API style.
4
+ metadata:
5
+ author: Vũ Lưu
6
+ version: "2026.3.23"
7
+ source: Hand-written based on https://vuejs.org and instructions/vue.md
8
+ ---
9
+
10
+ # Vue 3 (Composition API)
11
+
12
+ > This skill focuses on the **Composition API** and **`<script setup>`** explicitly strongly typed with TypeScript.
13
+
14
+ ## Key Rules (from instructions)
15
+
16
+ - **Prefer TypeScript** over JavaScript (`<script setup lang="ts">`).
17
+ - **Always use Composition API** over Options API.
18
+ - **Prefer `<script setup>`** over explicit `setup()` functions.
19
+ - **Prefer `shallowRef` over `ref`** for performance if deep reactivity is not used.
20
+ - **Discourage Reactive Props Destructure** (use `props.myProp` instead).
21
+
22
+ ## Core
23
+
24
+ | Topic | Description | Reference |
25
+ |-------|-------------|-----------|
26
+ | State & Reactivity | `shallowRef`, `ref`, `computed`, `watch` | [state](references/state.md) |
27
+ | Props & Emits | `defineProps` (no destructuring), `defineEmits` | [props-emits](references/props-emits.md) |
28
+ | Lifecycle Hooks | `onMounted`, `onUpdated`, `onUnmounted` | [lifecycle](references/lifecycle.md) |
29
+
30
+ ## Features & Patterns
31
+
32
+ | Topic | Description | Reference |
33
+ |-------|-------------|-----------|
34
+ | Composables | State logic reuse (instead of Mixins) | [composables](references/composables.md) |
35
+ | Provide / Inject | Dependency injection across deep component trees | [provide-inject](references/provide-inject.md) |
36
+
37
+ ## Quick Reference
38
+
39
+ ### Full SFC Template (`<script setup>`)
40
+
41
+ ```vue
42
+ <script setup lang="ts">
43
+ import { shallowRef, computed, watch, onMounted } from 'vue'
44
+
45
+ // -- Props & Emits --
46
+ interface Props {
47
+ title: string
48
+ count?: number
49
+ }
50
+ // ❌ Do NOT destructure props, keep the `props` object
51
+ const props = withDefaults(defineProps<Props>(), {
52
+ count: 0
53
+ })
54
+
55
+ const emit = defineEmits<{
56
+ update: [newCount: number]
57
+ }>()
58
+
59
+ // -- State --
60
+ // ✅ Prefer shallowRef if deep tracking isn't needed
61
+ const localCount = shallowRef(props.count)
62
+
63
+ // -- Computed --
64
+ const doubled = computed(() => localCount.value * 2)
65
+
66
+ // -- Watchers --
67
+ watch(() => props.count, (newVal) => {
68
+ localCount.value = newVal
69
+ })
70
+
71
+ // -- Methods --
72
+ function increment() {
73
+ localCount.value++
74
+ emit('update', localCount.value)
75
+ }
76
+
77
+ // -- Lifecycle --
78
+ onMounted(() => {
79
+ console.log('Component mounted')
80
+ })
81
+ </script>
82
+
83
+ <template>
84
+ <div>
85
+ <h1>{{ props.title }}</h1>
86
+ <p>Count: {{ localCount }} | Doubled: {{ doubled }}</p>
87
+ <button @click="increment">Increment</button>
88
+ </div>
89
+ </template>
90
+ ```
@@ -0,0 +1,54 @@
1
+ # Composables
2
+
3
+ **Rule:** Always use Composables instead of Mixins.
4
+
5
+ Composables are plain functions that use the Composition API to encapsulate and reuse stateful logic.
6
+
7
+ ## 1. Defining a Composable
8
+
9
+ By convention, composable functions start with `use`. They should return `refs` or `computed` properties so components can choose what to expose or destructure.
10
+
11
+ ```ts
12
+ // composables/useMouse.ts
13
+ import { shallowRef, onMounted, onUnmounted } from 'vue'
14
+
15
+ export function useMouse() {
16
+ // Encapsulated state
17
+ const x = shallowRef(0)
18
+ const y = shallowRef(0)
19
+
20
+ // Encapsulated logic & side-effects
21
+ function update(event: MouseEvent) {
22
+ x.value = event.pageX
23
+ y.value = event.pageY
24
+ }
25
+
26
+ onMounted(() => window.addEventListener('mousemove', update))
27
+ onUnmounted(() => window.removeEventListener('mousemove', update))
28
+
29
+ // Return values (not reactive destructuring here, returning the refs directly)
30
+ return { x, y }
31
+ }
32
+ ```
33
+
34
+ ## 2. Using the Composable
35
+
36
+ ```vue
37
+ <script setup lang="ts">
38
+ import { useMouse } from './composables/useMouse'
39
+
40
+ // Consume the composable
41
+ const { x, y } = useMouse()
42
+ </script>
43
+
44
+ <template>
45
+ Mouse position: {{ x }}, {{ y }}
46
+ </template>
47
+ ```
48
+
49
+ ## Mixins vs Composables
50
+
51
+ Why Composables are strictly preferred:
52
+ - **No Property Name Conflicts:** You dynamically rename destructured properties when calling the composable.
53
+ - **Clear Origins:** You can easily trace exactly which state/method came from which composable.
54
+ - **TypeScript Support:** Composables are regular functions and type-check perfectly without advanced trickery.
@@ -0,0 +1,31 @@
1
+ # Lifecycle Hooks (`<script setup>`)
2
+
3
+ In Composition API, lifecycle hooks are imported functions that you call inside `setup()`.
4
+
5
+ ## Core Hooks
6
+
7
+ ```vue
8
+ <script setup lang="ts">
9
+ import { onMounted, onUpdated, onUnmounted } from 'vue'
10
+
11
+ onMounted(() => {
12
+ console.log('The component is now mounted to the DOM.')
13
+ // E.g., fetch data, initialize third-party libraries, attach global listeners
14
+ })
15
+
16
+ onUpdated(() => {
17
+ console.log('Component updated its DOM because reactive state changed.')
18
+ })
19
+
20
+ onUnmounted(() => {
21
+ console.log('The component is being removed from the DOM.')
22
+ // E.g., cleanup intervals, remove event listeners (if not scoped to the element)
23
+ })
24
+ </script>
25
+ ```
26
+
27
+ ## Usage Rules
28
+
29
+ - Hooks **must be called synchronously** during the `setup()` execution.
30
+ - You can call a hook multiple times in the same component, and all callbacks will be executed in the order they were registered.
31
+ - Avoid placing heavy initialization tasks directly in the component root; place DOM-dependent logic inside `onMounted`.
@@ -0,0 +1,62 @@
1
+ # Props and Emits (`<script setup>`)
2
+
3
+ ## `defineProps` (No Reactive Destructure!)
4
+
5
+ **Rule:** Discourage using Reactive Props Destructure. Destructuring `props` removes primitive reactivity, leading to bugs. Always use the `props.` object prefix instead.
6
+
7
+ ```vue
8
+ <script setup lang="ts">
9
+ // ❌ BAD: Destructuring the props object breaks reactivity!
10
+ // const { title } = defineProps<{ title: string }>()
11
+
12
+ // ✅ GOOD: Keep the `props` reference intact.
13
+ const props = defineProps<{
14
+ title: string
15
+ items: string[]
16
+ }>()
17
+
18
+ console.log(props.title) // Safe
19
+ </script>
20
+
21
+ <template>
22
+ <h1>{{ props.title }}</h1>
23
+ </template>
24
+ ```
25
+
26
+ ### With Default Values (`withDefaults`)
27
+
28
+ ```vue
29
+ <script setup lang="ts">
30
+ interface MenuProps {
31
+ id: number
32
+ isActive?: boolean
33
+ label?: string
34
+ }
35
+
36
+ // ✅ Provide default values safely without destructuring
37
+ const props = withDefaults(defineProps<MenuProps>(), {
38
+ isActive: false,
39
+ label: 'Unknown Item'
40
+ })
41
+ </script>
42
+ ```
43
+
44
+ ## `defineEmits`
45
+
46
+ Use TypeScript syntax to strictly type the events your component can emit.
47
+
48
+ ```vue
49
+ <script setup lang="ts">
50
+ // Best Practice: Type-based declaration
51
+ const emit = defineEmits<{
52
+ // eventName: [payloadType1, payloadType2]
53
+ open: [id: number]
54
+ update: [value: string, timestamp: Date]
55
+ close: []
56
+ }>()
57
+
58
+ function triggerUpdate() {
59
+ emit('update', 'Success!', new Date())
60
+ }
61
+ </script>
62
+ ```
@@ -0,0 +1,47 @@
1
+ # Provide / Inject (`<script setup>`)
2
+
3
+ Provide and Inject are used for **dependency injection** to pass data deep into the component tree without prop drilling.
4
+
5
+ ## Usage
6
+
7
+ ### 1. In the Ancestor Component (`provide`)
8
+
9
+ ```vue
10
+ <!-- App.vue -->
11
+ <script setup lang="ts">
12
+ import { provide, shallowRef } from 'vue'
13
+
14
+ const theme = shallowRef('dark')
15
+
16
+ // Provide the value (it remains reactive if passed directly)
17
+ provide('theme-context', theme)
18
+
19
+ function toggleTheme() {
20
+ theme.value = theme.value === 'dark' ? 'light' : 'dark'
21
+ }
22
+ </script>
23
+ ```
24
+
25
+ ### 2. In the Descendant Component (`inject`)
26
+
27
+ ```vue
28
+ <!-- DeepChild.vue -->
29
+ <script setup lang="ts">
30
+ import { inject, Ref } from 'vue'
31
+
32
+ // Inject the value, providing a fallback default
33
+ const theme = inject<Ref<string>>('theme-context', shallowRef('light'))
34
+ </script>
35
+
36
+ <template>
37
+ <div :class="`theme-${theme}`">
38
+ Current theme is {{ theme }}
39
+ </div>
40
+ </template>
41
+ ```
42
+
43
+ ## Best Practices
44
+
45
+ - Always type your injected properties clearly or specify defaults.
46
+ - Ideally, **keep mutations in the provider** to preserve the one-way data flow. If the descendant needs to change the data, provide an update function alongside the state.
47
+ - Use `Symbol` keys for enterprise scale apps to avoid naming collisions.
@@ -0,0 +1,65 @@
1
+ # State & Reactivity (`<script setup>`)
2
+
3
+ The Composition API allows you to declare reactive state flexibly.
4
+
5
+ ## `shallowRef` vs `ref` (Rule: Prefer `shallowRef` if possible)
6
+
7
+ By default, `ref` will make the entire structure deeply reactive, which can have an unintended performance cost for large datasets that only get replaced entirely.
8
+
9
+ ```ts
10
+ import { ref, shallowRef } from 'vue'
11
+
12
+ // ✅ PREFERRED: Using shallowRef when deep reactivity isn't needed
13
+ // Use this if you only intend to overwrite the .value property and don't mutate its inner contents.
14
+ const rawDataList = shallowRef<Item[]>([])
15
+
16
+ // Updating shallowRef (must reassign .value)
17
+ rawDataList.value = [...newData]
18
+
19
+ // ⚠️ Use `ref` only when you specifically need to mutate inner nested object properties
20
+ const user = ref({ name: 'Alice', age: 30 })
21
+ user.value.age++ // Deeply reactive, triggers updates
22
+ ```
23
+
24
+ ## `computed` (Derived State)
25
+
26
+ Computed properties automatically update when their reactive dependencies change.
27
+
28
+ ```ts
29
+ import { shallowRef, computed } from 'vue'
30
+
31
+ const count = shallowRef(1)
32
+ const doubled = computed(() => count.value * 2)
33
+ ```
34
+
35
+ ## `watch` & `watchEffect` (Side Effects)
36
+
37
+ Use `watch` to run side effects in response to reactive state changes.
38
+
39
+ ```ts
40
+ import { shallowRef, watch, watchEffect } from 'vue'
41
+
42
+ const question = shallowRef('')
43
+ const answer = shallowRef('Thinking...')
44
+
45
+ // watch (explicit target, old/new values)
46
+ watch(question, async (newQuestion, oldQuestion) => {
47
+ if (newQuestion.includes('?')) {
48
+ answer.value = 'Fetching answer!'
49
+ // call an API...
50
+ }
51
+ })
52
+
53
+ // watch a getter for specific property access
54
+ const state = shallowRef({ id: 1, name: 'bob' })
55
+
56
+ watch(
57
+ () => state.value.id,
58
+ (newId) => { console.log('ID triggered watch:', newId) }
59
+ )
60
+
61
+ // watchEffect (auto-track dependencies used synchronously inside the callback)
62
+ watchEffect(() => {
63
+ console.log(`Current answer is: ${answer.value}`)
64
+ })
65
+ ```
@@ -0,0 +1,33 @@
1
+ ---
2
+ name: vue-antdv-tailwind
3
+ description: Best practices for mixing Ant Design Vue components with Tailwind CSS utility classes. Use this skill to keep styling consistent without custom CSS files.
4
+ metadata:
5
+ author: Vũ Lưu
6
+ version: "2026.3.23"
7
+ source: Hand-written based on builderx_spa conventions
8
+ ---
9
+
10
+ # Ant Design Vue + Tailwind CSS
11
+
12
+ > BuilderX SPA mixes Ant Design Vue's robust component library with Tailwind CSS's utility engine.
13
+
14
+ ## Core
15
+
16
+ | Topic | Description | Reference |
17
+ |-------|-------------|-----------|
18
+ | Styling Rules | How to properly mix AntD and Tailwind | [styling-rules](references/styling-rules.md) |
19
+
20
+ ## Quick Reference
21
+
22
+ ```vue
23
+ <template>
24
+ <div class="flex items-center justify-between p-4 bg-white rounded shadow">
25
+ <h3 class="text-lg font-bold text-gray-800">Settings</h3>
26
+
27
+ <!-- Override/extend AntD with Tailwind -->
28
+ <a-button type="primary" class="bg-blue-600 hover:bg-blue-700">
29
+ Save
30
+ </a-button>
31
+ </div>
32
+ </template>
33
+ ```
@@ -0,0 +1,61 @@
1
+ # Styling Rules (AntD + Tailwind)
2
+
3
+ ## 1. Respect Component Responsibilities
4
+
5
+ - **Ant Design Vue (`<a-...>`)**: Use for functional structure (Drawers, Modals, Forms, Buttons, Selects, Tables).
6
+ - **Tailwind CSS (`class="..."`)**: Use for layout (`flex`, `grid`, `absolute`), spacing (`m-4`, `p-2`), typography (`text-center`, `text-lg`), and colors.
7
+
8
+ ## 2. Avoid Custom `<style>` Blocks
9
+
10
+ Whenever possible, avoid writing custom `.scss` or `.css`. Instead of:
11
+
12
+ ```vue
13
+ <!-- ❌ BAD: Writing custom CSS classes for layout -->
14
+ <template>
15
+ <div class="header-container">
16
+ <a-button>Click Me</a-button>
17
+ </div>
18
+ </template>
19
+
20
+ <style scoped>
21
+ .header-container {
22
+ display: flex;
23
+ justify-content: flex-end;
24
+ padding: 16px;
25
+ background-color: #f8f9fa;
26
+ }
27
+ </style>
28
+ ```
29
+
30
+ Do this:
31
+
32
+ ```vue
33
+ <!-- ✅ GOOD: Use Tailwind directly -->
34
+ <template>
35
+ <div class="flex justify-end p-4 bg-gray-50">
36
+ <a-button>Click Me</a-button>
37
+ </div>
38
+ </template>
39
+ ```
40
+
41
+ ## 3. Styling Ant Design Internals
42
+
43
+ Sometimes AntD wraps elements deeply and you need to style inner parts. Use Tailwind's arbitrary selectors or general cascading, rather than `::v-deep`.
44
+
45
+ However, for simple spacing, you can always apply Tailwind directly to the Ant component.
46
+
47
+ ```vue
48
+ <!-- Adds margin right to the AntD button -->
49
+ <a-button class="mr-2">Cancel</a-button>
50
+ ```
51
+
52
+ ## 4. Theme Integration
53
+
54
+ If modifying AntD primary colors globally, do so in Vue/Vite configuration configuration. If you need dynamic or context-specific color overrides in a template, Tailwind arbitrary values are highly reliable:
55
+
56
+ ```vue
57
+ <a-button class="!bg-[#FF5722] !border-none !text-white">
58
+ Danger Actions
59
+ </a-button>
60
+ ```
61
+ *(Notice the `!` to force `!important` so it overrides AntD's core rules)*
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 hyf0, SerKo <https://github.com/serkodev>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -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,5 @@
1
+ # Sync Info
2
+
3
+ - **Source:** `vendor/vuejs-ai/skills/vue-best-practices`
4
+ - **Git SHA:** `f3dd1bf4d3ac78331bdc903e4519d561c538ca6a`
5
+ - **Synced:** 2026-03-24