angular/devtools/projects/ng-devtools/src/lib/theme-service.ts

44 lines
1.3 KiB
TypeScript
Raw Normal View History

/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import {Injectable, Renderer2, RendererFactory2} from '@angular/core';
import {ReplaySubject, Subject} from 'rxjs';
2020-06-02 16:09:38 +00:00
export type Theme = 'dark-theme'|'light-theme';
2020-06-02 16:09:38 +00:00
@Injectable({
providedIn: 'root',
})
export class ThemeService {
private renderer: Renderer2;
currentTheme: Subject<Theme> = new ReplaySubject();
2020-06-02 16:09:38 +00:00
constructor(private _rendererFactory: RendererFactory2) {
this.renderer = this._rendererFactory.createRenderer(null, null);
this.toggleDarkMode(this._prefersDarkMode);
2020-06-02 16:09:38 +00:00
}
toggleDarkMode(isDark: boolean): void {
const removeClass = isDark ? 'light-theme' : 'dark-theme';
const addClass = !isDark ? 'light-theme' : 'dark-theme';
2020-06-02 16:09:38 +00:00
this.renderer.removeClass(document.body, removeClass);
this.renderer.addClass(document.body, addClass);
this.currentTheme.next(addClass);
}
initializeThemeWatcher(): void {
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', (e) => {
this.toggleDarkMode(this._prefersDarkMode);
});
}
private get _prefersDarkMode(): boolean {
return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
}
2020-06-02 16:09:38 +00:00
}