User:MathAfrique/Moyai.js

Source: Wikipedia, the free encyclopedia.
Note: After saving, you have to bypass your browser's cache to see the changes. Google Chrome, Firefox, Microsoft Edge and Safari: Hold down the ⇧ Shift key and click the Reload toolbar button. For details and instructions about other browsers, see Wikipedia:Bypass your cache.
/**
 * @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);
	}
}());