Merge branch 'i18n-dynamic' into 'develop'

Fix locale dynamic imports

See merge request soapbox-pub/soapbox!2674
This commit is contained in:
Alex Gleason 2023-09-14 03:22:47 +00:00
commit 005d8fa246
5 changed files with 19 additions and 15 deletions

View file

@ -4,7 +4,7 @@ import { createSelector } from 'reselect';
import { v4 as uuid } from 'uuid'; import { v4 as uuid } from 'uuid';
import { patchMe } from 'soapbox/actions/me'; import { patchMe } from 'soapbox/actions/me';
import messages from 'soapbox/locales/messages'; import messages from 'soapbox/messages';
import toast from 'soapbox/toast'; import toast from 'soapbox/toast';
import { isLoggedIn } from 'soapbox/utils/auth'; import { isLoggedIn } from 'soapbox/utils/auth';

View file

@ -2,7 +2,7 @@ import { getLocale, getSettings } from 'soapbox/actions/settings';
import { importEntities } from 'soapbox/entity-store/actions'; import { importEntities } from 'soapbox/entity-store/actions';
import { Entities } from 'soapbox/entity-store/entities'; import { Entities } from 'soapbox/entity-store/entities';
import { selectEntity } from 'soapbox/entity-store/selectors'; import { selectEntity } from 'soapbox/entity-store/selectors';
import messages from 'soapbox/locales/messages'; import messages from 'soapbox/messages';
import { ChatKeys, IChat, isLastMessage } from 'soapbox/queries/chats'; import { ChatKeys, IChat, isLastMessage } from 'soapbox/queries/chats';
import { queryClient } from 'soapbox/queries/client'; import { queryClient } from 'soapbox/queries/client';
import { getUnreadChatsCount, updateChatListItem, updateChatMessage } from 'soapbox/utils/chats'; import { getUnreadChatsCount, updateChatListItem, updateChatMessage } from 'soapbox/utils/chats';

View file

@ -42,7 +42,7 @@ import {
useInstance, useInstance,
useRegistrationStatus, useRegistrationStatus,
} from 'soapbox/hooks'; } from 'soapbox/hooks';
import MESSAGES from 'soapbox/locales/messages'; import MESSAGES from 'soapbox/messages';
import { normalizeSoapboxConfig } from 'soapbox/normalizers'; import { normalizeSoapboxConfig } from 'soapbox/normalizers';
import { queryClient } from 'soapbox/queries/client'; import { queryClient } from 'soapbox/queries/client';
import { useCachedLocationHandler } from 'soapbox/utils/redirect'; import { useCachedLocationHandler } from 'soapbox/utils/redirect';

View file

@ -2,28 +2,32 @@ type MessageJson = Record<string, string>;
type MessageModule = { default: MessageJson }; type MessageModule = { default: MessageJson };
/** Import custom messages */ /** Import custom messages */
const importCustom = (locale: string): Promise<MessageModule> => { const importCustom = async (locale: string): Promise<MessageModule> => {
return import(/* webpackChunkName: "locale_[request]" */`custom/locales/${locale}.json`) try {
.catch(() => ({ default: {} })); return await import(`../../custom/locales/${locale}.json`);
} catch {
return ({ default: {} });
}
}; };
/** Import git-checked messages */ /** Import git-checked messages */
const importMessages = (locale: string): Promise<MessageModule> => { const importMessages = (locale: string): Promise<MessageModule> => {
return import(/* webpackChunkName: "locale_[request]" */`./${locale}.json`); return import(`./locales/${locale}.json`);
}; };
/** Override custom messages */ /** Override custom messages */
const importMessagesWithCustom = (locale: string): Promise<MessageJson> => { const importMessagesWithCustom = async (locale: string): Promise<MessageJson> => {
return Promise.all([ try {
importMessages(locale), const messages = await Promise.all([
importCustom(locale), importMessages(locale),
]).then(messages => { importCustom(locale),
]);
const [native, custom] = messages; const [native, custom] = messages;
return Object.assign(native.default, custom.default); return Object.assign(native.default, custom.default);
}).catch(error => { } catch (error) {
console.error(error); console.error(error);
throw error; throw error;
}); }
}; };
const locales = [ const locales = [

View file

@ -1,6 +1,6 @@
import { z } from 'zod'; import { z } from 'zod';
import { locales } from 'soapbox/locales/messages'; import { locales } from 'soapbox/messages';
const skinToneSchema = z.union([ const skinToneSchema = z.union([
z.literal(1), z.literal(2), z.literal(3), z.literal(4), z.literal(5), z.literal(6), z.literal(1), z.literal(2), z.literal(3), z.literal(4), z.literal(5), z.literal(6),