UNPKG

@wordpress/compose

Version:
77 lines (66 loc) 2.26 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = useCopyOnClick; var _clipboard = _interopRequireDefault(require("clipboard")); var _element = require("@wordpress/element"); var _deprecated = _interopRequireDefault(require("@wordpress/deprecated")); /** * External dependencies */ /** * WordPress dependencies */ /** * Copies the text to the clipboard when the element is clicked. * * @deprecated * * @param {Object} ref Reference with the element. * @param {string|Function} text The text to copy. * @param {number} timeout Optional timeout to reset the returned * state. 4 seconds by default. * * @return {boolean} Whether or not the text has been copied. Resets after the * timeout. */ function useCopyOnClick(ref, text, timeout = 4000) { (0, _deprecated.default)('wp.compose.useCopyOnClick', { since: '10.3', plugin: 'Gutenberg', alternative: 'wp.compose.useCopyToClipboard' }); const clipboard = (0, _element.useRef)(); const [hasCopied, setHasCopied] = (0, _element.useState)(false); (0, _element.useEffect)(() => { let timeoutId; // Clipboard listens to click events. clipboard.current = new _clipboard.default(ref.current, { text: () => typeof text === 'function' ? text() : text }); clipboard.current.on('success', ({ clearSelection, trigger }) => { // Clearing selection will move focus back to the triggering button, // ensuring that it is not reset to the body, and further that it is // kept within the rendered node. clearSelection(); // Handle ClipboardJS focus bug, see https://github.com/zenorocha/clipboard.js/issues/680 if (trigger) { trigger.focus(); } if (timeout) { setHasCopied(true); clearTimeout(timeoutId); timeoutId = setTimeout(() => setHasCopied(false), timeout); } }); return () => { clipboard.current.destroy(); clearTimeout(timeoutId); }; }, [text, timeout, setHasCopied]); return hasCopied; } //# sourceMappingURL=index.js.map