Merge pull request #110 from JsSucks/sass

Sass
This commit is contained in:
Alexei Stukov 2018-02-11 21:20:08 +02:00 committed by GitHub
commit 702b770058
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 44 additions and 13 deletions

View File

@ -11,11 +11,12 @@
import { DOM, BdUI } from 'ui'; import { DOM, BdUI } from 'ui';
import BdCss from './styles/index.scss'; import BdCss from './styles/index.scss';
import { Events, CssEditor, Globals, PluginManager, ThemeManager, ModuleManager, WebpackModules } from 'modules'; import { Events, CssEditor, Globals, PluginManager, ThemeManager, ModuleManager, WebpackModules } from 'modules';
import { ClientLogger as Logger } from 'common'; import { ClientLogger as Logger, ClientIPC } from 'common';
class BetterDiscord { class BetterDiscord {
constructor() { constructor() {
window.ClientIPC = ClientIPC;
window.css = CssEditor; window.css = CssEditor;
window.pm = PluginManager; window.pm = PluginManager;
window.events = Events; window.events = Events;

View File

@ -10,7 +10,7 @@
import ContentManager from './contentmanager'; import ContentManager from './contentmanager';
import { DOM } from 'ui'; import { DOM } from 'ui';
import { FileUtils } from 'common'; import { FileUtils, ClientIPC } from 'common';
class Theme { class Theme {
@ -94,7 +94,12 @@ export default class extends ContentManager {
static get loadContent() { return this.loadTheme } static get loadContent() { return this.loadTheme }
static async loadTheme(paths, configs, info, main) { static async loadTheme(paths, configs, info, main) {
try { try {
const css = await FileUtils.readFile(paths.mainPath); let css = '';
if (info.type === 'sass') {
css = await ClientIPC.send('bd-compileSass', { path: paths.mainPath });
} else {
css = await FileUtils.readFile(paths.mainPath);
}
const instance = new Theme({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName }, css }); const instance = new Theme({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName }, css });
if (instance.enabled) instance.enable(); if (instance.enabled) instance.enable();
return instance; return instance;

View File

@ -20,7 +20,12 @@ export class ClientIPC {
const __eid = Date.now().toString(); const __eid = Date.now().toString();
ipcRenderer.send(channel, Object.assign(message ? message : {}, { __eid })); ipcRenderer.send(channel, Object.assign(message ? message : {}, { __eid }));
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
ipcRenderer.once(__eid, (event, arg) => resolve(arg)); ipcRenderer.once(__eid, (event, arg) => {
if (arg.err) {
return reject(arg.err);
}
resolve(arg);
});
}); });
} }
} }

View File

@ -9,6 +9,7 @@
*/ */
const path = require('path'); const path = require('path');
const sass = require('node-sass');
/** /**
* DEVELOPMENT VARIABLES * DEVELOPMENT VARIABLES
@ -62,6 +63,20 @@ class Comms {
o.reply(filenames); o.reply(filenames);
}); });
}); });
BDIpc.on('bd-compileSass', o => {
const { scss, path } = o.args;
if (!scss && !path) return;
const data = scss ? `${scss} @import '${path}';` : `@import '${path}';`;
sass.render({ data }, (err, result) => {
if (err) {
o.reply({ err });
return;
}
o.reply(result.css.toString());
});
});
} }
async readFile(o, json) { async readFile(o, json) {

View File

@ -4,9 +4,10 @@
"authors": [ "Jiiks" ], "authors": [ "Jiiks" ],
"version": 1.0, "version": 1.0,
"description": "Example Theme 1 Description", "description": "Example Theme 1 Description",
"icon": "" "icon": "",
"type": "sass"
}, },
"main": "index.css", "main": "index.scss",
"defaultConfig": [ "defaultConfig": [
{ {
"category": "default", "category": "default",

View File

@ -1,7 +0,0 @@
div {
background: red;
}
span {
border: 1px solid brown;
}

View File

@ -0,0 +1,9 @@
@import 'vars.scss';
div {
background: $divBg;
}
span {
border: 1px solid rgba(20, 20, 20, $spanOpacity);
}

View File

@ -0,0 +1,2 @@
$divBg: green !default;
$spanOpacity: 0.5 !default;