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

@@ -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;
};