Files
parcer/src/context/browserSteps.tsx

119 lines
3.6 KiB
TypeScript
Raw Normal View History

2024-07-26 20:20:11 +05:30
import React, { createContext, useContext, useState } from 'react';
2024-08-09 09:33:05 +05:30
export interface TextStep {
2024-08-06 03:10:54 +05:30
id: number;
type: 'text';
label: string;
data: string;
selectorObj: SelectorObject;
}
interface ScreenshotStep {
id: number;
type: 'screenshot';
2024-08-06 03:14:03 +05:30
fullPage: boolean;
2024-08-06 03:10:54 +05:30
}
2024-08-11 08:14:20 +05:30
export interface ListStep {
2024-08-08 21:11:02 +05:30
id: number;
type: 'list';
listSelector: string;
fields: { [key: string]: TextStep };
}
2024-08-06 03:10:54 +05:30
2024-08-08 21:11:02 +05:30
type BrowserStep = TextStep | ScreenshotStep | ListStep;
2024-08-06 03:10:54 +05:30
2024-08-10 04:10:00 +05:30
export interface SelectorObject {
selector: string;
tag?: string;
2024-08-04 03:07:15 +05:30
attribute?: string;
2024-08-04 03:15:50 +05:30
[key: string]: any;
}
2024-07-26 20:20:11 +05:30
interface BrowserStepsContextType {
2024-07-26 20:22:20 +05:30
browserSteps: BrowserStep[];
2024-08-06 03:10:54 +05:30
addTextStep: (label: string, data: string, selectorObj: SelectorObject) => void;
2024-08-08 23:57:26 +05:30
addListStep: (listSelector: string, fields: { [key: string]: TextStep }) => void
addScreenshotStep: (fullPage: boolean) => void;
2024-07-26 20:22:20 +05:30
deleteBrowserStep: (id: number) => void;
2024-08-06 03:10:54 +05:30
updateBrowserTextStepLabel: (id: number, newLabel: string) => void;
2024-07-26 20:20:11 +05:30
}
const BrowserStepsContext = createContext<BrowserStepsContextType | undefined>(undefined);
export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {
2024-07-26 20:22:20 +05:30
const [browserSteps, setBrowserSteps] = useState<BrowserStep[]>([]);
2024-08-06 03:10:54 +05:30
const addTextStep = (label: string, data: string, selectorObj: SelectorObject) => {
2024-07-26 20:22:20 +05:30
setBrowserSteps(prevSteps => [
...prevSteps,
2024-08-06 03:10:54 +05:30
{ id: Date.now(), type: 'text', label, data, selectorObj }
]);
};
2024-08-11 08:14:20 +05:30
const addListStep = (listSelector: string, newFields: { [key: string]: TextStep }) => {
setBrowserSteps(prevSteps => {
const existingListStepIndex = prevSteps.findIndex(
step => step.type === 'list' && step.listSelector === listSelector
);
if (existingListStepIndex !== -1) {
// Update the existing ListStep with new fields
const updatedSteps = [...prevSteps];
const existingListStep = updatedSteps[existingListStepIndex] as ListStep;
updatedSteps[existingListStepIndex] = {
...existingListStep,
fields: { ...existingListStep.fields, ...newFields }
};
return updatedSteps;
} else {
// Create a new ListStep
return [
...prevSteps,
{ id: Date.now(), type: 'list', listSelector, fields: newFields }
];
}
});
2024-08-08 23:56:00 +05:30
};
2024-08-11 08:14:52 +05:30
2024-08-08 23:56:00 +05:30
const addScreenshotStep = (fullPage: boolean) => {
2024-08-06 03:10:54 +05:30
setBrowserSteps(prevSteps => [
...prevSteps,
{ id: Date.now(), type: 'screenshot', fullPage }
2024-07-26 20:22:20 +05:30
]);
};
const deleteBrowserStep = (id: number) => {
setBrowserSteps(prevSteps => prevSteps.filter(step => step.id !== id));
};
2024-08-06 03:10:54 +05:30
const updateBrowserTextStepLabel = (id: number, newLabel: string) => {
2024-07-26 20:22:20 +05:30
setBrowserSteps(prevSteps =>
prevSteps.map(step =>
step.id === id ? { ...step, label: newLabel } : step
)
);
};
return (
2024-08-04 03:15:50 +05:30
<BrowserStepsContext.Provider value={{
browserSteps,
2024-08-06 03:10:54 +05:30
addTextStep,
2024-08-08 23:56:57 +05:30
addListStep,
2024-08-06 03:10:54 +05:30
addScreenshotStep,
2024-08-04 03:15:50 +05:30
deleteBrowserStep,
2024-08-06 03:10:54 +05:30
updateBrowserTextStepLabel,
}}>
2024-07-26 20:22:20 +05:30
{children}
</BrowserStepsContext.Provider>
2024-07-26 20:20:11 +05:30
);
};
export const useBrowserSteps = () => {
2024-07-26 20:22:20 +05:30
const context = useContext(BrowserStepsContext);
if (!context) {
throw new Error('useBrowserSteps must be used within a BrowserStepsProvider');
}
return context;
2024-08-06 03:10:54 +05:30
};