Theme manager base

This commit is contained in:
Jiiks 2018-02-05 16:19:24 +02:00
parent 83783a9ece
commit 2472743660
2 changed files with 50 additions and 2 deletions

View File

@ -9,6 +9,43 @@
*/
import ContentManager from './contentmanager';
import { DOM } from 'ui';
import { FileUtils } from 'common';
class Theme {
constructor(themeInternals) {
this.__themeInternals = themeInternals;
this.enable = this.enable.bind(this);
this.disable = this.disable.bind(this);
}
get configs() { return this.__themeInternals.configs }
get info() { return this.__themeInternals.info }
get icon() { return this.info.icon }
get paths() { return this.__themeInternals.paths }
get main() { return this.__themeInternals.main }
get defaultConfig() { return this.configs.defaultConfig }
get userConfig() { return this.configs.userConfig }
get name() { return this.info.name }
get authors() { return this.info.authors }
get version() { return this.info.version }
get themePath() { return this.paths.contentPath }
get dirName() { return this.paths.dirName }
get enabled() { return this.userConfig.enabled }
get themeConfig() { return this.userConfig.config }
get css() { return this.__themeInternals.css }
get id() { return this.name.toLowerCase().replace(/\s+/g, '-') }
enable() {
DOM.injectTheme(this.css, this.id);
}
disable() {
DOM.deleteTheme(this.id);
}
}
export default class extends ContentManager {
@ -24,4 +61,15 @@ export default class extends ContentManager {
return this.loadAllContent;
}
static get loadContent() { return this.loadTheme }
static async loadTheme(paths, configs, info, main) {
try {
const css = await FileUtils.readFile(paths.mainPath);
const instance = new Theme({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName }, css });
return instance;
} catch (err) {
throw err;
}
}
}

View File

@ -1,9 +1,9 @@
{
"info": {
"name": "Example Theme",
"name": "Example Theme 1",
"authors": [ "Jiiks" ],
"version": 1.0,
"description": "Example Theme Description",
"description": "Example Theme 1 Description",
"icon": ""
},
"main": "index.css"