supastarter includes next-i18next to translate your web app. To learn more you can visit next-i18next github and the i18next documentation.


The translations of you app are stored in /public/locales/{lang}/{ns}.json.

{lang} is the language code and {ns} is the namespace. This structure enables you to split your translations into multiple files and only load the necessary files for each page.

Add a new language

To add new languages there are a few steps to do so:

  1. Add the new language code (e.g. fr) to the locales array in next-i18next.config.js
  2. In the config/i18n.ts add the name of the new language (e.g. French) to the localeNames object
  3. Add a folder with the language code to the /public/locales/ (e.g. /public/locales/fr).
  4. Copy all the translation files from the /public/locales/en folder to the new language folder

Now you can start translating your app in these files.

For an easier translation flow you can use tools like Localazy or SimpleLocalize. We will add integration guides for tools like those later.

Translating with i18n-ally

Creating the translations for your components right within your editor is easy and fast using the i18n-ally extension for VSCode. When you created a new translatable string in your component like t('hero.title') you can simple focus and hover that string with your cursor and the extension will show you the translations as well as action buttons to add/edit a translation:

i18n-ally VSCode Plugini18n-ally VSCode Plugin

When you click the edit button you will be promted with an input to enter the translation. After you hit enter, you have to select in which namespace file you want to save this translation and the extension will do the rest.

To see the translation in your app, make sure the namespace file is added in the getStaticProps function of the page that uses the component:



Get your SaaS started in minutes

Save time and focus on your business with supastarter, the scalable and production-ready starter kit for your SaaS.

Get started →

© 2022 supastarter. All rights reserved.


  • Demo
  • Pricing
  • FAQ
  • Documentation
  • Changelog
  • Roadmap
  • Starter templates