125 lines
4 KiB
JavaScript
125 lines
4 KiB
JavaScript
import { Dom7 } from 'framework7'
|
|
import { LocalStorage } from "../../utils/LocalStorage.mjs";
|
|
|
|
class ThemesController {
|
|
constructor() {
|
|
this.themes_map = {
|
|
dark : {
|
|
id: 'theme-dark',
|
|
type:'dark'
|
|
},
|
|
light: {
|
|
id: 'theme-light',
|
|
type: 'light'
|
|
}};
|
|
|
|
this.name_colors = [
|
|
"canvas-background",
|
|
"canvas-content-background",
|
|
"canvas-page-border",
|
|
|
|
"canvas-ruler-background",
|
|
"canvas-ruler-border",
|
|
"canvas-ruler-margins-background",
|
|
"canvas-ruler-mark",
|
|
"canvas-ruler-handle-border",
|
|
"canvas-ruler-handle-border-disabled",
|
|
|
|
"canvas-high-contrast",
|
|
"canvas-high-contrast-disabled",
|
|
|
|
"canvas-cell-border",
|
|
"canvas-cell-title-border",
|
|
"canvas-cell-title-border-hover",
|
|
"canvas-cell-title-border-selected",
|
|
"canvas-cell-title-hover",
|
|
"canvas-cell-title-selected",
|
|
|
|
"canvas-dark-cell-title",
|
|
"canvas-dark-cell-title-hover",
|
|
"canvas-dark-cell-title-selected",
|
|
"canvas-dark-cell-title-border",
|
|
"canvas-dark-cell-title-border-hover",
|
|
"canvas-dark-cell-title-border-selected",
|
|
"canvas-dark-content-background",
|
|
"canvas-dark-page-border",
|
|
|
|
"canvas-scroll-thumb",
|
|
"canvas-scroll-thumb-hover",
|
|
"canvas-scroll-thumb-pressed",
|
|
"canvas-scroll-thumb-border",
|
|
"canvas-scroll-thumb-border-hover",
|
|
"canvas-scroll-thumb-border-pressed",
|
|
"canvas-scroll-arrow",
|
|
"canvas-scroll-arrow-hover",
|
|
"canvas-scroll-arrow-pressed",
|
|
"canvas-scroll-thumb-target",
|
|
"canvas-scroll-thumb-target-hover",
|
|
"canvas-scroll-thumb-target-pressed",
|
|
];
|
|
}
|
|
|
|
init() {
|
|
const obj = LocalStorage.getItem("ui-theme");
|
|
let theme = this.themes_map.light;
|
|
if ( !!obj )
|
|
theme = this.themes_map[JSON.parse(obj).type];
|
|
else
|
|
if ( window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches ) {
|
|
theme = this.themes_map['dark'];
|
|
LocalStorage.setItem("ui-theme", JSON.stringify(theme));
|
|
}
|
|
|
|
this.switchDarkTheme(theme, true);
|
|
|
|
$$(window).on('storage', e => {
|
|
if ( e.key == LocalStorage.prefix + 'ui-theme' ) {
|
|
if ( !!e.newValue ) {
|
|
this.switchDarkTheme(JSON.parse(e.newValue), true);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
get isCurrentDark() {
|
|
const obj = LocalStorage.getItem("ui-theme");
|
|
return !!obj ? JSON.parse(obj).type === 'dark' : false;
|
|
}
|
|
|
|
get_current_theme_colors(colors) {
|
|
let out_object = {};
|
|
const style = getComputedStyle(document.body);
|
|
colors.forEach((item, index) => {
|
|
out_object[item] = style.getPropertyValue('--' + item).trim()
|
|
})
|
|
|
|
return out_object;
|
|
}
|
|
|
|
switchDarkTheme(dark) {
|
|
const theme = typeof dark == 'object' ? dark : this.themes_map[dark ? 'dark' : 'light'];
|
|
const refresh_only = !!arguments[1];
|
|
|
|
if ( !refresh_only )
|
|
LocalStorage.setItem("ui-theme", JSON.stringify(theme));
|
|
|
|
const $body = $$('body');
|
|
$body.attr('class') && $body.attr('class', $body.attr('class').replace(/\s?theme-type-(?:dark|light)/, ''));
|
|
$body.addClass(`theme-type-${theme.type}`);
|
|
|
|
const on_engine_created = api => {
|
|
let obj = this.get_current_theme_colors(this.name_colors);
|
|
obj.type = theme.type;
|
|
obj.name = theme.id;
|
|
|
|
api.asc_setSkin(obj);
|
|
};
|
|
|
|
const api = Common.EditorApi ? Common.EditorApi.get() : undefined;
|
|
if(!api) Common.Notifications.on('engineCreated', on_engine_created);
|
|
else on_engine_created(api);
|
|
}
|
|
}
|
|
|
|
const themes = new ThemesController()
|
|
export {themes as Themes} |