1
0
mirror of synced 2025-12-20 10:28:40 -05:00
Files
docs/components/lib/copy-code.ts
Grace Park 8ba413cabc React Cleanup: Documentation (#20517)
* initial documentation changes

* editing layouts terminology

* update to match other files

* move javascripts to components/lib

* fix: dockerfile

* update based on Mikes updates to the javascripts directory

* update components/README.md

Co-authored-by: Mike Surowiec <mikesurowiec@users.noreply.github.com>
2021-07-27 09:07:18 -07:00

21 lines
589 B
TypeScript

export default function copyCode() {
const buttons = Array.from(document.querySelectorAll('button.js-btn-copy'))
if (!buttons) return
buttons.forEach((button) =>
button.addEventListener('click', async () => {
const text = (button as HTMLElement).dataset.clipboardText
if (!text) return
await navigator.clipboard.writeText(text)
const beforeTooltip = button.getAttribute('aria-label') || ''
button.setAttribute('aria-label', 'Copied!')
setTimeout(() => {
button.setAttribute('aria-label', beforeTooltip)
}, 2000)
})
)
}