Browse Source

Avoids unnecessary callback on first load

main
Eric Amodio 2 years ago
parent
commit
314662b29b
1 changed files with 7 additions and 6 deletions
  1. +7
    -6
      src/webviews/apps/shared/theme.ts

+ 7
- 6
src/webviews/apps/shared/theme.ts View File

@ -2,7 +2,7 @@
import { darken, lighten, opacity } from './colors'; import { darken, lighten, opacity } from './colors';
export function initializeAndWatchThemeColors(callback?: () => void) { export function initializeAndWatchThemeColors(callback?: () => void) {
const onColorThemeChanged = () => {
const onColorThemeChanged = (mutations?: MutationRecord[]) => {
const body = document.body; const body = document.body;
const computedStyle = window.getComputedStyle(body); const computedStyle = window.getComputedStyle(body);
@ -133,13 +133,14 @@ export function initializeAndWatchThemeColors(callback?: () => void) {
bodyStyle.setProperty('--color-alert-neutralBorder', 'var(--vscode-input-foreground)'); bodyStyle.setProperty('--color-alert-neutralBorder', 'var(--vscode-input-foreground)');
bodyStyle.setProperty('--color-alert-foreground', 'var(--vscode-input-foreground)'); bodyStyle.setProperty('--color-alert-foreground', 'var(--vscode-input-foreground)');
callback?.();
if (mutations != null) {
callback?.();
}
}; };
const observer = new MutationObserver(onColorThemeChanged);
observer.observe(document.body, { attributes: true, attributeFilter: ['class'] });
onColorThemeChanged(); onColorThemeChanged();
const observer = new MutationObserver(onColorThemeChanged);
observer.observe(document.body, { attributeFilter: ['class'] });
return observer; return observer;
} }

Loading…
Cancel
Save