Use deepmerge function from existing dependency

This commit is contained in:
Peter Smit
2025-09-04 19:11:26 +02:00
parent e3f70d0635
commit 6ea6cfac3e

View File

@@ -1,19 +1,7 @@
import deepmerge from 'deepmerge'
import { getRequestConfig } from 'next-intl/server'
import { getUserLocale } from './lib/locale'
function mergeDeep<T>(target: T, source: Partial<T>): T {
for (const key in source) {
const value = (source as any)[key]
if (value && typeof value === 'object' && !Array.isArray(value)) {
;(target as any)[key] = mergeDeep((target as any)[key] || {}, value)
} else {
;(target as any)[key] = value
}
}
return target
}
export const localeLabels = {
'en-US': 'English',
fi: 'Suomi',
@@ -44,15 +32,20 @@ export const defaultLocale: Locale = 'en-US'
export default getRequestConfig(async () => {
const locale = await getUserLocale()
const defaultMessages = (await import('../messages/en-US.json')).default
const localeMessages = (await import(`../messages/${locale}.json`)).default
const messages = mergeDeep(structuredClone(defaultMessages), localeMessages)
let messages: any
if (locale === defaultLocale) {
messages = localeMessages
} else {
messages = deepmerge(
(await import(`../messages/${defaultLocale}.json`)).default,
localeMessages,
) as any
}
return {
locale,
locale,
messages,
}
})