From 35cedbdbb39928f05b99bd813763b254a33fb5b2 Mon Sep 17 00:00:00 2001 From: Samuel Elliott Date: Sun, 10 Jun 2018 21:28:23 +0100 Subject: [PATCH] Use a single badge component --- client/src/styles/partials/badges.scss | 59 +++++++++---------- .../src/styles/partials/variables/images.scss | 2 + client/src/ui/commoncomponents.js | 1 - client/src/ui/components/bd/BdBadge.vue | 16 ++--- .../src/ui/components/bd/BdMessageBadge.vue | 33 ----------- client/src/ui/components/bd/index.js | 1 - client/src/ui/profilebadges.js | 29 +++++---- 7 files changed, 58 insertions(+), 83 deletions(-) delete mode 100644 client/src/ui/components/bd/BdMessageBadge.vue diff --git a/client/src/styles/partials/badges.scss b/client/src/styles/partials/badges.scss index 585fef64..5326fce7 100644 --- a/client/src/styles/partials/badges.scss +++ b/client/src/styles/partials/badges.scss @@ -18,50 +18,49 @@ background-size: cover; cursor: pointer; height: 16px; + width: 16px; margin-right: 6px; } .bd-profile-badge-developer, -.bd-profile-badge-contributor, -.bd-message-badge-developer, -.bd-message-badge-contributor { +.bd-profile-badge-webdev, +.bd-profile-badge-contributor { background-image: $logoSmallBw; - width: 16px; filter: brightness(10); - cursor: pointer; + + .theme-light [class*="topSectionNormal-"] .bd-profile-badges-profile-modal > &, + .theme-light :not(.bd-profile-badges-profile-modal) > & { + background-image: $logoSmallLight; + filter: none; + } } -.theme-light [class*="topSectionNormal-"] .bd-profile-badge-developer, -.theme-light [class*="topSectionNormal-"] .bd-profile-badge-contributor, -.theme-light .bd-message-badge-developer, -.theme-light .bd-message-badge-contributor { - background-image: url(''); - filter: none; -} - -.bd-message-badges-wrap { +.bd-profile-badges.bd-profile-badges-nametag { display: inline-block; margin-left: 6px; height: 11px; - .bd-message-badge-developer, - .bd-message-badge-contributor { + .bd-profile-badge { width: 12px; height: 12px; + + &:last-child { + margin-right: 0; + } } } -.member-username .bd-message-badges-wrap { - display: inline-block; - height: 17px; - width: 14px; - - .bd-message-badge-developer, - .bd-message-badge-contributor { - width: 14px; - height: 16px; - background-position: center; - background-size: 12px 12px; - background-repeat: no-repeat; - } -} +// .member-username .bd-profile-badges { +// display: inline-block; +// height: 17px; +// width: 14px; +// +// .bd-badge, +// .bd-badge-c { +// width: 14px; +// height: 16px; +// background-position: center; +// background-size: 12px 12px; +// background-repeat: no-repeat; +// } +// } diff --git a/client/src/styles/partials/variables/images.scss b/client/src/styles/partials/variables/images.scss index 25e043fd..4a2f0b3f 100644 --- a/client/src/styles/partials/variables/images.scss +++ b/client/src/styles/partials/variables/images.scss @@ -1,3 +1,5 @@ $logoSmallBw: url(); +$logoSmallLight: url(''); + $logoBigBw: url(); diff --git a/client/src/ui/commoncomponents.js b/client/src/ui/commoncomponents.js index 8a7388c9..e357fbae 100644 --- a/client/src/ui/commoncomponents.js +++ b/client/src/ui/commoncomponents.js @@ -7,4 +7,3 @@ export { default as Setting } from './components/bd/setting/Setting.vue'; export { default as Card } from './components/bd/Card.vue'; export { default as ContentAuthor } from './components/bd/ContentAuthor.vue'; export { default as BdBadge } from './components/bd/BdBadge.vue'; -export { default as BdMessageBadge } from './components/bd/BdMessageBadge.vue'; diff --git a/client/src/ui/components/bd/BdBadge.vue b/client/src/ui/components/bd/BdBadge.vue index bf38307a..266ee6de 100644 --- a/client/src/ui/components/bd/BdBadge.vue +++ b/client/src/ui/components/bd/BdBadge.vue @@ -9,10 +9,10 @@ */ @@ -21,12 +21,12 @@ import { shell } from 'electron'; export default { - props: ['webdev', 'developer', 'contributor'], + props: ['contributor', 'type'], methods: { click() { - if (this.developer) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp'); - if (this.webdev) return shell.openExternal('https://betterdiscord.net'); - if (this.contributor) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp/graphs/contributors'); + if (this.contributor.developer) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp'); + if (this.contributor.webdev) return shell.openExternal('https://betterdiscord.net'); + if (this.contributor.contributor) return shell.openExternal('https://github.com/JsSucks/BetterDiscordApp/graphs/contributors'); } } } diff --git a/client/src/ui/components/bd/BdMessageBadge.vue b/client/src/ui/components/bd/BdMessageBadge.vue deleted file mode 100644 index 3664c4bc..00000000 --- a/client/src/ui/components/bd/BdMessageBadge.vue +++ /dev/null @@ -1,33 +0,0 @@ -/** - * BetterDiscord BD Message 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. -*/ - - - - diff --git a/client/src/ui/components/bd/index.js b/client/src/ui/components/bd/index.js index 532c5478..6e75be68 100644 --- a/client/src/ui/components/bd/index.js +++ b/client/src/ui/components/bd/index.js @@ -5,4 +5,3 @@ export { default as PluginsView } from './PluginsView.vue'; export { default as ThemesView } from './ThemesView.vue'; export { default as UpdaterView } from './UpdaterView.vue'; export { default as BdBadge } from './BdBadge.vue'; -export { default as BdMessageBadge } from './BdMessageBadge.vue'; diff --git a/client/src/ui/profilebadges.js b/client/src/ui/profilebadges.js index fc585ecf..5a1cf6f4 100644 --- a/client/src/ui/profilebadges.js +++ b/client/src/ui/profilebadges.js @@ -12,7 +12,7 @@ import { Module, ReactComponents, ReactHelpers, MonkeyPatch, WebpackModules } fr import { Reflection } from 'ui'; import { Utils, ClientLogger as Logger } from 'common'; import DOM from './dom'; -import { BdBadge, BdMessageBadge } from './components/bd'; +import { BdBadge } from './components/bd'; import VueInjector from './vueinjector'; import contributors from '../data/contributors'; @@ -42,13 +42,16 @@ export default class extends Module { const message = ReactHelpers.findProp(component, 'message'); if (!message || !message.author) return; const user = message.author; - const c = contributors.find(c => c.id === user.id); - if (!c) return; + const contributor = contributors.find(c => c.id === user.id); + if (!contributor) return; const username = ReactHelpers.findByProp(retVal, 'type', 'h2'); if (!username) return; - username.props.children.splice(1, 0, VueInjector.createReactElement(BdMessageBadge, c)); + username.props.children.splice(1, 0, VueInjector.createReactElement(BdBadge, { + contributor, + type: 'nametag' + })); }); // Rerender all messages @@ -104,10 +107,13 @@ export default class extends Module { const user = ReactHelpers.findProp(this, 'user'); if (!user) return; - const c = contributors.find(c => c.id === user.id); - if (!c) return; + const contributor = contributors.find(c => c.id === user.id); + if (!contributor) return; - retVal.props.children.splice(1, 0, VueInjector.createReactElement(BdMessageBadge, c)); + retVal.props.children.splice(1, 0, VueInjector.createReactElement(BdBadge, { + contributor, + type: 'nametag' + })); } catch (err) { Logger.err('ProfileBadges', ['Error thrown while rendering a NameTag', err]); } @@ -136,10 +142,13 @@ export default class extends Module { this.unpatchUserProfileModal = MonkeyPatch('ProfileBadges', this.UserProfileModal.component.prototype).after('renderBadges', (component, args, retVal, setRetVal) => { const user = ReactHelpers.findProp(component, 'user'); if (!user) return; - const c = contributors.find(c => c.id === user.id); - if (!c) return; + const contributor = contributors.find(c => c.id === user.id); + if (!contributor) return; - const element = VueInjector.createReactElement(BdBadge, c); + const element = VueInjector.createReactElement(BdBadge, { + contributor, + type: 'profile-modal' + }); if (!retVal) { setRetVal(ReactHelpers.React.createElement('div', {