feat: browser steps context

This commit is contained in:
karishmas6
2024-07-26 20:20:11 +05:30
parent 3c91a49ecb
commit 826ec27236

View File

@@ -0,0 +1,53 @@
import React, { createContext, useContext, useState } from 'react';
interface BrowserStep {
id: number;
label: string;
description: string;
}
interface BrowserStepsContextType {
browserSteps: BrowserStep[];
addBrowserStep: (label: string, description: string) => void;
deleteBrowserStep: (id: number) => void;
updateBrowserStepLabel: (id: number, newLabel: string) => void;
}
const BrowserStepsContext = createContext<BrowserStepsContextType | undefined>(undefined);
export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {
const [browserSteps, setBrowserSteps] = useState<BrowserStep[]>([]);
const addBrowserStep = (label: string, description: string) => {
setBrowserSteps(prevSteps => [
...prevSteps,
{ id: Date.now(), label, description }
]);
};
const deleteBrowserStep = (id: number) => {
setBrowserSteps(prevSteps => prevSteps.filter(step => step.id !== id));
};
const updateBrowserStepLabel = (id: number, newLabel: string) => {
setBrowserSteps(prevSteps =>
prevSteps.map(step =>
step.id === id ? { ...step, label: newLabel } : step
)
);
};
return (
<BrowserStepsContext.Provider value={{ browserSteps, addBrowserStep, deleteBrowserStep, updateBrowserStepLabel }}>
{children}
</BrowserStepsContext.Provider>
);
};
export const useBrowserSteps = () => {
const context = useContext(BrowserStepsContext);
if (!context) {
throw new Error('useBrowserSteps must be used within a BrowserStepsProvider');
}
return context;
};