tanstack-router-best-practices
TanStack Router best practices for type-safe routing, data loading, search params, and navigation. Activate when building React applications with complex routing needs.
What this skill does
# TanStack Router Best Practices Comprehensive guidelines for implementing TanStack Router patterns in React applications. These rules optimize type safety, data loading, navigation, and code organization. ## When to Apply - Setting up application routing - Creating new routes and layouts - Implementing search parameter handling - Configuring data loaders - Setting up code splitting - Integrating with TanStack Query - Refactoring navigation patterns ## Rule Categories by Priority | Priority | Category | Rules | Impact | |----------|----------|-------|--------| | CRITICAL | Type Safety | 4 rules | Prevents runtime errors and enables refactoring | | CRITICAL | Route Organization | 5 rules | Ensures maintainable route structure | | HIGH | Router Config | 1 rule | Global router defaults | | HIGH | Data Loading | 6 rules | Optimizes data fetching and caching | | HIGH | Search Params | 5 rules | Enables type-safe URL state | | HIGH | Error Handling | 1 rule | Handles 404 and errors gracefully | | MEDIUM | Navigation | 5 rules | Improves UX and accessibility | | MEDIUM | Code Splitting | 3 rules | Reduces bundle size | | MEDIUM | Preloading | 3 rules | Improves perceived performance | | LOW | Route Context | 3 rules | Enables dependency injection | ## Quick Reference ### Type Safety (Prefix: `ts-`) - `ts-register-router` — Register router type for global inference - `ts-use-from-param` — Use `from` parameter for type narrowing - `ts-route-context-typing` — Type route context with createRootRouteWithContext - `ts-query-options-loader` — Use queryOptions in loaders for type inference ### Router Config (Prefix: `router-`) - `router-default-options` — Configure router defaults (scrollRestoration, defaultErrorComponent, etc.) ### Route Organization (Prefix: `org-`) - `org-file-based-routing` — Prefer file-based routing for conventions - `org-route-tree-structure` — Follow hierarchical route tree patterns - `org-pathless-layouts` — Use pathless routes for shared layouts - `org-index-routes` — Understand index vs layout routes - `org-virtual-routes` — Understand virtual file routes ### Data Loading (Prefix: `load-`) - `load-use-loaders` — Use route loaders for data fetching - `load-loader-deps` — Define loaderDeps for cache control - `load-ensure-query-data` — Use ensureQueryData with TanStack Query - `load-deferred-data` — Split critical and non-critical data - `load-error-handling` — Handle loader errors appropriately - `load-parallel` — Leverage parallel route loading ### Search Params (Prefix: `search-`) - `search-validation` — Always validate search params - `search-type-inheritance` — Leverage parent search param types - `search-middleware` — Use search param middleware - `search-defaults` — Provide sensible defaults - `search-custom-serializer` — Configure custom search param serializers ### Error Handling (Prefix: `err-`) - `err-not-found` — Handle not-found routes properly ### Navigation (Prefix: `nav-`) - `nav-link-component` — Prefer Link component for navigation - `nav-active-states` — Configure active link states - `nav-use-navigate` — Use useNavigate for programmatic navigation - `nav-relative-paths` — Understand relative path navigation - `nav-route-masks` — Use route masks for modal URLs ### Code Splitting (Prefix: `split-`) - `split-lazy-routes` — Use .lazy.tsx for code splitting - `split-critical-path` — Keep critical config in main route file - `split-auto-splitting` — Enable autoCodeSplitting when possible ### Preloading (Prefix: `preload-`) - `preload-intent` — Enable intent-based preloading - `preload-stale-time` — Configure preload stale time - `preload-manual` — Use manual preloading strategically ### Route Context (Prefix: `ctx-`) - `ctx-root-context` — Define context at root route - `ctx-before-load` — Extend context in beforeLoad - `ctx-dependency-injection` — Use context for dependency injection ## How to Use Each rule file in the `rules/` directory contains: 1. **Explanation** — Why this pattern matters 2. **Bad Example** — Anti-pattern to avoid 3. **Good Example** — Recommended implementation 4. **Context** — When to apply or skip this rule ## Full Reference See individual rule files in `rules/` directory for detailed guidance and code examples.
Related in Web Dev
generating-lwc-components
IncludedLightning Web Components with PICKLES methodology and 165-point scoring. Use this skill when the user creates or edits LWC components, builds wire service patterns, or writes Jest tests for LWC. TRIGGER when: user creates/edits LWC components, touches lwc/**/*.js, .html, .css, .js-meta.xml files, or asks about wire service, SLDS, or Jest LWC tests. DO NOT TRIGGER when: Apex classes (use generating-apex), Aura components, or Visualforce.
tanstack-query
IncludedManage server state in React with TanStack Query v5. Set up queries with useQuery, mutations with useMutation, configure QueryClient caching strategies, implement optimistic updates, and handle infinite scroll with useInfiniteQuery. Use when: setting up data fetching in React projects, migrating from v4 to v5, or fixing object syntax required errors, query callbacks removed issues, cacheTime renamed to gcTime, isPending vs isLoading confusion, keepPreviousData removed problems.
document-processor-api
IncludedProcess documents with Nutrient DWS. Use when the user wants to generate PDFs from HTML or URLs, convert Office/images/PDFs, assemble or split packets, OCR scans, extract text/tables/key-value pairs, redact PII, watermark, sign, fill forms, optimize PDFs, or produce compliance outputs like PDF/A or PDF/UA. Triggers include convert to PDF, merge these PDFs, OCR this scan, extract tables, redact PII, sign this PDF, make this PDF/A, or linearize for web delivery.
nutrient-document-processing
IncludedProcess documents with Nutrient DWS. Use when the user wants to generate PDFs from HTML or URLs, convert Office/images/PDFs, assemble or split packets, OCR scans, extract text/tables/key-value pairs, redact PII, watermark, sign, fill forms, optimize PDFs, or produce compliance outputs like PDF/A or PDF/UA. Triggers include convert to PDF, merge these PDFs, OCR this scan, extract tables, redact PII, sign this PDF, make this PDF/A, or linearize for web delivery.
tanstack-query
IncludedManage server state in React with TanStack Query v5. Covers useMutationState, simplified optimistic updates, throwOnError, network mode (offline/PWA), and infiniteQueryOptions. Use when setting up data fetching, fixing v4→v5 migration errors (object syntax, gcTime, isPending, keepPreviousData), or debugging SSR/hydration issues with streaming server components.
accelint-nextjs-best-practices
IncludedNext.js performance optimization and best practices. Use when writing Next.js code (App Router or Pages Router); implementing Server Components, Server Actions, or API routes; optimizing RSC serialization, data fetching, or server-side rendering; reviewing Next.js code for performance issues; fixing authentication in Server Actions; or implementing Suspense boundaries, parallel data fetching, or request deduplication.