Device Context

This commit is contained in:
2025-04-12 14:52:18 -04:00
parent 9514b1be33
commit 83486927e0
2 changed files with 54 additions and 36 deletions

View File

@@ -3,51 +3,34 @@
import { Geist, Geist_Mono } from "next/font/google";
import "./globals.css";
import { useEffect, useState } from "react";
import * as rdd from "react-device-detect";
import { useRouter } from "next/navigation";
import { DeviceProvider } from "@/lib/context/DeviceContext";
import MobileNav from "@/lib/components/MobileNav";
const geistSans = Geist({
variable: "--font-geist-sans",
subsets: ["latin"],
variable: "--font-geist-sans",
subsets: ["latin"],
});
const geistMono = Geist_Mono({
variable: "--font-geist-mono",
subsets: ["latin"],
variable: "--font-geist-mono",
subsets: ["latin"],
});
export default function RootLayout({
children,
children,
}: Readonly<{
children: React.ReactNode;
children: React.ReactNode;
}>) {
const router = useRouter();
const [isSafari, setIsSafari] = useState<boolean>(false);
const [isMobile, setIsMobile] = useState<boolean>(false);
useEffect(() => {
setIsSafari(rdd.isSafari);
setIsMobile(rdd.isMobile);
}, []);
useEffect(() => {
}, [isMobile, isSafari, router]);
return (
<html data-theme="drinky" lang="en">
<body
className={`${geistSans.variable} ${geistMono.variable} antialiased`}
suppressHydrationWarning={true}
>
{children}
{isMobile && (
<MobileNav />
)}
</body>
</html>
);
return (
<html data-theme="drinky" lang="en">
<body
className={`${geistSans.variable} ${geistMono.variable} antialiased`}
suppressHydrationWarning={true}
>
<DeviceProvider>
{children}
</DeviceProvider>
</body>
</html>
);
}

View File

@@ -0,0 +1,35 @@
"use client";
import React, { createContext, useContext, useEffect, useState } from "react";
import * as rdd from "react-device-detect";
interface DeviceContextProps {
isSafari: boolean;
isMobile: boolean;
}
const DeviceContext = createContext<DeviceContextProps | undefined>(undefined);
export const DeviceProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {
const [isSafari, setIsSafari] = useState<boolean>(false);
const [isMobile, setIsMobile] = useState<boolean>(false);
useEffect(() => {
setIsSafari(rdd.isSafari);
setIsMobile(rdd.isMobile);
}, []);
return (
<DeviceContext.Provider value={{ isSafari, isMobile }}>
{children}
</DeviceContext.Provider>
);
};
export const useDevice = (): DeviceContextProps => {
const context = useContext(DeviceContext);
if (!context) {
throw new Error("useDevice must be used within a DeviceProvider");
}
return context;
};