diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/StepOverflowMenu.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/StepOverflowMenu.tsx index 3dd7f529743..c26460fe472 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/StepOverflowMenu.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/StepOverflowMenu.tsx @@ -21,6 +21,7 @@ import { OPEN_STEP_DETAILS_EVENT } from '../../../../analytics/constants' import { getBatchEditFormHasUnsavedChanges, getCurrentFormHasUnsavedChanges, + getPipetteEntities, getSavedStepForms, getUnsavedForm, } from '../../../../step-forms/selectors' @@ -61,12 +62,16 @@ export function StepOverflowMenu(props: StepOverflowMenuProps): JSX.Element { const dispatch = useDispatch>() const formData = useSelector(getUnsavedForm) const savedStepFormData = useSelector(getSavedStepForms)[stepId] + const pipetteEntities = useSelector(getPipetteEntities) + const isPipetteStep = savedStepFormData.stepType === 'moveLiquid' || savedStepFormData.stepType === 'mix' const isThermocyclerProfile = savedStepFormData.stepType === 'thermocycler' && savedStepFormData.thermocyclerFormType === 'thermocyclerProfile' + const is96Channel = + pipetteEntities[savedStepFormData.pipette]?.name === 'p1000_96' const duplicateStep = ( stepId: StepIdType @@ -132,7 +137,8 @@ export function StepOverflowMenu(props: StepOverflowMenuProps): JSX.Element { {formData != null ? null : ( {t('edit_step')} )} - {isPipetteStep || isThermocyclerProfile ? ( + {/* Note the following 96-channel check is temp */} + {(isPipetteStep && !is96Channel) || isThermocyclerProfile ? ( { diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/__tests__/StepOverflowMenu.test.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/__tests__/StepOverflowMenu.test.tsx index d283468dc33..9c1de4044d0 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/__tests__/StepOverflowMenu.test.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/__tests__/StepOverflowMenu.test.tsx @@ -11,6 +11,7 @@ import { analyticsEvent } from '../../../../../analytics/actions' import { getCurrentFormHasUnsavedChanges, getCurrentFormIsPresaved, + getPipetteEntities, getSavedStepForms, getUnsavedForm, } from '../../../../../step-forms/selectors' @@ -24,6 +25,8 @@ import type * as OpentronsComponents from '@opentrons/components' const mockConfirm = vi.fn() const mockCancel = vi.fn() +const mockId = 'mockId' +const mockId96 = '96MockId' vi.mock('../../../../../ui/steps') vi.mock('../../../../../step-forms/selectors') @@ -72,6 +75,16 @@ describe('StepOverflowMenu', () => { [moveLiquidStepId]: { stepType: 'moveLiquid', id: moveLiquidStepId, + pipette: mockId, + }, + }) + vi.mocked(getPipetteEntities).mockReturnValue({ + [mockId]: { + name: 'p50_single_flex', + spec: {} as any, + id: mockId, + tiprackLabwareDef: [], + tiprackDefURI: ['mockDefURI1', 'mockDefURI2'], }, }) }) @@ -94,4 +107,25 @@ describe('StepOverflowMenu', () => { screen.getByText('Duplicate steps') screen.getByText('Delete steps') }) + + it('should not render view details button if pipette is 96-channel', () => { + vi.mocked(getSavedStepForms).mockReturnValue({ + [moveLiquidStepId]: { + stepType: 'moveLiquid', + id: moveLiquidStepId, + pipette: mockId96, + }, + }) + vi.mocked(getPipetteEntities).mockReturnValue({ + [mockId96]: { + name: 'p1000_96', + spec: {} as any, + id: mockId96, + tiprackLabwareDef: [], + tiprackDefURI: ['mockDefURI1_96'], + }, + }) + render(props) + expect(screen.queryByText('View details')).not.toBeInTheDocument() + }) })