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