GitLab Dark Theme

Forces GitLab to use it's dark mode when not logged in.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name        GitLab Dark Theme
// @namespace   https://greasyfork.org/users/581142
// @include     /^https?:\/{2}(?:git(?:\.(?:linux-kernel\.at|coop|fosscommunity\.in|jami\.net|oeru\.org|pleroma\.social)|lab\.(?:com|(?:gnome|haskell|trisquel|torproject|isc)\.org|e\.foundation|freedesktop\.org)|gud\.io)|(?:code\.(?:briarproject|videolan)|0xacab|salsa\.debian|framagit|dev\.gajim)\.org||lab\.libreho\.st)\//
// @grant       none
// @version     1.0.6
// @author      brian6932
// @run-at      document-start
// @license		MPL-2.0
// @description Forces GitLab to use it's dark mode when not logged in.
// ==/UserScript==
// jshint esversion: 11

// I can't do anything about the initial screen flash.
const
	dark = () => {
		if (!globalThis.document.cookie.includes('gitlab_user=true')) {
			const oldGon = globalThis.gon
			globalThis.Object.defineProperties(
				globalThis.Object.defineProperty(globalThis, 'gon', {
					__proto__: null,
					value: { __proto__: null },
					enumerable: true,
					configurable: true
				}).gon,
				{
					__proto__: null,
					user_color_scheme: {
						__proto__: null,
						value: 'dark',
						enumerable: true
					},
					user_color_mode: {
						__proto__: null,
						value: 'gl-system',
						enumerable: true
					}
				}
			)

			if (oldGon)
				for (const prop in oldGon)
					if (!(prop in globalThis.gon))
						globalThis.gon[prop] = oldGon[prop]

			globalThis.document.documentElement.classList.add('gl-dark')
		}
	},
	eventType = 'beforescriptexecute'

// Chromium and WebKit don't support this for some reason, and I cba to use a polyfill here.
if (GM_info.platform.browserName === 'Firefox' || globalThis.geteventTypeListeners?.(globalThis).hasOwnProperty(eventType))
	globalThis.addEventListener(eventType, dark)
else
	dark()