commit
0bb70aebde
|
@ -8,7 +8,7 @@
|
||||||
* LICENSE file in the root directory of this source tree.
|
* LICENSE file in the root directory of this source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { DOM, BdUI } from 'ui';
|
import { DOM, BdUI, ProfileBadges } from 'ui';
|
||||||
import BdCss from './styles/index.scss';
|
import BdCss from './styles/index.scss';
|
||||||
import { Events, CssEditor, Globals, PluginManager, ThemeManager } from 'modules';
|
import { Events, CssEditor, Globals, PluginManager, ThemeManager } from 'modules';
|
||||||
import { ClientLogger as Logger } from 'common';
|
import { ClientLogger as Logger } from 'common';
|
||||||
|
@ -16,6 +16,7 @@ import { ClientLogger as Logger } from 'common';
|
||||||
class BetterDiscord {
|
class BetterDiscord {
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
|
ProfileBadges.init(); // Not final way to do it
|
||||||
DOM.injectStyle(BdCss, 'bdmain');
|
DOM.injectStyle(BdCss, 'bdmain');
|
||||||
Events.on('global-ready', this.globalReady.bind(this));
|
Events.on('global-ready', this.globalReady.bind(this));
|
||||||
}
|
}
|
||||||
|
@ -27,6 +28,7 @@ class BetterDiscord {
|
||||||
}
|
}
|
||||||
|
|
||||||
globalReady() {
|
globalReady() {
|
||||||
|
BdUI.initUiEvents();
|
||||||
this.vueInstance = BdUI.injectUi();
|
this.vueInstance = BdUI.injectUi();
|
||||||
(async () => {
|
(async () => {
|
||||||
this.init();
|
this.init();
|
||||||
|
|
|
@ -5,3 +5,4 @@ export { default as PluginManager } from './pluginmanager';
|
||||||
export { default as ThemeManager } from './thememanager';
|
export { default as ThemeManager } from './thememanager';
|
||||||
export { default as Globals } from './globals';
|
export { default as Globals } from './globals';
|
||||||
export { default as Vendor } from './vendor';
|
export { default as Vendor } from './vendor';
|
||||||
|
export { default as WebpackModules } from './webpackmodules';
|
||||||
|
|
|
@ -5,5 +5,6 @@
|
||||||
@import './sidebarview/index.scss';
|
@import './sidebarview/index.scss';
|
||||||
@import './bdsettings/index.scss';
|
@import './bdsettings/index.scss';
|
||||||
@import './generic/index.scss';
|
@import './generic/index.scss';
|
||||||
|
@import './profilebadges.scss';
|
||||||
|
|
||||||
@import './discordoverrides.scss';
|
@import './discordoverrides.scss';
|
||||||
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
.bd-profile-badges-wrap {
|
||||||
|
display: flex;
|
||||||
|
margin-top: 8px;
|
||||||
|
flex: 1 1 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-profile-badges {
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-profile-badge {
|
||||||
|
background-position: 50%;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: cover;
|
||||||
|
cursor: pointer;
|
||||||
|
height: 16px;
|
||||||
|
margin-right: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-profile-badge-developer,
|
||||||
|
.bd-profile-badge-contributor {
|
||||||
|
background-image: $logoSmallBw;
|
||||||
|
width: 16px;
|
||||||
|
filter: brightness(10);
|
||||||
|
|
||||||
|
.theme-light [class*="topSectionNormal-"] & {
|
||||||
|
background-image: url('');
|
||||||
|
filter: none;
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,23 +8,36 @@
|
||||||
* LICENSE file in the root directory of this source tree.
|
* LICENSE file in the root directory of this source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import Dom from './dom';
|
import DOM from './dom';
|
||||||
import Vue from 'vue';
|
import Vue from './vue';
|
||||||
import VTooltip from 'v-tooltip';
|
|
||||||
import { BdSettingsWrapper } from './components';
|
import { BdSettingsWrapper } from './components';
|
||||||
|
import { Events, WebpackModules } from 'modules';
|
||||||
|
import { Utils } from 'common';
|
||||||
|
|
||||||
export default class {
|
export default class {
|
||||||
|
|
||||||
|
static initUiEvents() {
|
||||||
|
//this.profilePopupModule.open
|
||||||
|
const defer = setInterval(() => {
|
||||||
|
if (!this.profilePopupModule) return;
|
||||||
|
clearInterval(defer);
|
||||||
|
this.profilePopupModule.open = Utils.overload(this.profilePopupModule.open, userid => {
|
||||||
|
Events.emit('ui-event', {
|
||||||
|
event: 'profile-popup-open',
|
||||||
|
data: { userid }
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}, 100);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static get profilePopupModule() {
|
||||||
|
return WebpackModules.getModuleByProps(['fetchMutualFriends', 'setSection']);
|
||||||
|
}
|
||||||
|
|
||||||
static injectUi() {
|
static injectUi() {
|
||||||
Vue.use(VTooltip, {
|
DOM.createElement('bdtooltips').appendTo(DOM.bdBody);
|
||||||
defaultContainer: 'bdtooltips',
|
DOM.createElement('div', null, 'bd-settings').appendTo(DOM.bdBody);
|
||||||
defaultClass: 'bd-tooltip',
|
|
||||||
defaultTargetClass: 'bd-has-tooltip',
|
|
||||||
defaultInnerSelector: '.bd-tooltip-inner',
|
|
||||||
defaultTemplate: '<div class="bd-tooltip"><span class="bd-tooltip-inner"></span></div>'
|
|
||||||
});
|
|
||||||
|
|
||||||
Dom.createElement('div', null, 'bd-settings').appendTo(Dom.bdBody);
|
|
||||||
|
|
||||||
const vueInstance = new Vue({
|
const vueInstance = new Vue({
|
||||||
el: '#bd-settings',
|
el: '#bd-settings',
|
||||||
components: { BdSettingsWrapper },
|
components: { BdSettingsWrapper },
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
/**
|
||||||
|
* BetterDiscord BD Badge Component
|
||||||
|
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
|
||||||
|
* All rights reserved.
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div :class="{'bd-profile-badges-wrap': !hasBadges}">
|
||||||
|
<div class="bd-profile-badges">
|
||||||
|
<div v-if="developer" v-tooltip="'BetterDiscord Developer'" class="bd-profile-badge bd-profile-badge-developer" @click="onClick"></div>
|
||||||
|
<div v-else-if="webdev" v-tooltip="'BetterDiscord Web Developer'" class="bd-profile-badge bd-profile-badge-developer" @click="onClick"></div>
|
||||||
|
<div v-else-if="contributor" v-tooltip="'BetterDiscord Contributor'" class="bd-profile-badge bd-profile-badge-contributor" @click="onClick"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
// Imports
|
||||||
|
import { shell } from 'electron';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
props: ['webdev', 'developer', 'contributor', 'hasBadges'],
|
||||||
|
methods: {
|
||||||
|
onClick() {
|
||||||
|
if (this.developer) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp');
|
||||||
|
if (this.webdev) return shell.openExternal('http://betterdiscord.net');
|
||||||
|
if (this.contributor) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp/graphs/contributors');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -4,3 +4,4 @@ export { default as UISettings } from './UISettings.vue';
|
||||||
export { default as EmoteSettings } from './EmoteSettings.vue';
|
export { default as EmoteSettings } from './EmoteSettings.vue';
|
||||||
export { default as CssEditorView } from './CssEditor.vue';
|
export { default as CssEditorView } from './CssEditor.vue';
|
||||||
export { default as PluginsView } from './PluginsView.vue';
|
export { default as PluginsView } from './PluginsView.vue';
|
||||||
|
export { default as BdBadge } from './BdBadge.vue';
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
/**
|
||||||
|
* BetterDiscord Developer/Contributor Profile Badges
|
||||||
|
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
|
||||||
|
* All rights reserved.
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import DOM from './dom';
|
||||||
|
import { BdBadge } from './components/bd';
|
||||||
|
import VueInjector from './vueinjector';
|
||||||
|
import { Events } from 'modules';
|
||||||
|
|
||||||
|
export default class {
|
||||||
|
|
||||||
|
static init() {
|
||||||
|
Events.on('ui-event', this.uiEvent.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
static uiEvent(e) {
|
||||||
|
const { event, data } = e;
|
||||||
|
if (event !== 'profile-popup-open') return;
|
||||||
|
const { userid } = data;
|
||||||
|
if (!userid) return;
|
||||||
|
|
||||||
|
this.inject(userid);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inject(userid) {
|
||||||
|
const contributor = this.contributors.find(c => c.id == userid);
|
||||||
|
if (!contributor) return;
|
||||||
|
|
||||||
|
setTimeout(() => {
|
||||||
|
let hasBadges = false;
|
||||||
|
let root = document.querySelector('[class*=profileBadges]');
|
||||||
|
if (root) {
|
||||||
|
hasBadges = true;
|
||||||
|
} else {
|
||||||
|
root = document.querySelector('[class*="headerInfo"]');
|
||||||
|
}
|
||||||
|
|
||||||
|
VueInjector.inject(
|
||||||
|
root,
|
||||||
|
DOM.createElement('div', null, 'bdprofilebadges'),
|
||||||
|
{ BdBadge },
|
||||||
|
`<BdBadge developer="${contributor.developer}" contributor="${contributor.contributor}" webdev="${contributor.webdev}" hasBadges="${hasBadges}" />`
|
||||||
|
);
|
||||||
|
}, 200);
|
||||||
|
}
|
||||||
|
|
||||||
|
static filter(mutation) {
|
||||||
|
return mutation.target.firstChild && mutation.target.className.includes('modal');
|
||||||
|
}
|
||||||
|
|
||||||
|
static get contributors() {
|
||||||
|
return [
|
||||||
|
{ 'id': 81388395867156480, 'webdev': true, 'developer': true, 'contributor': true }, // Jiiks
|
||||||
|
{ 'id': 98003542823944192, 'webdev': false, 'developer': true, 'contributor': true }, // Pohky
|
||||||
|
{ 'id': 138850472541814784, 'webdev': true, 'developer': false, 'contributor': true }, // Hammock
|
||||||
|
{ 'id': 249746236008169473, 'webdev': false, 'developer': true, 'contributor': true }, // Zerebos
|
||||||
|
{ 'id': 125367412370440192, 'webdev': false, 'developer': true, 'contributor': true }, // Pierce
|
||||||
|
{ 'id': 284056145272766465, 'webdev': false, 'developer': false, 'contributor': true }, // Samuel Elliott
|
||||||
|
{ 'id': 184021060562321419, 'webdev': false, 'developer': false, 'contributor': true }, // Lilian Tedone
|
||||||
|
{ 'id': 76052829285916672, 'webdev': false, 'developer': false, 'contributor': true }, // samfun123
|
||||||
|
{ 'id': 171005991272316937, 'webdev': false, 'developer': false, 'contributor': true }, // samogot
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,2 +1,4 @@
|
||||||
export { default as DOM } from './dom';
|
export { default as DOM } from './dom';
|
||||||
export { default as BdUI } from './bdui';
|
export { default as BdUI } from './bdui';
|
||||||
|
export { default as VueInjector } from './vueinjector';
|
||||||
|
export { default as ProfileBadges } from './profilebadges';
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
/**
|
||||||
|
* BetterDiscord Client UI Module
|
||||||
|
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
|
||||||
|
* All rights reserved.
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import Vue from 'vue';
|
||||||
|
import VTooltip from 'v-tooltip';
|
||||||
|
|
||||||
|
Vue.use(VTooltip, {
|
||||||
|
defaultContainer: 'bdtooltips',
|
||||||
|
defaultClass: 'bd-tooltip',
|
||||||
|
defaultTargetClass: 'bd-has-tooltip',
|
||||||
|
defaultInnerSelector: '.bd-tooltip-inner',
|
||||||
|
defaultTemplate: '<div class="bd-tooltip"><span class="bd-tooltip-inner"></span></div>'
|
||||||
|
});
|
||||||
|
|
||||||
|
export default Vue;
|
|
@ -0,0 +1,25 @@
|
||||||
|
/**
|
||||||
|
* BetterDiscord VUE Injector Module
|
||||||
|
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
|
||||||
|
* All rights reserved.
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import Vue from './vue';
|
||||||
|
|
||||||
|
export default class {
|
||||||
|
|
||||||
|
static inject(root, bdnode, components, template) {
|
||||||
|
bdnode.appendTo(root);
|
||||||
|
|
||||||
|
return new Vue({
|
||||||
|
el: bdnode.element,
|
||||||
|
components,
|
||||||
|
template
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -2,7 +2,7 @@
|
||||||
"name": "betterdiscord",
|
"name": "betterdiscord",
|
||||||
"description": "BetterDiscord",
|
"description": "BetterDiscord",
|
||||||
"author": "Jiiks",
|
"author": "Jiiks",
|
||||||
"version": "0.4.0",
|
"version": "2.0.0a",
|
||||||
"homepage": "https://betterdiscord.net",
|
"homepage": "https://betterdiscord.net",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"main": "./core/index.js",
|
"main": "./core/index.js",
|
||||||
|
|
Loading…
Reference in New Issue