lbry-desktop/ui/component/copyableText/view.jsx

59 lines
1.3 KiB
React
Raw Normal View History

2018-10-04 09:39:14 -04:00
// @flow
2018-11-25 20:21:25 -05:00
import * as ICONS from 'constants/icons';
2019-02-13 12:27:20 -04:00
import { FormField } from 'component/common/form';
2018-10-04 09:39:14 -04:00
import Button from 'component/button';
2019-10-29 12:23:56 -04:00
import React, { useRef } from 'react';
2018-10-04 09:39:14 -04:00
type Props = {
copyable: string,
2019-01-22 15:36:28 -05:00
snackMessage: ?string,
doToast: ({ message: string }) => void,
2019-02-20 11:18:59 -05:00
label?: string,
2018-10-04 09:39:14 -04:00
};
2019-10-29 12:23:56 -04:00
export default function CopyableText(props: Props) {
const { copyable, doToast, snackMessage, label } = props;
2018-10-04 09:39:14 -04:00
2019-10-29 12:23:56 -04:00
const input = useRef();
2019-02-20 11:18:59 -05:00
2019-10-29 12:23:56 -04:00
function copyToClipboard() {
const topRef = input.current;
if (topRef && topRef.input && topRef.input.current) {
topRef.input.current.select();
}
document.execCommand('copy');
}
2019-10-29 12:23:56 -04:00
function onFocus() {
2019-02-20 11:18:59 -05:00
// We have to go a layer deep since the input is inside the form component
2019-10-29 12:23:56 -04:00
const topRef = input.current;
2019-02-20 11:18:59 -05:00
if (topRef && topRef.input && topRef.input.current) {
topRef.input.current.select();
}
}
2018-10-04 09:39:14 -04:00
2019-10-29 12:23:56 -04:00
return (
<FormField
type="text"
className="form-field--copyable"
readOnly
label={label}
value={copyable || ''}
ref={input}
onFocus={onFocus}
inputButton={
<Button
button="inverse"
icon={ICONS.COPY}
onClick={() => {
copyToClipboard();
doToast({
message: snackMessage || __('Text copied'),
});
}}
/>
}
/>
);
2018-10-04 09:39:14 -04:00
}