Files
linsa-linsa-io/web/lib/providers/jazz-provider.tsx
2024-09-09 18:20:42 +07:00

58 lines
1.5 KiB
TypeScript

"use client"
import { createJazzReactApp } from "jazz-react"
import { LaAccount } from "@/lib/schema"
import { useAuth, useClerk } from "@clerk/nextjs"
import { useJazzClerkAuth } from "jazz-react-auth-clerk"
import { usePathname } from "next/navigation"
const Jazz = createJazzReactApp({
AccountSchema: LaAccount
})
export const { useAccount, useAccountOrGuest, useCoState, useAcceptInvite } = Jazz
function assertPeerUrl(url: string | undefined): asserts url is `wss://${string}` | `ws://${string}` {
if (!url) {
throw new Error("NEXT_PUBLIC_JAZZ_PEER_URL is not defined")
}
if (!url.startsWith("wss://") && !url.startsWith("ws://")) {
throw new Error("NEXT_PUBLIC_JAZZ_PEER_URL must start with wss:// or ws://")
}
}
const rawUrl = process.env.NEXT_PUBLIC_JAZZ_PEER_URL
assertPeerUrl(rawUrl)
const JAZZ_PEER_URL = rawUrl
interface ChildrenProps {
children: React.ReactNode
}
export function JazzAndAuth({ children }: ChildrenProps) {
const pathname = usePathname()
return pathname === "/" ? <JazzGuest>{children}</JazzGuest> : <JazzAuth>{children}</JazzAuth>
}
export function JazzAuth({ children }: ChildrenProps) {
const clerk = useClerk()
const { isLoaded } = useAuth()
const [authMethod] = useJazzClerkAuth(clerk)
if (!isLoaded) return null
return (
<Jazz.Provider auth={authMethod || "guest"} peer={JAZZ_PEER_URL}>
{children}
</Jazz.Provider>
)
}
export function JazzGuest({ children }: ChildrenProps) {
return (
<Jazz.Provider auth="guest" peer={JAZZ_PEER_URL}>
{children}
</Jazz.Provider>
)
}