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