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,10 +3,7 @@
import { Geist, Geist_Mono } from "next/font/google"; import { Geist, Geist_Mono } from "next/font/google";
import "./globals.css"; import "./globals.css";
import { useEffect, useState } from "react"; import { DeviceProvider } from "@/lib/context/DeviceContext";
import * as rdd from "react-device-detect";
import { useRouter } from "next/navigation";
import MobileNav from "@/lib/components/MobileNav"; import MobileNav from "@/lib/components/MobileNav";
const geistSans = Geist({ const geistSans = Geist({
@@ -24,29 +21,15 @@ export default function RootLayout({
}: Readonly<{ }: 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 ( return (
<html data-theme="drinky" lang="en"> <html data-theme="drinky" lang="en">
<body <body
className={`${geistSans.variable} ${geistMono.variable} antialiased`} className={`${geistSans.variable} ${geistMono.variable} antialiased`}
suppressHydrationWarning={true} suppressHydrationWarning={true}
> >
<DeviceProvider>
{children} {children}
{isMobile && ( </DeviceProvider>
<MobileNav />
)}
</body> </body>
</html> </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;
};