React Translations API
@resourge/react-translations provides React-specific utilities built on top of the core @resourge/translations library to facilitate translation integration in React apps.
SetupReactTranslations(config)
Section titled “SetupReactTranslations(config)”Creates and initializes the translation setup for React applications.
Parameters:
- config(- SetupTranslationsConfig): Configuration object including languages, default language, plugins, translations or loading strategies.
Returns:
An object containing:
- TranslationInstance: The initialized translation instance (core library instance).
- useTranslation: React hook to access translations and language controls.
useTranslation()
Section titled “useTranslation()”React hook to access translation state and functions within components wrapped by TranslationProvider.
Returns:
Section titled “Returns:”- T(- Record<string, any>): Translations object for the current language.
- changeLanguage(lang: string): Promise<void>: Function to change the current language dynamically.
- languages(- string[]): Array of available language codes.
- language(- string): Current active language code.
- addEventListener(event: 'languageChange' | 'missingRequestKeys', callback: Function): () => void: Adds an event listener; returns a function to remove the listener.
TranslationProvider
Section titled “TranslationProvider”React context provider component that supplies the translation instance to descendant components.
Props:
Section titled “Props:”- TranslationInstance: The translation instance returned by- SetupReactTranslations.
- children: React nodes to be wrapped by the provider.
- components(optional): Custom components map to be used within translations.
Trans Component
Section titled “Trans Component”Component for rendering translated strings that contain embedded HTML-like tags, replaced by React components.
Props:
Section titled “Props:”- message(- string): The translated string with embedded tags.
- components(- ReactElement[] | Record<string, ReactElement>, optional): Mapping of tag names to React elements to replace tags in the message.
Behavior:
Section titled “Behavior:”- Parses the messageprop as HTML-like content.
- Replaces recognized tags with corresponding React components from componentsprop or provider.
- Unrecognized tags render as <missing-translation-tag>with the tag name.
Example Usage
Section titled “Example Usage”import React from 'react';import { SetupReactTranslations, TranslationProvider, useTranslation, Trans } from '@resourge/react-translations';
const { TranslationInstance, useTranslation } = SetupReactTranslations({  langs: ['en', 'fr'],  defaultLanguage: 'en',  translations: {    greeting: {      en: 'Hello, <strong>{name}</strong>!',      fr: 'Bonjour, <strong>{name}</strong>!',    }  }});
function Greeting({ name }: { name: string }) {  const { T } = useTranslation();  return <Trans message={T.greeting} components={{ strong: <strong /> }} />;}
function App() {  return (    <TranslationProvider TranslationInstance={TranslationInstance}>      <Greeting name="Alice" />    </TranslationProvider>  );}
export default App;Additional Notes
Section titled “Additional Notes”- @resourge/react-translationsdepends on the core- @resourge/translationsfor the translation engine.
- Supports dynamic language switching and event subscriptions.
- Provides React-friendly components and hooks for seamless integration.