mirror of
https://github.com/BBaoVanC/bobatheme.git
synced 2025-06-12 09:47:29 -05:00
Improve code block copy text
- Use JS to get it directly from the code block instead of needing a separate `pre.code-raw` to get it from. That makes it possible to: - bashsession: Don't copy prompt or command output
This commit is contained in:
@ -12,14 +12,19 @@ window.onscroll = function() {
|
||||
window.onload = () => {
|
||||
document.querySelectorAll(".code-block").forEach(codeBlock => {
|
||||
const button = codeBlock.querySelector(".code-header > .code-copy-button");
|
||||
// TODO: maybe get this from HTMLElement.innerText on the actual code block content element
|
||||
// but it's hard to select it; `data-lang` attribute might not always be there (if lang is unset)
|
||||
const rawCode = codeBlock.querySelector("pre.code-raw").innerText;
|
||||
|
||||
// lang will not be unset because we default it to text
|
||||
// clone it so it doesn't change the actual DOM element
|
||||
const codeElem = codeBlock.querySelector("code[data-lang]").cloneNode(true);
|
||||
// bashsession: remove command output lines
|
||||
codeElem.querySelectorAll(".go").forEach(e => e.parentNode.removeChild(e));
|
||||
// bashsession: remove prompt symbol
|
||||
codeElem.querySelectorAll(".gp").forEach(e => e.parentNode.removeChild(e));
|
||||
const rawCode = codeElem.innerText;
|
||||
|
||||
const originalCopyText = button.innerHTML;
|
||||
button.onclick = event => {
|
||||
navigator.clipboard.writeText(rawCode);
|
||||
console.log(rawCode);
|
||||
// TODO: maybe we could add a fancier indicator, like a flash or something
|
||||
event.target.innerHTML = "Copied!";
|
||||
setTimeout(() => {
|
||||
|
Reference in New Issue
Block a user