All files / modules/75-cf/components/IdentifierText IdentifierText.tsx

78.57% Statements 11/14
100% Branches 2/2
50% Functions 1/2
76.92% Lines 10/13

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              10x 10x 10x 10x 10x 10x           10x 93x 93x   93x                                                  
/*
 * Copyright 2022 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 { Button, Container, Icon, Text, TextProps, Utils } from '@wings-software/uicore'
import { FontVariation, Color } from '@harness/design-system'
import { useStrings } from 'framework/strings'
import { useToaster } from '@common/exports'
import css from './IdentifierText.module.scss'
export interface IdentifierTextProps extends TextProps {
  identifier?: string
  allowCopy?: boolean
}
 
export const IdentifierText: React.FC<IdentifierTextProps> = ({ identifier, style, allowCopy, ...props }) => {
  const { getString } = useStrings()
  const { showSuccess, clear } = useToaster()
 
  return (
    <Container className={css.identifierContainer}>
      <Text inline font={{ variation: FontVariation.SMALL }} margin={{ right: 'xsmall' }}>
        {getString('idLabel')}
      </Text>
      <Text inline {...props} font={{ variation: FontVariation.SMALL }}>
        {identifier}
      </Text>
      {allowCopy && (
        <Button
          noStyling
          className={css.copyButton}
          title={getString('clickToCopy')}
          onClick={() => {
            Utils.copy(identifier as string)
            clear()
            showSuccess(getString('copiedToClipboard'))
          }}
        >
          <Icon name="duplicate" size={12} color={Color.GREY_350} />
        </Button>
      )}
    </Container>
  )
}