2021-12-10 02:37:01 +00:00
|
|
|
/**
|
|
|
|
|
* @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
|
|
|
|
|
*/
|
|
|
|
|
|
2021-12-09 05:44:17 +00:00
|
|
|
import {Injectable, Renderer2, RendererFactory2} from '@angular/core';
|
|
|
|
|
import {ReplaySubject, Subject} from 'rxjs';
|
2020-06-02 16:09:38 +00:00
|
|
|
|
2021-12-09 05:44:17 +00:00
|
|
|
export type Theme = 'dark-theme'|'light-theme';
|
2020-06-03 19:19:38 +00:00
|
|
|
|
2020-06-02 16:09:38 +00:00
|
|
|
@Injectable({
|
|
|
|
|
providedIn: 'root',
|
|
|
|
|
})
|
|
|
|
|
export class ThemeService {
|
|
|
|
|
private renderer: Renderer2;
|
2020-08-08 20:43:42 +00:00
|
|
|
currentTheme: Subject<Theme> = new ReplaySubject();
|
2020-06-02 16:09:38 +00:00
|
|
|
|
|
|
|
|
constructor(private _rendererFactory: RendererFactory2) {
|
|
|
|
|
this.renderer = this._rendererFactory.createRenderer(null, null);
|
2020-07-13 14:56:08 +00:00
|
|
|
this.toggleDarkMode(this._prefersDarkMode);
|
2020-06-02 16:09:38 +00:00
|
|
|
}
|
|
|
|
|
|
2020-06-12 19:18:34 +00:00
|
|
|
toggleDarkMode(isDark: boolean): void {
|
2020-07-13 17:39:13 +00:00
|
|
|
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);
|
|
|
|
|
}
|
2020-07-13 14:56:08 +00:00
|
|
|
|
2021-02-25 10:34:39 +00:00
|
|
|
initializeThemeWatcher(): void {
|
2020-07-13 14:56:08 +00:00
|
|
|
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
|
|
|
}
|