"use client"; import { observer } from "mobx-react"; import Image from "next/image"; import Link from "next/link"; import { useTheme } from "next-themes"; import useSWR from "swr"; // plane imports import { SPACE_BASE_PATH } from "@plane/constants"; // assets import PlaneBackgroundPatternDark from "@/app/assets/auth/background-pattern-dark.svg?url"; import PlaneBackgroundPattern from "@/app/assets/auth/background-pattern.svg?url"; import BlackHorizontalLogo from "@/app/assets/plane-logos/black-horizontal-with-blue-logo.png?url"; import WhiteHorizontalLogo from "@/app/assets/plane-logos/white-horizontal-with-blue-logo.png?url"; // components import { LogoSpinner } from "@/components/common/logo-spinner"; import { InstanceFailureView } from "@/components/instance/instance-failure-view"; // hooks import { useInstance } from "@/hooks/store/use-instance"; import { useUser } from "@/hooks/store/use-user"; export const InstanceProvider = observer(({ children }: { children: React.ReactNode }) => { const { fetchInstanceInfo, instance, error } = useInstance(); const { fetchCurrentUser } = useUser(); const { resolvedTheme } = useTheme(); const patternBackground = resolvedTheme === "dark" ? PlaneBackgroundPatternDark : PlaneBackgroundPattern; useSWR("INSTANCE_INFO", () => fetchInstanceInfo(), { revalidateOnFocus: false, revalidateIfStale: false, errorRetryCount: 0, }); useSWR("CURRENT_USER", () => fetchCurrentUser(), { shouldRetryOnError: false, revalidateOnFocus: true, revalidateIfStale: true, }); if (!instance && !error) return (
); const logo = resolvedTheme === "light" ? BlackHorizontalLogo : WhiteHorizontalLogo; if (error) { return (
Plane logo
Plane background pattern
); } return children; });