From 28011ef4b70fe49a1e40ff470085f34a09fe481b Mon Sep 17 00:00:00 2001 From: Jethary Rader <66035149+jerader@users.noreply.github.com> Date: Wed, 22 May 2024 14:29:54 -0400 Subject: [PATCH] fix(protocol-designer): missing labware modal logic (#15248) closes RQA-2769 --- protocol-designer/src/ui/modules/selectors.ts | 8 ++++++ .../addAndSelectStepWithHints.test.ts | 28 +++++++++++++++++-- .../src/ui/steps/actions/thunks/index.ts | 19 +++++++++---- 3 files changed, 46 insertions(+), 9 deletions(-) diff --git a/protocol-designer/src/ui/modules/selectors.ts b/protocol-designer/src/ui/modules/selectors.ts index ea8f3ba54334..03e0886833fd 100644 --- a/protocol-designer/src/ui/modules/selectors.ts +++ b/protocol-designer/src/ui/modules/selectors.ts @@ -117,6 +117,14 @@ export const getMagnetModuleHasLabware: Selector = createSelector( } ) +/** Returns boolean if heater-shaker module has labware */ +export const getHeaterShakerModuleHasLabware: Selector = createSelector( + getInitialDeckSetup, + initialDeckSetup => { + return getModuleHasLabware(initialDeckSetup, HEATERSHAKER_MODULE_TYPE) + } +) + /** Returns all moduleIds and if they have labware for MoaM */ export const getTemperatureModulesHaveLabware: Selector< ModuleAndLabware[] diff --git a/protocol-designer/src/ui/steps/actions/__tests__/addAndSelectStepWithHints.test.ts b/protocol-designer/src/ui/steps/actions/__tests__/addAndSelectStepWithHints.test.ts index 56046da6a98b..fa749bfa4e2a 100644 --- a/protocol-designer/src/ui/steps/actions/__tests__/addAndSelectStepWithHints.test.ts +++ b/protocol-designer/src/ui/steps/actions/__tests__/addAndSelectStepWithHints.test.ts @@ -26,6 +26,9 @@ beforeEach(() => { false ) vi.mocked(uiModuleSelectors.getTemperatureModuleIds).mockReturnValue(null) + vi.mocked(uiModuleSelectors.getHeaterShakerModuleHasLabware).mockReturnValue( + false + ) vi.mocked(uiModuleSelectors.getSingleThermocyclerModuleId).mockReturnValue( null ) @@ -92,6 +95,7 @@ describe('addAndSelectStepWithHints', () => { getSingleTemperatureModuleId: null, getSingleThermocyclerModuleId: null, getTemperatureModuleIds: [], + getHeaterShakerModuleHasLabware: false, }, }, { @@ -105,12 +109,13 @@ describe('addAndSelectStepWithHints', () => { getThermocyclerModuleHasLabware: false, getSingleTemperatureModuleId: 'something', getSingleThermocyclerModuleId: null, - getTemperatureModuleIds: ['mockId'], + getTemperatureModuleIds: [], + getHeaterShakerModuleHasLabware: false, }, }, { - testName: 'temperature step, when thermocycler has no labware', - stepType: 'temperature' as StepType, + testName: 'thermocycler step, when thermocycler has no labware', + stepType: 'thermocycler' as StepType, selectorValues: { getMagnetModuleHasLabware: false, getTemperatureModulesHaveLabware: [], @@ -118,6 +123,20 @@ describe('addAndSelectStepWithHints', () => { getSingleTemperatureModuleId: null, getSingleThermocyclerModuleId: 'something', getTemperatureModuleIds: [], + getHeaterShakerModuleHasLabware: false, + }, + }, + { + testName: 'heaterShaker step, when heaterShaker has no labware', + stepType: 'heaterShaker' as StepType, + selectorValues: { + getMagnetModuleHasLabware: false, + getTemperatureModulesHaveLabware: [], + getThermocyclerModuleHasLabware: false, + getSingleTemperatureModuleId: null, + getSingleThermocyclerModuleId: 'something', + getTemperatureModuleIds: [], + getHeaterShakerModuleHasLabware: false, }, }, ].forEach(({ testName, stepType, selectorValues }) => { @@ -128,6 +147,9 @@ describe('addAndSelectStepWithHints', () => { vi.mocked( uiModuleSelectors.getTemperatureModulesHaveLabware ).mockReturnValue(selectorValues.getTemperatureModulesHaveLabware) + vi.mocked( + uiModuleSelectors.getHeaterShakerModuleHasLabware + ).mockReturnValue(selectorValues.getHeaterShakerModuleHasLabware) vi.mocked( uiModuleSelectors.getThermocyclerModuleHasLabware ).mockReturnValue(selectorValues.getThermocyclerModuleHasLabware) diff --git a/protocol-designer/src/ui/steps/actions/thunks/index.ts b/protocol-designer/src/ui/steps/actions/thunks/index.ts index b59780e949c2..707b5e0713d6 100644 --- a/protocol-designer/src/ui/steps/actions/thunks/index.ts +++ b/protocol-designer/src/ui/steps/actions/thunks/index.ts @@ -49,9 +49,10 @@ export const addAndSelectStepWithHints: (arg: { const temperatureModuleOnDeck = uiModuleSelectors.getTemperatureModuleIds( state ) - const thermocyclerModuleOnDeck = uiModuleSelectors.getSingleThermocyclerModuleId( + const heaterShakerModuleHasLabware = uiModuleSelectors.getHeaterShakerModuleHasLabware( state ) + const tempHasNoLabware = temperatureModulesHaveLabware.some( module => !module.hasLabware ) @@ -59,19 +60,25 @@ export const addAndSelectStepWithHints: (arg: { const stepNeedsLiquid = ['mix', 'moveLiquid'].includes(payload.stepType) const stepMagnetNeedsLabware = ['magnet'].includes(payload.stepType) const stepTemperatureNeedsLabware = ['temperature'].includes(payload.stepType) + const stepThermocyclerNeedsLabware = ['thermocycler'].includes( + payload.stepType + ) + const stepHeaterShakerNeedsLabware = ['heaterShaker'].includes( + payload.stepType + ) + const stepModuleMissingLabware = (stepMagnetNeedsLabware && !magnetModuleHasLabware) || - (stepTemperatureNeedsLabware && - thermocyclerModuleOnDeck && - !thermocyclerModuleHasLabware) || - (temperatureModuleOnDeck?.length === 1 && tempHasNoLabware) + (stepThermocyclerNeedsLabware && !thermocyclerModuleHasLabware) || + (temperatureModuleOnDeck?.length === 0 && stepTemperatureNeedsLabware) || + (stepHeaterShakerNeedsLabware && !heaterShakerModuleHasLabware) if (stepNeedsLiquid && !deckHasLiquid) { dispatch(tutorialActions.addHint('add_liquids_and_labware')) } if (stepModuleMissingLabware) { dispatch(tutorialActions.addHint('module_without_labware')) - } else if (temperatureModuleOnDeck && tempHasNoLabware) { + } else if (temperatureModuleOnDeck != null && tempHasNoLabware) { dispatch(tutorialActions.addHint('multiple_modules_without_labware')) } }