- 
                Notifications
    You must be signed in to change notification settings 
- Fork 387
FAQ
Your locales directory can be structured like this with zero-configuration
  locales         # i18n, langs, locale are also acceptable
  βββ en.json
  βββ de-DE.json
  βββ zh-CN.yml   # YAML
  βββ zh-TW.ts    # You can mix different formats
  βββ ...
  βββ <country-code>.json
or
  locales
  βββ en
  |   βββ common.json
  |   βββ buttons.json
  |   βββ ...
  |   βββ <filenames>.json
  βββ de-DE
  |   βββ common.json
  |   βββ buttons.json
  |   βββ ...
  βββ <country-code>
      βββ common.json
      βββ buttons.json
      βββ ...
For more complex structures, please check out Path Matcher.
To get the best experience from this extension (and other translation services as well), We recommend you use the following setup:
- Use JSONorYAMLas your locale files. (Although other formats are supported as well, JSON and YAML works best for statistical analysis)
- The following configuration allows you to stay synced through all the locales.
This extension support numerous frameworks. Be sure the framework you are using is on the list.
Also, package.json is relied on to detect which framework you are using. It should be at the root of your project as well.
- 
Locales path config missing. localespath will be detected automatically the first time you open a project. If nothing shows up, you may need to configure it manually. There are two ways to do that:- Open Command Palette (Ctrl-Shift-Porββ§P), typei18n Ally: Manual configure locales paththen press enter and follow the guide.
- Go to the settings of VSCode and set i18n-ally.localesPathsmanually.
 
- Open Command Palette (
- 
The source / displaying locale. The default locale is set to English(en). If you don't have English in your supporting locales, you may need to config it through commandi18n Ally: Change source language
- Check your Directory structure
Usually, i18n ally looks for your package.json file at the root of your project. If you don't have it at the root, you can always specify the framework(s) you are using by i18n-ally.enabledFrameworks config.
Due to the discussion in #313, flags should not be used to represent languages. From v2.2.4, we changed the algorithm of match flags, language codes (the first two-letter locales in BCP-47) will no longer be used as a factor to match flags.
We would suggest you use a more specific en-US form instead of the en for example. But if you would like to set flags for two-letter locales anyway, you can use the config:
"i18n-ally.localeCountryMap": {
  "en": "br", // show UK's flag instead of US's
  "zh": "cn", // show Chinese flag for 'zh'
  "ko": "ko", // show Korean flag for 'ko'
}In some cases, you may use modules, monorepo or other philosophies to organize your locale files.
For example, you have the following directory structure need to be config.
  packages
  βββ pkgA
  |   βββ i18n
  |       βββ en.messages.json
  |       βββ zh-CN.messages.json
  |       βββ ...
  βββ pkgB
  |   βββ i18n
  |       βββ en.messages.json
  |       βββ zh-CN.messages.json
  |       βββ ...
  βββ ...
The following config would make it work,
{
  "i18n-ally.localesPaths": [
    "packages/**/**/i18n"
  ],
  "i18n-ally.pathMatcher": "{locale}.messages.json",
}Learn more about
pathMatcher
Lokalise is the fastest growing language cloud technology made by developers, for developers.
As a collaborative productivity platform, it helps structure and automate the translation and localization process for any company in the world.
Learn more
πβπ¨ Review & Collaborate
πͺ¨ Hard-coded Strings Extraction
βοΈ Configurations
π Migration
{ "i18n-ally.sortKeys": true, "i18n-ally.keepFulfilled": true, }