diff --git a/assets/locales/de.json b/assets/locales/de.json index f745b316..f9110f3c 100644 --- a/assets/locales/de.json +++ b/assets/locales/de.json @@ -151,10 +151,6 @@ "name": "Automatische Großschreibung von Emotes", "note": "Emote-Befehle werden automatisch großgeschrieben" }, - "showNames": { - "name": "Namen anzeigen", - "note": "Zeigt den Emote-Namen beim Hovern über diesem an" - }, "modifiers": { "name": "Emote-Modifikatoren anzeigen", "note": "Aktiviert Emote-Modifikatoren (flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)" diff --git a/assets/locales/en.json b/assets/locales/en.json index b61c477c..b283df7f 100644 --- a/assets/locales/en.json +++ b/assets/locales/en.json @@ -151,10 +151,6 @@ "name": "Emote Autocapitalization", "note": "Autocapitalize emote commands" }, - "showNames": { - "name": "Show Names", - "note": "Show emote names on hover" - }, "modifiers": { "name": "Show Emote Modifiers", "note": "Enable emote mods (flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)" diff --git a/assets/locales/ja.json b/assets/locales/ja.json index ae5d6d05..738b6b2b 100644 --- a/assets/locales/ja.json +++ b/assets/locales/ja.json @@ -130,10 +130,6 @@ "name": "絵文字自動補完", "note": "絵文字を自動で補完します" }, - "showNames": { - "name": "名前を表示", - "note": "ホバー時に絵文字の名前を表示します" - }, "modifiers": { "name": "BetterDiscord絵文字を表示", "note": "BetterDiscordの絵文字を有効化します(flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)" diff --git a/assets/locales/sv.json b/assets/locales/sv.json index 04df37ca..ee6b5e24 100644 --- a/assets/locales/sv.json +++ b/assets/locales/sv.json @@ -130,10 +130,6 @@ "name": "Automatiskt Stor Bokstav I Emotes", "note": "Gör automatiskt stor bokstav i emote kommandon" }, - "showNames": { - "name": "Visa namn", - "note": "Visa namn när musen hålls över en emote" - }, "modifiers": { "name": "Visa Emote Modifierare", "note": "Aktivera emote modifierare (flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)" diff --git a/src/builtins/emotes/category.jsx b/src/builtins/emotes/category.jsx index c6b8adee..b127a8c2 100644 --- a/src/builtins/emotes/category.jsx +++ b/src/builtins/emotes/category.jsx @@ -5,23 +5,23 @@ export default class Category extends React.Component { constructor(props) { super(props); this.state = { - opened: true + expanded: true }; } render() { return
-
-
this.setState({opened: !this.state.opened})}> -
+
+
this.setState({expanded: !this.state.expanded})}> +
{this.props.icon ? this.props.icon : null}
-
{this.props.label}
-
- +
{this.props.label}
+
+
- {this.state.opened && this.props.children} + {this.state.expanded && this.props.children}
; } } \ No newline at end of file diff --git a/src/data/settings/emoteconfig.js b/src/data/settings/emoteconfig.js index 05d7d7b0..99569a07 100644 --- a/src/data/settings/emoteconfig.js +++ b/src/data/settings/emoteconfig.js @@ -8,7 +8,6 @@ export default [ {type: "switch", id: "download", value: true}, {type: "switch", id: "emoteMenu", value: true}, {type: "switch", id: "hideEmojiMenu", value: false, enableWith: "emoteMenu"}, - {type: "switch", id: "showNames", value: true}, {type: "switch", id: "modifiers", value: true}, {type: "switch", id: "animateOnHover", value: false} ] diff --git a/src/data/strings.js b/src/data/strings.js index ef42be06..79cf29ab 100644 --- a/src/data/strings.js +++ b/src/data/strings.js @@ -155,10 +155,6 @@ export default { name: "Emote Autocapitalization", note: "Autocapitalize emote commands" }, - showNames: { - name: "Show Names", - note: "Show emote names on hover" - }, modifiers: { name: "Show Emote Modifiers", note: "Enable emote mods (flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)" diff --git a/src/modules/componentpatcher.js b/src/modules/componentpatcher.js index 74a9b882..39c28ce1 100644 --- a/src/modules/componentpatcher.js +++ b/src/modules/componentpatcher.js @@ -12,9 +12,11 @@ export default new class ComponentPatcher { initialize() { Utilities.suppressErrors(this.patchSocial.bind(this), "BD Social Patch")(); + /* Utilities.suppressErrors(this.patchGuildPills.bind(this), "BD Guild Pills Patch")(); Utilities.suppressErrors(this.patchGuildListItems.bind(this), "BD Guild List Items Patch")(); Utilities.suppressErrors(this.patchGuildSeparator.bind(this), "BD Guild Separator Patch")(); + */ Utilities.suppressErrors(this.patchMessageHeader.bind(this), "BD Message Header Patch")(); Utilities.suppressErrors(this.patchMemberList.bind(this), "BD Member List Patch")(); } @@ -57,7 +59,8 @@ export default new class ComponentPatcher { }; }); } - + + /* patchGuildListItems() { if (this.guildListItemsPatch) return; const listItemClass = DiscordModules.GuildClasses.listItem.split(" ")[0]; @@ -107,7 +110,7 @@ export default new class ComponentPatcher { if (!Separator) return; Separator.type = GuildSeparator; }); - } + }*/ patchMessageHeader() { if (this.messageHeaderPatch) return; @@ -156,18 +159,19 @@ export default new class ComponentPatcher { // Tropical's notes /* -html [maximized | bd] +html [maximized | bd | stable | canary | ptb] .iconWrapper-2OrFZ1 [type] .sidebar-2K8pFh [guild-id] -.wrapper-2jXpOf [voice | text | announcement | store | private | nsfw] -.chat-3bRxxu [channnel | guild-id] +.wrapper-2jXpOf [voice | text | announcement | store | private | nsfw | rules] +.chat-3bRxxu [channnel-name | guild-id] .listItem-2P_4kh [type | state] .privateChannels-1nO12o [library-hidden] .member-3-YXUe [user-id] -.message-2qnXI6 [type | author-id | group-end] +.message-2qnXI6 [type | author-id | group-end | message-content] .wrapper-3t9DeA [user-id | status] -.userPopout-3XzG_A [state | user-id] -.root-SR8cQa [state | user-id] +.userPopout-3XzG_A [user-id] +.root-SR8cQa [user-id] .contentRegion-3nDuYy [settings-page] .item-PXvHYJ [settings-page] +.wrapper-35wsBm [valid | expired | joined] */ \ No newline at end of file diff --git a/src/modules/datastore.js b/src/modules/datastore.js index e399e41c..6516bb98 100644 --- a/src/modules/datastore.js +++ b/src/modules/datastore.js @@ -65,7 +65,7 @@ export default new class DataStore { }; const newEmotes = { - general: {download: oldSettings["fork-es-3"], emoteMenu: oldSettings["bda-es-0"], hideEmojiMenu: !oldSettings["bda-es-9"], showNames: oldSettings["bda-es-6"], modifiers: oldSettings["bda-es-8"], animateOnHover: oldSettings["fork-es-2"]}, + general: {download: oldSettings["fork-es-3"], emoteMenu: oldSettings["bda-es-0"], hideEmojiMenu: !oldSettings["bda-es-9"], modifiers: oldSettings["bda-es-8"], animateOnHover: oldSettings["fork-es-2"]}, categories: {twitchglobal: oldSettings["bda-es-7"], twitchsubscriber: oldSettings["bda-es-7"], frankerfacez: oldSettings["bda-es-1"], bttv: oldSettings["bda-es-2"]} }; diff --git a/src/styles/builtins/emotemenu.css b/src/styles/builtins/emotemenu.css index baf151b2..923889ad 100644 --- a/src/styles/builtins/emotemenu.css +++ b/src/styles/builtins/emotemenu.css @@ -1,132 +1,82 @@ -#removemenu { - width: auto; - background: #505050; - z-index: 999999; - box-shadow: 0 0 2px #000; - padding: 2px; - left: 25px; - display: block; - cursor: pointer; - color: #fff; - position: fixed; -} - -#removemenu ul a { - text-decoration: none; - color: #fff; - padding: 3px; -} - -.emotewrapper { - position: relative; - display: inline-flex; - object-fit: contain; - margin: -0.1em 0.05em -0.2em 0.1em; - vertical-align: top; -} - -.emotewrapper.jumboable { - margin-bottom: 0; - margin-top: 0.2em; - vertical-align: -0.3em; -} - -.emote { - height: 1.45em; -} - -.emote.jumboable { - height: 2rem; -} - -.fav { - display: none; - position: absolute; - width: 15px; - height: 15px; - right: -7px; - background: url(""); - border: none; - background-size: 100% 100%; - background-repeat: no-repeat; - background-color: #303030; - border-radius: 5px; - top: -7px; - cursor: pointer; -} - -.fav.active { - background-color: yellow; -} - -.emotewrapper:hover .fav { - display: block; -} - -.emojiPicker-3m1S-j { - box-shadow: none; - border-top: none; - border-radius: 0 0 5px 5px; -} - -#bd-qem { - border-radius: 5px 5px 0 0; - background: #fff; - border-bottom: 1px solid rgba(0, 0, 0, 0.1); - height: 30px; - display: flex; - flex-direction: row; - padding-right: 1px; -} - -#bd-qem button { - border-left: 1px solid #efefef; - background: transparent; - box-shadow: #cecece 1px 0 0 0; - flex-grow: 1; -} - -#bd-qem button:hover { - background: #ececec; -} - -#bd-qem-twitch { - border-radius: 5px 0 0 0; - order: 2; -} - -#bd-qem-emojis { - border-radius: 0 5px 0 0; - order: 3; -} - -#bd-qem-favourite { - order: 3; -} - -#bd-qem button.active { - background-color: #e2e2e2; -} - -#bd-emote-menu { - width: 346px; - height: 329px; - background-color: #fff; - border-radius: 0 0 5px 5px; -} - -#bd-emote-menu .scrollerBase-289Jih { - height: 100%; +.bd-emote-menu { + min-height: 0; } .bd-emote-menu-inner { - padding: 5px 0 0 15px; + padding: 8px 0 0 16px; } -.bd-qme-hidden #bd-qem-emojis { - display: none; +.bd-emote-scroller { + height: 100%; } -.bd-em-scroller { - height: 400px; +.bd-emote-header { + display: flex; + align-items: center; + background: var(--background-secondary); + height: 32px; + padding: 0 4px; + position: sticky; + top: 0; + z-index: 2; +} + +.bd-emote-header-inner { + cursor: pointer; + display: flex; + align-items: center; + color: var(--header-secondary); + font-size: 12px; + font-weight: 600; + transition: color 0.125s; + width: fit-content; +} + +.bd-emote-header-inner:hover { + color: var(--header-primary); +} + +.bd-emote-header-icon { + width: 16px; + height: 16px; +} + +.bd-emote-header-icon svg { + max-height: 100%; + max-width: 100%; +} + +.bd-emote-header-label { + overflow: hidden; + text-overflow: ellipsis; + text-transform: uppercase; + white-space: nowrap; + margin: 0 8px; +} + +.bd-emote-collapse-icon svg { + transition: transform 0.1s; +} + +.bd-emote-collapse-icon.expanded svg { + transform: rotate(-90deg); +} + +.bd-emote-item { + display: inline-flex; + justify-content: center; + align-items: center; + padding: 2px; + border-radius: 5px; + width: 30px; + height: 30px; + position: relative; +} + +.bd-emote-item:hover { + background: var(--background-accent); +} + +.bd-emote-item img { + max-width: 100%; } \ No newline at end of file diff --git a/src/styles/builtins/emotes.css b/src/styles/builtins/emotes.css index 38a637b9..366e2df8 100644 --- a/src/styles/builtins/emotes.css +++ b/src/styles/builtins/emotes.css @@ -1,97 +1,53 @@ -.bd-emote-header { - color: var(--header-secondary); - justify-content: flex-start; - font-size: 12px; - font-weight: 600; - transition: color 0.125s; - align-items: center; - display: flex; -} - -.bd-emote-scroller { - max-height: 380px; -} - -.bd-emote-category { - margin-bottom: 12px; -} - -.bd-emote-content { - cursor: pointer; - position: sticky; - top: 0; - background: var(--background-secondary); - z-index: 2; -} - -.bd-emote-wrapper { - background-color: var(--background-secondary); - box-sizing: border-box; - height: 32px; - padding: 0 4px; - z-index: 1; -} - -.bd-emote-headerIcon { - width: 14px; - height: 14px; - margin-right: 8px; -} - -.bd-emote-headerLabel { - overflow: hidden; - text-overflow: ellipsis; - text-transform: uppercase; - white-space: nowrap; - margin-right: 8px; -} - -.bd-emote-headerIcon + .bd-emote-headerLabel { - margin-left: 8px; -} - -.bd-emote-headerCollapseIcon .bd-emote-opened { - transition: 0.3s; -} - -.bd-emote-headerCollapseIcon .bd-emote-closed { - transform: rotate(90deg); - transition: 0.3s; -} - -#emote-container { - padding: 10px; -} - -.emote-container { - display: inline-block; - padding: 2px; - border-radius: 5px; - width: 30px; - height: 30px; +.emotewrapper { position: relative; + display: inline-flex; + object-fit: contain; + margin: -0.1em 0.05em -0.2em 0.1em; + vertical-align: top; } -.emote-icon { - max-width: 100%; - max-height: 100%; +.emotewrapper.jumboable { + margin-bottom: 0; + margin-top: 0.2em; + vertical-align: -0.3em; +} + +.emote { + height: 1.45em; +} + +.emote.jumboable { + height: 2rem; +} + +.fav { + display: none; position: absolute; - margin: auto; - top: 0; - right: 0; - bottom: 0; - left: 0; + width: 15px; + height: 15px; + right: -7px; + background: url(""); + border: none; + background-size: 100% 100%; + background-repeat: no-repeat; + background-color: #303030; + border-radius: 5px; + top: -7px; cursor: pointer; } +.fav.active { + background-color: yellow; +} + +.emotewrapper:hover .fav { + display: block; +} + .emote.stop-animation { animation: none; } -.emote-container:hover { - background: rgba(123, 123, 123, 0.37); -} - .emoteflip, .emotespinflip { transform: scaleX(-1); diff --git a/src/styles/builtins/publicservers.css b/src/styles/builtins/publicservers.css index 0f514b8a..9f3e2b1c 100644 --- a/src/styles/builtins/publicservers.css +++ b/src/styles/builtins/publicservers.css @@ -64,9 +64,30 @@ position: relative; transition: box-shadow 0.2s ease-out, transform 0.2s ease-out, background 0.2s ease-out, opacity 0.2s ease-in; cursor: pointer; + background-color: var(--activity-card-background); +} + +.theme-light .bd-server-card { + box-shadow: 0 0 0 1px rgba(185, 187, 190, 0.3), var(--elevation-medium); +} + +.theme-dark .bd-server-card { background-color: var(--background-secondary-alt); } +.bd-server-card:hover, +.bd-server-card:focus, +.theme-light .bd-server-card:hover, +.theme-light .bd-server-card:focus { + transform: translateY(-1px); + box-shadow: var(--elevation-high); +} + +.theme-dark .bd-server-card:hover, +.theme-dark .bd-server-card:focus { + background-color: var(--background-tertiary); +} + .bd-placeholder-card { background-color: var(--background-secondary-alt); animation: bd-placeholder-card-pulse 1.8s ease-in-out infinite; @@ -77,12 +98,6 @@ position: relative; } -.bd-server-card:hover { - background-color: var(--background-tertiary); - transform: translateY(-1px); - box-shadow: var(--elevation-high); -} - .bd-server-header { height: 143px; position: relative; @@ -166,7 +181,7 @@ -webkit-box-orient: vertical; color: var(--header-secondary); font-size: 14px; - line-height: 18px; + line-height: normal; } .bd-server-footer { diff --git a/src/styles/buttons.css b/src/styles/buttons.css index 5b51dded..46cc8949 100644 --- a/src/styles/buttons.css +++ b/src/styles/buttons.css @@ -5,16 +5,16 @@ background-color: #3e82e5; color: #fff; border-radius: 3px; - padding: 3px 6px; - transition: opacity 250ms ease; + padding: 4px 8px; + transition: background-color 0.17s ease, color 0.17s ease, opacity 250ms ease; } .bd-button:hover { - background-color: rgb(56, 117, 206); + background-color: #3875ce; } .bd-button:active { - background-color: rgb(50, 104, 183); + background-color: #3268b7; } .bd-button.bd-button-success { diff --git a/src/styles/ui/addonlist.css b/src/styles/ui/addonlist.css index baf8cfca..f7a4df70 100644 --- a/src/styles/ui/addonlist.css +++ b/src/styles/ui/addonlist.css @@ -148,6 +148,7 @@ .bd-controls > .bd-addon-button { border-radius: 0; + padding: 3px 6px; } .bd-links .bd-addon-button + .bd-addon-button { @@ -166,16 +167,18 @@ border-radius: 0 3px 3px 0; } +.bd-controls > .bd-addon-button:only-child { + border-radius: 3px; +} + .bd-controls + .bd-addon-list { margin-top: 10px; } .bd-addon-controls { - display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; - gap: 5px; } .bd-addon-controls .bd-search { diff --git a/src/styles/ui/bdsettings.css b/src/styles/ui/bdsettings.css index c6074041..1a16207f 100644 --- a/src/styles/ui/bdsettings.css +++ b/src/styles/ui/bdsettings.css @@ -14,116 +14,10 @@ fill: #3e82e5; } -.standardSidebarView-3F1I7i .bd-versioninfo-wrapper { - bottom: 0; - left: 0; - position: fixed; - background: inherit; - right: 0; - padding: 5px; -} - -.standardSidebarView-3F1I7i .bd-versioninfo-wrapper span { - color: #b9bbbe; - font-weight: 600; - font-size: 11px; -} - -.standardSidebarView-3F1I7i .bd-versioninfo-wrapper a { - font-size: 11px; -} - .bd-button-title { margin-left: 10px; } -/* #bd-settings-sidebar .ui-tab-bar-item { - font-size: 16px; - font-weight: 500; - line-height: 20px; - text-overflow: ellipsis; - white-space: nowrap; - cursor: pointer; - flex-shrink: 0; - padding: 6px 10px; - border-radius: 3px; - position: relative; - overflow: hidden; -} -#bd-settings-sidebar .ui-tab-bar-item.selected { - cursor: default; -} -.theme-dark #bd-settings-sidebar .ui-tab-bar-item { - color: #b9bbbe; -} -.theme-dark #bd-settings-sidebar .ui-tab-bar-item:hover { - background-color: rgba(185,187,190,.1); - color: #f6f6f7; -} -.theme-dark #bd-settings-sidebar .ui-tab-bar-item.selected { - background-color: #7289da; - color: #fff; -} -.theme-light #bd-settings-sidebar .ui-tab-bar-item { - color: #72767d; -} -.theme-light #bd-settings-sidebar .ui-tab-bar-item:hover { - background-color: rgba(79,84,92,.1); - color: #4f545c; -} -.theme-light #bd-settings-sidebar .ui-tab-bar-item.selected { - background-color: #7289da; - color: #fff; -} - -#bd-settings-sidebar .ui-tab-bar-header { - font-size: 12px; - font-weight: 700; - line-height: 16px; - text-transform: uppercase; - text-overflow: ellipsis; - white-space: nowrap; - flex-shrink: 0; - padding: 6px 10px; - overflow: hidden; -} -.theme-dark #bd-settings-sidebar .ui-tab-bar-header { - color: #72767d; -} -.theme-light #bd-settings-sidebar .ui-tab-bar-header { - color: #b9bbbe; -} - -#bd-settings-sidebar .ui-tab-bar-separator { - height: 1px; - margin: 8px 10px; -} -.theme-dark #bd-settings-sidebar .ui-tab-bar-separator { - background-color: rgba(114,118,125,.3); -} -.theme-light #bd-settings-sidebar .ui-tab-bar-separator { - background-color: rgba(185,187,190,.3); -} - -.ui-flex { - display: flex; -} - -#bd-settingspane-container h2.ui-form-title { - font-size: 16px; - font-weight: 600; - line-height: 20px; - text-transform: uppercase; - display: inline-block; - margin-bottom: 20px; -} -.theme-dark #bd-settingspane-container h2.ui-form-title { - color: #f6f6f7; -} -.theme-light #bd-settingspane-container h2.ui-form-title { - color: #4f545c; -} */ - .bd-switch { background-color: #72767d; border-radius: 14px; @@ -191,104 +85,6 @@ cursor: not-allowed; } -.bd-switch-item { - flex-direction: column; - margin-top: 8px; -} - -.bd-switch-item h3 { - font-size: 16px; - font-weight: 500; - line-height: 24px; - flex: 1; -} - -.theme-dark .bd-switch-item h3 { - color: #f6f6f7; -} - -.theme-light .bd-switch-item h3 { - color: #4f545c; -} - -/* .ui-switch-item .style-description { - font-size: 14px; - font-weight: 500; - line-height: 20px; - margin-bottom: 10px; - padding-bottom: 10px; - border-bottom: 1px solid hsla(218,5%,47%,.3); -} -.theme-dark .ui-switch-item .style-description { - color: #72767d; -} -.theme-light .ui-switch-item .style-description { - color: rgba(114,118,125,.6); -} */ - -.bd-switch-item .bd-switch-wrapper { - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - position: relative; - width: 44px; - height: 24px; - display: block; - flex: 0 0 auto; -} - -.bd-switch-item .bd-switch-wrapper input { - position: absolute; - opacity: 0; - cursor: pointer; - width: 100%; - height: 100%; - z-index: 1; -} - -.bd-switch-item .bd-switch-wrapper .bd-switch { - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - background: #72767d; - border-radius: 14px; - transition: background 0.15s ease-in-out, box-shadow 0.15s ease-in-out, border 0.15s ease-in-out; -} - -.bd-switch-item .bd-switch-wrapper .bd-switch::before { - content: ""; - display: block; - width: 18px; - height: 18px; - position: absolute; - top: 3px; - left: 3px; - bottom: 3px; - background: #f6f6f7; - border-radius: 10px; - transition: all 0.15s ease; - box-shadow: 0 3px 1px 0 rgba(0, 0, 0, 0.05), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 3px 3px 0 rgba(0, 0, 0, 0.05); -} - -.bd-switch-item .bd-switch-wrapper .bd-switch.checked { - background: #7289da; -} - -.bd-switch-item .bd-switch-wrapper .bd-switch.checked::before { - transform: translateX(20px); -} - -#bd-settingspane-container .scroller-wrap { - height: 100%; -} - -#bd-settingspane-container .scroller-wrap .scroller { - display: flex; -} - .bd-select-wrapper { color: var(--text-muted); font-size: 13px; diff --git a/src/ui/emoteicon.jsx b/src/ui/emoteicon.jsx index e76e31ca..3187e2d2 100644 --- a/src/ui/emoteicon.jsx +++ b/src/ui/emoteicon.jsx @@ -8,7 +8,7 @@ const {ComponentDispatch} = WebpackModules.getByProps("ComponentDispatch"); export default class EmoteIcon extends React.Component { render() { - return
+ return
{this.props.emote}
; } diff --git a/src/ui/icons/downarrow.jsx b/src/ui/icons/downarrow.jsx index ae5c593a..556bd932 100644 --- a/src/ui/icons/downarrow.jsx +++ b/src/ui/icons/downarrow.jsx @@ -3,7 +3,7 @@ import {React} from "modules"; export default class DownArrow extends React.Component { render() { const size = this.props.size || "16px"; - return + return ; } diff --git a/src/ui/settings/addoncard.jsx b/src/ui/settings/addoncard.jsx index 1290db6d..7b6c301d 100644 --- a/src/ui/settings/addoncard.jsx +++ b/src/ui/settings/addoncard.jsx @@ -170,7 +170,7 @@ export default class AddonCard extends React.Component {
{this.buildTitle(name, version, {name: author, id: this.props.addon.authorId, link: this.props.addon.authorLink})}
-
{SimpleMarkdown.parseToReact(description)}
+
{SimpleMarkdown.parseToReact(description)}
{this.footer}
; }