diff options
Diffstat (limited to 'src/app/(main)/teams/TeamProvider.tsx')
| -rw-r--r-- | src/app/(main)/teams/TeamProvider.tsx | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/app/(main)/teams/TeamProvider.tsx b/src/app/(main)/teams/TeamProvider.tsx new file mode 100644 index 0000000..cea4161 --- /dev/null +++ b/src/app/(main)/teams/TeamProvider.tsx @@ -0,0 +1,21 @@ +'use client'; +import { Loading } from '@umami/react-zen'; +import { createContext, type ReactNode } from 'react'; +import { useTeamQuery } from '@/components/hooks/queries/useTeamQuery'; +import type { Team } from '@/generated/prisma/client'; + +export const TeamContext = createContext<Team>(null); + +export function TeamProvider({ teamId, children }: { teamId?: string; children: ReactNode }) { + const { data: team, isLoading, isFetching } = useTeamQuery(teamId); + + if (isFetching && isLoading) { + return <Loading placement="absolute" />; + } + + if (!team) { + return null; + } + + return <TeamContext.Provider value={team}>{children}</TeamContext.Provider>; +} |