MediaWiki:Scramble.js: Difference between revisions
Appearance
	
	
| No edit summary | No edit summary | ||
| (4 intermediate revisions by the same user not shown) | |||
| Line 10: | Line 10: | ||
|    shadowContainer.removeAttribute(scrambleAttrib); |    shadowContainer.removeAttribute(scrambleAttrib); | ||
|    container.appendChild(shadowContainer); |    container.appendChild(shadowContainer); | ||
|    scrambleNodes(container.childNodes); |    scrambleNodes(container.childNodes); | ||
| } | } | ||
| Line 36: | Line 30: | ||
|        node.nodeValue = newTextArray.join(""); |        node.nodeValue = newTextArray.join(""); | ||
|      } |      } | ||
|      else if(node.getAttribute(shadowContainerName) === "true") { |      else if(node.getAttribute && node.getAttribute(shadowContainerName) === "true") { | ||
|        // If we find the shadow copy, we  |        // If we find the shadow copy, we are done. | ||
|        return; |        return; | ||
|      } |      } | ||
| Line 63: | Line 57: | ||
| function setLooper(t) { | function setLooper(t) { | ||
|    t.setAttribute(scrambleCounterName, " |    t.setAttribute(scrambleCounterName, "0"); | ||
|    t._itv = setInterval((s) => { |    t._itv = setInterval((s) => { | ||
|      let iter = parseInt(s.getAttribute(scrambleCounterName)); |      let iter = parseInt(s.getAttribute(scrambleCounterName)); | ||
|      if(iter >  |      if(iter > 10) { | ||
|        unscramble(s); |        if(s.getAttribute(scrambleAttrib) === "true") { | ||
|         unscramble(s); | |||
|       } | |||
|        clearInterval(s._itv); |        clearInterval(s._itv); | ||
|      } else { |      } else { | ||
| Line 77: | Line 73: | ||
|        s.setAttribute(scrambleCounterName, iter.toString()); |        s.setAttribute(scrambleCounterName, iter.toString()); | ||
|      } |      } | ||
|    },  |    }, 500, t); | ||
| } | } | ||
| $('[' + scrambleAttrib + ']').each(function () { createShadowCopy(this | $('[' + scrambleAttrib + ']').each(function () {   | ||
|   createShadowCopy(this);   | |||
|   setLooper(this); | |||
| }); | |||
Latest revision as of 20:10, 24 August 2025
const alpha = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!";
const shadowContainerName = 'shadow-container';
const scrambleCounterName = 'scramble-counter';
const scrambleAttrib = 'data-scramble';
function createShadowCopy(container) {
  let shadowContainer = container.cloneNode(true);
  shadowContainer.style.display = 'none';
  shadowContainer.setAttribute(shadowContainerName, 'true');
  shadowContainer.removeAttribute(scrambleAttrib);
  container.appendChild(shadowContainer);
  
  scrambleNodes(container.childNodes);
}
function scrambleNodes(nodes) {
  nodes.forEach((node) => {
    if (node.nodeType == Node.TEXT_NODE) {
      let newTextArray = [];
      let oldValue = [...node.nodeValue];
      oldValue.forEach((char) => {
        if (/\S/.test(char)) {
          newTextArray.push(alpha[Math.floor(Math.random() * alpha.length)]);
        }
        else {
          newTextArray.push(char);
        }
      });
      node.nodeValue = newTextArray.join("");
    }
    else if(node.getAttribute && node.getAttribute(shadowContainerName) === "true") {
      // If we find the shadow copy, we are done.
      return;
    }
    else if(node.nodeType == Node.ELEMENT_NODE) {
      scrambleNodes(node.childNodes);
    }
  })
}
function unscramble(container) {
  children = Array.from(container.childNodes)
  let shadowCopy = children.find((node) => node.getAttribute && node.getAttribute(shadowContainerName));
  console.log(shadowCopy);
  
  if (shadowCopy) {
    while (container.firstChild) {
        container.removeChild(container.firstChild);
      }
    container.appendChild(shadowCopy);
    shadowCopy.style.display = '';
  }
}
function setLooper(t) {
  t.setAttribute(scrambleCounterName, "0");
  t._itv = setInterval((s) => {
    let iter = parseInt(s.getAttribute(scrambleCounterName));
    if(iter > 10) {
      if(s.getAttribute(scrambleAttrib) === "true") {
        unscramble(s);
      }
      clearInterval(s._itv);
    } else {
      console.log("Iter: " + iter);
      scrambleNodes(s.childNodes);
      iter = iter + 1;
      s.setAttribute(scrambleCounterName, iter.toString());
    }
  }, 500, t);
}
$('[' + scrambleAttrib + ']').each(function () { 
  createShadowCopy(this); 
  setLooper(this);
});