skills/nextjs/nextjs-state-management/SKILL.md
Apply best practices for managing URL, server, and client state in Next.js applications. Use when choosing between URL params, SWR/TanStack Query, Zustand, or Context for state, or when fixing hydration mismatches from localStorage.
npx skillsauth add hoangnguyen0403/agent-skills-standard nextjs-state-managementInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
useSearchParams + useRouter).useState.'use client' only) or Jotai.useState. Colocate as close to consumer as possible.See implementation examples
See implementation examples
See implementation examples
Wrap localStorage reads in useEffect or mounted flag to avoid hydration mismatches. Manage optimistic updates with useOptimistic in Next.js 15+.
If project already uses redux@4 + createStore + redux-thunk + next-redux-wrapper:
useSelector / useDispatch hooks — never connect HOC.RootState and typed AppDispatch for all selectors and dispatch calls.@reduxjs/toolkit) → RTK Query → then consider TanStack Query.See references/redux.md for typed selector and thunk patterns.
useState or URL params; avoid Zustand for basic UI.useEffect for data fetching: Use SWR or TanStack Query for server state.development
Standardize SRS and FRS specifications for technical behavior, interfaces, data contracts, quality constraints, and verification mapping. Use when writing SRS, functional specification, system behavior requirements, API/data contracts, or non-functional thresholds.
development
Standardize BRD and BRD-lite discovery for business goals, stakeholder impact, current-to-future state, and measurable value outcomes. Use when creating BRD, business case, project justification, ROI narrative, or AS-IS to TO-BE scope.
development
Implements a strict Red-Green-Refactor loop to ensure zero production code is written without a prior failing test. Use when: creating new features, fixing bugs, or expanding test coverage.
testing
Standardize PRD discovery and drafting for product scope, user outcomes, requirement IDs, and acceptance criteria. Use when creating PRD, product requirements, feature specification, or acceptance criteria plan.