All files / modules/70-pipeline/components/execution/StepDetails/tabs/HarnessApprovalTab/HarnessApprover HarnessApprover.tsx

100% Statements 12/12
64.29% Branches 9/14
100% Functions 2/2
100% Lines 12/12

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>
  )
}