All files / src/lib/utils next-i18next-utils.ts

27.27% Statements 3/11
0% Branches 0/8
0% Functions 0/2
27.27% Lines 3/11

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57                4x               4x                                                     4x                          
import { FlatNamespace } from 'i18next'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
 
import nextI18nextConfig from '../../../next-i18next.config'
 
/**
 * The default namespaces for translations.
 */
export const defaultNamespaces: Array<FlatNamespace> = ['common']
 
/**
 * Retrieves namespaces based on the provided requirements.
 * Note: The namespace from {@link defaultNamespaces} will always be added.
 * @param namespacesRequired The namespaces required.
 * @returns The retrieved namespaces.
 */
export const getNamespaces = (
  namespacesRequired:
    | Readonly<FlatNamespace>
    | ReadonlyArray<FlatNamespace>
    | undefined = undefined,
) => {
  // default with namespaces to always needed
  const namespaces: Array<FlatNamespace> = defaultNamespaces
 
  if (!namespacesRequired) {
    return namespaces
  }
 
  if (typeof namespacesRequired === 'string') {
    return [...new Set([...namespaces, namespacesRequired])]
  }
 
  namespacesRequired
  return [...new Set([...namespaces, ...namespacesRequired])]
}
 
/**
 * A wrapper function for server-side translations using next-i18next.
 * @param locale - The locale to use for translations. If not provided, the default locale specified in `nextI18nextConfig` will be used.
 * @param namespacesRequired - The namespaces required for translations. It can be a single `FlatNamespace` or an array of `FlatNamespace`. If not provided, {@link defaultNamespaces} will be used.
 * @returns {Promise<object>} - A Promise that resolves to an object containing the translations for the specified locale and namespaces.
 */
export const pageWithServerSideTranslations = async (
  locale?: string,
  namespacesRequired:
    | FlatNamespace
    | Array<FlatNamespace>
    | undefined = undefined,
) => {
  return serverSideTranslations(
    locale ?? nextI18nextConfig.i18n.defaultLocale,
    getNamespaces(namespacesRequired),
    nextI18nextConfig,
  )
}