omnidev / components /contexts /pro-context.tsx
kalhdrawi's picture
Reupload OmniDev clean version
1e075e6
raw
history blame
1.25 kB
"use client";
import React, { createContext, useContext, useState, ReactNode } from "react";
import { ProModal } from "@/components/pro-modal";
import { Page } from "@/types";
import { useEditor } from "@/hooks/useEditor";
interface ProContextType {
isOpen: boolean;
openProModal: (pages: Page[]) => void;
closeProModal: () => void;
}
const ProContext = createContext<ProContextType | undefined>(undefined);
export function ProProvider({ children }: { children: ReactNode }) {
const [isOpen, setIsOpen] = useState(false);
const { pages } = useEditor();
const isUnlimited = (process.env.UNLIMITED_MODE || '').toLowerCase() === 'true';
const openProModal = () => {
setIsOpen(true);
};
const closeProModal = () => {
setIsOpen(false);
};
const value = {
isOpen,
openProModal,
closeProModal,
};
return (
<ProContext.Provider value={value}>
{children}
{!isUnlimited && (
<ProModal open={isOpen} onClose={setIsOpen} pages={pages} />
)}
</ProContext.Provider>
);
}
export function useProModal() {
const context = useContext(ProContext);
if (context === undefined) {
throw new Error("useProModal must be used within a ProProvider");
}
return context;
}