/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* Add copy-to-clipboard buttons to code blocks */ window.addEventListener('load', function() { const COPY_BUTTON_TEXT_LABEL = 'Copy' const COPY_BUTTON_SUCCESS_TEXT_LABEL = 'Copied' function addCopyButtons(codeBlockSelector, copyButton) { document.querySelectorAll(codeBlockSelector).forEach(function(codeBlock) { codeBlock.parentNode.appendChild(copyButton.cloneNode(true)); }); } function createCopyButton() { const copyButton = document.createElement('button'); copyButton.classList.add('copyCodeButton'); copyButton.setAttribute('aria-label', 'Copy code to clipboard'); copyButton.setAttribute('type', 'button'); /* SVG is 'clipboard' icon from blueprintjs */ copyButton.innerHTML = '
' + ' ' + '' + COPY_BUTTON_TEXT_LABEL + '' + '
'; return copyButton; } addCopyButtons('.hljs', createCopyButton()); const clipboard = new ClipboardJS('.copyCodeButton', { target: function(trigger) { return trigger.parentNode.querySelector('code'); }, }); function showCopySuccess(copyButtonTextElement) { copyButtonTextElement.textContent = COPY_BUTTON_SUCCESS_TEXT_LABEL; setTimeout(function() { copyButtonTextElement.textContent = COPY_BUTTON_TEXT_LABEL; }, 2000); } clipboard.on('success', function(event) { event.clearSelection(); const copyButtonTextElement = event.trigger.querySelector('.copyCodeButtonTextLabel'); showCopySuccess(copyButtonTextElement) }); });