2023-08-11 11:48:33 +00:00
|
|
|
// mobx
|
|
|
|
import { observable, action, computed, makeObservable, runInAction } from "mobx";
|
|
|
|
// types
|
2023-08-31 19:04:57 +00:00
|
|
|
import { IThemeStore } from "types/theme";
|
2023-08-11 11:48:33 +00:00
|
|
|
|
|
|
|
class ThemeStore implements IThemeStore {
|
|
|
|
theme: "light" | "dark" = "light";
|
|
|
|
// root store
|
|
|
|
rootStore;
|
|
|
|
|
|
|
|
constructor(_rootStore: any | null = null) {
|
|
|
|
makeObservable(this, {
|
|
|
|
// observable
|
|
|
|
theme: observable,
|
|
|
|
// action
|
|
|
|
setTheme: action,
|
|
|
|
// computed
|
|
|
|
});
|
|
|
|
|
|
|
|
this.rootStore = _rootStore;
|
|
|
|
}
|
|
|
|
|
|
|
|
setTheme = async (_theme: "light" | "dark" | string) => {
|
|
|
|
try {
|
|
|
|
localStorage.setItem("app_theme", _theme);
|
|
|
|
this.theme = _theme === "light" ? "light" : "dark";
|
|
|
|
} catch (error) {
|
|
|
|
console.error("setting user theme error", error);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ThemeStore;
|