Locale files are JSON files that contain a set of translations for text strings used throughout the theme and theme editor. In addition to giving merchants a single place to easily edit words and phrases that are repeated throughout the theme, locale files allow you translate storefront content, and theme editor settings, to multiple langages for international merchants and customers. ## Location Locale files are located in the `locales` directory of the theme: ```text └── theme ... └── locales ``` ## Subtypes There are two types of locale files: | Type | Description | | --- | --- | | [Storefront](/docs/storefronts/themes/architecture/locales/storefront-locale-files) | Storefront locale files have a `.json` file extension, and control translations for storefront content. These translations can be edited by merchants through the [Shopify Language Editor](https://help.shopify.com/manual/online-store/themes/customizing-themes/language/change-wording#overview-of-the-language-editor). | | [Schema](/docs/storefronts/themes/architecture/locales/schema-locale-files) | Schema locale files have a `.schema.json` file extension, and control translations for theme editor settings. | ## Schema Locale files need to follow a specific [naming structure](#name-locale-files). They also follow a basic organizational structure: - **Category**: The top-level category of your translations. - **Group**: The second level grouping of translations within a category. - **Description**: The third level, which represents the individual translations. <p> <div class="react-code-block" data-preset="file"> <div class="react-code-block-preload ThemeMode-dim"> <div class="react-code-block-preload-bar "></div> <div class="react-code-block-preload-placeholder-container"> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> </div> </div> <script data-option="filename" data-value="Example"></script> <script type="text/plain" data-language="json"> RAW_MD_CONTENT{ "my_category": { "my_group": { "my_description": "translation text", ... }, ... }, ... } END_RAW_MD_CONTENT</script> </div> </p> > Tip: > When naming translation descriptions, try to be descriptive enough to give the translation context. For example, `blogs.article_comment.submit_button_text` gives more context than `blogs.article_comment.submit`. ### Name locale files Locale file naming must follow the standard [IETF language tag nomenclature](https://en.wikipedia.org/wiki/IETF_language_tag), where the first lowercase letter code represents the language, and the second uppercase letter code represents the region. For example: | Language | Storefront | Schema | | --- | --- | --- | | English - Great Britain | `en-GB.json` | `en-GB.schema.json` | | Spanish - Spain | `es-ES.json` | `es-ES.schema.json` | | French - Canada | `fr-CA.json` | `fr-CA.schema.json` | If a language isn’t region specific, you can use the 2-letter lowercase language representation. For example: | Language | Storefront | Schema | | --- | --- | --- | | Finnish - All regions | `fi.json` | `fi.schema.json` | Additionally, you must designate a [default locale file](#the-default-locale-file) for each type. #### The default locale file You must designate a default locale file in the format of `*.default.json`, where `*` is your selected language. This file contains the translations for the default language of the theme. Only one default file is permitted. Most themes use `en.default.json`, which sets the default locale of the theme to English. > Tip: > This also applies to schema locale files with an extension of `.schema.json`. ## Requirements and limitations - A maximum of 3400 translations are allowed in a single locale file - Translation values cannot exceed 1000 characters ## Usage When working with locale files, you should familiarize yourself with referencing locale files. The code for referencing locale files varies depending on whether you're referencing a [storefront locale file](/docs/storefronts/themes/architecture/locales/storefront-locale-files) or a [schema locale file](/docs/storefronts/themes/architecture/locales/schema-locale-files#reference-schema-translations).