|
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