i18n: The Type-Safe Approach
Estimated reading time: 4 minutes

19/07/2024
Internationalization (i18n) is a crucial aspect of modern web development. This article explores how to implement a type-safe i18n solution using the typed-locale library in a React application.
Introduction to typed-locale
typed-locale is a lightweight, type-safe internationalization library designed to work with TypeScript. It provides an API for managing translations with type safety for both keys and variables.
Setting Up the Project
Let's create a new React project using Vite with TypeScript:
Now, install typed-locale:
Defining Translations
Create a new file called translations.ts in the src folder:
Creating the Translator
Now, let's create a custom hook to use our translations. Create a new file called useTranslator.ts:
Using the Translator in Components
Now, let's use our translator in a React component. Update your App.tsx:
Type Safety Features
typed-locale provides several type safety features:
- 
Autocomplete for translation keys: The IDE provides autocomplete suggestions for all available translation keys. 
- 
Type checking for variables: TypeScript catches incorrect variable usage: // This will cause a TypeScript error translator((t) => t.greeting, { wrongVariable: "World" });
- 
Nested translations: The type system understands nested translations, allowing translator(t => t.nav.home).
- 
Pluralization: The itemCounttranslation demonstrates how typed-locale handles pluralization, automatically selecting the correct plural form based on thecountvalue.
Technical Advantages
The type-safe approach using typed-locale offers several technical advantages:
- 
Compile-time error detection: Translation-related errors are caught during compilation rather than at runtime. 
- 
Improved developer experience: Autocomplete for translation keys enhances productivity. 
- 
Refactoring support: TypeScript's refactoring tools work seamlessly with the translation keys. 
- 
Prevents key typos: The callback approach eliminates string typos in translation keys. 
- 
Small bundle size: At 1kB, typed-locale has minimal impact on application size. 
- 
Framework agnostic: While this example uses React, typed-locale can be used with any JavaScript framework or vanilla JS. 
Conclusion
Implementing i18n with a type-safe approach using typed-locale provides a robust solution for managing translations in TypeScript projects. By leveraging the type system, developers can create more reliable internationalized applications while maintaining code quality and productivity.