|
1 | | -import { QueryClient, QueryClientProvider } from "@tanstack/react-query" |
| 1 | +import { MutationCache, QueryCache, QueryClient, QueryClientProvider } from "@tanstack/react-query" |
2 | 2 | import { RouterProvider, createRouter } from "@tanstack/react-router" |
3 | | -import React from "react" |
| 3 | +import React, { StrictMode } from "react" |
4 | 4 | import ReactDOM from "react-dom/client" |
5 | 5 | import { routeTree } from "./routeTree.gen" |
6 | 6 |
|
7 | | -import { StrictMode } from "react" |
8 | | -import { OpenAPI } from "./client" |
| 7 | +import { ApiError, OpenAPI } from "./client" |
9 | 8 | import { CustomProvider } from "./components/ui/provider" |
10 | 9 |
|
11 | 10 | OpenAPI.BASE = import.meta.env.VITE_API_URL |
12 | 11 | OpenAPI.TOKEN = async () => { |
13 | 12 | return localStorage.getItem("access_token") || "" |
14 | 13 | } |
15 | 14 |
|
16 | | -const queryClient = new QueryClient() |
| 15 | +const handleApiError = (error: Error) => { |
| 16 | + if (error instanceof ApiError && [401, 403].includes(error.status)) { |
| 17 | + localStorage.removeItem("access_token") |
| 18 | + window.location.href = "/login" |
| 19 | + } |
| 20 | +} |
| 21 | +const queryClient = new QueryClient({ |
| 22 | + queryCache: new QueryCache({ |
| 23 | + onError: handleApiError, |
| 24 | + }), |
| 25 | + mutationCache: new MutationCache({ |
| 26 | + onError: handleApiError, |
| 27 | + }), |
| 28 | +}) |
17 | 29 |
|
18 | 30 | const router = createRouter({ routeTree }) |
19 | 31 | declare module "@tanstack/react-router" { |
|
0 commit comments