From ef7009f5a139aa2d3ef8dcdce5710e491f5ae290 Mon Sep 17 00:00:00 2001 From: Jiiks Date: Wed, 17 Jan 2018 13:28:52 +0200 Subject: [PATCH] Base for CSS Editor --- client/src/index.js | 3 +- client/src/modules/csseditor.js | 29 +++ client/src/modules/index.js | 3 +- core/src/main.js | 6 +- core/src/modules/csseditor.js | 52 ++++ core/src/modules/index.js | 3 +- tests/csseditor/index.html | 108 ++++++++ tests/csseditor/main.css | 448 ++++++++++++++++++++++++++++++++ 8 files changed, 648 insertions(+), 4 deletions(-) create mode 100644 client/src/modules/csseditor.js create mode 100644 core/src/modules/csseditor.js create mode 100644 tests/csseditor/index.html create mode 100644 tests/csseditor/main.css diff --git a/client/src/index.js b/client/src/index.js index be4117c9..d10044ed 100644 --- a/client/src/index.js +++ b/client/src/index.js @@ -10,13 +10,14 @@ 'use strict'; -const { Global, Logger, Utils, PluginManager, BDIpc, WebpackModules, SocketProxy } = require('./modules'); +const { Global, Logger, Utils, PluginManager, BDIpc, WebpackModules, SocketProxy, CssEditor } = require('./modules'); class BetterDiscord { constructor() { window.bdUtils = Utils; window.wpm = WebpackModules; + window.cssEditor = CssEditor; } } diff --git a/client/src/modules/csseditor.js b/client/src/modules/csseditor.js new file mode 100644 index 00000000..72ffcd41 --- /dev/null +++ b/client/src/modules/csseditor.js @@ -0,0 +1,29 @@ +/** + * BetterDiscord CSS Editor + * Copyright (c) 2015-present JsSucks - https://github.com/JsSucks + * All rights reserved. + * https://github.com/JsSucks - https://betterdiscord.net + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. +*/ + +const { Module } = require('./modulebase'); +const { BDIpc } = require('./bdipc'); + +class CssEditor extends Module { + + setInitialState() { + this.state = { + css: '' + } + window.cssEditor = this; + } + + show() { + BDIpc.send('openCssEditor', {}); + } +} + +const _instance = new CssEditor(); +module.exports = { 'CssEditor': _instance } \ No newline at end of file diff --git a/client/src/modules/index.js b/client/src/modules/index.js index a409a8f6..f356537a 100644 --- a/client/src/modules/index.js +++ b/client/src/modules/index.js @@ -5,4 +5,5 @@ export { Pluging } from './plugin'; export { BDIpc } from './bdipc'; export { WebpackModules } from './webpackmodules'; export { Events } from './events'; -export { SocketProxy } from './discordsocket'; \ No newline at end of file +export { SocketProxy } from './discordsocket'; +export { CssEditor } from './csseditor'; \ No newline at end of file diff --git a/core/src/main.js b/core/src/main.js index b3a4f528..d0f28d8a 100644 --- a/core/src/main.js +++ b/core/src/main.js @@ -23,7 +23,7 @@ const __DEV = { const __pluginPath = path.resolve(__dirname, '..', '..', 'tests', 'plugins'); const __themePath = path.resolve(__dirname, '..', '..', 'tests', 'themes'); -const { Utils, FileUtils, BDIpc, Config, WindowUtils } = require('./modules'); +const { Utils, FileUtils, BDIpc, Config, WindowUtils, CSSEditor } = require('./modules'); const { BrowserWindow } = require('electron'); const Common = {}; @@ -51,6 +51,10 @@ class Comms { o.reply(Common.Config.config); }); + BDIpc.on('bd-openCssEditor', o => { + o.reply(CSSEditor.openEditor()); + }); + BDIpc.on('bd-readFile', this.readFile); BDIpc.on('bd-readJson', o => this.readFile(o, true)); } diff --git a/core/src/modules/csseditor.js b/core/src/modules/csseditor.js new file mode 100644 index 00000000..db5e98ec --- /dev/null +++ b/core/src/modules/csseditor.js @@ -0,0 +1,52 @@ +/** + * BetterDiscord CSSEditor Module + * Copyright (c) 2015-present JsSucks - https://github.com/JsSucks + * All rights reserved. + * https://github.com/JsSucks - https://betterdiscord.net + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. +*/ + +const path = require('path'); +const { BrowserWindow } = require('electron'); + +const { Module } = require('./modulebase'); + +class CSSEditor extends Module { + + openEditor() { + if (this.editor && this.editor.open) { + this.editor.focus(); + this.editor.flashFrame(true); + return true; + } + + this.editor = new BrowserWindow(this.options); + this.editor.loadURL(`file://${this.editorPath}/index.html`); + this.editor.open = true; + + this.editor.webContents.on('close', () => { + this.editor.open = false; + }); + + return true; + } + + //TODO user options from config + get options() { + return { + width: 800, + height: 600, + frame: false + }; + } + + //TODO Currently uses a development path + get editorPath() { + return path.resolve(__dirname, '..', '..', '..', 'tests', 'csseditor'); + } + +} + +module.exports = { 'CSSEditor': new CSSEditor() }; \ No newline at end of file diff --git a/core/src/modules/index.js b/core/src/modules/index.js index 983b5553..8a2670f0 100644 --- a/core/src/modules/index.js +++ b/core/src/modules/index.js @@ -1,3 +1,4 @@ export { BDIpc } from './bdipc'; export { Utils, FileUtils, WindowUtils } from './utils'; -export { Config } from './config'; \ No newline at end of file +export { Config } from './config'; +export { CSSEditor } from './csseditor'; \ No newline at end of file diff --git a/tests/csseditor/index.html b/tests/csseditor/index.html new file mode 100644 index 00000000..78c2dd86 --- /dev/null +++ b/tests/csseditor/index.html @@ -0,0 +1,108 @@ + + + CSS Editor + + + + + + + + +
+ + +
+
+ + CSS Editor +
+
Your external editor is proxied to this window
+
+
+ Saved! +
+
+
Loading Please Wait
+
+
+

Keybinds

+ + + + + + + + + + + + + +
Exit:ESC
Save:Ctrl/Cmd + S
Update:Ctrl/Cmd + H
+
+
+

CM Keybinds

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Search:Ctrl/Cmd + F
Find Next:Ctrl/Cmd + G
Find PreviousCtrl-Shift/Cmd-Option + G
ReplaceCtrl-Shift/Cmd-Option + F
Replace AllCtrl-Shift/Cmd-Option-Shift + R
Persistent Search:Alt + F
Jump To Line:Alt + G
+
+
+ + +
+
+ Live Update +
+
+
+ Auto Save +
+
+
+ Use External Editor +
+
+
+ + + + + + + + + + + + + + \ No newline at end of file diff --git a/tests/csseditor/main.css b/tests/csseditor/main.css new file mode 100644 index 00000000..753690c4 --- /dev/null +++ b/tests/csseditor/main.css @@ -0,0 +1,448 @@ +html, body { + margin: 0; + padding: 0; + max-height: 100%; + background: #2c383e; + min-width: 700px; + min-height: 400px; +} + +.titlebg { + z-index: 0; + position: absolute; + left: 0; + right: 0; + top: 0; + height: 40px; + /*background: #2c383e;*/ + background: #292b2f; + /*border-bottom: 1px solid #303e46;*/ + border-bottom: 1px solid hsla(218,5%,47%,.3); +} + +.titlebar { + z-index: 1; + display: flex; + height: 23px; + /*background: #2c383e;*/ + background: #292b2f; + -webkit-app-region: drag; + /*border-bottom: 1px solid #303e46;*/ + border-bottom: 1px solid hsla(218,5%,47%,.3); + padding: 10px; + margin-right: 70px; + max-height: 20px; + min-height: 20px; +} + + .titlebar .title { + color: #bac9d2; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + line-height: 18px; + display: inline-block; + margin-left: 10px; + margin-top: 2px; + } + + .titlebar .icon { + width: 16px; + height: 16px; + background-size: 100% 100%; + display: block; + margin-top: 2px; + background-image: url(""); + } + +button.close, +button.aot { + position: absolute; + border-radius: 3px; + width: 25px; + font-size: 12px; + font-weight: 600; + /*background: #263238;*/ + background: #36393f; + color: #bac9d2; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + transition: background-color .2s ease; + cursor: pointer; + border: 0; + height: 25px; + z-index: 900062; + padding: 0; + margin: 0; +} + + button.close:hover, + button.aot:hover { + /* background: #303f46;*/ + background: #44474e; + color: #FFF; + } + +button.close { + right: 8px; + top: 8px; +} + +button.aot { + right: 38px; + top: 8px; +} + + button.aot.enabled { + /*background: #376982;*/ + background: #3a71c1; + } + +.spacer { + flex-grow: 1; +} + +.container { + display: flex; + flex-direction: column; + max-height: 100%; +} + +#cm-container { + flex-grow: 1; + display: flex; + flex-direction: column; +} + +.CodeMirror { + height: 100%; +} + +.controls { + display: flex; + padding: 5px; + height: 40px; + min-height: 40px; + /*background: #2c383e;*/ + /*border-top: 1px solid #38444a;*/ + overflow: hidden; + background: #292b2f; + border-top: 1px solid hsla(218,5%,47%,.3); +} + + .controls button { + border-radius: 3px; + width: 100px; + padding: 10px 20px; + font-size: 16px; + font-weight: 600; + /* background: #263238;*/ + background: #36393f; + color: #bac9d2; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + transition: background-color .2s ease; + cursor: pointer; + border: 0; + margin-left: 5px; + } + + .controls button:hover { + /*background: #303f46;*/ + background: #44474e; + color: #FFF; + } + + .controls .checkbox-container { + display: flex; + cursor: pointer; + margin-left: 5px; + margin-top: 10px; + } + + .controls .checkbox-container:hover .checkbox + span { + color: #FFF; + } + + .controls .checkbox-container:hover .checkbox { + /*background: #303f46;*/ + background: #44474e; + border-color: #44474e; + /*border-color: #303f46;*/ + } + + .controls .checkbox-container .checkbox { + position: relative; + width: 15px; + height: 15px; + /*background: #263238;*/ + background: #36393f; + /*border: 3px solid #263238;*/ + border: 3px solid #36393f; + border-radius: 3px; + margin-right: 5px; + -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; + } + + .controls .checkbox-container.checked .checkbox { + /*background: #376982;*/ + /*border: 3px solid #376982;*/ + background: #3a71c1; + border: 3px solid #3a71c1; + } + + .controls .checkbox-container.checked .checkbox::after { + opacity: 1; + } + + .controls .checkbox-container .checkbox + span { + color: #bac9d2; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + line-height: 20px; + font-size: 16px; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + } + + .controls .checkbox-container .checkbox::after { + content: ""; + position: absolute; + top: -2px; + left: 3px; + width: 8px; + height: 13px; + border: 2px solid #bac9d2; + border-top-width: 0; + border-left-width: 0; + -webkit-transform: rotate(40deg); + transform: rotate(40deg); + opacity: 0; + */ -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; + } + +button:focus, button:active { + outline: none; +} + +.CodeMirror-overlayscroll .CodeMirror-scrollbar-filler { + background: #38444a; +} + +.CodeMirror-overlayscroll-horizontal div, +.CodeMirror-overlayscroll-vertical div { + background: rgb(56, 68, 74); +} + +.cm-s-material.CodeMirror { + background: #36393f; +} + +.cm-s-material .CodeMirror-gutters { + background: #292b2f; +} + +#hints { + position: fixed; + z-index: 90000; + bottom: 100px; + /*background: rgba(34, 44, 49, 0.4);*/ + background: #292b2f; + border-radius: 5px; + left: 10px; + padding: 10px; + color: #bac9d2; + -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; + opacity: 0; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + pointer-events: none; +} + + #hints.visible { + opacity: 1; + } + + #hints h3 { + margin: 0; + margin-bottom: 10px; + border-bottom: 1px solid hsla(218,5%,47%,.3); + /*border-bottom: 1px solid #38444a;*/ + } + + #hints table { + color: #bac9d2; + } + +#cmhints { + position: fixed; + z-index: 90000; + bottom: 100px; + /*background: rgba(34, 44, 49, 0.4);*/ + background: #292b2f; + border-radius: 5px; + right: 10px; + padding: 10px; + color: #bac9d2; + -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; + opacity: 0; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + pointer-events: none; +} + + #cmhints.visible { + opacity: 1; + } + + #cmhints h3 { + margin: 0; + margin-bottom: 10px; + border-bottom: 1px solid hsla(218,5%,47%,.3); + /*border-bottom: 1px solid #38444a;*/ + } + + #cmhints table { + color: #bac9d2; + } + +.CodeMirror-hints { + /*background: #1e262a;*/ + background: #292b2f; + box-shadow: 2px 3px 5px rgba(4, 4, 4, 0.22); + border: 1px solid #262f33; +} + + .CodeMirror-hints::-webkit-scrollbar { + background: transparent; + } + + .CodeMirror-hints::-webkit-scrollbar-thumb { + background-color: rgba(0,0,0,.4); + border-color: transparent; + } + + .CodeMirror-hints::-webkit-scrollbar-thumb, + .CodeMirror-hints::-webkit-scrollbar-track { + background-clip: padding-box; + border-width: 3px; + border-style: solid; + border-radius: 7px; + } + + .CodeMirror-hints::-webkit-scrollbar-track { + background-color: transparent; + border-color: transparent; + } + +.cm-s-material .CodeMirror-linenumber { + color: #f6f6f7; +} + +.CodeMirror-hint { + color: #bac9d2; +} + +li.CodeMirror-hint-active { + color: #bac9d2; + /*background: #3b4950;*/ + background: #36393f; +} + +#eehint { + position: absolute; + z-index: 9000; + top: 70px; + left: 0; + right: 0; + text-align: center; + color: #FFF; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; + opacity: 0; + pointer-events: none; +} + + #eehint span { + /* background: rgba(44, 56, 62, 0.51);*/ + background: #292b2f; + padding: 10px; + border-radius: 10px; + pointer-events: none; + -webkit-user-select: none; + user-select: none; + } + + #eehint.visible { + opacity: 1; + } + +.CodeMirror-dialog-top { + bottom: 0; + top: auto; + border: none; + background: #1e262a; +} + +#spinner { + background: rgba(51, 48, 48, 0.41); + position: absolute; + top: 41px; + left: 0; + right: 0; + bottom: 0; + z-index: 90000; +} + + #spinner.hidden { + display: none; + } + + #spinner .valign { + position: absolute; + left: 50%; + top: 50%; + transform: translate(-50%, -50%); + color: #bac9d2; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + font-weight: 600; + font-size: 2em; + } + +.checkbox-container.hidden, +button.hidden { + display: none; +} + +#alert { + position: absolute; + bottom: 55px; + z-index: 9; + left: 50px; + font-family: Whitney,Helvetica Neue,Helvetica,Arial,sans-serif; + color: #FFF; + padding: 2px 15px; + border-radius: 5px; + pointer-events: none; + opacity: 0; + -webkit-transition: 0.2s all ease; + -moz-transition: 0.2s all ease; + transition: 0.2s all ease; +} + + #alert.success { + background: rgba(77, 255, 77, 0.15); + } + + #alert.danger { + background: rgba(255, 77, 77, 0.15); + } + + #alert.visible { + opacity: 1; + }