summaryrefslogtreecommitdiffstats
path: root/browser/components/newtab/content-src/components/ASRouterAdmin/CopyButton.jsx
blob: 07ce12d7bf327711ac5437831c9850bc7fe613d4 (plain)
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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

import React, { useState, useRef, useCallback } from "react";

export const CopyButton = ({
  className,
  label,
  copiedLabel,
  inputSelector,
  transformer,
  ...props
}) => {
  const [copied, setCopied] = useState(false);
  const timeout = useRef(null);
  const onClick = useCallback(() => {
    let text = document.querySelector(inputSelector).value;
    if (transformer) text = transformer(text);
    navigator.clipboard.writeText(text);

    clearTimeout(timeout.current);
    setCopied(true);
    timeout.current = setTimeout(() => setCopied(false), 1500);
  }, [inputSelector, transformer]);
  return (
    <button className={className} onClick={e => onClick()} {...props}>
      {(copied && copiedLabel) || label}
    </button>
  );
};