summaryrefslogtreecommitdiff
path: root/packages/frontend/src
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-01-22 17:11:00 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-01-22 17:11:00 +0900
commit945129c371d313b51cfd0d885e9e96018b1785bb (patch)
treee2e286ae83701c609ea2e0e2078fd20b1981bf87 /packages/frontend/src
parentMerge branch 'develop' (diff)
parent13.1.4 (diff)
downloadmisskey-945129c371d313b51cfd0d885e9e96018b1785bb.tar.gz
misskey-945129c371d313b51cfd0d885e9e96018b1785bb.tar.bz2
misskey-945129c371d313b51cfd0d885e9e96018b1785bb.zip
Merge branch 'develop'
Diffstat (limited to 'packages/frontend/src')
-rw-r--r--packages/frontend/src/config.ts6
-rw-r--r--packages/frontend/src/i18n.ts4
-rw-r--r--packages/frontend/src/init.ts11
-rw-r--r--packages/frontend/src/scripts/achievements.ts6
4 files changed, 22 insertions, 5 deletions
diff --git a/packages/frontend/src/config.ts b/packages/frontend/src/config.ts
index 4b084d365b..073b21a0ae 100644
--- a/packages/frontend/src/config.ts
+++ b/packages/frontend/src/config.ts
@@ -10,8 +10,12 @@ export const apiUrl = url + '/api';
export const wsUrl = url.replace('http://', 'ws://').replace('https://', 'wss://') + '/streaming';
export const lang = miLocalStorage.getItem('lang');
export const langs = _LANGS_;
-export const locale = JSON.parse(miLocalStorage.getItem('locale'));
+export let locale = JSON.parse(miLocalStorage.getItem('locale'));
export const version = _VERSION_;
export const instanceName = siteName === 'Misskey' ? host : siteName;
export const ui = miLocalStorage.getItem('ui');
export const debug = miLocalStorage.getItem('debug') === 'true';
+
+export function updateLocale(newLocale) {
+ locale = newLocale;
+}
diff --git a/packages/frontend/src/i18n.ts b/packages/frontend/src/i18n.ts
index 31e066960d..220c6210c0 100644
--- a/packages/frontend/src/i18n.ts
+++ b/packages/frontend/src/i18n.ts
@@ -3,3 +3,7 @@ import { locale } from '@/config';
import { I18n } from '@/scripts/i18n';
export const i18n = markRaw(new I18n(locale));
+
+export function updateI18n(newLocale) {
+ i18n.ts = newLocale;
+}
diff --git a/packages/frontend/src/init.ts b/packages/frontend/src/init.ts
index 079003ee83..36897545e2 100644
--- a/packages/frontend/src/init.ts
+++ b/packages/frontend/src/init.ts
@@ -25,10 +25,10 @@ import JSON5 from 'json5';
import widgets from '@/widgets';
import directives from '@/directives';
import components from '@/components';
-import { version, ui, lang, host } from '@/config';
+import { version, ui, lang, host, updateLocale } from '@/config';
import { applyTheme } from '@/scripts/theme';
import { isDeviceDarkmode } from '@/scripts/is-device-darkmode';
-import { i18n } from '@/i18n';
+import { i18n, updateI18n } from '@/i18n';
import { confirm, alert, post, popup, toast } from '@/os';
import { stream } from '@/stream';
import * as sound from '@/scripts/sound';
@@ -87,9 +87,12 @@ import { fetchCustomEmojis } from './custom-emojis';
if (localeOutdated) {
const res = await window.fetch(`/assets/locales/${lang}.${version}.json`);
if (res.status === 200) {
- miLocalStorage.setItem('locale', await res.text());
+ const newLocale = await res.text();
+ const parsedNewLocale = JSON.parse(newLocale);
+ miLocalStorage.setItem('locale', newLocale);
miLocalStorage.setItem('localeVersion', version);
- location.reload();
+ updateLocale(parsedNewLocale);
+ updateI18n(parsedNewLocale);
}
}
//#endregion
diff --git a/packages/frontend/src/scripts/achievements.ts b/packages/frontend/src/scripts/achievements.ts
index c97358e880..f511fce3ea 100644
--- a/packages/frontend/src/scripts/achievements.ts
+++ b/packages/frontend/src/scripts/achievements.ts
@@ -40,6 +40,7 @@ export const ACHIEVEMENT_TYPES = [
'loggedInOnNewYearsDay',
'noteClipped1',
'noteFavorited1',
+ 'myNoteFavorited1',
'profileFilled',
'markedAsCat',
'following1',
@@ -240,6 +241,11 @@ export const ACHIEVEMENT_BADGES = {
bg: null,
frame: 'bronze',
},
+ 'myNoteFavorited1': {
+ img: '/fluent-emoji/1f320.png',
+ bg: null,
+ frame: 'silver',
+ },
'profileFilled': {
img: '/fluent-emoji/1f44c.png',
bg: 'linear-gradient(0deg, rgb(187 183 59), rgb(255 143 77))',