/** * Copyright (c) 2023-present Plane Software, Inc. and contributors * SPDX-License-Identifier: AGPL-3.0-only * See the LICENSE file for details. */ import { observer } from "mobx-react"; import { Link } from "react-router"; import { useTheme } from "next-themes"; import useSWR from "swr"; // plane imports import { SPACE_BASE_PATH } from "@plane/constants"; import { PlaneLockup } from "@plane/propel/icons"; // assets import PlaneBackgroundPatternDark from "@/app/assets/auth/background-pattern-dark.svg?url"; import PlaneBackgroundPattern from "@/app/assets/auth/background-pattern.svg?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(function InstanceProvider({ 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 (
); if (error) { return (
Plane background pattern
); } return children; });