Skip to content

Specify your translation key by typed object instead of a string

License

Notifications You must be signed in to change notification settings

WojciechCendrzak/i18n-keys

Repository files navigation

Build Status Coverage Status npm version npm bundle size

i18n-keys

This library will help to access the translation field from JSON / TypeScript file and take advantage of TypeScript.

It is useful when the localization file grows. Works fine with i18n, i18next.

The idea is simple, handy, and quite helpful:

Instead of accessing field by a string path like this:

i18next.t('homePage.header.buttons.signIn.title');

you can access translation key in that way:

i18next.t(translationKeys.homePage.header.buttons.signIn.title);

The only thing you need to do is to initialize translationKeys object like:

import en from './en.json'; // or `./en.ts`
import i18next from 'i18n-js';

i18next.init({
  lng: 'en',
  resources: {
    en: {
      translation: en,
    },
  },
});

const translationKeys = getTranslationKeys(en);

You can enjoy the benefits of TypeScript as well as IntelliSense of your IDE and lint.

Then you can use like this:

const text = i18next.t(translationKeys.homePage.header.buttons.signIn.title);

Check the example folder!

About

Specify your translation key by typed object instead of a string

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published