Skip to content

Commit

Permalink
perf(web/IntlProvider): faster messages mapping
Browse files Browse the repository at this point in the history
  • Loading branch information
enisdenjo committed Nov 12, 2021
1 parent 05dd55d commit 9ace4f5
Showing 1 changed file with 35 additions and 19 deletions.
54 changes: 35 additions & 19 deletions web/src/lib/intl/IntlProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,25 +24,41 @@ export const IntlProvider: React.FC<IntlProviderProps> = ({
}) => {
const [locale, setLocale] = useState<Locale>(() => retrieveLocale() || defaultLocale);

const mappedMessages = useMemo(
() => ({
en: Object.keys(messages).reduce((acc, curr) => ({ ...acc, [curr]: messages[curr].en }), {}),
hr: Object.keys(messages).reduce((acc, curr) => {
const baMessage = messages[curr].hr;
if (!baMessage && locale === 'hr') {
// eslint-disable-next-line no-console
console.warn(
`intl: key "${curr}" does not have a "hr" message, using "en" message sa fallback`,
);
}
return {
...acc,
[curr]: baMessage ? baMessage : messages[curr].en,
};
}, {}),
}),
[messages, locale],
);
const mappedMessages = useMemo(() => {
const en: Record<string, string> = {};
for (const [key, value] of Object.entries(messages)) {
if (__DEV__ && !value.en) {
// eslint-disable-next-line no-console
console.warn(`intl: key "${key}" does not have an "en" message`);
}
if (__DEV__ && key in en) {
// eslint-disable-next-line no-console
console.warn(
`intl: key "${key}" already has an "en" message, replacing "${en[key]}" with "${value.en}"`,
);
}
en[key] = value.en;
}

const hr: Record<string, string> = {};
for (const [key, value] of Object.entries(messages)) {
if (__DEV__ && !value.hr) {
// eslint-disable-next-line no-console
console.warn(
`intl: key "${key}" does not have a "hr" message, using "en" message sa fallback`,
);
}
if (__DEV__ && key in hr) {
// eslint-disable-next-line no-console
console.warn(
`intl: key "${key}" already has a "hr" message, replacing "${hr[key]}" with "${value.hr}"`,
);
}
hr[key] = value.hr || messages[key].en;
}

return { en, hr };
}, []);

const localeContextValue = useMemo<LocaleContextValue>(
() => ({
Expand Down

0 comments on commit 9ace4f5

Please sign in to comment.