- Improve localStorage access in ActivityFeed, ChatWidget, and AdminPage with try-catch blocks to handle potential errors gracefully. - Update performance tracking in AnalyticsProvider and analytics.ts to ensure robust error handling and prevent failures from affecting user experience. - Refactor Web Vitals tracking to include error handling for observer initialization and data collection. - Ensure consistent handling of hydration mismatches in components like BackgroundBlobs and ChatWidget to improve rendering reliability.
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
"use client";
|
|
|
|
import React, { useEffect, useState } from "react";
|
|
import { usePathname } from "next/navigation";
|
|
import dynamic from "next/dynamic";
|
|
import { ToastProvider } from "@/components/Toast";
|
|
import { AnalyticsProvider } from "@/components/AnalyticsProvider";
|
|
|
|
// Dynamic import with SSR disabled to avoid framer-motion issues
|
|
const BackgroundBlobs = dynamic(() => import("@/components/BackgroundBlobs").catch(() => ({ default: () => null })), {
|
|
ssr: false,
|
|
loading: () => null,
|
|
});
|
|
|
|
const ChatWidget = dynamic(() => import("./ChatWidget").catch(() => ({ default: () => null })), {
|
|
ssr: false,
|
|
loading: () => null,
|
|
});
|
|
|
|
export default function ClientProviders({
|
|
children,
|
|
}: {
|
|
children: React.ReactNode;
|
|
}) {
|
|
const [mounted, setMounted] = useState(false);
|
|
const [is404Page, setIs404Page] = useState(false);
|
|
const pathname = usePathname();
|
|
|
|
useEffect(() => {
|
|
setMounted(true);
|
|
// Check if we're on a 404 page by looking for the data attribute or pathname
|
|
const check404 = () => {
|
|
if (typeof window !== "undefined") {
|
|
const has404Component = document.querySelector('[data-404-page]');
|
|
const is404Path = pathname === '/404' || window.location.pathname === '/404' || window.location.pathname.includes('404');
|
|
setIs404Page(!!has404Component || is404Path);
|
|
}
|
|
};
|
|
// Check immediately and after a short delay
|
|
check404();
|
|
const timeout = setTimeout(check404, 100);
|
|
const interval = setInterval(check404, 500);
|
|
return () => {
|
|
clearTimeout(timeout);
|
|
clearInterval(interval);
|
|
};
|
|
}, [pathname]);
|
|
|
|
return (
|
|
<AnalyticsProvider>
|
|
<ToastProvider>
|
|
{mounted && <BackgroundBlobs />}
|
|
<div className="relative z-10">{children}</div>
|
|
{mounted && !is404Page && <ChatWidget />}
|
|
</ToastProvider>
|
|
</AnalyticsProvider>
|
|
);
|
|
}
|