--- title: Route Module Type Safety --- # Route Module Type Safety [MODES: framework]

React Router generates route-specific types to power type inference for URL params, loader data, and more. This guide will help you set it up if you didn't start with a template. To learn more about how type safety works in React Router, check out [Type Safety Explanation](../explanation/type-safety). ## 1. Add `.react-router/` to `.gitignore` React Router generates types into a `.react-router/` directory at the root of your app. This directory is fully managed by React Router and should be gitignore'd. ```txt .react-router/ ``` ## 2. Include the generated types in tsconfig Edit your tsconfig to get TypeScript to use the generated types. Additionally, `rootDirs` needs to be configured so the types can be imported as relative siblings to route modules. ```json filename=tsconfig.json { "include": [".react-router/types/**/*"], "compilerOptions": { "rootDirs": [".", "./.react-router/types"] } } ``` If you are using multiple `tsconfig` files for your app, you'll need to make these changes in whichever one `include`s your app directory. For example, the [`node-custom-server` template](https://github.com/remix-run/react-router-templates/tree/390fcec476dd336c810280479688fe893da38713/node-custom-server) contains `tsconfig.json`, `tsconfig.node.json`, and `tsconfig.vite.json`. Since `tsconfig.vite.json` is the one that [includes the app directory](https://github.com/remix-run/react-router-templates/blob/390fcec476dd336c810280479688fe893da38713/node-custom-server/tsconfig.vite.json#L4-L6), that's the one that sets up `.react-router/types` for route module type safety. ## 3. Generate types before type checking If you want to run type checking as its own command — for example, as part of your Continuous Integration pipeline — you'll need to make sure to generate types _before_ running typechecking: ```json { "scripts": { "typecheck": "react-router typegen && tsc" } } ``` ## 4. Typing `AppLoadContext` ## Extending app `Context` types To define your app's `context` type, add the following in a `.ts` or `.d.ts` file within your project: ```typescript import "react-router"; declare module "react-router" { interface AppLoadContext { // add context properties here } } ``` ## 5. Type-only auto-imports (optional) When auto-importing the `Route` type helper, TypeScript will generate: ```ts filename=app/routes/my-route.tsx import { Route } from "./+types/my-route"; ``` But if you enable [verbatimModuleSyntax](https://www.typescriptlang.org/tsconfig/#verbatimModuleSyntax): ```json filename=tsconfig.json { "compilerOptions": { "verbatimModuleSyntax": true } } ``` Then, you will get the `type` modifier for the import automatically as well: ```ts filename=app/routes/my-route.tsx import type { Route } from "./+types/my-route"; // ^^^^ ``` This helps tools like bundlers to detect type-only module that can be safely excluded from the bundle. ## Conclusion React Router's Vite plugin should be automatically generating types into `.react-router/types/` anytime you edit your route config (`routes.ts`). That means all you need to do is run `react-router dev` (or your custom dev server) to get to up-to-date types in your routes. Check out our [Type Safety Explanation](../explanation/type-safety) for an example of how to pull in those types into your routes.