mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-06-20 03:40:29 +08:00
- README: add a visible ## Security section (official sources, vuln reporting via SECURITY.md, GateGuard/IOC/AgentShield guardrails, security guide); make stats line a plain paragraph to clear MD028 - eslint: empty catch comment in run-with-flags.js; drop unneeded escape in github-coordination/parsing.js; remove unused execFileSync import in its test (#2236 follow-ups) - markdownlint: wrap bare URLs in rules/vue/*.md (#2250 follow-up) npm run lint green; full suite 2836/2836.
2.4 KiB
2.4 KiB
paths
| paths | |
|---|---|
|
Vue Patterns
This file extends common/patterns.md with Vue specific content.
Composables
- The composable (
useXxx) is the reusable-logic unit. In Feature-Sliced Design it lives in the slicemodelsegment. - Accept
MaybeRefOrGetter<T>inputs and normalize withtoValue, so callers can pass a ref, a getter, or a raw value. - Return
toRefs(reactive(...))so consumers can destructure without losing reactivity. - A composable that uses lifecycle hooks or
provide/injectmust be called inside a componentsetup, not lazily or conditionally.
Props, Emits, v-model
- Type-based
defineProps<Props>()and tuple-formdefineEmits<{ change: [id: number] }>(). defineModel<T>('name', { default })for two-way binding. It compiles to a prop plus anupdate:*emit.
Provide / Inject
- Use
provide/injectfor tree-scoped data without prop drilling. - Type-safe collision-free keys:
const key = Symbol() as InjectionKey<T>. - The provider owns mutations. Expose a
readonlyref plus an explicit updater function, never a raw mutable ref.
Pinia (FSD model segment)
- Prefer setup stores:
refis state,computedis getters,functionis actions. - Setup stores do not get
$resetfor free. Define your own. - Use
storeToRefsfor state and getters. Destructure actions directly off the store. - Never persist raw auth tokens to
localStorage.
vue-router
- Lazy-load route components with dynamic
import(). - A global
beforeEachauth gate keyed onmeta.requiresAuth. Guards returnfalse(cancel), a route location (redirect), orundefined/true(continue). - Watch
() => route.params.id, not the wholerouteobject.
vue-query (server cache)
@tanstack/vue-queryowns server-cache state. Pinia owns client state.- Put request functions plus
queryOptionsfactories in the FSDapisegment. - Critical: put the ref or computed ITSELF in the query key, never
.value. Passing.valuefreezes the key and kills reactive refetch.
useQuery({ queryKey: ['auction', id], queryFn: () => fetchAuction(toValue(id)) })
// after a mutation
queryClient.invalidateQueries({ queryKey: ['auction', id] })
Reference
- ECC skills:
frontend-patterns,vite-patterns. - Docs: https://pinia.vuejs.org/ · https://router.vuejs.org/ · https://tanstack.com/query/latest/docs/framework/vue/overview · https://vuejs.org/guide/reusability/composables.html