From aecc0b54a105e39f9b7a675fe2ee655670de38b6 Mon Sep 17 00:00:00 2001 From: Thomas Heartman Date: Fri, 12 Jan 2024 16:48:34 +0530 Subject: [PATCH] feat: show suspended states in change request badge (#5871) This updates the CR badge to show suspended states correctly. image --- .../ChangeRequestStatusBadge.tsx | 36 ++++++++++--------- 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/frontend/src/component/changeRequest/ChangeRequestStatusBadge/ChangeRequestStatusBadge.tsx b/frontend/src/component/changeRequest/ChangeRequestStatusBadge/ChangeRequestStatusBadge.tsx index 5c5d320616..67026ea1f2 100644 --- a/frontend/src/component/changeRequest/ChangeRequestStatusBadge/ChangeRequestStatusBadge.tsx +++ b/frontend/src/component/changeRequest/ChangeRequestStatusBadge/ChangeRequestStatusBadge.tsx @@ -7,6 +7,7 @@ import { CircleOutlined, Close, Error as ErrorIcon, + PauseCircle, } from '@mui/icons-material'; import { HtmlTooltip } from 'component/common/HtmlTooltip/HtmlTooltip'; @@ -60,27 +61,30 @@ export const ChangeRequestStatusBadge: VFC = ({ ); case 'Scheduled': { const { schedule } = changeRequest; - const color = schedule!.status === 'pending' ? 'warning' : 'error'; - const icon = - schedule?.status === 'pending' ? ( - - ) : ( - - ); - const scheduledAt = new Date( - schedule!.scheduledAt, - ).toLocaleString(); + const scheduledAt = new Date(schedule.scheduledAt).toLocaleString(); - const tooltipTitle = (() => { + const { color, icon, tooltipTitle } = (() => { switch (schedule.status) { case 'failed': - return `Failed on ${scheduledAt} because of ${ - schedule.reason || schedule.failureReason - }`; + return { + color: 'error' as const, + icon: , + tooltipTitle: `Failed on ${scheduledAt} because of ${ + schedule.reason ?? schedule.failureReason + }`, + }; case 'suspended': - return schedule.reason; + return { + color: 'disabled' as const, + icon: , + tooltipTitle: `Suspended because: ${schedule.reason}`, + }; default: - return `Scheduled for ${scheduledAt}`; + return { + color: 'warning' as const, + icon: , + tooltipTitle: `Scheduled for ${scheduledAt}`, + }; } })();