Extract global BetterDiscord.vendor into separate module, so it can be used through require

This commit is contained in:
samogot 2018-01-27 16:40:35 +02:00
parent d980a23dd3
commit 63c239f36f
4 changed files with 41 additions and 15 deletions

View File

@ -5,13 +5,13 @@
* https://github.com/JsSucks - https://betterdiscord.net * https://github.com/JsSucks - https://betterdiscord.net
* *
* This source code is licensed under the MIT license found in the * This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree. * LICENSE file in the root directory of this source tree.
*/ */
'use strict'; 'use strict';
const styles = require('./styles/index.scss'); const styles = require('./styles/index.scss');
const { Global, Logger, Utils, PluginManager, BDIpc, WebpackModules, SocketProxy, Events } = require('./modules'); const { Global, Logger, Utils, PluginManager, BDIpc, WebpackModules, SocketProxy, Events, Vendor } = require('./modules');
//const { UI } = require('./modules/ui/index.jsx'); //const { UI } = require('./modules/ui/index.jsx');
class BetterDiscord { class BetterDiscord {
@ -50,11 +50,5 @@ if (window.BetterDiscord) {
Logger.log('main', 'Attempting to inject again?'); Logger.log('main', 'Attempting to inject again?');
} else { } else {
let bdInstance = new BetterDiscord(); let bdInstance = new BetterDiscord();
window.BetterDiscord = { window.BetterDiscord = {'vendor': Vendor};
'vendor': {
jQuery: require('jquery'),
$: require('jquery'),
moment: WebpackModules.getModuleByName('Moment')
}
};
} }

View File

@ -5,10 +5,11 @@
* https://github.com/JsSucks - https://betterdiscord.net * https://github.com/JsSucks - https://betterdiscord.net
* *
* This source code is licensed under the MIT license found in the * This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree. * LICENSE file in the root directory of this source tree.
*/ */
const { Module } = require('./modulebase'); const { Module } = require('./modulebase');
const { Vendor } = require('./vendor');
const fs = window.require('fs'); const fs = window.require('fs');
const path = window.require('path'); const path = window.require('path');
@ -29,7 +30,7 @@ class Logger {
} }
level = this.parseLevel(level); level = this.parseLevel(level);
console[level]('[%cBetter%cDiscord:%s] %s', 'color: #3E82E5', '', `${module}${level === 'debug' ? '|DBG' : ''}`, message); console[level]('[%cBetter%cDiscord:%s] %s', 'color: #3E82E5', '', `${module}${level === 'debug' ? '|DBG' : ''}`, message);
logs.push(`[${BetterDiscord.vendor.moment().format('DD/MM/YY hh:mm:ss')}|${module}|${level}] ${message}`); logs.push(`[${Vendor.moment().format('DD/MM/YY hh:mm:ss')}|${module}|${level}] ${message}`);
window.bdlogs = logs; window.bdlogs = logs;
} }
@ -78,7 +79,7 @@ class Utils {
}); });
} }
} }
} }
class FileUtils { class FileUtils {
@ -208,13 +209,13 @@ class Filters {
}; };
} }
static byDisplayName(name) { static byDisplayName(name) {
return module => { return module => {
return module && module.displayName === name; return module && module.displayName === name;
}; };
} }
static combine(...filters) { static combine(...filters) {
return module => { return module => {
return filters.every(filter => filter(module)); return filters.every(filter => filter(module));
}; };

View File

@ -0,0 +1,30 @@
/**
* BetterDiscord Client Utils 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 {WebpackModules} = require('./webpackmodules');
const jQuery = require('jquery');
class Vendor {
static get jQuery() {
return jQuery;
}
static get $() {
return jQuery;
}
static get moment() {
return WebpackModules.getModuleByName('Moment');
}
}
module.exports = {Vendor};

View File

@ -7,4 +7,5 @@ export { WebpackModules } from './core/webpackmodules';
export { Events } from './core/events'; export { Events } from './core/events';
export { SocketProxy } from './core/discordsocket'; export { SocketProxy } from './core/discordsocket';
export { CssEditor } from './core/csseditor'; export { CssEditor } from './core/csseditor';
export { Settings } from './core/settings'; export { Settings } from './core/settings';
export { Vendor } from './core/vendor';