Skip to content

Commit

Permalink
fix(web): NV-3147 - prevent updating variants to have empty condition…
Browse files Browse the repository at this point in the history
…s (front-end only)

fix(web): prevent updating variants to have empty conditions (front-end only)
  • Loading branch information
Joel Anton authored Jan 17, 2024
2 parents 62cff36 + 812c7b7 commit 25a41e1
Show file tree
Hide file tree
Showing 4 changed files with 69 additions and 18 deletions.
34 changes: 34 additions & 0 deletions apps/web/cypress/tests/notification-editor/variants.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -841,6 +841,40 @@ describe('Workflow Editor - Variants', function () {
cy.wait('@getWorkflow');
cy.getByTestId('variants-count').should('not.exist');
});

it('should not allow removing all conditions from a variant', function () {
createWorkflow('Test Removing All Conditions');

dragAndDrop('inApp');
editChannel('inApp');
fillEditorContent('inApp');
goBack();

showStepActions('inApp');
addVariantActionClick('inApp');
addConditions();

cy.getByTestId('notification-template-submit-btn').click();
cy.wait('@updateWorkflow');

cy.reload();
cy.wait('@getWorkflow');

// edit the variant condition
cy.getByTestId('editor-sidebar-edit-conditions').click();

// open conditions row menu
cy.getByTestId('conditions-row-btn').click();

// delete the condition
cy.contains('Delete').click();

// submit ("Apply conditions") should be disabled
cy.getByTestId('apply-conditions-btn').should('be.disabled').click({ force: true });

// tooltip should warn the user
cy.get('div[role="tooltip"]').contains('At least one condition is required');
});
});

describe('Variants List Errors', function () {
Expand Down
51 changes: 33 additions & 18 deletions apps/web/src/components/conditions/Conditions.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,19 @@ import { OnlineConditionRow } from './OnlineConditionRow';
import { DefaultGroupOperatorData, DefaultOperatorData } from './constants';
import { PreviousStepsConditionRow } from './PreviousStepsConditionRow';

export interface IConditionsComponentProps {
isOpened: boolean;
isReadonly?: boolean;
onClose: () => void;
updateConditions: (data: IConditions[]) => void;
conditions?: IConditions[];
name: string;
label?: string;
filterPartsList: IFilterTypeList[];
defaultFilter?: FilterPartTypeEnum;
shouldDisallowEmptyConditions?: boolean;
}

export function Conditions({
isOpened,
isReadonly = false,
Expand All @@ -36,17 +49,8 @@ export function Conditions({
label = '',
filterPartsList,
defaultFilter,
}: {
isOpened: boolean;
isReadonly?: boolean;
onClose: () => void;
updateConditions: (data: IConditions[]) => void;
conditions?: IConditions[];
name: string;
label?: string;
filterPartsList: IFilterTypeList[];
defaultFilter?: FilterPartTypeEnum;
}) {
shouldDisallowEmptyConditions,
}: IConditionsComponentProps) {
const { colorScheme } = useMantineTheme();

const {
Expand Down Expand Up @@ -95,9 +99,17 @@ export function Conditions({
remove(index);
}

/** Flag for determining if conditions are empty but expected not to be */
const hasDisallowedEmptyConditions = Boolean(
shouldDisallowEmptyConditions && getValues().conditions?.some(({ children }) => !children?.[0])
);

const isSubmitDisabled =
!isDirty || isReadonly || (conditions?.length === 0 && fields?.length === 0) || hasDisallowedEmptyConditions;

const onApplyConditions = async () => {
await trigger('conditions');
if (!errors.conditions) {
if (!errors.conditions && !isSubmitDisabled) {
updateConditions(getValues('conditions'));
onClose();
}
Expand All @@ -121,13 +133,16 @@ export function Conditions({
<Button variant="outline" onClick={onClose} data-test-id="conditions-form-cancel-btn">
Cancel
</Button>
<Tooltip position="top" error disabled={isValid} label={'Some conditions are missing values'}>
<Tooltip
position="top"
error
disabled={isValid && !hasDisallowedEmptyConditions}
label={
hasDisallowedEmptyConditions ? 'At least one condition is required' : 'Some conditions are missing values'
}
>
<div>
<Button
disabled={!isDirty || isReadonly || (conditions?.length === 0 && fields?.length === 0)}
onClick={onApplyConditions}
data-test-id="apply-conditions-btn"
>
<Button disabled={isSubmitDisabled} onClick={onApplyConditions} data-test-id="apply-conditions-btn">
Apply conditions
</Button>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ export const EditorSidebarHeaderActions = () => {
conditions={conditions}
filterPartsList={filterPartsList}
defaultFilter={FilterPartTypeEnum.PAYLOAD}
shouldDisallowEmptyConditions={isUnderVariantPath}
/>
)}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,7 @@ export const VariantItemCard = ({
conditions={conditions}
filterPartsList={filterPartsList}
defaultFilter={FilterPartTypeEnum.PAYLOAD}
shouldDisallowEmptyConditions
/>
)}
<DeleteConfirmModal
Expand Down

0 comments on commit 25a41e1

Please sign in to comment.