Adjust how locales are handled
Allows POEditor to be the main copy of translated strings (aside from en-US)
This commit is contained in:
parent
2779d9bc4f
commit
2ace4925a2
|
@ -0,0 +1,68 @@
|
||||||
|
# BetterDiscord Changelog
|
||||||
|
|
||||||
|
This changelog starts with the restructured 1.0.0 release that happened after context isolation changes. The changelogs here should more-or-less mirror the ones that get shown in the client but probably with less formatting and pizzazz.
|
||||||
|
|
||||||
|
## Unreleased
|
||||||
|
|
||||||
|
### Added
|
||||||
|
- Added an option to prevent Discord from hijacking the media keys.
|
||||||
|
- Added command line flag to launch a vanilla version of Discord `--vanilla`
|
||||||
|
- Added an option for app-wide `ctrl+shift+c` shortcut for inspect element.
|
||||||
|
- Added emote blocklist to `BdApi` via `BdApi.Emotes.blocklist`.
|
||||||
|
- Added the ability to remove Discord's forced minimum window size.
|
||||||
|
- Added a basic core updater to hopefully prevent the need for future installs.
|
||||||
|
- Added an option to log out all console logs to file for developers.
|
||||||
|
- Added an option to disable Discord's console warning.
|
||||||
|
|
||||||
|
### Removed
|
||||||
|
- Class normalizer was removed as it does more harm than good.
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
- Addon error modals got a makeover thanks to [Strencher](https://github.com/Strencher) and [Tropical](https://github.com/Tropix126)
|
||||||
|
- Emotes are now downloaded as a single asar bundle as opposed to individual JSON files.
|
||||||
|
- Strings are now bundles with the main payload, but may move to a separate asar like the emotes.
|
||||||
|
- `BdApi` functions related to window preferences no longer work and are deprecated.
|
||||||
|
- Guild classes are obtained later from webpack in case it's not loaded in fast enough.
|
||||||
|
- DataStore now has additional protections (`try..catch`).
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
- Fixed an issue with old METAs used in themes cause the css to render invalid.
|
||||||
|
- Fixed crashing issues with plugins using `Buffer`.
|
||||||
|
- Fixed a bug for manual and 3rd party installations that don't create the BD folder.
|
||||||
|
- Fixed incorrect path usage for some Mac devices.
|
||||||
|
- Fixed colored text not doing anything.
|
||||||
|
- Fixed detached css window not loading saved css.
|
||||||
|
- Fixed an issue where toggling settings collections would remove incorrect panels.
|
||||||
|
- Fixed the file watchers not properly matching duplicate files.
|
||||||
|
- Fixed Hide GIF and Hide Gift options for Discord's changes
|
||||||
|
- Fixed public servers button not showing.
|
||||||
|
- Fixed multiple error modals showing on startup if multiple plugins had errors.
|
||||||
|
- Fixed incorrect styling on emotes.
|
||||||
|
- Fixed system editor edit buttons using an old Electron API (`openItem` vs `openPath`)
|
||||||
|
|
||||||
|
|
||||||
|
## 1.0.0
|
||||||
|
|
||||||
|
### Added
|
||||||
|
- **Everything** is entirely rewritten, for better or worse.
|
||||||
|
- **Emotes and Custom CSS** can be completely turned off for those not interested. It saves on memory too by not loading those components.
|
||||||
|
- **Floating editors** for both custom css and plugins/themes are now available.
|
||||||
|
- **Monaco** is now used as the main CSS editor, in place of Ace.
|
||||||
|
- **Settings panels** are completely new and sleek. They are also highly extensible for potential future features :eyes:
|
||||||
|
- **Translations** are now integrated starting with only a couple languages, but feel free to contribute your own!
|
||||||
|
- **Public servers** got a new makeover thanks to some design help from Tropical and Gibbu!
|
||||||
|
We added settings to hide the **Gif Picker** and the **Nitro Gift** buttons in the textarea.
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
- **Patcher API** was added to `BdApi` under `BdApi.Patcher`. The old `BdApi.monkeyPatch` was patched to use the Patcher as well. This allows plugins and patches to play nice with one another.
|
||||||
|
- **jQuery** was removed from dependencies.
|
||||||
|
- **General performance** improvements throughout the app, from startup to emotes to addons.
|
||||||
|
- **Exporting** by plugins is now highly encouraged over trying to match your meta name and class name.
|
||||||
|
- **Plugins and Themes** pages have more options for sorting, views and more. The entire panel got a facelift!
|
||||||
|
- **Blankslates** have been added all over for that added UX.
|
||||||
|
- **Several unused UI features** have been removed for a more performant and usable experience.
|
||||||
|
- **Debugger Hotkey** is now a built-in feature!
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
- **Minimal mode** has been redesigned from the ground up and now works as intended.
|
||||||
|
- **Emote menus** are fixed and now use React Patching to properly integrate into the new Emoji Picker. (Thanks Strencher#1044!)
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -1,6 +1,82 @@
|
||||||
|
/* eslint-disable no-multi-spaces */
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
en: require("./en.json"),
|
"en-US": require("./en-us.json"), // English, US
|
||||||
de: require("./de.json"),
|
"en-GB": require("./en-gb.json"), // English, UK
|
||||||
ja: require("./ja.json"),
|
"zh-CN": require("./zh-cn.json"), // Chinese, Simplified
|
||||||
sv: require("./sv.json")
|
"zh-TW": require("./zh-tw.json"), // Chinese, Traditional
|
||||||
|
"cs": require("./cs.json"), // Czech
|
||||||
|
"da": require("./da.json"), // Danish
|
||||||
|
"nl": require("./nl.json"), // Dutch
|
||||||
|
"fr": require("./fr.json"), // French
|
||||||
|
"de": require("./de.json"), // German
|
||||||
|
"el": require("./el.json"), // Greek
|
||||||
|
"hu": require("./hu.json"), // Hungarian
|
||||||
|
"it": require("./it.json"), // Italian
|
||||||
|
"ja": require("./ja.json"), // Japanese
|
||||||
|
"ko": require("./ko.json"), // Korean
|
||||||
|
"pl": require("./pl.json"), // Polish
|
||||||
|
"pt-PT": require("./pt-pt.json"), // Portuguese, Portugal
|
||||||
|
"pt-BR": require("./pt-br.json"), // Protuguese, Brazil
|
||||||
|
"ru": require("./ru.json"), // Russian
|
||||||
|
"sk": require("./sk.json"), // Slovak
|
||||||
|
"es-ES": require("./es-es.json"), // Spanish (Spain)
|
||||||
|
"sv-SE": require("./sv-se.json"), // Swedish
|
||||||
|
"tr": require("./tr.json"), // Turkish
|
||||||
|
"bg": require("./bg.json"), // Bulgarian
|
||||||
|
"uk": require("./uk.json"), // Ukrainian
|
||||||
|
"fi": require("./fi.json"), // Finnish
|
||||||
|
"no": require("./no.json"), // Norwegian
|
||||||
|
"hr": require("./hr.json"), // Croation
|
||||||
|
"ro": require("./ro.json"), // Romanian
|
||||||
|
"lt": require("./lt.json"), // Lithuanian
|
||||||
|
"th": require("./th.json"), // Thai
|
||||||
|
"vi": require("./vi.json"), // Vietnamese
|
||||||
|
"hi": require("./hi.json"), // Hindi
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
|
The following is the list of Discord's available locales as of April 15th 2021
|
||||||
|
|
||||||
|
English, US: en-US
|
||||||
|
English, UK: en-GB
|
||||||
|
Chinese Simplified:
|
||||||
|
Traditional Chinese: zh-TW
|
||||||
|
Czech: cs
|
||||||
|
Danish: da
|
||||||
|
Dutch: nl
|
||||||
|
French: fr
|
||||||
|
German: de
|
||||||
|
Greek: el
|
||||||
|
Hungarian: hu
|
||||||
|
Italian: it
|
||||||
|
Japanese: ja
|
||||||
|
Korean: ko
|
||||||
|
Polish: pl
|
||||||
|
Portuguese: pt-PT
|
||||||
|
Portuguese, Brazilian: pt-BR
|
||||||
|
Russian: ru
|
||||||
|
Slovak: sk
|
||||||
|
Spanish: es-ES
|
||||||
|
Swedish: sv-SE
|
||||||
|
Turkish: tr
|
||||||
|
Bulgarian: bg
|
||||||
|
Ukrainian: uk
|
||||||
|
Finnish: fi
|
||||||
|
Norwegian: no
|
||||||
|
Croatian: hr
|
||||||
|
Romanian: ro
|
||||||
|
Lithuanian: lt
|
||||||
|
Thai: th
|
||||||
|
Vietnamese: vi
|
||||||
|
Hindi: hi
|
||||||
|
|
||||||
|
List was retrieved using: DiscordModules.LocaleManager.getLanguages().map(l => `${l.englishName}: ${l.code}`)
|
||||||
|
|
||||||
|
This means that the above list includes locales that exist in their current system, but are not yet available to select via UI.
|
||||||
|
|
||||||
|
That list can be checked with DiscordModules.LocaleManager.getAvailableLocales()
|
||||||
|
|
||||||
|
*/
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
|
@ -6,8 +6,8 @@ import Events from "./emitter";
|
||||||
const {Dispatcher, DiscordConstants, UserSettingsStore} = DiscordModules;
|
const {Dispatcher, DiscordConstants, UserSettingsStore} = DiscordModules;
|
||||||
|
|
||||||
export default new class LocaleManager {
|
export default new class LocaleManager {
|
||||||
get discordLocale() {return UserSettingsStore.locale.split("-")[0];}
|
get discordLocale() {return UserSettingsStore.locale;}
|
||||||
get defaultLocale() {return "en";}
|
get defaultLocale() {return "en-US";}
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
this.locale = "";
|
this.locale = "";
|
||||||
|
@ -18,7 +18,7 @@ export default new class LocaleManager {
|
||||||
this.setLocale(this.discordLocale);
|
this.setLocale(this.discordLocale);
|
||||||
Dispatcher.subscribe(DiscordConstants.ActionTypes.USER_SETTINGS_UPDATE, ({settings}) => {
|
Dispatcher.subscribe(DiscordConstants.ActionTypes.USER_SETTINGS_UPDATE, ({settings}) => {
|
||||||
const newLocale = settings.locale;
|
const newLocale = settings.locale;
|
||||||
if (newLocale && newLocale != this.locale) this.setLocale(newLocale.split("-")[0]);
|
if (newLocale && newLocale != this.locale) this.setLocale(newLocale);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,11 +8,12 @@
|
||||||
--switch-color: rgb(114, 118, 125);
|
--switch-color: rgb(114, 118, 125);
|
||||||
--symbol1path: path('M5.13231 6.72963L6.7233 5.13864L14.855 13.2704L13.264 14.8614L5.13231 6.72963Z');
|
--symbol1path: path('M5.13231 6.72963L6.7233 5.13864L14.855 13.2704L13.264 14.8614L5.13231 6.72963Z');
|
||||||
--symbol2path: path('M13.2704 5.13864L14.8614 6.72963L6.72963 14.8614L5.13864 13.2704L13.2704 5.13864Z');
|
--symbol2path: path('M13.2704 5.13864L14.8614 6.72963L6.72963 14.8614L5.13864 13.2704L13.2704 5.13864Z');
|
||||||
|
|
||||||
border-radius: 14px;
|
border-radius: 14px;
|
||||||
width: 40px;
|
width: 40px;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
background-color: var(--switch-color);
|
background-color: var(--switch-color);
|
||||||
transition: 250ms cubic-bezier(0, .3, .7, 1) background-color;
|
transition: 250ms cubic-bezier(0, 0.3, 0.7, 1) background-color;
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,17 +21,17 @@
|
||||||
--switch-color: rgba(100, 137, 126);
|
--switch-color: rgba(100, 137, 126);
|
||||||
}
|
}
|
||||||
|
|
||||||
.full-motion .bd-switch input:active + .bd-switch-body {
|
|
||||||
--symbol1path: path('M6.56666 11.0013L6.56666 8.96683L13.5667 8.96683L13.5667 11.0013L6.56666 11.0013Z');
|
|
||||||
--symbol2path: path('M13.5582 8.96683L13.5582 11.0013L6.56192 11.0013L6.56192 8.96683L13.5582 8.96683Z');
|
|
||||||
}
|
|
||||||
|
|
||||||
.bd-switch input:checked + .bd-switch-body {
|
.bd-switch input:checked + .bd-switch-body {
|
||||||
--switch-color: rgb(67, 181, 129);
|
--switch-color: rgb(67, 181, 129);
|
||||||
--symbol1path: path('M7.89561 14.8538L6.30462 13.2629L14.3099 5.25755L15.9009 6.84854L7.89561 14.8538Z');
|
--symbol1path: path('M7.89561 14.8538L6.30462 13.2629L14.3099 5.25755L15.9009 6.84854L7.89561 14.8538Z');
|
||||||
--symbol2path: path('M4.08643 11.0903L5.67742 9.49929L9.4485 13.2704L7.85751 14.8614L4.08643 11.0903Z');
|
--symbol2path: path('M4.08643 11.0903L5.67742 9.49929L9.4485 13.2704L7.85751 14.8614L4.08643 11.0903Z');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.full-motion .bd-switch input:active + .bd-switch-body {
|
||||||
|
--symbol1path: path('M6.56666 11.0013L6.56666 8.96683L13.5667 8.96683L13.5667 11.0013L6.56666 11.0013Z');
|
||||||
|
--symbol2path: path('M13.5582 8.96683L13.5582 11.0013L6.56192 11.0013L6.56192 8.96683L13.5582 8.96683Z');
|
||||||
|
}
|
||||||
|
|
||||||
.bd-switch input:checked:active + .bd-switch-body {
|
.bd-switch input:checked:active + .bd-switch-body {
|
||||||
--switch-color: rgba(81, 162, 128);
|
--switch-color: rgba(81, 162, 128);
|
||||||
}
|
}
|
||||||
|
@ -42,7 +43,7 @@
|
||||||
|
|
||||||
.bd-switch .bd-switch-symbol path {
|
.bd-switch .bd-switch-symbol path {
|
||||||
fill: var(--switch-color);
|
fill: var(--switch-color);
|
||||||
transition: 250ms cubic-bezier(0, .3, .7, 1);
|
transition: 250ms cubic-bezier(0, 0.3, 0.7, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
.bd-switch .bd-switch-symbol path:first-child {
|
.bd-switch .bd-switch-symbol path:first-child {
|
||||||
|
@ -71,7 +72,7 @@
|
||||||
width: 28px;
|
width: 28px;
|
||||||
height: 18px;
|
height: 18px;
|
||||||
margin: 3px;
|
margin: 3px;
|
||||||
transition: 250ms cubic-bezier(0, .3, .7, 1);
|
transition: 250ms cubic-bezier(0, 0.3, 0.7, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
.bd-switch input:active + .bd-switch-body .bd-switch-slider {
|
.bd-switch input:active + .bd-switch-body .bd-switch-slider {
|
||||||
|
@ -87,7 +88,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.bd-switch-body .bd-switch-slider .bd-switch-handle {
|
.bd-switch-body .bd-switch-slider .bd-switch-handle {
|
||||||
transition: 250ms cubic-bezier(0, .3, .7, 1);
|
transition: 250ms cubic-bezier(0, 0.3, 0.7, 1);
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,8 +16,8 @@ export default class Switch extends React.Component {
|
||||||
render() {
|
render() {
|
||||||
const enabledClass = this.props.disabled ? " bd-switch-disabled" : "";
|
const enabledClass = this.props.disabled ? " bd-switch-disabled" : "";
|
||||||
const checkedClass = this.state.checked ? " bd-switch-checked" : "";
|
const checkedClass = this.state.checked ? " bd-switch-checked" : "";
|
||||||
return <div className={`bd-switch` + enabledClass + checkedClass} disabled={this.props.disabled} checked={this.state.checked} onChange={this.onChange}>
|
return <div className={`bd-switch` + enabledClass + checkedClass}>
|
||||||
<input id={this.props.id} type="checkbox" />
|
<input id={this.props.id} type="checkbox" disabled={this.props.disabled} checked={this.state.checked} onChange={this.onChange} />
|
||||||
<div className="bd-switch-body">
|
<div className="bd-switch-body">
|
||||||
<svg className="bd-switch-slider" viewBox="0 0 28 20" preserveAspectRatio="xMinYMid meet">
|
<svg className="bd-switch-slider" viewBox="0 0 28 20" preserveAspectRatio="xMinYMid meet">
|
||||||
<rect className="bd-switch-handle" fill="white" x="4" y="0" height="20" width="20" rx="10"></rect>
|
<rect className="bd-switch-handle" fill="white" x="4" y="0" height="20" width="20" rx="10"></rect>
|
||||||
|
|
Loading…
Reference in New Issue