ads-fe 0.0.1
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.
- package/README.md +99 -0
- package/dist/cli.js +545 -0
- package/dist/meta.js +93 -0
- package/package.json +43 -0
- package/skill.md +66 -0
- package/skills/core/SKILL.md +66 -0
- package/skills/core/references/app-development.md +45 -0
- package/skills/core/references/git.md +66 -0
- package/skills/core/references/monorepo.md +124 -0
- package/skills/element-plus-vue3/LICENSE.md +405 -0
- package/skills/element-plus-vue3/LICENSE.txt +202 -0
- package/skills/element-plus-vue3/SKILL.md +218 -0
- package/skills/element-plus-vue3/SYNC.md +5 -0
- package/skills/element-plus-vue3/api/component-api.md +94 -0
- package/skills/element-plus-vue3/api/global-config.md +89 -0
- package/skills/element-plus-vue3/api/props-and-events.md +101 -0
- package/skills/element-plus-vue3/examples/components/button.md +99 -0
- package/skills/element-plus-vue3/examples/components/date-picker.md +115 -0
- package/skills/element-plus-vue3/examples/components/dialog.md +106 -0
- package/skills/element-plus-vue3/examples/components/form.md +127 -0
- package/skills/element-plus-vue3/examples/components/input.md +123 -0
- package/skills/element-plus-vue3/examples/components/message.md +93 -0
- package/skills/element-plus-vue3/examples/components/overview.md +59 -0
- package/skills/element-plus-vue3/examples/components/select.md +133 -0
- package/skills/element-plus-vue3/examples/components/table.md +166 -0
- package/skills/element-plus-vue3/examples/guide/design.md +68 -0
- package/skills/element-plus-vue3/examples/guide/global-config.md +95 -0
- package/skills/element-plus-vue3/examples/guide/i18n.md +95 -0
- package/skills/element-plus-vue3/examples/guide/installation.md +110 -0
- package/skills/element-plus-vue3/examples/guide/quick-start.md +103 -0
- package/skills/element-plus-vue3/examples/guide/theme.md +78 -0
- package/skills/element-plus-vue3/templates/component-usage.md +92 -0
- package/skills/element-plus-vue3/templates/installation.md +82 -0
- package/skills/element-plus-vue3/templates/project-setup.md +83 -0
- package/skills/node/LICENSE.md +21 -0
- package/skills/node/SKILL.md +94 -0
- package/skills/node/SYNC.md +5 -0
- package/skills/node/rules/assets/graceful-server.test.ts +88 -0
- package/skills/node/rules/assets/graceful-server.ts +80 -0
- package/skills/node/rules/async-patterns.md +136 -0
- package/skills/node/rules/caching.md +198 -0
- package/skills/node/rules/environment.md +253 -0
- package/skills/node/rules/error-handling.md +164 -0
- package/skills/node/rules/flaky-tests.md +439 -0
- package/skills/node/rules/graceful-shutdown.md +204 -0
- package/skills/node/rules/logging.md +205 -0
- package/skills/node/rules/modules.md +105 -0
- package/skills/node/rules/node-modules-exploration.md +172 -0
- package/skills/node/rules/performance.md +130 -0
- package/skills/node/rules/profiling.md +183 -0
- package/skills/node/rules/streams.md +213 -0
- package/skills/node/rules/stuck-processes-and-tests.md +124 -0
- package/skills/node/rules/testing.md +218 -0
- package/skills/node/rules/typescript.md +262 -0
- package/skills/node/tile.json +11 -0
- package/skills/nuxt/GENERATION.md +5 -0
- package/skills/nuxt/LICENSE.md +21 -0
- package/skills/nuxt/SKILL.md +55 -0
- package/skills/nuxt/SYNC.md +5 -0
- package/skills/nuxt/references/advanced-hooks.md +289 -0
- package/skills/nuxt/references/advanced-layers.md +299 -0
- package/skills/nuxt/references/advanced-module-authoring.md +554 -0
- package/skills/nuxt/references/best-practices-data-fetching.md +357 -0
- package/skills/nuxt/references/best-practices-ssr.md +355 -0
- package/skills/nuxt/references/core-cli.md +263 -0
- package/skills/nuxt/references/core-config.md +162 -0
- package/skills/nuxt/references/core-data-fetching.md +236 -0
- package/skills/nuxt/references/core-deployment.md +224 -0
- package/skills/nuxt/references/core-directory-structure.md +269 -0
- package/skills/nuxt/references/core-modules.md +292 -0
- package/skills/nuxt/references/core-routing.md +226 -0
- package/skills/nuxt/references/features-components-autoimport.md +328 -0
- package/skills/nuxt/references/features-components.md +264 -0
- package/skills/nuxt/references/features-composables.md +276 -0
- package/skills/nuxt/references/features-server.md +265 -0
- package/skills/nuxt/references/features-state.md +194 -0
- package/skills/nuxt/references/rendering-modes.md +237 -0
- package/skills/pinia/GENERATION.md +5 -0
- package/skills/pinia/LICENSE.md +21 -0
- package/skills/pinia/SKILL.md +59 -0
- package/skills/pinia/SYNC.md +5 -0
- package/skills/pinia/references/advanced-hmr.md +61 -0
- package/skills/pinia/references/advanced-nuxt.md +119 -0
- package/skills/pinia/references/advanced-ssr.md +121 -0
- package/skills/pinia/references/best-practices-outside-component.md +115 -0
- package/skills/pinia/references/best-practices-testing.md +212 -0
- package/skills/pinia/references/core-stores.md +389 -0
- package/skills/pinia/references/features-composables.md +114 -0
- package/skills/pinia/references/features-composing-stores.md +134 -0
- package/skills/pinia/references/features-plugins.md +203 -0
- package/skills/pnpm/GENERATION.md +5 -0
- package/skills/pnpm/LICENSE.md +21 -0
- package/skills/pnpm/SKILL.md +42 -0
- package/skills/pnpm/SYNC.md +5 -0
- package/skills/pnpm/references/best-practices-ci.md +285 -0
- package/skills/pnpm/references/best-practices-migration.md +291 -0
- package/skills/pnpm/references/best-practices-performance.md +284 -0
- package/skills/pnpm/references/core-cli.md +229 -0
- package/skills/pnpm/references/core-config.md +188 -0
- package/skills/pnpm/references/core-store.md +179 -0
- package/skills/pnpm/references/core-workspaces.md +205 -0
- package/skills/pnpm/references/features-aliases.md +168 -0
- package/skills/pnpm/references/features-catalogs.md +159 -0
- package/skills/pnpm/references/features-hooks.md +233 -0
- package/skills/pnpm/references/features-overrides.md +184 -0
- package/skills/pnpm/references/features-patches.md +201 -0
- package/skills/pnpm/references/features-peer-deps.md +250 -0
- package/skills/slidev/LICENSE.md +21 -0
- package/skills/slidev/README.md +61 -0
- package/skills/slidev/SKILL.md +189 -0
- package/skills/slidev/SYNC.md +5 -0
- package/skills/slidev/references/animation-click-marker.md +37 -0
- package/skills/slidev/references/animation-drawing.md +68 -0
- package/skills/slidev/references/animation-rough-marker.md +53 -0
- package/skills/slidev/references/api-slide-hooks.md +37 -0
- package/skills/slidev/references/build-og-image.md +36 -0
- package/skills/slidev/references/build-pdf.md +40 -0
- package/skills/slidev/references/build-remote-assets.md +34 -0
- package/skills/slidev/references/build-seo-meta.md +43 -0
- package/skills/slidev/references/code-groups.md +64 -0
- package/skills/slidev/references/code-import-snippet.md +55 -0
- package/skills/slidev/references/code-line-highlighting.md +50 -0
- package/skills/slidev/references/code-line-numbers.md +46 -0
- package/skills/slidev/references/code-magic-move.md +57 -0
- package/skills/slidev/references/code-max-height.md +37 -0
- package/skills/slidev/references/code-twoslash.md +42 -0
- package/skills/slidev/references/core-animations.md +196 -0
- package/skills/slidev/references/core-cli.md +140 -0
- package/skills/slidev/references/core-components.md +197 -0
- package/skills/slidev/references/core-exporting.md +148 -0
- package/skills/slidev/references/core-frontmatter.md +195 -0
- package/skills/slidev/references/core-global-context.md +155 -0
- package/skills/slidev/references/core-headmatter.md +188 -0
- package/skills/slidev/references/core-hosting.md +152 -0
- package/skills/slidev/references/core-layouts.md +286 -0
- package/skills/slidev/references/core-syntax.md +155 -0
- package/skills/slidev/references/diagram-latex.md +55 -0
- package/skills/slidev/references/diagram-mermaid.md +44 -0
- package/skills/slidev/references/diagram-plantuml.md +45 -0
- package/skills/slidev/references/editor-monaco-run.md +44 -0
- package/skills/slidev/references/editor-monaco-write.md +24 -0
- package/skills/slidev/references/editor-monaco.md +50 -0
- package/skills/slidev/references/editor-prettier.md +40 -0
- package/skills/slidev/references/editor-side.md +23 -0
- package/skills/slidev/references/editor-vscode.md +55 -0
- package/skills/slidev/references/layout-canvas-size.md +25 -0
- package/skills/slidev/references/layout-draggable.md +57 -0
- package/skills/slidev/references/layout-global-layers.md +50 -0
- package/skills/slidev/references/layout-slots.md +75 -0
- package/skills/slidev/references/layout-transform.md +33 -0
- package/skills/slidev/references/layout-zoom.md +39 -0
- package/skills/slidev/references/presenter-notes-ruby.md +35 -0
- package/skills/slidev/references/presenter-recording.md +30 -0
- package/skills/slidev/references/presenter-remote.md +40 -0
- package/skills/slidev/references/presenter-timer.md +34 -0
- package/skills/slidev/references/style-direction.md +34 -0
- package/skills/slidev/references/style-icons.md +46 -0
- package/skills/slidev/references/style-scoped.md +50 -0
- package/skills/slidev/references/syntax-block-frontmatter.md +39 -0
- package/skills/slidev/references/syntax-comark.md +51 -0
- package/skills/slidev/references/syntax-frontmatter-merging.md +49 -0
- package/skills/slidev/references/syntax-importing-slides.md +60 -0
- package/skills/slidev/references/tool-eject-theme.md +27 -0
- package/skills/tsdown/LICENSE.md +22 -0
- package/skills/tsdown/README.md +77 -0
- package/skills/tsdown/SKILL.md +416 -0
- package/skills/tsdown/SYNC.md +5 -0
- package/skills/tsdown/references/README.md +139 -0
- package/skills/tsdown/references/advanced-benchmark.md +8 -0
- package/skills/tsdown/references/advanced-ci.md +89 -0
- package/skills/tsdown/references/advanced-hooks.md +363 -0
- package/skills/tsdown/references/advanced-plugins.md +381 -0
- package/skills/tsdown/references/advanced-programmatic.md +378 -0
- package/skills/tsdown/references/advanced-rolldown-options.md +117 -0
- package/skills/tsdown/references/guide-getting-started.md +183 -0
- package/skills/tsdown/references/guide-introduction.md +42 -0
- package/skills/tsdown/references/guide-migrate-from-tsup.md +199 -0
- package/skills/tsdown/references/option-cjs-default.md +98 -0
- package/skills/tsdown/references/option-cleaning.md +275 -0
- package/skills/tsdown/references/option-config-file.md +291 -0
- package/skills/tsdown/references/option-css.md +301 -0
- package/skills/tsdown/references/option-dependencies.md +385 -0
- package/skills/tsdown/references/option-dts.md +251 -0
- package/skills/tsdown/references/option-entry.md +211 -0
- package/skills/tsdown/references/option-exe.md +120 -0
- package/skills/tsdown/references/option-lint.md +127 -0
- package/skills/tsdown/references/option-log-level.md +91 -0
- package/skills/tsdown/references/option-minification.md +177 -0
- package/skills/tsdown/references/option-output-directory.md +272 -0
- package/skills/tsdown/references/option-output-format.md +183 -0
- package/skills/tsdown/references/option-package-exports.md +320 -0
- package/skills/tsdown/references/option-platform.md +256 -0
- package/skills/tsdown/references/option-root.md +88 -0
- package/skills/tsdown/references/option-shims.md +299 -0
- package/skills/tsdown/references/option-sourcemap.md +301 -0
- package/skills/tsdown/references/option-target.md +222 -0
- package/skills/tsdown/references/option-tree-shaking.md +335 -0
- package/skills/tsdown/references/option-unbundle.md +310 -0
- package/skills/tsdown/references/option-watch-mode.md +261 -0
- package/skills/tsdown/references/recipe-react.md +338 -0
- package/skills/tsdown/references/recipe-solid.md +42 -0
- package/skills/tsdown/references/recipe-svelte.md +54 -0
- package/skills/tsdown/references/recipe-vue.md +387 -0
- package/skills/tsdown/references/recipe-wasm.md +125 -0
- package/skills/tsdown/references/reference-cli.md +472 -0
- package/skills/turborepo/LICENSE.md +7 -0
- package/skills/turborepo/SKILL.md +951 -0
- package/skills/turborepo/SYNC.md +5 -0
- package/skills/turborepo/command/turborepo.md +70 -0
- package/skills/turborepo/references/best-practices/RULE.md +241 -0
- package/skills/turborepo/references/best-practices/dependencies.md +246 -0
- package/skills/turborepo/references/best-practices/packages.md +335 -0
- package/skills/turborepo/references/best-practices/structure.md +297 -0
- package/skills/turborepo/references/boundaries/RULE.md +126 -0
- package/skills/turborepo/references/caching/RULE.md +153 -0
- package/skills/turborepo/references/caching/gotchas.md +190 -0
- package/skills/turborepo/references/caching/remote-cache.md +127 -0
- package/skills/turborepo/references/ci/RULE.md +79 -0
- package/skills/turborepo/references/ci/github-actions.md +162 -0
- package/skills/turborepo/references/ci/patterns.md +145 -0
- package/skills/turborepo/references/ci/vercel.md +103 -0
- package/skills/turborepo/references/cli/RULE.md +100 -0
- package/skills/turborepo/references/cli/commands.md +297 -0
- package/skills/turborepo/references/configuration/RULE.md +235 -0
- package/skills/turborepo/references/configuration/global-options.md +239 -0
- package/skills/turborepo/references/configuration/gotchas.md +368 -0
- package/skills/turborepo/references/configuration/tasks.md +325 -0
- package/skills/turborepo/references/environment/RULE.md +123 -0
- package/skills/turborepo/references/environment/gotchas.md +175 -0
- package/skills/turborepo/references/environment/modes.md +101 -0
- package/skills/turborepo/references/filtering/RULE.md +148 -0
- package/skills/turborepo/references/filtering/patterns.md +152 -0
- package/skills/turborepo/references/watch/RULE.md +99 -0
- package/skills/vite/GENERATION.md +5 -0
- package/skills/vite/LICENSE.md +21 -0
- package/skills/vite/SKILL.md +72 -0
- package/skills/vite/SYNC.md +5 -0
- package/skills/vite/references/build-and-ssr.md +164 -0
- package/skills/vite/references/core-config.md +162 -0
- package/skills/vite/references/core-features.md +205 -0
- package/skills/vite/references/core-plugin-api.md +235 -0
- package/skills/vite/references/environment-api.md +108 -0
- package/skills/vite/references/rolldown-migration.md +157 -0
- package/skills/vitepress/GENERATION.md +5 -0
- package/skills/vitepress/LICENSE.md +21 -0
- package/skills/vitepress/SKILL.md +65 -0
- package/skills/vitepress/SYNC.md +5 -0
- package/skills/vitepress/references/advanced-i18n.md +299 -0
- package/skills/vitepress/references/advanced-ssr.md +228 -0
- package/skills/vitepress/references/core-cli.md +119 -0
- package/skills/vitepress/references/core-config.md +189 -0
- package/skills/vitepress/references/core-markdown.md +277 -0
- package/skills/vitepress/references/core-routing.md +169 -0
- package/skills/vitepress/references/features-code-blocks.md +243 -0
- package/skills/vitepress/references/features-data-loading.md +220 -0
- package/skills/vitepress/references/features-dynamic-routes.md +235 -0
- package/skills/vitepress/references/features-vue.md +224 -0
- package/skills/vitepress/references/recipes-deploy.md +240 -0
- package/skills/vitepress/references/theme-config.md +315 -0
- package/skills/vitepress/references/theme-custom.md +269 -0
- package/skills/vitepress/references/theme-customization.md +290 -0
- package/skills/vitest/GENERATION.md +5 -0
- package/skills/vitest/LICENSE.md +21 -0
- package/skills/vitest/SKILL.md +52 -0
- package/skills/vitest/SYNC.md +5 -0
- package/skills/vitest/references/advanced-environments.md +264 -0
- package/skills/vitest/references/advanced-projects.md +300 -0
- package/skills/vitest/references/advanced-type-testing.md +237 -0
- package/skills/vitest/references/advanced-vi.md +249 -0
- package/skills/vitest/references/core-cli.md +166 -0
- package/skills/vitest/references/core-config.md +174 -0
- package/skills/vitest/references/core-describe.md +193 -0
- package/skills/vitest/references/core-expect.md +219 -0
- package/skills/vitest/references/core-hooks.md +244 -0
- package/skills/vitest/references/core-test-api.md +233 -0
- package/skills/vitest/references/features-concurrency.md +250 -0
- package/skills/vitest/references/features-context.md +238 -0
- package/skills/vitest/references/features-coverage.md +207 -0
- package/skills/vitest/references/features-filtering.md +211 -0
- package/skills/vitest/references/features-mocking.md +265 -0
- package/skills/vitest/references/features-snapshots.md +207 -0
- package/skills/vue/GENERATION.md +5 -0
- package/skills/vue/LICENSE.md +21 -0
- package/skills/vue/SKILL.md +84 -0
- package/skills/vue/SYNC.md +5 -0
- package/skills/vue/references/advanced-patterns.md +314 -0
- package/skills/vue/references/core-new-apis.md +264 -0
- package/skills/vue/references/script-setup-macros.md +204 -0
- package/skills/vue-best-practices/LICENSE.md +21 -0
- package/skills/vue-best-practices/SKILL.md +154 -0
- package/skills/vue-best-practices/SYNC.md +5 -0
- package/skills/vue-best-practices/references/animation-class-based-technique.md +254 -0
- package/skills/vue-best-practices/references/animation-state-driven-technique.md +291 -0
- package/skills/vue-best-practices/references/component-async.md +97 -0
- package/skills/vue-best-practices/references/component-data-flow.md +307 -0
- package/skills/vue-best-practices/references/component-fallthrough-attrs.md +174 -0
- package/skills/vue-best-practices/references/component-keep-alive.md +137 -0
- package/skills/vue-best-practices/references/component-slots.md +216 -0
- package/skills/vue-best-practices/references/component-suspense.md +228 -0
- package/skills/vue-best-practices/references/component-teleport.md +108 -0
- package/skills/vue-best-practices/references/component-transition-group.md +128 -0
- package/skills/vue-best-practices/references/component-transition.md +125 -0
- package/skills/vue-best-practices/references/composables.md +290 -0
- package/skills/vue-best-practices/references/directives.md +162 -0
- package/skills/vue-best-practices/references/perf-avoid-component-abstraction-in-lists.md +159 -0
- package/skills/vue-best-practices/references/perf-v-once-v-memo-directives.md +182 -0
- package/skills/vue-best-practices/references/perf-virtualize-large-lists.md +187 -0
- package/skills/vue-best-practices/references/plugins.md +166 -0
- package/skills/vue-best-practices/references/reactivity.md +344 -0
- package/skills/vue-best-practices/references/render-functions.md +201 -0
- package/skills/vue-best-practices/references/sfc.md +310 -0
- package/skills/vue-best-practices/references/state-management.md +135 -0
- package/skills/vue-best-practices/references/updated-hook-performance.md +187 -0
- package/skills/vue-router-best-practices/LICENSE.md +21 -0
- package/skills/vue-router-best-practices/SKILL.md +23 -0
- package/skills/vue-router-best-practices/SYNC.md +5 -0
- package/skills/vue-router-best-practices/reference/router-beforeenter-no-param-trigger.md +167 -0
- package/skills/vue-router-best-practices/reference/router-beforerouteenter-no-this.md +176 -0
- package/skills/vue-router-best-practices/reference/router-guard-async-await-pattern.md +227 -0
- package/skills/vue-router-best-practices/reference/router-navigation-guard-infinite-loop.md +187 -0
- package/skills/vue-router-best-practices/reference/router-navigation-guard-next-deprecated.md +150 -0
- package/skills/vue-router-best-practices/reference/router-param-change-no-lifecycle.md +181 -0
- package/skills/vue-router-best-practices/reference/router-simple-routing-cleanup.md +209 -0
- package/skills/vue-router-best-practices/reference/router-use-vue-router-for-production.md +183 -0
- package/skills/vue-testing-best-practices/LICENSE.md +21 -0
- package/skills/vue-testing-best-practices/SKILL.md +29 -0
- package/skills/vue-testing-best-practices/SYNC.md +5 -0
- package/skills/vue-testing-best-practices/reference/async-component-testing.md +163 -0
- package/skills/vue-testing-best-practices/reference/teleport-testing-complexity.md +158 -0
- package/skills/vue-testing-best-practices/reference/testing-async-await-flushpromises.md +175 -0
- package/skills/vue-testing-best-practices/reference/testing-browser-vs-node-runners.md +208 -0
- package/skills/vue-testing-best-practices/reference/testing-component-blackbox-approach.md +144 -0
- package/skills/vue-testing-best-practices/reference/testing-composables-helper-wrapper.md +238 -0
- package/skills/vue-testing-best-practices/reference/testing-e2e-playwright-recommended.md +242 -0
- package/skills/vue-testing-best-practices/reference/testing-no-snapshot-only.md +197 -0
- package/skills/vue-testing-best-practices/reference/testing-pinia-store-setup.md +228 -0
- package/skills/vue-testing-best-practices/reference/testing-suspense-async-components.md +229 -0
- package/skills/vue-testing-best-practices/reference/testing-vitest-recommended-for-vue.md +204 -0
- package/skills/vueuse-functions/LICENSE.md +21 -0
- package/skills/vueuse-functions/SKILL.md +419 -0
- package/skills/vueuse-functions/SYNC.md +5 -0
- package/skills/vueuse-functions/references/computedAsync.md +195 -0
- package/skills/vueuse-functions/references/computedEager.md +62 -0
- package/skills/vueuse-functions/references/computedInject.md +137 -0
- package/skills/vueuse-functions/references/computedWithControl.md +98 -0
- package/skills/vueuse-functions/references/createEventHook.md +86 -0
- package/skills/vueuse-functions/references/createGenericProjection.md +25 -0
- package/skills/vueuse-functions/references/createGlobalState.md +95 -0
- package/skills/vueuse-functions/references/createInjectionState.md +226 -0
- package/skills/vueuse-functions/references/createProjection.md +31 -0
- package/skills/vueuse-functions/references/createRef.md +54 -0
- package/skills/vueuse-functions/references/createReusableTemplate.md +361 -0
- package/skills/vueuse-functions/references/createSharedComposable.md +42 -0
- package/skills/vueuse-functions/references/createTemplatePromise.md +306 -0
- package/skills/vueuse-functions/references/createUnrefFn.md +51 -0
- package/skills/vueuse-functions/references/extendRef.md +76 -0
- package/skills/vueuse-functions/references/from.md +80 -0
- package/skills/vueuse-functions/references/get.md +30 -0
- package/skills/vueuse-functions/references/injectLocal.md +35 -0
- package/skills/vueuse-functions/references/isDefined.md +31 -0
- package/skills/vueuse-functions/references/logicAnd.md +40 -0
- package/skills/vueuse-functions/references/logicNot.md +36 -0
- package/skills/vueuse-functions/references/logicOr.md +40 -0
- package/skills/vueuse-functions/references/makeDestructurable.md +41 -0
- package/skills/vueuse-functions/references/onClickOutside.md +228 -0
- package/skills/vueuse-functions/references/onElementRemoval.md +88 -0
- package/skills/vueuse-functions/references/onKeyStroke.md +212 -0
- package/skills/vueuse-functions/references/onLongPress.md +235 -0
- package/skills/vueuse-functions/references/onStartTyping.md +53 -0
- package/skills/vueuse-functions/references/provideLocal.md +37 -0
- package/skills/vueuse-functions/references/reactify.md +144 -0
- package/skills/vueuse-functions/references/reactifyObject.md +62 -0
- package/skills/vueuse-functions/references/reactiveComputed.md +34 -0
- package/skills/vueuse-functions/references/reactiveOmit.md +86 -0
- package/skills/vueuse-functions/references/reactivePick.md +106 -0
- package/skills/vueuse-functions/references/refAutoReset.md +46 -0
- package/skills/vueuse-functions/references/refDebounced.md +81 -0
- package/skills/vueuse-functions/references/refDefault.md +36 -0
- package/skills/vueuse-functions/references/refManualReset.md +48 -0
- package/skills/vueuse-functions/references/refThrottled.md +99 -0
- package/skills/vueuse-functions/references/refWithControl.md +146 -0
- package/skills/vueuse-functions/references/set.md +30 -0
- package/skills/vueuse-functions/references/syncRef.md +195 -0
- package/skills/vueuse-functions/references/syncRefs.md +128 -0
- package/skills/vueuse-functions/references/templateRef.md +86 -0
- package/skills/vueuse-functions/references/toObserver.md +38 -0
- package/skills/vueuse-functions/references/toReactive.md +41 -0
- package/skills/vueuse-functions/references/toRef.md +74 -0
- package/skills/vueuse-functions/references/toRefs.md +78 -0
- package/skills/vueuse-functions/references/tryOnBeforeMount.md +34 -0
- package/skills/vueuse-functions/references/tryOnBeforeUnmount.md +32 -0
- package/skills/vueuse-functions/references/tryOnMounted.md +34 -0
- package/skills/vueuse-functions/references/tryOnScopeDispose.md +31 -0
- package/skills/vueuse-functions/references/tryOnUnmounted.md +32 -0
- package/skills/vueuse-functions/references/unrefElement.md +54 -0
- package/skills/vueuse-functions/references/until.md +161 -0
- package/skills/vueuse-functions/references/useAbs.md +31 -0
- package/skills/vueuse-functions/references/useActiveElement.md +86 -0
- package/skills/vueuse-functions/references/useAnimate.md +180 -0
- package/skills/vueuse-functions/references/useArrayDifference.md +84 -0
- package/skills/vueuse-functions/references/useArrayEvery.md +59 -0
- package/skills/vueuse-functions/references/useArrayFilter.md +63 -0
- package/skills/vueuse-functions/references/useArrayFind.md +50 -0
- package/skills/vueuse-functions/references/useArrayFindIndex.md +59 -0
- package/skills/vueuse-functions/references/useArrayFindLast.md +52 -0
- package/skills/vueuse-functions/references/useArrayIncludes.md +63 -0
- package/skills/vueuse-functions/references/useArrayJoin.md +74 -0
- package/skills/vueuse-functions/references/useArrayMap.md +59 -0
- package/skills/vueuse-functions/references/useArrayReduce.md +81 -0
- package/skills/vueuse-functions/references/useArraySome.md +59 -0
- package/skills/vueuse-functions/references/useArrayUnique.md +76 -0
- package/skills/vueuse-functions/references/useAsyncQueue.md +136 -0
- package/skills/vueuse-functions/references/useAsyncState.md +185 -0
- package/skills/vueuse-functions/references/useAsyncValidator.md +70 -0
- package/skills/vueuse-functions/references/useAuth.md +123 -0
- package/skills/vueuse-functions/references/useAverage.md +36 -0
- package/skills/vueuse-functions/references/useAxios.md +325 -0
- package/skills/vueuse-functions/references/useBase64.md +136 -0
- package/skills/vueuse-functions/references/useBattery.md +80 -0
- package/skills/vueuse-functions/references/useBluetooth.md +174 -0
- package/skills/vueuse-functions/references/useBreakpoints.md +176 -0
- package/skills/vueuse-functions/references/useBroadcastChannel.md +73 -0
- package/skills/vueuse-functions/references/useBrowserLocation.md +56 -0
- package/skills/vueuse-functions/references/useCached.md +52 -0
- package/skills/vueuse-functions/references/useCeil.md +31 -0
- package/skills/vueuse-functions/references/useChangeCase.md +79 -0
- package/skills/vueuse-functions/references/useClamp.md +85 -0
- package/skills/vueuse-functions/references/useClipboard.md +122 -0
- package/skills/vueuse-functions/references/useClipboardItems.md +93 -0
- package/skills/vueuse-functions/references/useCloned.md +91 -0
- package/skills/vueuse-functions/references/useColorMode.md +172 -0
- package/skills/vueuse-functions/references/useConfirmDialog.md +159 -0
- package/skills/vueuse-functions/references/useCookies.md +162 -0
- package/skills/vueuse-functions/references/useCountdown.md +105 -0
- package/skills/vueuse-functions/references/useCounter.md +86 -0
- package/skills/vueuse-functions/references/useCssSupports.md +33 -0
- package/skills/vueuse-functions/references/useCssVar.md +50 -0
- package/skills/vueuse-functions/references/useCurrentElement.md +61 -0
- package/skills/vueuse-functions/references/useCycleList.md +75 -0
- package/skills/vueuse-functions/references/useDark.md +142 -0
- package/skills/vueuse-functions/references/useDateFormat.md +145 -0
- package/skills/vueuse-functions/references/useDebounceFn.md +100 -0
- package/skills/vueuse-functions/references/useDebouncedRefHistory.md +40 -0
- package/skills/vueuse-functions/references/useDeviceMotion.md +80 -0
- package/skills/vueuse-functions/references/useDeviceOrientation.md +64 -0
- package/skills/vueuse-functions/references/useDevicePixelRatio.md +47 -0
- package/skills/vueuse-functions/references/useDevicesList.md +89 -0
- package/skills/vueuse-functions/references/useDisplayMedia.md +67 -0
- package/skills/vueuse-functions/references/useDocumentVisibility.md +44 -0
- package/skills/vueuse-functions/references/useDraggable.md +289 -0
- package/skills/vueuse-functions/references/useDrauu.md +65 -0
- package/skills/vueuse-functions/references/useDropZone.md +83 -0
- package/skills/vueuse-functions/references/useElementBounding.md +131 -0
- package/skills/vueuse-functions/references/useElementByPoint.md +46 -0
- package/skills/vueuse-functions/references/useElementHover.md +79 -0
- package/skills/vueuse-functions/references/useElementSize.md +79 -0
- package/skills/vueuse-functions/references/useElementVisibility.md +163 -0
- package/skills/vueuse-functions/references/useEventBus.md +101 -0
- package/skills/vueuse-functions/references/useEventListener.md +226 -0
- package/skills/vueuse-functions/references/useEventSource.md +204 -0
- package/skills/vueuse-functions/references/useExtractedObservable.md +198 -0
- package/skills/vueuse-functions/references/useEyeDropper.md +72 -0
- package/skills/vueuse-functions/references/useFavicon.md +69 -0
- package/skills/vueuse-functions/references/useFetch.md +546 -0
- package/skills/vueuse-functions/references/useFileDialog.md +91 -0
- package/skills/vueuse-functions/references/useFileSystemAccess.md +161 -0
- package/skills/vueuse-functions/references/useFirestore.md +129 -0
- package/skills/vueuse-functions/references/useFloor.md +31 -0
- package/skills/vueuse-functions/references/useFocus.md +99 -0
- package/skills/vueuse-functions/references/useFocusTrap.md +245 -0
- package/skills/vueuse-functions/references/useFocusWithin.md +57 -0
- package/skills/vueuse-functions/references/useFps.md +28 -0
- package/skills/vueuse-functions/references/useFullscreen.md +74 -0
- package/skills/vueuse-functions/references/useFuse.md +75 -0
- package/skills/vueuse-functions/references/useGamepad.md +176 -0
- package/skills/vueuse-functions/references/useGeolocation.md +63 -0
- package/skills/vueuse-functions/references/useIDBKeyval.md +93 -0
- package/skills/vueuse-functions/references/useIdle.md +88 -0
- package/skills/vueuse-functions/references/useImage.md +90 -0
- package/skills/vueuse-functions/references/useInfiniteScroll.md +156 -0
- package/skills/vueuse-functions/references/useIntersectionObserver.md +117 -0
- package/skills/vueuse-functions/references/useInterval.md +112 -0
- package/skills/vueuse-functions/references/useIntervalFn.md +50 -0
- package/skills/vueuse-functions/references/useIpcRenderer.md +144 -0
- package/skills/vueuse-functions/references/useIpcRendererInvoke.md +58 -0
- package/skills/vueuse-functions/references/useIpcRendererOn.md +52 -0
- package/skills/vueuse-functions/references/useJwt.md +57 -0
- package/skills/vueuse-functions/references/useKeyModifier.md +87 -0
- package/skills/vueuse-functions/references/useLastChanged.md +63 -0
- package/skills/vueuse-functions/references/useLocalStorage.md +41 -0
- package/skills/vueuse-functions/references/useMagicKeys.md +245 -0
- package/skills/vueuse-functions/references/useManualRefHistory.md +204 -0
- package/skills/vueuse-functions/references/useMath.md +47 -0
- package/skills/vueuse-functions/references/useMax.md +36 -0
- package/skills/vueuse-functions/references/useMediaControls.md +201 -0
- package/skills/vueuse-functions/references/useMediaQuery.md +53 -0
- package/skills/vueuse-functions/references/useMemoize.md +175 -0
- package/skills/vueuse-functions/references/useMemory.md +70 -0
- package/skills/vueuse-functions/references/useMin.md +36 -0
- package/skills/vueuse-functions/references/useMounted.md +38 -0
- package/skills/vueuse-functions/references/useMouse.md +113 -0
- package/skills/vueuse-functions/references/useMouseInElement.md +132 -0
- package/skills/vueuse-functions/references/useMousePressed.md +116 -0
- package/skills/vueuse-functions/references/useMutationObserver.md +60 -0
- package/skills/vueuse-functions/references/useNProgress.md +78 -0
- package/skills/vueuse-functions/references/useNavigatorLanguage.md +57 -0
- package/skills/vueuse-functions/references/useNetwork.md +106 -0
- package/skills/vueuse-functions/references/useNow.md +83 -0
- package/skills/vueuse-functions/references/useObjectUrl.md +55 -0
- package/skills/vueuse-functions/references/useObservable.md +91 -0
- package/skills/vueuse-functions/references/useOffsetPagination.md +199 -0
- package/skills/vueuse-functions/references/useOnline.md +41 -0
- package/skills/vueuse-functions/references/usePageLeave.md +43 -0
- package/skills/vueuse-functions/references/useParallax.md +58 -0
- package/skills/vueuse-functions/references/useParentElement.md +54 -0
- package/skills/vueuse-functions/references/usePerformanceObserver.md +48 -0
- package/skills/vueuse-functions/references/usePermission.md +78 -0
- package/skills/vueuse-functions/references/usePointer.md +91 -0
- package/skills/vueuse-functions/references/usePointerLock.md +59 -0
- package/skills/vueuse-functions/references/usePointerSwipe.md +80 -0
- package/skills/vueuse-functions/references/usePrecision.md +49 -0
- package/skills/vueuse-functions/references/usePreferredColorScheme.md +42 -0
- package/skills/vueuse-functions/references/usePreferredContrast.md +42 -0
- package/skills/vueuse-functions/references/usePreferredDark.md +41 -0
- package/skills/vueuse-functions/references/usePreferredLanguages.md +41 -0
- package/skills/vueuse-functions/references/usePreferredReducedMotion.md +42 -0
- package/skills/vueuse-functions/references/usePreferredReducedTransparency.md +42 -0
- package/skills/vueuse-functions/references/usePrevious.md +40 -0
- package/skills/vueuse-functions/references/useProjection.md +38 -0
- package/skills/vueuse-functions/references/useQRCode.md +53 -0
- package/skills/vueuse-functions/references/useRTDB.md +83 -0
- package/skills/vueuse-functions/references/useRafFn.md +68 -0
- package/skills/vueuse-functions/references/useRefHistory.md +285 -0
- package/skills/vueuse-functions/references/useResizeObserver.md +108 -0
- package/skills/vueuse-functions/references/useRound.md +31 -0
- package/skills/vueuse-functions/references/useRouteHash.md +27 -0
- package/skills/vueuse-functions/references/useRouteParams.md +38 -0
- package/skills/vueuse-functions/references/useRouteQuery.md +79 -0
- package/skills/vueuse-functions/references/useSSRWidth.md +47 -0
- package/skills/vueuse-functions/references/useScreenOrientation.md +98 -0
- package/skills/vueuse-functions/references/useScreenSafeArea.md +60 -0
- package/skills/vueuse-functions/references/useScriptTag.md +116 -0
- package/skills/vueuse-functions/references/useScroll.md +238 -0
- package/skills/vueuse-functions/references/useScrollLock.md +66 -0
- package/skills/vueuse-functions/references/useSessionStorage.md +41 -0
- package/skills/vueuse-functions/references/useShare.md +67 -0
- package/skills/vueuse-functions/references/useSortable.md +276 -0
- package/skills/vueuse-functions/references/useSorted.md +90 -0
- package/skills/vueuse-functions/references/useSpeechRecognition.md +90 -0
- package/skills/vueuse-functions/references/useSpeechSynthesis.md +101 -0
- package/skills/vueuse-functions/references/useStepper.md +137 -0
- package/skills/vueuse-functions/references/useStorage.md +278 -0
- package/skills/vueuse-functions/references/useStorageAsync.md +136 -0
- package/skills/vueuse-functions/references/useStyleTag.md +131 -0
- package/skills/vueuse-functions/references/useSubject.md +77 -0
- package/skills/vueuse-functions/references/useSubscription.md +33 -0
- package/skills/vueuse-functions/references/useSum.md +36 -0
- package/skills/vueuse-functions/references/useSupported.md +29 -0
- package/skills/vueuse-functions/references/useSwipe.md +75 -0
- package/skills/vueuse-functions/references/useTemplateRefsList.md +37 -0
- package/skills/vueuse-functions/references/useTextDirection.md +75 -0
- package/skills/vueuse-functions/references/useTextSelection.md +43 -0
- package/skills/vueuse-functions/references/useTextareaAutosize.md +94 -0
- package/skills/vueuse-functions/references/useThrottleFn.md +57 -0
- package/skills/vueuse-functions/references/useThrottledRefHistory.md +47 -0
- package/skills/vueuse-functions/references/useTimeAgo.md +154 -0
- package/skills/vueuse-functions/references/useTimeAgoIntl.md +117 -0
- package/skills/vueuse-functions/references/useTimeout.md +113 -0
- package/skills/vueuse-functions/references/useTimeoutFn.md +51 -0
- package/skills/vueuse-functions/references/useTimeoutPoll.md +47 -0
- package/skills/vueuse-functions/references/useTimestamp.md +93 -0
- package/skills/vueuse-functions/references/useTitle.md +115 -0
- package/skills/vueuse-functions/references/useToNumber.md +54 -0
- package/skills/vueuse-functions/references/useToString.md +34 -0
- package/skills/vueuse-functions/references/useToggle.md +103 -0
- package/skills/vueuse-functions/references/useTransition.md +265 -0
- package/skills/vueuse-functions/references/useTrunc.md +33 -0
- package/skills/vueuse-functions/references/useUrlSearchParams.md +121 -0
- package/skills/vueuse-functions/references/useUserMedia.md +96 -0
- package/skills/vueuse-functions/references/useVModel.md +182 -0
- package/skills/vueuse-functions/references/useVModels.md +67 -0
- package/skills/vueuse-functions/references/useVibrate.md +86 -0
- package/skills/vueuse-functions/references/useVirtualList.md +182 -0
- package/skills/vueuse-functions/references/useWakeLock.md +51 -0
- package/skills/vueuse-functions/references/useWebNotification.md +175 -0
- package/skills/vueuse-functions/references/useWebSocket.md +299 -0
- package/skills/vueuse-functions/references/useWebWorker.md +60 -0
- package/skills/vueuse-functions/references/useWebWorkerFn.md +102 -0
- package/skills/vueuse-functions/references/useWindowFocus.md +46 -0
- package/skills/vueuse-functions/references/useWindowScroll.md +46 -0
- package/skills/vueuse-functions/references/useWindowSize.md +78 -0
- package/skills/vueuse-functions/references/useZoomFactor.md +53 -0
- package/skills/vueuse-functions/references/useZoomLevel.md +53 -0
- package/skills/vueuse-functions/references/watchArray.md +53 -0
- package/skills/vueuse-functions/references/watchAtMost.md +63 -0
- package/skills/vueuse-functions/references/watchDebounced.md +101 -0
- package/skills/vueuse-functions/references/watchDeep.md +54 -0
- package/skills/vueuse-functions/references/watchExtractedObservable.md +192 -0
- package/skills/vueuse-functions/references/watchIgnorable.md +120 -0
- package/skills/vueuse-functions/references/watchImmediate.md +44 -0
- package/skills/vueuse-functions/references/watchOnce.md +41 -0
- package/skills/vueuse-functions/references/watchPausable.md +86 -0
- package/skills/vueuse-functions/references/watchThrottled.md +108 -0
- package/skills/vueuse-functions/references/watchTriggerable.md +98 -0
- package/skills/vueuse-functions/references/watchWithFilter.md +54 -0
- package/skills/vueuse-functions/references/whenever.md +108 -0
- package/skills/web-design-guidelines/SKILL.md +39 -0
- package/skills/web-design-guidelines/SYNC.md +5 -0
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: script-setup-macros
|
|
3
|
+
description: Vue 3 script setup syntax and compiler macros for defining props, emits, models, and more
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Script Setup & Macros
|
|
7
|
+
|
|
8
|
+
`<script setup>` is the recommended syntax for Vue SFCs with Composition API. It provides better runtime performance and IDE type inference.
|
|
9
|
+
|
|
10
|
+
## Basic Syntax
|
|
11
|
+
|
|
12
|
+
```vue
|
|
13
|
+
<script setup lang="ts">
|
|
14
|
+
// Top-level bindings are exposed to template
|
|
15
|
+
import { ref } from 'vue'
|
|
16
|
+
import MyComponent from './MyComponent.vue'
|
|
17
|
+
|
|
18
|
+
const count = ref(0)
|
|
19
|
+
const increment = () => count.value++
|
|
20
|
+
</script>
|
|
21
|
+
|
|
22
|
+
<template>
|
|
23
|
+
<button @click="increment">{{ count }}</button>
|
|
24
|
+
<MyComponent />
|
|
25
|
+
</template>
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
## defineProps
|
|
29
|
+
|
|
30
|
+
Declare component props with full TypeScript support.
|
|
31
|
+
|
|
32
|
+
```ts
|
|
33
|
+
// Type-based declaration (recommended)
|
|
34
|
+
const props = defineProps<{
|
|
35
|
+
title: string
|
|
36
|
+
count?: number
|
|
37
|
+
items: string[]
|
|
38
|
+
}>()
|
|
39
|
+
|
|
40
|
+
// With defaults (Vue 3.5+)
|
|
41
|
+
const { title, count = 0 } = defineProps<{
|
|
42
|
+
title: string
|
|
43
|
+
count?: number
|
|
44
|
+
}>()
|
|
45
|
+
|
|
46
|
+
// With defaults (Vue 3.4 and below)
|
|
47
|
+
const props = withDefaults(defineProps<{
|
|
48
|
+
title: string
|
|
49
|
+
items?: string[]
|
|
50
|
+
}>(), {
|
|
51
|
+
items: () => [] // Use factory for arrays/objects
|
|
52
|
+
})
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## defineEmits
|
|
56
|
+
|
|
57
|
+
Declare emitted events with typed payloads.
|
|
58
|
+
|
|
59
|
+
```ts
|
|
60
|
+
// Named tuple syntax (recommended)
|
|
61
|
+
const emit = defineEmits<{
|
|
62
|
+
update: [value: string]
|
|
63
|
+
change: [id: number, name: string]
|
|
64
|
+
close: []
|
|
65
|
+
}>()
|
|
66
|
+
|
|
67
|
+
emit('update', 'new value')
|
|
68
|
+
emit('change', 1, 'name')
|
|
69
|
+
emit('close')
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
## defineModel
|
|
73
|
+
|
|
74
|
+
Two-way binding prop consumed via `v-model`. Available in Vue 3.4+.
|
|
75
|
+
|
|
76
|
+
```ts
|
|
77
|
+
// Basic usage - creates "modelValue" prop
|
|
78
|
+
const model = defineModel<string>()
|
|
79
|
+
model.value = 'hello' // Emits "update:modelValue"
|
|
80
|
+
|
|
81
|
+
// Named model - consumed via v-model:name
|
|
82
|
+
const count = defineModel<number>('count', { default: 0 })
|
|
83
|
+
|
|
84
|
+
// With modifiers
|
|
85
|
+
const [value, modifiers] = defineModel<string>()
|
|
86
|
+
if (modifiers.trim) {
|
|
87
|
+
// Handle trim modifier
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// With transformers
|
|
91
|
+
const [value, modifiers] = defineModel({
|
|
92
|
+
get(val) { return val?.toLowerCase() },
|
|
93
|
+
set(val) { return modifiers.trim ? val?.trim() : val }
|
|
94
|
+
})
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
Parent usage:
|
|
98
|
+
```vue
|
|
99
|
+
<Child v-model="name" />
|
|
100
|
+
<Child v-model:count="total" />
|
|
101
|
+
<Child v-model.trim="text" />
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
## defineExpose
|
|
105
|
+
|
|
106
|
+
Explicitly expose properties to parent via template refs. Components are closed by default.
|
|
107
|
+
|
|
108
|
+
```ts
|
|
109
|
+
import { ref } from 'vue'
|
|
110
|
+
|
|
111
|
+
const count = ref(0)
|
|
112
|
+
const reset = () => { count.value = 0 }
|
|
113
|
+
|
|
114
|
+
defineExpose({
|
|
115
|
+
count,
|
|
116
|
+
reset
|
|
117
|
+
})
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
Parent access:
|
|
121
|
+
```ts
|
|
122
|
+
const childRef = ref<{ count: number; reset: () => void }>()
|
|
123
|
+
childRef.value?.reset()
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
## defineOptions
|
|
127
|
+
|
|
128
|
+
Declare component options without a separate `<script>` block. Available in Vue 3.3+.
|
|
129
|
+
|
|
130
|
+
```ts
|
|
131
|
+
defineOptions({
|
|
132
|
+
inheritAttrs: false,
|
|
133
|
+
name: 'CustomName'
|
|
134
|
+
})
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
## defineSlots
|
|
138
|
+
|
|
139
|
+
Provide type hints for slot props. Available in Vue 3.3+.
|
|
140
|
+
|
|
141
|
+
```ts
|
|
142
|
+
const slots = defineSlots<{
|
|
143
|
+
default(props: { item: string; index: number }): any
|
|
144
|
+
header(props: { title: string }): any
|
|
145
|
+
}>()
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
## Generic Components
|
|
149
|
+
|
|
150
|
+
Declare generic type parameters using the `generic` attribute.
|
|
151
|
+
|
|
152
|
+
```vue
|
|
153
|
+
<script setup lang="ts" generic="T extends string | number">
|
|
154
|
+
defineProps<{
|
|
155
|
+
items: T[]
|
|
156
|
+
selected: T
|
|
157
|
+
}>()
|
|
158
|
+
</script>
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
Multiple generics with constraints:
|
|
162
|
+
```vue
|
|
163
|
+
<script setup lang="ts" generic="T, U extends Record<string, T>">
|
|
164
|
+
import type { Item } from './types'
|
|
165
|
+
defineProps<{
|
|
166
|
+
data: U
|
|
167
|
+
key: keyof U
|
|
168
|
+
}>()
|
|
169
|
+
</script>
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
## Local Custom Directives
|
|
173
|
+
|
|
174
|
+
Use `vNameOfDirective` naming convention.
|
|
175
|
+
|
|
176
|
+
```ts
|
|
177
|
+
const vFocus = {
|
|
178
|
+
mounted: (el: HTMLElement) => el.focus()
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
// Or import and rename
|
|
182
|
+
import { myDirective as vMyDirective } from './directives'
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
```vue
|
|
186
|
+
<template>
|
|
187
|
+
<input v-focus />
|
|
188
|
+
</template>
|
|
189
|
+
```
|
|
190
|
+
|
|
191
|
+
## Top-level await
|
|
192
|
+
|
|
193
|
+
Use `await` directly in `<script setup>`. The component becomes async and must be used with `<Suspense>`.
|
|
194
|
+
|
|
195
|
+
```vue
|
|
196
|
+
<script setup lang="ts">
|
|
197
|
+
const data = await fetch('/api/data').then(r => r.json())
|
|
198
|
+
</script>
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
<!--
|
|
202
|
+
Source references:
|
|
203
|
+
- https://vuejs.org/api/sfc-script-setup.html
|
|
204
|
+
-->
|
|
@@ -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,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
|
+
```
|