react-state

Minimal, scalable state management with React 18+ useSyncExternalStore.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "react-state" with this command: npx skills add fusengine/agents/fusengine-agents-react-state

Zustand for React

Minimal, scalable state management with React 18+ useSyncExternalStore.

Agent Workflow (MANDATORY)

Before ANY implementation, use TeamCreate to spawn 3 agents:

  • fuse-ai-pilot:explore-codebase - Analyze existing stores and state patterns

  • fuse-ai-pilot:research-expert - Verify latest Zustand v5 docs via Context7/Exa

  • mcp__context7__query-docs - Check middleware and TypeScript patterns

After implementation, run fuse-ai-pilot:sniper for validation.

Overview

When to Use

  • Managing global state in React applications

  • Need state shared across components

  • Persisting state to localStorage/sessionStorage

  • Building UI state (modals, sidebars, theme, cart)

  • Replacing React Context for complex state

Why Zustand v5

Feature Benefit

Minimal API Simple create() function, no boilerplate

React 18 native useSyncExternalStore, no shims needed

TypeScript first Full inference with currying pattern

Middleware stack devtools, persist, immer composable

Bundle size ~2KB gzipped, smallest state library

No providers Direct store access, no Context wrapper

Critical Rules

  • useShallow for arrays/objects - Prevent unnecessary re-renders

  • Currying syntax v5 - create<State>()((set) => ({...}))

  • SOLID paths - Stores in modules/[feature]/src/stores/

  • Separate stores - One store per domain (auth, cart, ui, theme)

  • Server state elsewhere - Use TanStack Query for server state

SOLID Architecture

Module Structure

Stores organized by feature module:

  • modules/cores/stores/

  • Shared stores (theme, ui)

  • modules/auth/src/stores/

  • Auth state

  • modules/cart/src/stores/

  • Cart state

  • modules/[feature]/src/interfaces/

  • Store types

File Organization

File Purpose Max Lines

store.ts

Store creation with create() 50

store.interface.ts

TypeScript interfaces 30

use-store.ts

Custom hook with selector 20

Key Concepts

Store Creation (v5 Syntax)

Double parentheses required for TypeScript inference. Currying pattern ensures full type safety.

Middleware Composition

Stack middlewares: devtools -> persist -> immer. Order matters for TypeScript types.

Selector Pattern

Always use useStore((s) => s.field) for performance. Use useShallow for array/object selectors.

Reference Guide

Need Reference

Initial setup installation.md

Store patterns store-patterns.md

Middleware middleware.md

TypeScript typescript.md

Slices pattern slices.md

Auto selectors auto-selectors.md

Reset state reset-state.md

Subscribe API subscribe-api.md

Testing testing.md

Migration v4→v5 migration-v5.md

Best Practices

  • Selector pattern - Always use useStore((s) => s.field) for performance

  • useShallow - Wrap array/object selectors to prevent re-renders

  • Separate stores - One store per domain (auth, cart, ui, theme)

  • Server data elsewhere - Use TanStack Query for server state

  • DevTools in dev only - Wrap devtools in process.env check

  • Partialize persist - Only persist necessary fields, never tokens

Forbidden Patterns

Pattern Reason Alternative

Persisting auth tokens Security vulnerability httpOnly cookies

Without useShallow on objects Excessive re-renders useShallow(selector)

v4 syntax TypeScript inference broken v5 currying create<T>()()

Giant monolithic store Hard to maintain Slices or separate stores

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Automation

laravel-livewire

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

laravel-blade

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

laravel-architecture

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

nextjs-i18n

No summary provided by upstream source.

Repository SourceNeeds Review