51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import {
|
|
MutationCache,
|
|
QueryCache,
|
|
QueryClient,
|
|
QueryClientProvider,
|
|
} from "@tanstack/react-query"
|
|
import { RouterProvider, createRouter } from "@tanstack/react-router"
|
|
import React, { StrictMode } from "react"
|
|
import ReactDOM from "react-dom/client"
|
|
import { routeTree } from "./routeTree.gen"
|
|
|
|
import { ApiError, OpenAPI } from "./client"
|
|
import { CustomProvider } from "./components/ui/provider"
|
|
|
|
OpenAPI.BASE = import.meta.env.VITE_API_URL
|
|
OpenAPI.TOKEN = async () => {
|
|
return localStorage.getItem("access_token") || ""
|
|
}
|
|
|
|
const handleApiError = (error: Error) => {
|
|
if (error instanceof ApiError && [401, 403].includes(error.status)) {
|
|
localStorage.removeItem("access_token")
|
|
window.location.href = "/login"
|
|
}
|
|
}
|
|
const queryClient = new QueryClient({
|
|
queryCache: new QueryCache({
|
|
onError: handleApiError,
|
|
}),
|
|
mutationCache: new MutationCache({
|
|
onError: handleApiError,
|
|
}),
|
|
})
|
|
|
|
const router = createRouter({ routeTree })
|
|
declare module "@tanstack/react-router" {
|
|
interface Register {
|
|
router: typeof router
|
|
}
|
|
}
|
|
|
|
ReactDOM.createRoot(document.getElementById("root")!).render(
|
|
<StrictMode>
|
|
<CustomProvider>
|
|
<QueryClientProvider client={queryClient}>
|
|
<RouterProvider router={router} />
|
|
</QueryClientProvider>
|
|
</CustomProvider>
|
|
</StrictMode>,
|
|
)
|