From 01b7e81f443d9857e4e9efb54525bbefa866ead2 Mon Sep 17 00:00:00 2001 From: Jiiks Date: Mon, 19 Mar 2018 13:45:20 -0300 Subject: [PATCH 1/2] add global getters --- client/src/modules/contentmanager.js | 2 +- client/src/modules/globals.js | 12 ++++++++++++ client/src/modules/settings.js | 2 +- client/src/modules/updater.js | 4 ++-- 4 files changed, 16 insertions(+), 4 deletions(-) diff --git a/client/src/modules/contentmanager.js b/client/src/modules/contentmanager.js index cf2f81657..2826120cc 100644 --- a/client/src/modules/contentmanager.js +++ b/client/src/modules/contentmanager.js @@ -44,7 +44,7 @@ export default class { * returns {String} */ static get contentPath() { - return this._contentPath ? this._contentPath : (this._contentPath = Globals.getObject('paths').find(path => path.id === this.pathId).path); + return Globals.getPath(this.pathId); } /** diff --git a/client/src/modules/globals.js b/client/src/modules/globals.js index f355f0519..50b3dbb83 100644 --- a/client/src/modules/globals.js +++ b/client/src/modules/globals.js @@ -63,4 +63,16 @@ export default new class extends Module { return this.state[name]; } + getPath(id) { + return this.state.paths.find(path => path.id === id).path; + } + + static get paths() { + return this.state.paths; + } + + static get version() { + return this.state.version; + } + } diff --git a/client/src/modules/settings.js b/client/src/modules/settings.js index f03117bdc..de4f4a0b8 100644 --- a/client/src/modules/settings.js +++ b/client/src/modules/settings.js @@ -133,6 +133,6 @@ export default new class Settings { } get dataPath() { - return this._dataPath ? this._dataPath : (this._dataPath = Globals.getObject('paths').find(p => p.id === 'data').path); + return Globals.getPath('data'); } } diff --git a/client/src/modules/updater.js b/client/src/modules/updater.js index a03f9b7db..08efbc8cb 100644 --- a/client/src/modules/updater.js +++ b/client/src/modules/updater.js @@ -48,8 +48,8 @@ export default class { try { Events.emit('update-check-end'); Logger.info('Updater', - `Latest Version: ${e.version} - Current Version: ${Globals.getObject('version')}`); - if (e.version !== Globals.getObject('version')) { + `Latest Version: ${e.version} - Current Version: ${Globals.version}`); + if (e.version !== Globals.version) { this.updatesAvailable = true; Events.emit('updates-available'); } From a150c3cd4a60a18216f34ecb241f190cfc4d1000 Mon Sep 17 00:00:00 2001 From: Jiiks Date: Mon, 19 Mar 2018 14:15:31 -0300 Subject: [PATCH 2/2] Move stuff to their locations. Use tests as the proxy install dir when testing --- core/src/main.js | 92 ++-- .../modules/Example Module/config.json | 0 .../{ => ext}/modules/Example Module/index.js | 0 .../plugins/Depend Error Test/config.json | 0 .../plugins/Depend Error Test/index.js | 0 tests/{ => ext}/plugins/Example 2/config.json | 0 tests/{ => ext}/plugins/Example 2/index.js | 0 tests/{ => ext}/plugins/Example 3/config.json | 0 tests/{ => ext}/plugins/Example 3/index.js | 0 tests/{ => ext}/plugins/Example 4/config.json | 0 tests/{ => ext}/plugins/Example 4/index.js | 0 tests/{ => ext}/plugins/Example/component.js | 0 tests/{ => ext}/plugins/Example/config.json | 0 tests/{ => ext}/plugins/Example/index.js | 0 .../plugins/Patcher Test/config.json | 0 tests/{ => ext}/plugins/Patcher Test/index.js | 0 .../plugins/Permission Test/config.json | 0 .../plugins/Permission Test/index.js | 0 tests/{ => ext}/themes/Example/background.jpg | Bin tests/{ => ext}/themes/Example/config.json | 0 tests/{ => ext}/themes/Example/index.scss | 0 tests/{ => ext}/themes/Example/vars.scss | 0 tests/ext/themes/SimplerFlat/.DS_Store | Bin 0 -> 6148 bytes tests/ext/themes/SimplerFlat/config.json | 198 ++++++++ tests/ext/themes/SimplerFlat/index.scss | 479 ++++++++++++++++++ tests/ext/themes/SimplerFlat/vars.scss | 40 ++ 26 files changed, 754 insertions(+), 55 deletions(-) rename tests/{ => ext}/modules/Example Module/config.json (100%) rename tests/{ => ext}/modules/Example Module/index.js (100%) rename tests/{ => ext}/plugins/Depend Error Test/config.json (100%) rename tests/{ => ext}/plugins/Depend Error Test/index.js (100%) rename tests/{ => ext}/plugins/Example 2/config.json (100%) rename tests/{ => ext}/plugins/Example 2/index.js (100%) rename tests/{ => ext}/plugins/Example 3/config.json (100%) rename tests/{ => ext}/plugins/Example 3/index.js (100%) rename tests/{ => ext}/plugins/Example 4/config.json (100%) rename tests/{ => ext}/plugins/Example 4/index.js (100%) rename tests/{ => ext}/plugins/Example/component.js (100%) rename tests/{ => ext}/plugins/Example/config.json (100%) rename tests/{ => ext}/plugins/Example/index.js (100%) rename tests/{ => ext}/plugins/Patcher Test/config.json (100%) rename tests/{ => ext}/plugins/Patcher Test/index.js (100%) rename tests/{ => ext}/plugins/Permission Test/config.json (100%) rename tests/{ => ext}/plugins/Permission Test/index.js (100%) rename tests/{ => ext}/themes/Example/background.jpg (100%) rename tests/{ => ext}/themes/Example/config.json (100%) rename tests/{ => ext}/themes/Example/index.scss (100%) rename tests/{ => ext}/themes/Example/vars.scss (100%) create mode 100644 tests/ext/themes/SimplerFlat/.DS_Store create mode 100644 tests/ext/themes/SimplerFlat/config.json create mode 100644 tests/ext/themes/SimplerFlat/index.scss create mode 100644 tests/ext/themes/SimplerFlat/vars.scss diff --git a/core/src/main.js b/core/src/main.js index ed7c39d57..2c2b16d2c 100644 --- a/core/src/main.js +++ b/core/src/main.js @@ -11,39 +11,41 @@ const path = require('path'); const sass = require('node-sass'); -/** - * DEVELOPMENT VARIABLES - */ -const clientScriptPath = path.resolve(__dirname, '..', '..', 'client', 'dist').replace(/\\/g, '/'); - -const __DEV = { - TESTING: false, - clientScriptPath: `${clientScriptPath}/betterdiscord.client.js` -} - -const __dataPath = path.resolve(__dirname, '..', '..', 'tests', 'data'); -const __pluginPath = path.resolve(__dirname, '..', '..', 'tests', 'plugins'); -const __themePath = path.resolve(__dirname, '..', '..', 'tests', 'themes'); -const __modulePath = path.resolve(__dirname, '..', '..', 'tests', 'modules'); - -const { Utils, FileUtils, BDIpc, Config, WindowUtils, CSSEditor, Database } = require('./modules'); +const { FileUtils, BDIpc, Config, WindowUtils, CSSEditor, Database } = require('./modules'); const { BrowserWindow, dialog } = require('electron'); -const Common = {}; +const tests = true; +const _clientScript = tests + ? path.resolve(__dirname, '..', '..', 'client', 'dist', 'betterdiscord.client.js') + : path.resolve(__dirname, 'betterdiscord.client.js'); +const _dataPath = tests + ? path.resolve(__dirname, '..', '..', 'tests', 'data') + : path.resolve(__dirname, 'data'); +const _extPath = tests + ? path.resolve(__dirname, '..', '..', 'tests', 'ext') + : path.resolve(__dirname, 'ext'); +const _pluginPath = path.resolve(_extPath, 'plugins'); +const _themePath = path.resolve(_extPath, 'themes'); +const _modulePath = path.resolve(_extPath, 'modules'); + +const paths = [ + { id: 'cs', path: _clientScript.replace(/\\/g, '/') }, + { id: 'data', path: _dataPath.replace(/\\/g, '/') }, + { id: 'ext', path: _extPath.replace(/\\/g, '/') }, + { id: 'plugins', path: _pluginPath.replace(/\\/g, '/') }, + { id: 'themes', path: _themePath.replace(/\\/g, '/') }, + { id: 'modules', path: _modulePath.replace(/\\/g, '/') } +]; + +const sparkplug = path.resolve(__dirname, 'sparkplug.js').replace(/\\/g, '/'); -const dummyArgs = { - 'version': '2.0.0a', - 'paths': [ - { 'id': 'base', 'path': 'basePath' }, - { 'id': 'data', 'path': __dataPath }, - { 'id': 'plugins', 'path': __pluginPath }, - { 'id': 'themes', 'path': __themePath }, - { 'id': 'modules', 'path': __modulePath } - ] -}; -const dbInstance = new Database(dummyArgs.paths.find(path => path.id === 'data').path); -console.log(dummyArgs); +const Common = {}; +const globals = { + version: '2.0.0a', + paths +} +const dbInstance = new Database(paths.find(path => path.id === 'data').path); class Comms { @@ -120,7 +122,6 @@ class BetterDiscord { constructor(args) { if (BetterDiscord.loaded) { - // Creating two BetterDiscord objects??? console.log('Creating two BetterDiscord objects???'); return null; } @@ -128,7 +129,7 @@ class BetterDiscord { this.injectScripts = this.injectScripts.bind(this); this.ignite = this.ignite.bind(this); - Common.Config = new Config(args || dummyArgs); + Common.Config = new Config(globals); this.comms = new Comms(this); this.init(); } @@ -139,16 +140,6 @@ class BetterDiscord { this.csseditor = new CSSEditor(this); - //Log some events for now - //this.windowUtils.webContents.on('did-start-loading', e => this.windowUtils.executeJavascript(`console.info('did-start-loading');`)); - //this.windowUtils.webContents.on('did-stop-loading', e => this.windowUtils.executeJavascript(`console.info('did-stop-loading');`)); - //this.windowUtils.webContents.on('did-get-response-details', e => this.ignite(this.windowUtils.window)); - //this.windowUtils.webContents.on('page-favicon-updated', e => this.windowUtils.executeJavascript(`console.info('page-favicon-updated');`)); - //this.windowUtils.webContents.on('will-navigate', e => this.windowUtils.executeJavascript(`console.info('will-navigate');`)); - //this.windowUtils.webContents.on('did-navigate', e => this.windowUtils.executeJavascript(`console.info('did-navigate');`)); - //this.windowUtils.webContents.on('did-navigate-in-page', e => this.windowUtils.executeJavascript(`console.info('did-navigate-in-page');`)); - //this.windowUtils.webContents.on('did-finish-load', e => this.injectScripts(true)); - this.windowUtils.events('did-get-response-details', () => this.ignite(this.windowUtils.window)); this.windowUtils.events('did-finish-load', e => this.injectScripts(true)); @@ -157,13 +148,13 @@ class BetterDiscord { }); setTimeout(() => { - if (__DEV) { this.injectScripts(); } + this.injectScripts(); }, 500); } async waitForWindow() { const self = this; - return new Promise((resolve, reject) => { + return new Promise(resolve => { const defer = setInterval(() => { const windows = BrowserWindow.getAllWindows(); @@ -173,13 +164,7 @@ class BetterDiscord { }); } - if (__DEV && __DEV.TESTING && windows.length > 0) { - resolve(windows[0]); - clearInterval(defer); - return; - } - - if (windows.length === 1 && windows[0].webContents.getURL().includes("discordapp.com")) { + if (windows.length === 1 && windows[0].webContents.getURL().includes('discordapp.com')) { resolve(windows[0]); clearInterval(defer); } @@ -189,15 +174,12 @@ class BetterDiscord { ignite(window) { //Hook things that Discord removes from global. These will be removed again in the client script - const sp = path.resolve(__dirname, 'sparkplug.js').replace(/\\/g, '/'); - window.webContents.executeJavaScript(`require("${sp}");`); + window.webContents.executeJavaScript(`require("${sparkplug}");`); } injectScripts(reload = false) { console.log(`RELOAD? ${reload}`); - if (__DEV) { - this.windowUtils.injectScript(__DEV.clientScriptPath); - } + this.windowUtils.injectScript(paths.find(path => path.id === 'cs').path); } get fileUtils() { return FileUtils; } diff --git a/tests/modules/Example Module/config.json b/tests/ext/modules/Example Module/config.json similarity index 100% rename from tests/modules/Example Module/config.json rename to tests/ext/modules/Example Module/config.json diff --git a/tests/modules/Example Module/index.js b/tests/ext/modules/Example Module/index.js similarity index 100% rename from tests/modules/Example Module/index.js rename to tests/ext/modules/Example Module/index.js diff --git a/tests/plugins/Depend Error Test/config.json b/tests/ext/plugins/Depend Error Test/config.json similarity index 100% rename from tests/plugins/Depend Error Test/config.json rename to tests/ext/plugins/Depend Error Test/config.json diff --git a/tests/plugins/Depend Error Test/index.js b/tests/ext/plugins/Depend Error Test/index.js similarity index 100% rename from tests/plugins/Depend Error Test/index.js rename to tests/ext/plugins/Depend Error Test/index.js diff --git a/tests/plugins/Example 2/config.json b/tests/ext/plugins/Example 2/config.json similarity index 100% rename from tests/plugins/Example 2/config.json rename to tests/ext/plugins/Example 2/config.json diff --git a/tests/plugins/Example 2/index.js b/tests/ext/plugins/Example 2/index.js similarity index 100% rename from tests/plugins/Example 2/index.js rename to tests/ext/plugins/Example 2/index.js diff --git a/tests/plugins/Example 3/config.json b/tests/ext/plugins/Example 3/config.json similarity index 100% rename from tests/plugins/Example 3/config.json rename to tests/ext/plugins/Example 3/config.json diff --git a/tests/plugins/Example 3/index.js b/tests/ext/plugins/Example 3/index.js similarity index 100% rename from tests/plugins/Example 3/index.js rename to tests/ext/plugins/Example 3/index.js diff --git a/tests/plugins/Example 4/config.json b/tests/ext/plugins/Example 4/config.json similarity index 100% rename from tests/plugins/Example 4/config.json rename to tests/ext/plugins/Example 4/config.json diff --git a/tests/plugins/Example 4/index.js b/tests/ext/plugins/Example 4/index.js similarity index 100% rename from tests/plugins/Example 4/index.js rename to tests/ext/plugins/Example 4/index.js diff --git a/tests/plugins/Example/component.js b/tests/ext/plugins/Example/component.js similarity index 100% rename from tests/plugins/Example/component.js rename to tests/ext/plugins/Example/component.js diff --git a/tests/plugins/Example/config.json b/tests/ext/plugins/Example/config.json similarity index 100% rename from tests/plugins/Example/config.json rename to tests/ext/plugins/Example/config.json diff --git a/tests/plugins/Example/index.js b/tests/ext/plugins/Example/index.js similarity index 100% rename from tests/plugins/Example/index.js rename to tests/ext/plugins/Example/index.js diff --git a/tests/plugins/Patcher Test/config.json b/tests/ext/plugins/Patcher Test/config.json similarity index 100% rename from tests/plugins/Patcher Test/config.json rename to tests/ext/plugins/Patcher Test/config.json diff --git a/tests/plugins/Patcher Test/index.js b/tests/ext/plugins/Patcher Test/index.js similarity index 100% rename from tests/plugins/Patcher Test/index.js rename to tests/ext/plugins/Patcher Test/index.js diff --git a/tests/plugins/Permission Test/config.json b/tests/ext/plugins/Permission Test/config.json similarity index 100% rename from tests/plugins/Permission Test/config.json rename to tests/ext/plugins/Permission Test/config.json diff --git a/tests/plugins/Permission Test/index.js b/tests/ext/plugins/Permission Test/index.js similarity index 100% rename from tests/plugins/Permission Test/index.js rename to tests/ext/plugins/Permission Test/index.js diff --git a/tests/themes/Example/background.jpg b/tests/ext/themes/Example/background.jpg similarity index 100% rename from tests/themes/Example/background.jpg rename to tests/ext/themes/Example/background.jpg diff --git a/tests/themes/Example/config.json b/tests/ext/themes/Example/config.json similarity index 100% rename from tests/themes/Example/config.json rename to tests/ext/themes/Example/config.json diff --git a/tests/themes/Example/index.scss b/tests/ext/themes/Example/index.scss similarity index 100% rename from tests/themes/Example/index.scss rename to tests/ext/themes/Example/index.scss diff --git a/tests/themes/Example/vars.scss b/tests/ext/themes/Example/vars.scss similarity index 100% rename from tests/themes/Example/vars.scss rename to tests/ext/themes/Example/vars.scss diff --git a/tests/ext/themes/SimplerFlat/.DS_Store b/tests/ext/themes/SimplerFlat/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..5008ddfcf53c02e82d7eee2e57c38e5672ef89f6 GIT binary patch literal 6148 zcmeH~Jr2S!425mzP>H1@V-^m;4Wg<&0T*E43hX&L&p$$qDprKhvt+--jT7}7np#A3 zem<@ulZcFPQ@L2!n>{z**++&mCkOWA81W14cNZlEfg7;MkzE(HCqgga^y>{tEnwC%0;vJ&^%eQ zLs35+`xjp>T0.content, .chat form, .chat div[class^="titleWrapper"]>div, div[class^="typing"] { + background-color: $color-medium!important; +} + + /* User list panel */ + +.channel-members-wrap, .channel-members { + background-color: $color-dark!important; +} + + /* Channel list panel */ + +div[class^="channels"], div[class^="channels"]>div[class^="flex"] { + background-color: $color-dark!important; +} + +.guild { + background-color: transparent!important; +} + +.guilds-add { + background-color: $color-very-dark!important; +} + +.guilds-add, .guilds-add-inner { + color: $color-light!important; + border-color: $color-light!important; +} + + /* Guilds list panel */ + +div#app-mount[class^="appMount"], div.guilds-wrapper { + background-color: $color-very-dark; +} + +.app.flex-vertical>div[class^="layers-"], +.app.flex-vertical>div[class^="layers-"]>div[class^="layer-"], +.app.flex-vertical>div[class^="layers-"]>div[class^="layer-"]>div[class^="flex-"] { + background-color: $color-very-dark; +} + + + /* Right settings panel */ + +.ui-standard-sidebar-view .content-region { + background-color: $color-medium!important; +} + + /* Left settings panel */ + +.ui-standard-sidebar-view .sidebar-region { + background-color: $color-dark!important; +} + + /* Friends panel */ + +#friends, #friends>div { + background-color: $color-medium!important; +} + + /* Context menus */ + +div[class^="contextMenu"] { + background-color: $color-dark!important; +} + +div[class^="contextMenu"] div[class^="itemGroup"] div[class^="item"] { + background-color: $color-dark!important; +} + +div[class^="contextMenu"] div[class^="itemGroup"] div[class^="item"]:hover { + background-color: $color-very-dark!important; +} + + /* nochannel */ + +div[class^="noChannel"] { + background-color: $color-medium!important; +} + + /* cards */ + +div[class^="row"]>div[class^="flex"]:before { + background-color: $color-dark!important; + border-color: $color-very-dark!important; +} + + /* modals */ + +div[class^="theme-light wrapper"] { + background: transparent; +} + +.form-header header, div[class^="blurb"], div[class^="expireText"] { + color: $main-text-color!important; +} + +div[class^="modal-"] form { + border-radius: 5px; +} + +div[class^="modal-"] form, .form-header, .form-inner { + background-color: $color-medium!important; +} + +div[class^="modal-"] form>div:last-child, .form-actions { + background-color: $color-dark!important; +} + + /* themed popouts */ + +.themed-popout { + background-color: $color-dark!important; +} + +.themed-popout .header, .messages-popout .message-group { + background-color: $color-medium!important; +} + + /* search results */ + +.search-results-wrap { + background-color: $color-medium!important; +} + +.search-header { + background-color: $color-dark!important; +} + +.search-result-message.hit { + background-color: $color-dark!important; + box-shadow: none!important; +} + +.search-results-wrap .channel-separator .channel-name, .search-result:before, .search-result:after { + background: transparent!important; +} + +.message-group:hover .action-buttons { + background: transparent!important; + box-shadow: none!important; +} + +.action-buttons>div { + background-color: $color-light!important; + color: $color-very-dark!important; + border-radius: 3px; +} + +.action-buttons>div>.text { + color: $color-very-dark!important; +} + + /* Various other things */ + +.popout>div>div[class^="body"], .popout>div>div[class^="footer"] { + background-color: $color-dark!important; +} + + /* Scroll bars */ + +.scroller-wrap .scroller::-webkit-scrollbar-track-piece, .bd-scroller-wrap .bd-scroller::-webkit-scrollbar-track-piece { + background-color: $color-medium!important; + background-clip:padding-box; + border:3px solid $color-light!important; + border-radius:7px; +} + +.scroller-wrap .scroller::-webkit-scrollbar-thumb, .bd-scroller-wrap .bd-scroller::-webkit-scrollbar-thumb { + background-clip:padding-box; + background-color:$color-dark!important; + border:3px solid $color-light!important; + border-radius:7px; +} + + +/* Other bits and bobs */ + +div[class^="searchBar"], .searchBar-YMJBu9 { + background-color: $color-light!important; +} + +/* message inside modal */ + +form div[class^="message"] { + background-color: $color-dark!important; +} + +/* new messages divider */ + +.messages .divider span { + background-color: $color-medium!important; +} + +/* Command autosuggest */ + +div[class^="autocomplete-"] { + background-color: $color-dark!important; +} + +div[class^="selectorSelected"] { + background-color: $color-medium!important; +} + +/* Code blocks */ + +.markup pre, .markup code { + background-color: $color-dark!important; + border-color: $color-very-dark!important; +} + +/* message accessories */ + +.message .accessory>div { + background-color: $color-dark; +} + + +/* Text stuff */ + +.app :not(div[class^="channels"]) :not(code):not(.kawaii-linenumbers):not(li):not(span):not(.user-name):not(.member-username):not(.markup):not(form):not(textarea):not(button):not(.guild):not(a):not(.discord-tag):not(.username):not(.discriminator):not(.ui-button-contents) { + color:$main-text-color!important; +} + +:not(code):not(kawaii-linenumbers):not(li):not(span):not(.markup):not(form):not(textarea) { + font-family:$global-font, Whitney, Helvetica Neue, Helvetica, Arial, sans-serif; +} + +.markup,form,textarea { + color:$chat-text-color!important; + font-family:$chat-font, Whitney, Helvetica Neue, Helvetica, Arial, sans-serif; +} + +.markup { +font-size:$chat-font-size!important; +} + +div[class^="ace_"] { + font-family: $code-font, monospace!important; +} + +code,code span,.kawaii-linenumbers,.kawaii-linenumbers li { + font-family: $code-font, Whitney, Helvetica Neue, Helvetica, Arial, sans-serif!important; + font-size: $code-font-size!important; + font-weight: $code-font-weight!important; +} + +code,.kawaii-linenumbers { + color:$code-text-color!important; +} + + +/* Emoji Picker */ + +div[class^="emojiPicker-"] div[class^="stickyHeader-"] { + background: transparent; +} + +div[class^="emojiPicker-"] { + background-color: $color-light; +} + +.search-bar.search-bar-light { + background-color: $color-light; +} + +.search-bar.search-bar-light input, .search-bar.search-bar-light input::-webkit-input-placeholder { + color: $main-text-color; +} + +.search-bar.search-bar-light input::-webkit-input-placeholder { + opacity: 0.6; +} + +.search-bar-light .search-bar-icon .icon { + filter: invert(100%); +} + +div[class^="emojiPicker-"] div[class^="scroller-"]::-webkit-scrollbar-track-piece { + background-color: $color-medium; + background-clip:padding-box; + border-radius:7px; +} + +div[class^="emojiPicker-"] div[class^="scroller-"]::-webkit-scrollbar-thumb { + background-clip:padding-box; + background-color:$color-dark!important; + border: none!important; + border-radius:7px; +} + +/* Emoji drop shadow so that dark emojis are visible on the dark background */ + +.message-group .emoji { + filter: drop-shadow(0px 0px 1px #FFF); +} + + +/* BD button */ + +.bd-settings-wrapper .bd-settings-button:not(.bd-active) { + background-color: $color-very-dark; +} + +/* BD interface */ + + + /*sidebar*/ + +.bd-sidebar-view .bd-sidebar-region { + background-color: $color-dark; +} + + /*content*/ + +.bd-sidebar-view .bd-content-region { + background-color: $color-medium; +} + + /*modals*/ + +.bd-modal .bd-modal-inner { + background-color: $color-medium; +} + + /*color picker*/ + +.bd-form-colourpicker .vc-chrome { + z-index: 1; + + & .vc-chrome-body { + background-color: $color-medium; + } +} + + + +/* Channel List stuff */ + +*[class^="colorUnread"] { + color: $main-color; +} + +div[class^="wrapperHovered"] div[class^="content"] { + background-color: $color-very-dark; +} + +*[class^="colorHovered"], *[class^="colorSelected"] { + color: #FFFFFF; + opacity: 0.8; +} + +div[class^="nameUnread"] { + color: $main-color; +} + + +/** Collapsing stuff **/ + +@if $collapsing-panels { + + /* Channels list */ + + div[class^="channels"]:not(:hover) { + width: 3em; + } + + .channel.private a { + padding-left: 0.4em; + margin-left: 0px; + } + + .private-channels .search-bar, .private-channels .btn-friends, .private-channels header { + overflow: hidden; + transition: height 0.3s; + } + + .private-channels:not(:hover) .search-bar, .private-channels:not(:hover) .btn-friends, .private-channels:not(:hover) header { + height: 0px; + font-size: 0px; + } + + div[class^="wrapperDefaultVoice"]+div, div[class^="wrapperHoveredVoice"]+div, div[class^="wrapperSelectedVoice"]+div { + padding-left: 0.5em; + } + + +/* Foldaway channel members sidebar */ + + .channel-members-wrap { + min-width:1px; + } + + .channel-members-wrap:not(:hover) { + width: 1px; + } + + .channel-members { + padding-top:0; + padding-bottom:0; + width: 100%; + } +} + +/* Compact Server List */ + +@if $compact-server-list { + + .guilds-wrapper .guilds .guild.selected:before { + margin-top: -10px; + } + + .guilds-wrapper .guilds .guild.selected { + z-index: 2; + transform: scale(1.2); + margin: 10px; + margin-left: 5px; + } + + .guilds-wrapper .guilds .guild.unread:not(.selected)::before { + margin-top: 1px; + height: 15px; + border-radius: 10px; + } + + .guilds-wrapper .guilds .guild:not(.guilds-add) { + height: 30px; + } + + .guilds-wrapper .guilds .guild:first-child { + height: 50px; + } + + .guilds-wrapper .guilds .guild.selected::before { + animation: selectserver 0.4s cubic-bezier(1, 0, 1, 0); + -webkit-animation: selectserver 0.4s cubic-bezier(1, 0, 1, 0); + } + + .guilds-wrapper .guilds .guild:not(:first-child):not(.selected) div:not(.badge) { + transition: height 0.5s; + -webkit-transition: height 0.5s; + } + + .guilds-wrapper .guilds .guild:not(:first-child):not(.selected):hover div:not(.badge) { + height: 50px; + transform: scale(1.2); + -webkit-transform: scale(1.2); + transition: height 0.5s; + -webkit-transition: height 0.5s; + margin-bottom: 0px; + } + + .guilds-wrapper .guilds .guild:not(:first-child):not(.selected):hover { + z-index: 3; + } + + .guilds-wrapper .guilds .guild .badge { + bottom: 14px; + } + + .guilds-wrapper .guilds .guild:not(:first-child):not(.selected):hover .badge { + transform:scale(1.35); + bottom: 19px; + right: -7px; + } +} diff --git a/tests/ext/themes/SimplerFlat/vars.scss b/tests/ext/themes/SimplerFlat/vars.scss new file mode 100644 index 000000000..994ba0f4a --- /dev/null +++ b/tests/ext/themes/SimplerFlat/vars.scss @@ -0,0 +1,40 @@ + + +/* Theme */ +$main-color: #00FAFA !default; /*Main general theme color (#00FAFA Light Cyan by default)*/ + +/* Text */ +$main-text-color: #FAFAFA !default; /*The colour of text onscreen in most places (#FAFAFA light grey by default)*/ +$chat-text-color: #FFFFFF !default; /*The chat will be this color*/ +$code-text-color: #CCCCCC !default; /*The non-syntax hilighted bits in code blocks will be this color*/ + +/* Background */ +$color-light: #3E3E3E !default; /*These are all colors used in the background*/ +$color-medium: #2E2E2E !default; +$color-dark: #1E1E1E !default; +$color-very-dark: #0E0E0E !default; + +/* Tinting */ + +$tint-color: $main-color !default; +$tint-strength: 0% !default; + +/* Font */ +$global-font: 'Whitney' !default; /*This font will appear most places*/ +$chat-font: 'Whitney' !default; /*This font will appear in the main chat*/ +$chat-font-size: 15px !default; +$code-font: monospace !default; /*This will appear in code blocks*/ +$code-font-size: 14px !default; +$code-font-weight: 700 !default; + +/* other */ + +$collapsing-panels: false !default; +$compact-server-list: false !default; + +/* do some stuff with the vars */ + +$color-light: mix($tint-color, $color-light, $tint-strength); +$color-medium: mix($tint-color, $color-medium, $tint-strength); +$color-dark: mix($tint-color, $color-dark, $tint-strength); +$color-very-dark: mix($tint-color, $color-very-dark, $tint-strength);