Files
file-one/src/routes/__root.tsx

45 lines
1.2 KiB
TypeScript
Raw Normal View History

2025-09-13 22:02:27 +01:00
import "@/styles/globals.css"
2025-09-14 21:46:38 +00:00
import { ConvexProviderWithAuthKit } from "@convex-dev/workos"
import { QueryClient, QueryClientProvider } from "@tanstack/react-query"
import { createRootRoute, Outlet } from "@tanstack/react-router"
import { TanStackRouterDevtools } from "@tanstack/router-devtools"
2025-09-14 21:46:38 +00:00
import { AuthKitProvider, useAuth } from "@workos-inc/authkit-react"
import { ConvexReactClient } from "convex/react"
import { toast } from "sonner"
import { formatError } from "@/lib/error"
2025-09-13 22:02:27 +01:00
export const Route = createRootRoute({
component: RootLayout,
})
const convexClient = new ConvexReactClient(process.env.BUN_PUBLIC_CONVEX_URL!)
const queryClient = new QueryClient({
defaultOptions: {
mutations: {
onError: (error) => {
console.log(error)
toast.error(formatError(error))
},
throwOnError: false,
},
},
})
2025-09-13 22:02:27 +01:00
function RootLayout() {
return (
<QueryClientProvider client={queryClient}>
2025-09-14 21:46:38 +00:00
<AuthKitProvider
clientId={process.env.BUN_PUBLIC_WORKOS_CLIENT_ID!}
redirectUri={process.env.BUN_PUBLIC_WORKOS_REDIRECT_URI!}
>
<ConvexProviderWithAuthKit
client={convexClient}
useAuth={useAuth}
>
<Outlet />
</ConvexProviderWithAuthKit>
</AuthKitProvider>
</QueryClientProvider>
2025-09-13 22:02:27 +01:00
)
}