MUI: Темный режим с использованием класса

#typescript #material-ui #next.js #darkmode

Вопрос:

Мы строим Next.js приложение. Мы находимся в процессе перехода от чистых эмоций к MUI.

В нашем приложении есть темный режим, который был переключен путем отсоединения и прикрепления класса к документу. Мы не можем использовать состояние реакции, потому что это вызовет вспышку с отображением кода на стороне сервера в Next.js.

Мы избежали этой вспышки с помощью следующего noflash.js сценария:

 (function () {
  // Change these if you use something different in your hook.
  var storageKey = 'darkMode';
  var classNameDark = 'dark-mode';
  var classNameLight = 'light-mode';

  function setClassOnDocumentBody(darkMode) {
    document.body.classList.add(darkMode ? classNameDark : classNameLight);
    document.body.classList.remove(darkMode ? classNameLight : classNameDark);
  }

  var preferDarkQuery = '(prefers-color-scheme: dark)';
  var mql = window.matchMedia(preferDarkQuery);
  var supportsColorSchemeQuery = mql.media === preferDarkQuery;
  // eslint-disable-next-line unicorn/no-null
  var localStorageTheme = null;
  try {
    localStorageTheme = localStorage.getItem(storageKey);
  } catch {
    // Do nothing
  }
  
  var localStorageExists = localStorageTheme !== null;
  if (localStorageExists) {
    localStorageTheme = JSON.parse(localStorageTheme);
  }

  // Determine the source of truth
  if (localStorageExists) {
    // source of truth from localStorage
    setClassOnDocumentBody(localStorageTheme);
  } else if (supportsColorSchemeQuery) {
    // source of truth from system
    setClassOnDocumentBody(mql.matches);
    localStorage.setItem(storageKey, mql.matches);
  } else {
    // source of truth from document.body
    var isDarkMode = document.body.classList.contains(classNameDark);
    localStorage.setItem(storageKey, JSON.stringify(isDarkMode));
  }
})();
 

В документах MUI описано только, как переключать темный режим через состояние реакции.

Есть ли способ установить значение для MUI с помощью класса? (Или переменная CSS, которая задается классом?)

Выглядит невозможным Редактировать: прямо сейчас.