feat: handle discarded steps in add list step
This commit is contained in:
@@ -65,12 +65,19 @@ export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({
|
|||||||
step => step.type === 'list' && step.id === listId
|
step => step.type === 'list' && step.id === listId
|
||||||
);
|
);
|
||||||
if (existingListStepIndex !== -1) {
|
if (existingListStepIndex !== -1) {
|
||||||
// Update the existing ListStep with new fields
|
// Update the existing ListStep with new fields, excluding discarded ones
|
||||||
const updatedSteps = [...prevSteps];
|
const updatedSteps = [...prevSteps];
|
||||||
const existingListStep = updatedSteps[existingListStepIndex] as ListStep;
|
const existingListStep = updatedSteps[existingListStepIndex] as ListStep;
|
||||||
|
const filteredNewFields = Object.entries(newFields).reduce((acc, [key, value]) => {
|
||||||
|
if (!discardedFields.has(`${listId}-${key}`)) {
|
||||||
|
acc[key] = value;
|
||||||
|
}
|
||||||
|
return acc;
|
||||||
|
}, {} as { [key: string]: TextStep });
|
||||||
|
|
||||||
updatedSteps[existingListStepIndex] = {
|
updatedSteps[existingListStepIndex] = {
|
||||||
...existingListStep,
|
...existingListStep,
|
||||||
fields: { ...existingListStep.fields, ...newFields },
|
fields: { ...existingListStep.fields, ...filteredNewFields },
|
||||||
pagination: pagination,
|
pagination: pagination,
|
||||||
limit: limit,
|
limit: limit,
|
||||||
};
|
};
|
||||||
@@ -84,7 +91,6 @@ export const BrowserStepsProvider: React.FC<{ children: React.ReactNode }> = ({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const addScreenshotStep = (fullPage: boolean) => {
|
const addScreenshotStep = (fullPage: boolean) => {
|
||||||
setBrowserSteps(prevSteps => [
|
setBrowserSteps(prevSteps => [
|
||||||
...prevSteps,
|
...prevSteps,
|
||||||
|
|||||||
Reference in New Issue
Block a user