diff --git a/app/src/organisms/Devices/ProtocolRun/RunFailedModal.tsx b/app/src/organisms/Devices/ProtocolRun/RunFailedModal.tsx index 395b9d73f24..10ef0b8bd3c 100644 --- a/app/src/organisms/Devices/ProtocolRun/RunFailedModal.tsx +++ b/app/src/organisms/Devices/ProtocolRun/RunFailedModal.tsx @@ -25,7 +25,6 @@ import { useDownloadRunLog } from '../hooks' import type { RunError, RunCommandErrors } from '@opentrons/api-client' import type { LegacyModalProps } from '../../../molecules/LegacyModal' -import { RunCommandError } from '@opentrons/shared-data' /** * This modal is for Desktop app @@ -126,17 +125,14 @@ export function RunFailedModal({ {commandErrorList?.pageLength} errors - {commandErrorList?.data.map((error: RunCommandError, index) => { + {commandErrorList?.data.map((error: RunError, index) => { return ( - {t('error_info', { - errorCode: error.errorCode, - errorType: error.detail - })} + {error.errorCode}: {error.detail} ) })} diff --git a/app/src/organisms/OnDeviceDisplay/RunningProtocol/RunFailedModal.tsx b/app/src/organisms/OnDeviceDisplay/RunningProtocol/RunFailedModal.tsx index c4db8a35360..6b0c8b7c033 100644 --- a/app/src/organisms/OnDeviceDisplay/RunningProtocol/RunFailedModal.tsx +++ b/app/src/organisms/OnDeviceDisplay/RunningProtocol/RunFailedModal.tsx @@ -20,25 +20,27 @@ import { SmallButton } from '../../../atoms/buttons' import { Modal } from '../../../molecules/Modal' import type { ModalHeaderBaseProps } from '../../../molecules/Modal/types' -import type { RunError } from '@opentrons/api-client' +import type { RunCommandErrors, RunError } from '@opentrons/api-client' interface RunFailedModalProps { runId: string setShowRunFailedModal: (showRunFailedModal: boolean) => void errors?: RunError[] + commandErrorList?: RunCommandErrors } export function RunFailedModal({ runId, setShowRunFailedModal, errors, + commandErrorList }: RunFailedModalProps): JSX.Element | null { const { t, i18n } = useTranslation(['run_details', 'shared', 'branded']) const navigate = useNavigate() const { stopRun } = useStopRunMutation() const [isCanceling, setIsCanceling] = React.useState(false) - if (errors == null || errors.length === 0) return null + if ((errors == null || errors.length === 0) && (commandErrorList == null || commandErrorList.data.length === 0)) return null const modalHeader: ModalHeaderBaseProps = { title: t('run_failed_modal_title'), } @@ -60,6 +62,10 @@ export function RunFailedModal({ }, }) } + if ( + highestPriorityError != null && + (commandErrorList == null || commandErrorList?.data?.length === 0) + ) { return ( ) } +else{ + return ( + { + setShowRunFailedModal(false) + }} + > + + + + {commandErrorList?.pageLength} errors + + + + {commandErrorList?.data.map((error: RunError, index) => { + return ( + + {error.errorCode}: {error.detail} + + )})} + + + + {t('branded:contact_information')} + + + + + + ) +} +} const SCROLL_BAR_STYLE = css` overflow-y: ${OVERFLOW_AUTO}; diff --git a/app/src/pages/RunSummary/index.tsx b/app/src/pages/RunSummary/index.tsx index 5a9ec110fea..4a13b1018c6 100644 --- a/app/src/pages/RunSummary/index.tsx +++ b/app/src/pages/RunSummary/index.tsx @@ -38,6 +38,7 @@ import { useProtocolQuery, useInstrumentsQuery, useDeleteRunMutation, + useAllRunCommandErrorsQuery, } from '@opentrons/react-api-client' import { LargeButton } from '../../atoms/buttons' @@ -145,6 +146,14 @@ export function RunSummary(): JSX.Element { localRobot?.serverHealth?.serialNumber ?? null + const { data: commandErrorList } = useAllRunCommandErrorsQuery(runId, null, { + enabled: + runStatus != null && + // @ts-expect-error runStatus expected to possibly not be terminal + RUN_STATUSES_TERMINAL.includes(runStatus) && + isRunCurrent, + }) + let headerText = t('run_complete_splash') if (runStatus === RUN_STATUS_FAILED) { headerText = t('run_failed_splash') @@ -321,6 +330,7 @@ export function RunSummary(): JSX.Element { runId={runId} setShowRunFailedModal={setShowRunFailedModal} errors={runRecord?.data.errors} + commandErrorList={commandErrorList} /> ) : null}