← Все примеры

JavaScript Продуктивность web.telegram.org

Telegram: кнопка копирования сообщения

Добавляет к каждому сообщению небольшую кнопку «Copy», копирующую текст в буфер обмена одним кликом.

Код для копирования

// Add a small "Copy" button to each message bubble
function addCopyButtons() {
  const msgs = document.querySelectorAll('.bubbles .bubble .message, .Message .text-content');
  msgs.forEach(function (m) {
    if (m.dataset.jzCopy) { return; }
    m.dataset.jzCopy = '1';
    const b = document.createElement('button');
    b.textContent = 'Copy';
    b.style.cssText = 'margin-left:6px;font-size:11px;padding:1px 6px;cursor:pointer;'
      + 'border:1px solid currentColor;border-radius:6px;background:transparent;color:inherit';
    b.addEventListener('click', function (e) {
      e.stopPropagation();
      navigator.clipboard.writeText(m.textContent || '');
    });
    m.appendChild(b);
  });
}
addCopyButtons();
const obs = new MutationObserver(addCopyButtons);
obs.observe(document.documentElement, { childList: true, subtree: true });

Как использовать этот пример

  1. Скопируй код кнопкой выше.
  2. Установи JustZix (2 минуты) и открой расширение на нужной странице.
  3. Добавь новое правило, совпадающее с этой страницей.
  4. Вставь код в панель JavaScript правила и сохрани — он запускается при каждом заходе на страницу.

Оцени этот пример

Оценок пока нет — оцени первым.

Этот пример работает?

Сниппеты бесполезны, если их некуда вставить.

JustZix устанавливается за 2 минуты и запускает твой код на каждой подходящей странице. Без аккаунта, без оплаты.

Скачать бесплатно Смотреть применение