🏠 Home 

Wikipedia skins

Restore the old Wikipedia look or choose between other available skins: Vector 2022, Vector legacy 2010, MinervaNeue, MonoBook, Timeless, Modern, Cologne Blue

// ==UserScript==
// @name           Wikipedia skins
// @name:pl        Wikipedia skins
// @description    Restore the old Wikipedia look or choose between other available skins: Vector 2022, Vector legacy 2010, MinervaNeue, MonoBook, Timeless, Modern, Cologne Blue
// @description:pl Przywróć stary wygląd Wikipedii lub wybierz spośród innych dostępnych skórek: Vector 2022, Vector legacy 2010, MinervaNeue, MonoBook, Timeless, Modern, Cologne Blue
// @version        1.3.1
// @author         Pabli
// @homepageURL    https://greasyfork.org/scripts/523252-wikipedia-skins
// @supportURL     https://greasyfork.org/scripts/523252-wikipedia-skins/feedback
// @namespace      https://github.com/pabli24
// @license        MIT
// @match          *://*.wikipedia.org/*
// @match          *://*.wiktionary.org/*
// @match          *://*.wikiquote.org/*
// @match          *://*.wikinews.org/*
// @match          *://*.wikidata.org/*
// @match          *://*.wikivoyage.org/*
// @match          *://*.wikiversity.org/*
// @match          *://*.wikifunctions.org/*
// @match          *://*.wikisource.org/*
// @match          *://*.wikibooks.org/*
// @match          *://*.wikimedia.org/*
// @match          *://*.mediawiki.org/*
// @match          *://www.google.com/search*
// @match          *://duckduckgo.com/*
// @run-at         document-start
// @icon           
// @grant          GM_info
// @grant          GM_setValue
// @grant          GM_getValue
// @grant          GM_registerMenuCommand
// ==/UserScript==
(async () => {
'use strict';
// https://en.wikipedia.org/wiki/Wikipedia:Skin
const skin = await GM_getValue('skin', 'vector');
if (window.location.hostname !== 'www.google.com' && window.location.hostname !== 'duckduckgo.com') {
const skins = {
'vector-2022': 'Vector 2022 (default on desktop from 2022)',
vector: 'Vector legacy 2010 (default on desktop from 2010 to 2021)',
minerva: 'MinervaNeue (mobile)',
monobook: 'MonoBook (default from 2004 to 2009)',
timeless: 'Timeless',
modern: 'Modern (created in 2008 and deprecated in 2021)',
cologneblue: 'Cologne Blue (created in 2002 and deprecated in 2019)'
};
const options = {
nostalgia: {
value: await GM_getValue('nostalgia', true),
label: 'Nostalgia on the nostalgia.wikipedia.org (original skin from 2001)',
},
cleanUrl: {
value: await GM_getValue('cleanUrl', true),
label: 'Clean URL (remove ?useskin=skinname from the URL)',
},
};
Object.entries(skins).forEach(([key, label]) => {
GM_registerMenuCommand(
`${skin === key ? '◉' : '○'} ${label}`,
async () => {
await GM_setValue('skin', key);
const url = new URL(window.location.href);
url.searchParams.append('useskin', key);
window.location.href = url;
}
);
});
Object.entries(options).forEach(([key, config]) => {
GM_registerMenuCommand(
`${config.value ? '☑' : '☐'} ${config.label}`,
async () => {
options[key].value = !options[key].value;
await GM_setValue(key, options[key].value);
deleteUseskinParam()
window.location.reload();
}
);
});
if (options.nostalgia.value && window.location.hostname === 'nostalgia.wikipedia.org') return;
function deleteUseskinParam() {
const url = new URL(window.location.href);
if (!url.searchParams.has('useskin')) return;
url.searchParams.delete('useskin');
window.history.replaceState({}, '', url);
}
const url = new URL(window.location.href);
if (!url.searchParams.has('useskin') && url.pathname !== '/') {
url.searchParams.append('useskin', skin);
window.location.href = url;
} else if (options.cleanUrl.value) {
deleteUseskinParam();
let lastUrl = window.location.href;
const interval = setInterval(() => {
if (window.location.href === lastUrl) return;
deleteUseskinParam();
lastUrl = window.location.href;
}, 200);
setTimeout(() => {
clearInterval(interval);
}, 3000);
}
}
const matches = GM_info.script.matches.slice(0, -2); // Remove google, ddg
const userMatches = GM_info.script?.options?.override?.use_matches || []; // Tampermonkey only
const allMatches = [...matches, ...userMatches];
const domains = allMatches.map(url => url.replace(/^.+\:\/\/\*?\.?([^\/]+)\/.*$/, '$1'));
function linkUseskin(e) {
let link = e.target.closest('a[href]:not([href^="#"])');
if (!link || link.dataset.useskin) return;
if (!link.getAttribute('href').startsWith('/') &&
!domains.some(domain => link.hostname.endsWith(`.${domain}`) || link.hostname === domain)) return;
const url = new URL(link.href);
if (url.searchParams.has('useskin')) {
url.searchParams.delete('useskin');
}
url.searchParams.append('useskin', skin);
link.href = url.toString();
link.dataset.useskin = true;
}
document.addEventListener('mouseover', linkUseskin);
document.addEventListener('focusin', linkUseskin);
})();