mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-11-26 19:56:11 +01:00
c148156409
Behaviour now matches GH. Safeguard added in the for loop because
`textContent` may be null in which case it does not make sense to render
the copy button.
Co-authored-by: silverwind <me@silverwind.io>
(cherry picked from commit 5d1abdce3e
)
22 lines
646 B
JavaScript
22 lines
646 B
JavaScript
import {svg} from '../svg.js';
|
|
|
|
export function makeCodeCopyButton() {
|
|
const button = document.createElement('button');
|
|
button.classList.add('code-copy', 'ui', 'button');
|
|
button.innerHTML = svg('octicon-copy');
|
|
return button;
|
|
}
|
|
|
|
export function renderCodeCopy() {
|
|
const els = document.querySelectorAll('.markup .code-block code');
|
|
if (!els.length) return;
|
|
|
|
for (const el of els) {
|
|
if (!el.textContent) continue;
|
|
const btn = makeCodeCopyButton();
|
|
// remove final trailing newline introduced during HTML rendering
|
|
btn.setAttribute('data-clipboard-text', el.textContent.replace(/\r?\n$/, ''));
|
|
el.after(btn);
|
|
}
|
|
}
|