Bilibili Auto Theme

Sync Bilibili theme_style cookie with system dark/light mode

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         Bilibili Auto Theme
// @namespace    https://bilibili.com/
// @version      1.0.1
// @description  Sync Bilibili theme_style cookie with system dark/light mode
// @match        *://*.bilibili.com/*
// @run-at       document-start
// @grant        none
// @license      MIT
// ==/UserScript==

(function () {
  const COOKIE_KEY = "theme_style";
  const DARK_QUERY = "(prefers-color-scheme: dark)";

  const getCookie = (key) =>
    document.cookie.match(new RegExp(`(?:^|; )${key}=([^;]*)`))?.[1];

  const setThemeCookie = (theme) => {
    document.cookie = `${COOKIE_KEY}=${theme}; domain=.bilibili.com; path=/; max-age=31536000; secure`;
    console.log("[Theme Sync] Cookie updated:", theme);
  };

  const updateTheme = () => {
    const isDark = window.matchMedia(DARK_QUERY).matches;
    const systemTheme = isDark ? "dark" : "light";
    const currentTheme = getCookie(COOKIE_KEY);

    if (currentTheme !== systemTheme) {
      setThemeCookie(systemTheme);
      // recommended small delay to ensure cookie applied before reload
      setTimeout(() => window.location.reload(), 100);
    }
  };

  // Initial sync
  updateTheme();

  // Watch for system theme changes
  window.matchMedia(DARK_QUERY).addEventListener("change", updateTheme);
})();