feat: add isShadow field browser steps
This commit is contained in:
@@ -5,6 +5,7 @@ export interface TextStep {
|
|||||||
type: 'text';
|
type: 'text';
|
||||||
label: string;
|
label: string;
|
||||||
data: string;
|
data: string;
|
||||||
|
isShadow?: boolean;
|
||||||
selectorObj: SelectorObject;
|
selectorObj: SelectorObject;
|
||||||
actionId?: string;
|
actionId?: string;
|
||||||
}
|
}
|
||||||
@@ -21,10 +22,12 @@ export interface ListStep {
|
|||||||
id: number;
|
id: number;
|
||||||
type: 'list';
|
type: 'list';
|
||||||
listSelector: string;
|
listSelector: string;
|
||||||
|
isShadow?: boolean;
|
||||||
fields: { [key: string]: TextStep };
|
fields: { [key: string]: TextStep };
|
||||||
pagination?: {
|
pagination?: {
|
||||||
type: string;
|
type: string;
|
||||||
selector: string;
|
selector: string;
|
||||||
|
isShadow?: boolean;
|
||||||
};
|
};
|
||||||
limit?: number;
|
limit?: number;
|
||||||
actionId?: string;
|
actionId?: string;
|
||||||
@@ -36,14 +39,14 @@ export interface SelectorObject {
|
|||||||
selector: string;
|
selector: string;
|
||||||
tag?: string;
|
tag?: string;
|
||||||
attribute?: string;
|
attribute?: string;
|
||||||
shadow?: boolean;
|
isShadow?: boolean;
|
||||||
[key: string]: any;
|
[key: string]: any;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface BrowserStepsContextType {
|
interface BrowserStepsContextType {
|
||||||
browserSteps: BrowserStep[];
|
browserSteps: BrowserStep[];
|
||||||
addTextStep: (label: string, data: string, selectorObj: SelectorObject, actionId: string) => void;
|
addTextStep: (label: string, data: string, selectorObj: SelectorObject, actionId: string) => void;
|
||||||
addListStep: (listSelector: string, fields: { [key: string]: TextStep }, listId: number, actionId: string, pagination?: { type: string; selector: string }, limit?: number) => void
|
addListStep: (listSelector: string, fields: { [key: string]: TextStep }, listId: number, actionId: string, pagination?: { type: string; selector: string, isShadow?: boolean }, limit?: number, isShadow?: boolean) => void
|
||||||
addScreenshotStep: (fullPage: boolean, actionId: string) => void;
|
addScreenshotStep: (fullPage: boolean, actionId: string) => void;
|
||||||
deleteBrowserStep: (id: number) => void;
|
deleteBrowserStep: (id: number) => void;
|
||||||
updateBrowserTextStepLabel: (id: number, newLabel: string) => void;
|
updateBrowserTextStepLabel: (id: number, newLabel: string) => void;
|
||||||
@@ -68,7 +71,15 @@ export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({
|
|||||||
]);
|
]);
|
||||||
};
|
};
|
||||||
|
|
||||||
const addListStep = (listSelector: string, newFields: { [key: string]: TextStep }, listId: number, actionId: string, pagination?: { type: string; selector: string }, limit?: number) => {
|
const addListStep = (
|
||||||
|
listSelector: string,
|
||||||
|
newFields: { [key: string]: TextStep },
|
||||||
|
listId: number,
|
||||||
|
actionId: string,
|
||||||
|
pagination?: { type: string; selector: string; isShadow?: boolean },
|
||||||
|
limit?: number,
|
||||||
|
isShadow?: boolean
|
||||||
|
) => {
|
||||||
setBrowserSteps(prevSteps => {
|
setBrowserSteps(prevSteps => {
|
||||||
const existingListStepIndex = prevSteps.findIndex(step => step.type === 'list' && step.id === listId);
|
const existingListStepIndex = prevSteps.findIndex(step => step.type === 'list' && step.id === listId);
|
||||||
|
|
||||||
@@ -101,7 +112,8 @@ export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({
|
|||||||
fields: mergedFields,
|
fields: mergedFields,
|
||||||
pagination: pagination || existingListStep.pagination,
|
pagination: pagination || existingListStep.pagination,
|
||||||
limit: limit,
|
limit: limit,
|
||||||
actionId
|
actionId,
|
||||||
|
isShadow: isShadow !== undefined ? isShadow : existingListStep.isShadow
|
||||||
};
|
};
|
||||||
return updatedSteps;
|
return updatedSteps;
|
||||||
} else {
|
} else {
|
||||||
@@ -115,7 +127,16 @@ export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({
|
|||||||
|
|
||||||
return [
|
return [
|
||||||
...prevSteps,
|
...prevSteps,
|
||||||
{ id: listId, type: 'list', listSelector, fields: fieldsWithActionId, pagination, limit, actionId }
|
{
|
||||||
|
id: listId,
|
||||||
|
type: 'list',
|
||||||
|
listSelector,
|
||||||
|
fields: fieldsWithActionId,
|
||||||
|
pagination,
|
||||||
|
limit,
|
||||||
|
actionId,
|
||||||
|
isShadow
|
||||||
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user