User:MathAfrique/Moyai.js

/** * @name mediawiki-userscript-moyai * @version 1.0.0 * @description Put some 🗿 in your Wikipedia! * @author https://en.wikipedia.org/wiki/User:MathAfrique * @see https://en.wikipedia.org/wiki/User:MathAfrique/Moyai * @icon https://upload.wikimedia.org/wikipedia/commons/c/c6/Fluent_Emoji_flat_1f5ff.svg * @include http://*.wikipedia.org/* * @updateURL https://en.wikipedia.org/w/index.php?title=User:MathAfrique/Moyai.js&action=raw&ctype=text/javascript * @usage mw.loader.load("/w/index.php?title=User:MathAfrique/Moyai.js&action=raw&ctype=text/javascript"); // Backlink: User:MathAfrique/Moyai.js */
 * (function {

if (mw.config.get("wgServer") !== '//en.wikipedia.org') { return; }	if (mw.config.get("gmMediawikiUserScriptMoyai")) { return; }	mw.config.set("gmMediawikiUserScriptMoyai", true);

/** Moyai fountain generator - shows the script is working. */	class Fountain { constructor { this.limit = 10; this.particles = [];

this.width = this.height = 600; this.sizes = [8, 12, 16, 20, 24];

this.$container = $(document.createElement("div")); this.$container.addClass(""); $(document.body).append(this.$container);

this.$container.css("height", "600px"); this.$container.css("width", "600px");

this.$container.css("pointer-events", "none"); this.$container.css("user-select", "none");

this.$container.css("position", "fixed"); this.$container.css("right", "0"); this.$container.css("bottom", "0");

if (mw.config.get("wgPageName") !== "Moai") { this.$container.css("opacity", "25%"); }		}		loop { if (this.particles.length < this.limit) { this.voxel; }			this.particles.forEach(this.recompute, this); const reloopFn = requestAnimationFrame.bind(null, this.loop.bind(this)); setTimeout(reloopFn, 12); }

voxel { const size = this.sizes[Math.floor(Math.random * this.sizes.length)];

const speedHorz = Math.random * 10; const speedVert = Math.random * 25; const spinVal = Math.random * 360; const spinSpeed = Math.random * 35 * (Math.random <= 0.5 ? -1 : 1); const top = this.height - size / 2; const left = this.width - size / 2; const $element = $(document.createElement("span")); $element.text("🗿"); $element.addClass("particle"); $element.css({               "font-size": size + "px",                "left": left + "px",				"pointer-events": "none",				"position": "absolute",                "top": top + "px",                "transform": "initial",				"user-select": "none",				"will-change": "transform"			}); this.$container.append($element); this.particles.push({ $element, size, speedHorz, speedVert, spinVal, spinSpeed, top, left }); }		recompute(p) { p.left = p.left - p.speedHorz; p.top = p.top - p.speedVert; p.speedVert = Math.min(p.size, p.speedVert - 1); p.spinVal = p.spinVal + p.spinSpeed; if (p.top >= this.height + p.size) { this.particles = this.particles.filter((o) => o !== p); p.$element.remove; return; }           p.$element.css({                "font-size": p.size + "px",                "left": p.left + "px",				"pointer-events": "none",				"position": "absolute",                "top": p.top + "px",                "transform": "rotate(" + p.spinVal + "deg);",				"user-select": "none",				"will-change": "transform"            }); }	}	const fountain = new Fountain; fountain.loop;

const skin = mw.config.get("skin");

const moyai = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMTAwcHgiIHdpZHRoPSIxMDBweCI+PGZvcmVpZ25PYmplY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEwMCIgaGVpZ2h0PSIxMDAiIHN0eWxlPSJkaXNwbGF5OiBmbGV4O3RleHQtYWxpZ246IGNlbnRlcjsiPjxzcGFuIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIiBzdHlsZT0iZm9udC1zaXplOjEwMHB4O2xpbmUtaGVpZ2h0OjFlbTt0ZXh0LWluZGVudDotMXJlbTt2ZXJ0aWNhbC1hbGlnbjpib3R0b207Ij7wn5e/PC9zcGFuPjwvZm9yZWlnbk9iamVjdD48L3N2Zz4="; const wordmark = "data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 286 42"><foreignObject width="100%" height="100%"><div xmlns="http://www.w3.org/1999/xhtml" id="title" style="-webkit-font-smoothing:antialiased;display:inline-block;float:left;font-family:'Linux Libertine Capitals';font-size:60px;line-height: 0.7em;overflow:hidden;text-shadow: currentcolor -0.001px -0.001px 0,currentcolor 0.001px -0.001px 0,currentcolor -0.001px 0.001px 0,currentcolor 0.001px 0.001px 0;white-space:nowrap;">MoaipediA</div><style>@font-face{font-family:"Linux Libertine Capitals";src:url("data:application/font-woff;base64,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") format("woff");font-weight:normal;font-style:normal;}</style></foreignObject></svg>";

switch (skin) { case "vector-2022": $(".mw-logo-icon").attr("src", moyai); $(".mw-logo-wordmark").attr("src", wordmark); $(".mw-logo-wordmark").css("height", "auto"); break; case "vector": case "monobook": $(".mw-wiki-logo").css("background-image", "url('" + moyai + "')"); $(".mw-wiki-logo").css("background-size", "128px"); break; case "cologneblue": $("#sitetitle").css("background-image", "url('" + moyai + "')"); $("#sitetitle").css("background-position", "center left"); $("#sitetitle").css("background-repeat", "no-repeat"); $("#sitetitle").css("background-size", "contain"); $("#sitetitle").css("background-color", "#6a8"); $("#sitetitle").css("padding-left", "53px"); break; case "minerva": $(".branding-box img").removeAttr("style"); $(".branding-box img").removeAttr("width"); $(".branding-box img").attr("src", wordmark); break; case "timeless": $(".mw-wiki-title img").attr("src", wordmark); $(".mw-wiki-logo img").attr("src", moyai); } });