MediaWiki:Common.js: Difference between revisions

From OmegaMMO
(Created page with "→‎Any JavaScript here will be loaded for all users on every page load.: // Asegurarse de que el DOM esté listo antes de ejecutar el script $(function() { // Función para copiar texto al portapapeles function copyTextToClipboard(text) { if (!navigator.clipboard) { // Fallback para navegadores antiguos o si navigator.clipboard no está disponible // Puedes usar un alert o un método más simple como un prompt (ver notas abajo)...")
 
No edit summary
 
Line 31: Line 31:
         }
         }
     });
     });
});
/* Click-to-copy para .copy-tag */
mw.loader.using([]).then(function () {
  function copyText(txt) {
    if (navigator.clipboard && navigator.clipboard.writeText) {
      return navigator.clipboard.writeText(txt);
    }
    // Fallback para navegadores viejos
    return new Promise(function (resolve) {
      var ta = document.createElement('textarea');
      ta.value = txt;
      document.body.appendChild(ta);
      ta.select();
      document.execCommand('copy');
      document.body.removeChild(ta);
      resolve();
    });
  }
  $(document).on('click', '.copy-tag', function () {
    var $el = $(this);
    var txt = $el.attr('data-copy') || $el.text();
    copyText(txt).then(function () {
      $el.addClass('copied');
      setTimeout(function(){ $el.removeClass('copied'); }, 1400);
    });
  });
});
});

Latest revision as of 21:36, 28 August 2025

/* Any JavaScript here will be loaded for all users on every page load. */
// Asegurarse de que el DOM esté listo antes de ejecutar el script
$(function() {
    // Función para copiar texto al portapapeles
    function copyTextToClipboard(text) {
        if (!navigator.clipboard) {
            // Fallback para navegadores antiguos o si navigator.clipboard no está disponible
            // Puedes usar un alert o un método más simple como un prompt (ver notas abajo)
            alert("Tu navegador no soporta la API de portapapeles. Por favor, copia el texto manualmente: " + text);
            return;
        }
        navigator.clipboard.writeText(text).then(function() {
            console.log('Texto copiado al portapapeles: ' + text);
            // Opcional: Mostrar un mensaje al usuario
            mw.notify('Texto copiado al portapapeles: ' + text, { tag: 'copy-success', type: 'success' });
        }).catch(function(err) {
            console.error('Error al copiar texto: ', err);
            mw.notify('No se pudo copiar el texto. Inténtalo de nuevo o cópialo manualmente.', { tag: 'copy-fail', type: 'error' });
        });
    }

    // Delegar el evento click para elementos con la clase 'copy-link'
    // Esto asegura que funcione incluso si el elemento se añade dinámicamente
    $('body').on('click', '.copy-link', function(e) {
        e.preventDefault(); // Evita que el enlace siga su href
        var textToCopy = $(this).data('text-to-copy');
        if (textToCopy) {
            copyTextToClipboard(textToCopy);
        } else {
            console.warn('El enlace de copia no tiene el atributo data-text-to-copy.');
        }
    });
});
/* Click-to-copy para .copy-tag */
mw.loader.using([]).then(function () {
  function copyText(txt) {
    if (navigator.clipboard && navigator.clipboard.writeText) {
      return navigator.clipboard.writeText(txt);
    }
    // Fallback para navegadores viejos
    return new Promise(function (resolve) {
      var ta = document.createElement('textarea');
      ta.value = txt;
      document.body.appendChild(ta);
      ta.select();
      document.execCommand('copy');
      document.body.removeChild(ta);
      resolve();
    });
  }

  $(document).on('click', '.copy-tag', function () {
    var $el = $(this);
    var txt = $el.attr('data-copy') || $el.text();
    copyText(txt).then(function () {
      $el.addClass('copied');
      setTimeout(function(){ $el.removeClass('copied'); }, 1400);
    });
  });
});