Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 | 2x 2x 2x 2x 2x 2x 2x 2x 2x 10x 10x 20x | /* * Copyright 2021 Harness Inc. All rights reserved. * Use of this source code is governed by the PolyForm Shield 1.0.0 license * that can be found in the licenses directory at the root of this repository, also available at * https://polyformproject.org/wp-content/uploads/2020/06/PolyForm-Shield-1.0.0.txt. */ import React from 'react' import { Icon, IconName } from '@wings-software/uicore' import moment from 'moment' import type { HarnessApprovalActivity } from 'services/pipeline-ng' import { String } from 'framework/strings' import type { StringKeys } from 'framework/strings' import { Collapse } from '@pipeline/components/execution/StepDetails/common/Collapse/Collapse' import css from './HarnessApprover.module.scss' const iconMap: Record<HarnessApprovalActivity['action'], IconName> = { APPROVE: 'tick', REJECT: 'cross' } const statusStringMap: Record<HarnessApprovalActivity['action'], StringKeys> = { APPROVE: 'pipeline.approvalStep.status.APPROVE', REJECT: 'pipeline.approvalStep.status.REJECT' } export interface HarnessApproverProps { approvalActivity: HarnessApprovalActivity } export function HarnessApprover(props: HarnessApproverProps): React.ReactElement { const { approvalActivity } = props return ( <div className={css.approver}> <Collapse title={ <React.Fragment> <div className={css.approverName}>{approvalActivity.user?.name}</div> <div className={css.status} data-status={approvalActivity.action}> <Icon name={iconMap[approvalActivity.action]} size={12} /> <String stringID={statusStringMap[approvalActivity.action]} /> </div> <div className={css.time}> {approvalActivity.approvedAt ? moment(approvalActivity.approvedAt).fromNow() : '-'} </div> </React.Fragment> } titleContentClassName={css.summary} > <React.Fragment> <String tagName="div" className={css.label} stringID="inputs" /> <ul className={css.approverInputs}> {Array.isArray(approvalActivity.approverInputs) && approvalActivity.approverInputs.length > 0 ? ( (approvalActivity.approverInputs || []).map((row, i) => ( <li key={i}> <span>{row.name}:</span> <span>{row.value}</span> </li> )) ) : ( <String stringID="pipeline.execution.noInputsText" /> )} </ul> <String tagName="div" className={css.label} stringID="common.comments" /> <div className={css.comments}>{approvalActivity.comments || '-'}</div> </React.Fragment> </Collapse> </div> ) } |