/*
Copyright (C) 2018 Cloudbase Solutions SRL
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
*/
import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'
import CopyButton from '@src/components/ui/CopyButton'
import DomUtils from '@src/utils/DomUtils'
import notificationStore from '@src/stores/NotificationStore'
const CopyButtonStyled = styled(CopyButton)`
background-position-y: 4px;
margin-left: 4px;
`
const Wrapper = styled.div`
cursor: pointer;
word-break: break-word;
&:hover ${CopyButtonStyled} {
opacity: 1;
}
`
type Props = {
value: string | null | undefined,
onCopy?: (value: string) => void,
useDangerousHtml?: boolean,
}
@observer
class CopyMultineValue extends React.Component {
handleCopy() {
let { value } = this.props
if (!value) {
return
}
if (this.props.useDangerousHtml) {
value = value.replace(/
/g, '\n').replace(/<.*?>/g, '')
}
const succesful = DomUtils.copyTextToClipboard(value)
if (this.props.onCopy) this.props.onCopy(value)
if (succesful) {
notificationStore.alert('The message has been copied to clipboard.')
}
}
render() {
let text: React.ReactNode = this.props.value
if (this.props.useDangerousHtml) {
text =
}
return (
{ this.handleCopy() }}
>
{text}
)
}
}
export default CopyMultineValue