MediaWiki:Common.js: Difference between revisions

From VRChat Wiki
m fix?: syntax error??
Tag: Reverted
fix: shorter edit summaries (https://github.com/vrchat-community/wiki-scripts/commit/e7df78534acdd90ece722dd6f433a86fa3f4971d); test: show commit messages in ci (https://github.com/vrchat-community/wiki-scripts/commit/07f619785b300a612cea03aa23210916324b8e5f)
 
(18 intermediate revisions by 2 users not shown)
Line 1: Line 1:
function e(e) {
/** @license
let [t, n] = mw.config.get("wgPageName").split("/");
* This file is auto-generated. Do not edit directly.
return !(!t || !e.includes(t) || !n || mw.config.get("wgPageContentLanguage") != n);
* @see https://github.com/vrchat-community/wiki-scripts/blob/main/src/index.ts
}
*/
e(["Template:MainPageInfopush", "Main_Page"]) && mw.loader.using(["oojs-ui-core", "oojs-ui-windows"]).done(() => {
(() => {
var e = new OO.ui.WindowManager();
var e = Object.defineProperty;
$(document.body).append(e.$element);
var __esmMin = (e, t) => () => (e && (t = e(e = 0)), t);
function t(t) {
var __export = (t, n) => {
var { articleTitle: n, articleContent: r } = t.dataset;
let r = {};
function i(e) {
for (var i in t) e(r, i, {
i.super.call(this, e), this.config = e || {};
get: t[i],
enumerable: !0
});
n && e(r, Symbol.toStringTag, { value: "Module" });
return r;
};
function isPage(e) {
let [t, n] = mw.config.get("wgPageName").split("/");
if (!t || !e.includes(t)) return !1;
if (n && mw.config.get("wgPageContentLanguage") !== n) return !1;
return !0;
}
document.querySelectorAll(".spoiler").forEach((e) => {
let t = e.querySelector(".spoiler-overlay");
t == null || t.addEventListener("click", () => {
e.dataset.open = "";
});
});
let __vitePreload = function(e, t, n) {
let r = Promise.resolve();
function handlePreloadError(e) {
let t = new Event("vite:preloadError", { cancelable: !0 });
t.payload = e;
window.dispatchEvent(t);
if (!t.defaultPrevented) throw e;
}
}
OO.inheritClass(i, OO.ui.ProcessDialog), i.static.name = "ArticleDialog", i.static.title = n, i.static.size = "large", i.static.actions = [{
return r.then((t) => {
for (let e of t || []) {
if (e.status !== "rejected") continue;
handlePreloadError(e.reason);
}
return e().catch(handlePreloadError);
});
};
function getArticleFromElement(e) {
let { articleId: t, articleTitle: n, articleContent: r } = e.dataset;
if (!t || !n || !r) return null;
return {
id: t,
title: n,
content: atob(r)
};
}
var ArticleDialog;
var t = __esmMin((() => {
ArticleDialog = class extends OO.ui.ProcessDialog {
constructor(e) {
super({
size: "large",
data: { title: e.title }
});
this.article = e;
}
initialize() {
super.initialize();
let e = new OO.ui.PanelLayout({
expanded: !1,
padded: !0,
scrollable: !0
});
e.$element.append(this.article.content);
this.$body.append(e.$element);
return this;
}
getActionProcess(e) {
switch (e) {
case "close": return new OO.ui.Process(() => {
this.close({ action: "close" });
});
}
return super.getActionProcess(e);
}
};
ArticleDialog.static.name = ArticleDialog.name;
ArticleDialog.static.actions = [{
action: "close",
action: "close",
flags: "safe",
flags: "safe",
icon: "close",
icon: "close",
label: "Close"
label: "Close"
}], i.prototype.initialize = function() {
}];
i.super.prototype.initialize.apply(this, arguments), this.content = new OO.ui.PanelLayout({
}));
$content: atob(r),
var n = __esmMin((() => {}));
expanded: !1,
function asyncGeneratorStep(e, t, n, r, i, a, o) {
padded: !0,
try {
scrollable: !0
var s = e[a](o), c = s.value;
}), this.$body.append(this.content.$element);
} catch (e) {
}, i.prototype.getActionProcess = function(e) {
n(e);
return e === "close" ? new OO.ui.Process(function() {
return;
this.close({ action: "close" });
}
}, this) : i.super.prototype.getActionProcess.call(this, e);
s.done ? t(c) : Promise.resolve(c).then(r, i);
}
function _asyncToGenerator(e) {
return function() {
var t = this, n = arguments;
return new Promise(function(r, i) {
var a = e.apply(t, n);
function _next(e) {
asyncGeneratorStep(a, r, i, _next, _throw, "next", e);
}
function _throw(e) {
asyncGeneratorStep(a, r, i, _next, _throw, "throw", e);
}
_next(void 0);
});
};
};
var a = new i();
e.addWindows([a]), e.openWindow(a);
}
}
let n = document.querySelectorAll(".tpl-infopush");
var r = __esmMin((() => {}));
for (let e of n) {
var i = /* @__PURE__ */ __export({}, 1);
let n = e.querySelector(".tpl-infopush-content"), r = n.querySelectorAll(".tpl-infopush-item"), i = r.length;
var a, o;
for (let e of r) {
var s = __esmMin((() => {
let { articleId: n } = e.dataset;
t();
!n || e.querySelector("a") || (e.style.cursor = "pointer", e.addEventListener("click", () => t(e)));
n();
r();
a = document.querySelectorAll(".tpl-infopush");
o = new OO.ui.WindowManager();
$(document.body).append(o.$element);
for (let e of a) {
let t = e.querySelector(".tpl-infopush-content");
let n = t.querySelectorAll(".tpl-infopush-item");
let r = n.length;
for (let e of n) {
if (e.querySelector("a")) continue;
let t = getArticleFromElement(e);
if (!t) continue;
e.style.cursor = "pointer";
e.addEventListener("click", _asyncToGenerator(function* () {
if (!(yield o.getWindow(t.id).then(() => !0).catch(() => !1))) {
let e = new ArticleDialog(t);
o.addWindows({ [t.id]: e });
}
yield o.openWindow(t.id).opening;
}));
}
let i = e.querySelector(".tpl-infopush-navigation");
let a = 0;
function showSlide(e) {
a = (e + r) % r;
t.style.transform = `translateX(-${a * 100}%)`;
}
let s;
function resetAutoAdvance() {
s && clearInterval(s);
s = setInterval(() => {
showSlide(a + 1);
}, 5e3);
}
i.querySelector(".tpl-infopush-navigation-previous").addEventListener("click", () => {
showSlide(a - 1);
resetAutoAdvance();
});
i.querySelector(".tpl-infopush-navigation-next").addEventListener("click", () => {
showSlide(a + 1);
resetAutoAdvance();
});
resetAutoAdvance();
showSlide(0);
}
}
let a = e.querySelector(".tpl-infopush-navigation"), o = 0;
}));
function s(e) {
isPage(["Template:MainPageInfopush", "Main_Page"]) && mw.loader.using(["oojs-ui-core", "oojs-ui-windows"]).then(() => __vitePreload(() => Promise.resolve().then(() => (s(), i)), void 0, {}.url));
o = (e + i) % i, n.style.transform = `translateX(-${o * 100}%)`;
var c = document.createElement("script");
}
c.setAttribute("defer", "defer");
let c;
c.setAttribute("data-domain", "wiki.vrchat.com");
function l() {
c.setAttribute("event-page-name", mw.config.get("wgTitle"));
c && clearInterval(c), c = setInterval(function() {
c.setAttribute("event-page-language", mw.config.get("wgPageContentLanguage"));
s(o + 1);
var l = mw.config.get("wgFormattedNamespaces");
}, 5e3);
c.setAttribute("event-page-namespace", l[mw.config.get("wgNamespaceNumber")]);
}
c.setAttribute("event-theme", mw.config.get("skin"));
a.querySelector(".tpl-infopush-navigation-previous").addEventListener("click", () => {
c.setAttribute("event-action", mw.config.get("wgAction"));
s(o - 1), l();
c.setAttribute("event-is-logged-in", String(mw.config.get("wgUserName") !== null));
}), a.querySelector(".tpl-infopush-navigation-next").addEventListener("click", () => {
var u = mw.config.get("wgUserGroups");
s(o + 1), l();
var d = u.includes("community-mod") || u.includes("moderator") || u.includes("sysop");
}), l(), s(0);
c.setAttribute("event-is-maintainer", String(d));
c.src = "https://plausible.io/js/script.pageview-props.outbound-links.js";
document.head.appendChild(c);
var f = "p-userpagetools";
function lowercaseFirst(e) {
return e.charAt(0).toLowerCase() + e.slice(1);
}
if (mw.util.isPortletVisible(f)) {
let e = lowercaseFirst(mw.config.get("wgPageName").split(":")[1]);
mw.util.addPortletLink(f, `https://vrchat.com/home/user/${e}`, "VRChat profile");
}
}
}), [...document.querySelectorAll(".spoiler")].map((e) => {
console.log("Wiki scripts loaded.");
e.querySelector(".spoiler-overlay")?.addEventListener("click", () => {
})();
e.dataset.open = "";
});
}), [...document.querySelectorAll(".youtube")].map((e) => {
let { videoId: t, ...n } = e.dataset, r = document.createElement("iframe");
r.setAttribute("width", "560"), r.setAttribute("height", "315"), r.setAttribute("frameborder", "0"), r.setAttribute("allow", [
"accelerometer",
"autoplay",
"clipboard-write",
"encrypted-media",
"gyroscope",
"picture-in-picture",
"web-share"
].join("; ")), r.setAttribute("referrerpolicy", "strict-origin-when-cross-origin"), r.setAttribute("allowfullscreen", "true"), Object.entries(n).map(([e, t]) => t && r.setAttribute(e, t)), r.setAttribute("style", e.getAttribute("style") || ""), r.src = `https://www.youtube-nocookie.com/embed/${t}?rel=0`, e.replaceWith(r);
});
var t = document.createElement("script");
t.setAttribute("defer", "defer"), t.setAttribute("data-domain", "wiki.vrchat.com"), t.setAttribute("event-page-name", mw.config.get("wgTitle")), t.setAttribute("event-page-language", mw.config.get("wgPageContentLanguage"));
const n = mw.config.get("wgFormattedNamespaces");
t.setAttribute("event-page-namespace", n[mw.config.get("wgNamespaceNumber")]), t.setAttribute("event-theme", mw.config.get("skin")), t.setAttribute("event-action", mw.config.get("wgAction")), t.setAttribute("event-is-logged-in", String(mw.config.get("wgUserName") !== null));
const r = mw.config.get("wgUserGroups"), i = r.includes("community-mod") || r.includes("moderator") || r.includes("sysop");
t.setAttribute("event-is-maintainer", String(i)), t.src = "https://plausible.io/js/script.pageview-props.outbound-links.js", document.head.appendChild(t);

Latest revision as of 04:35, 18 May 2026

/** @license
* This file is auto-generated. Do not edit directly.
* @see https://github.com/vrchat-community/wiki-scripts/blob/main/src/index.ts
*/
(() => {
	var e = Object.defineProperty;
	var __esmMin = (e, t) => () => (e && (t = e(e = 0)), t);
	var __export = (t, n) => {
		let r = {};
		for (var i in t) e(r, i, {
			get: t[i],
			enumerable: !0
		});
		n && e(r, Symbol.toStringTag, { value: "Module" });
		return r;
	};
	function isPage(e) {
		let [t, n] = mw.config.get("wgPageName").split("/");
		if (!t || !e.includes(t)) return !1;
		if (n && mw.config.get("wgPageContentLanguage") !== n) return !1;
		return !0;
	}
	document.querySelectorAll(".spoiler").forEach((e) => {
		let t = e.querySelector(".spoiler-overlay");
		t == null || t.addEventListener("click", () => {
			e.dataset.open = "";
		});
	});
	let __vitePreload = function(e, t, n) {
		let r = Promise.resolve();
		function handlePreloadError(e) {
			let t = new Event("vite:preloadError", { cancelable: !0 });
			t.payload = e;
			window.dispatchEvent(t);
			if (!t.defaultPrevented) throw e;
		}
		return r.then((t) => {
			for (let e of t || []) {
				if (e.status !== "rejected") continue;
				handlePreloadError(e.reason);
			}
			return e().catch(handlePreloadError);
		});
	};
	function getArticleFromElement(e) {
		let { articleId: t, articleTitle: n, articleContent: r } = e.dataset;
		if (!t || !n || !r) return null;
		return {
			id: t,
			title: n,
			content: atob(r)
		};
	}
	var ArticleDialog;
	var t = __esmMin((() => {
		ArticleDialog = class extends OO.ui.ProcessDialog {
			constructor(e) {
				super({
					size: "large",
					data: { title: e.title }
				});
				this.article = e;
			}
			initialize() {
				super.initialize();
				let e = new OO.ui.PanelLayout({
					expanded: !1,
					padded: !0,
					scrollable: !0
				});
				e.$element.append(this.article.content);
				this.$body.append(e.$element);
				return this;
			}
			getActionProcess(e) {
				switch (e) {
					case "close": return new OO.ui.Process(() => {
						this.close({ action: "close" });
					});
				}
				return super.getActionProcess(e);
			}
		};
		ArticleDialog.static.name = ArticleDialog.name;
		ArticleDialog.static.actions = [{
			action: "close",
			flags: "safe",
			icon: "close",
			label: "Close"
		}];
	}));
	var n = __esmMin((() => {}));
	function asyncGeneratorStep(e, t, n, r, i, a, o) {
		try {
			var s = e[a](o), c = s.value;
		} catch (e) {
			n(e);
			return;
		}
		s.done ? t(c) : Promise.resolve(c).then(r, i);
	}
	function _asyncToGenerator(e) {
		return function() {
			var t = this, n = arguments;
			return new Promise(function(r, i) {
				var a = e.apply(t, n);
				function _next(e) {
					asyncGeneratorStep(a, r, i, _next, _throw, "next", e);
				}
				function _throw(e) {
					asyncGeneratorStep(a, r, i, _next, _throw, "throw", e);
				}
				_next(void 0);
			});
		};
	}
	var r = __esmMin((() => {}));
	var i = /* @__PURE__ */ __export({}, 1);
	var a, o;
	var s = __esmMin((() => {
		t();
		n();
		r();
		a = document.querySelectorAll(".tpl-infopush");
		o = new OO.ui.WindowManager();
		$(document.body).append(o.$element);
		for (let e of a) {
			let t = e.querySelector(".tpl-infopush-content");
			let n = t.querySelectorAll(".tpl-infopush-item");
			let r = n.length;
			for (let e of n) {
				if (e.querySelector("a")) continue;
				let t = getArticleFromElement(e);
				if (!t) continue;
				e.style.cursor = "pointer";
				e.addEventListener("click", _asyncToGenerator(function* () {
					if (!(yield o.getWindow(t.id).then(() => !0).catch(() => !1))) {
						let e = new ArticleDialog(t);
						o.addWindows({ [t.id]: e });
					}
					yield o.openWindow(t.id).opening;
				}));
			}
			let i = e.querySelector(".tpl-infopush-navigation");
			let a = 0;
			function showSlide(e) {
				a = (e + r) % r;
				t.style.transform = `translateX(-${a * 100}%)`;
			}
			let s;
			function resetAutoAdvance() {
				s && clearInterval(s);
				s = setInterval(() => {
					showSlide(a + 1);
				}, 5e3);
			}
			i.querySelector(".tpl-infopush-navigation-previous").addEventListener("click", () => {
				showSlide(a - 1);
				resetAutoAdvance();
			});
			i.querySelector(".tpl-infopush-navigation-next").addEventListener("click", () => {
				showSlide(a + 1);
				resetAutoAdvance();
			});
			resetAutoAdvance();
			showSlide(0);
		}
	}));
	isPage(["Template:MainPageInfopush", "Main_Page"]) && mw.loader.using(["oojs-ui-core", "oojs-ui-windows"]).then(() => __vitePreload(() => Promise.resolve().then(() => (s(), i)), void 0, {}.url));
	var c = document.createElement("script");
	c.setAttribute("defer", "defer");
	c.setAttribute("data-domain", "wiki.vrchat.com");
	c.setAttribute("event-page-name", mw.config.get("wgTitle"));
	c.setAttribute("event-page-language", mw.config.get("wgPageContentLanguage"));
	var l = mw.config.get("wgFormattedNamespaces");
	c.setAttribute("event-page-namespace", l[mw.config.get("wgNamespaceNumber")]);
	c.setAttribute("event-theme", mw.config.get("skin"));
	c.setAttribute("event-action", mw.config.get("wgAction"));
	c.setAttribute("event-is-logged-in", String(mw.config.get("wgUserName") !== null));
	var u = mw.config.get("wgUserGroups");
	var d = u.includes("community-mod") || u.includes("moderator") || u.includes("sysop");
	c.setAttribute("event-is-maintainer", String(d));
	c.src = "https://plausible.io/js/script.pageview-props.outbound-links.js";
	document.head.appendChild(c);
	var f = "p-userpagetools";
	function lowercaseFirst(e) {
		return e.charAt(0).toLowerCase() + e.slice(1);
	}
	if (mw.util.isPortletVisible(f)) {
		let e = lowercaseFirst(mw.config.get("wgPageName").split(":")[1]);
		mw.util.addPortletLink(f, `https://vrchat.com/home/user/${e}`, "VRChat profile");
	}
	console.log("Wiki scripts loaded.");
})();