add copy button

This commit is contained in:
2026-04-29 11:54:00 +07:00
parent deaff4531c
commit d28906d74f

View File

@@ -1273,17 +1273,28 @@
expandedRows.add(idx); expandedRows.add(idx);
const detailTr = document.createElement('tr'); const detailTr = document.createElement('tr');
detailTr.className = 'row-detail'; detailTr.className = 'row-detail';
const section = (label, content, color = 'var(--text2)') => `
<div class="detail-section">
<div style="display:flex;align-items:center;justify-content:space-between;margin-bottom:6px">
<div class="detail-label">${label}</div>
<button onclick="copySection(this, ${JSON.stringify(content).replace(/"/g, '&quot;')})"
style="padding:2px 8px;border-radius:3px;border:1px solid var(--border2);background:transparent;
color:var(--text3);font-size:10px;font-family:var(--font-mono);cursor:pointer;transition:all .15s"
onmouseover="this.style.color='var(--text)';this.style.borderColor='var(--border3)'"
onmouseout="this.style.color='var(--text3)';this.style.borderColor='var(--border2)'">
copy
</button>
</div>
<div class="detail-val" style="color:${color}">${esc(content)}</div>
</div>`;
let sections = ''; let sections = '';
if (log.fullmessage) { if (log.fullmessage) sections += section('Full Message', log.fullmessage);
sections += `<div class="detail-section"><div class="detail-label">Full Message</div><div class="detail-val">${esc(log.fullmessage)}</div></div>`; if (log.exception) sections += section('Exception / Stack Trace', log.exception, 'var(--error)');
} if (log.props) sections += section('Properties', JSON.stringify(log.props, null, 2));
if (log.exception) {
sections += `<div class="detail-section"><div class="detail-label">Exception / Stack Trace</div><div class="detail-val" style="color:var(--error)">${esc(log.exception)}</div></div>`;
}
if (log.props) {
sections += `<div class="detail-section"><div class="detail-label">Properties</div><div class="detail-val">${esc(JSON.stringify(log.props, null, 2))}</div></div>`;
}
if (!sections) return; if (!sections) return;
detailTr.innerHTML = `<td colspan="3"><div class="detail-inner">${sections}</div></td>`; detailTr.innerHTML = `<td colspan="3"><div class="detail-inner">${sections}</div></td>`;
tr.after(detailTr); tr.after(detailTr);
} }
@@ -1485,6 +1496,20 @@
if (file) loadFile(file); if (file) loadFile(file);
}); });
window.copySection = function (btn, text) {
navigator.clipboard.writeText(text).then(() => {
const orig = btn.textContent;
btn.textContent = 'copied ✓';
btn.style.color = 'var(--info)';
btn.style.borderColor = 'var(--info)';
setTimeout(() => {
btn.textContent = orig;
btn.style.color = 'var(--text3)';
btn.style.borderColor = 'var(--border2)';
}, 1500);
});
};
// Load demo on start // Load demo on start
//loadDemo(); //loadDemo();
</script> </script>