Jump to content

MediaWiki:Common.js: Difference between revisions

From FC1
No edit summary
No edit summary
Line 8: Line 8:
   el.innerHTML = chars.map((c, i) => {
   el.innerHTML = chars.map((c, i) => {
     let styles = [];
     let styles = [];
    let delays = [];
      
      
    // Calculate Rainbow
     if (isRainbow) {
     if (isRainbow) {
       const hue = Math.round((i / total) * 360);
       const hue = Math.round((i / total) * 360);
       const rainbowDelay = -((i / total) * 3).toFixed(2);
       const rainbowDelay = -((i / total) * 3).toFixed(2);
       styles.push(`color: hsl(${hue}, 100%, 60%)`, `animation-delay: ${rainbowDelay}s`);
       styles.push(`color: hsl(${hue}, 100%, 60%)`);
      delays.push(`${rainbowDelay}s`);
     }
     }
      
      
    // Calculate Wavy
     if (isWavy) {
     if (isWavy) {
       const waveDelay = ((i / total) * 1).toFixed(2);
       const waveDelay = -((i / total) * 1).toFixed(2); // Negative delay starts animation mid-cycle
      // If rainbow is also present, we append the wave delay to the animation-delay list
       delays.push(`${waveDelay}s`);
       if (isRainbow) {
    }
        styles[1] += `, ${waveDelay}s`;
 
      } else {
    // Combine delays into a single animation-delay property
        styles.push(`animation-delay: ${waveDelay}s`);
    if (delays.length > 0) {
      }
      styles.push(`animation-delay: ${delays.join(', ')}`);
     }
     }



Revision as of 08:00, 14 March 2026

/* Any JavaScript here will be loaded for all users on every page load. */
function applyEffects(el) {
  const chars = el.textContent.split('');
  const total = chars.length;
  const isRainbow = el.classList.contains('rainbow');
  const isWavy = el.classList.contains('wavy');

  el.innerHTML = chars.map((c, i) => {
    let styles = [];
    let delays = [];
    
    // Calculate Rainbow
    if (isRainbow) {
      const hue = Math.round((i / total) * 360);
      const rainbowDelay = -((i / total) * 3).toFixed(2);
      styles.push(`color: hsl(${hue}, 100%, 60%)`);
      delays.push(`${rainbowDelay}s`);
    }
    
    // Calculate Wavy
    if (isWavy) {
      const waveDelay = -((i / total) * 1).toFixed(2); // Negative delay starts animation mid-cycle
      delays.push(`${waveDelay}s`);
    }

    // Combine delays into a single animation-delay property
    if (delays.length > 0) {
      styles.push(`animation-delay: ${delays.join(', ')}`);
    }

    return `<span style="${styles.join('; ')}">${c === ' ' ? '&nbsp;' : c}</span>`;
  }).join('');
}

$(document).ready(function() {
  $('.rainbow, .wavy').each(function() { applyEffects(this); });
});