From dc5ed986f77a893fbfa16d2c7d9d59d5bbb246e7 Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Sun, 17 Feb 2019 12:43:01 -0800 Subject: [PATCH 1/9] Update internationalization process with complete updated example. --- .../developers/internationalization.md | 170 +++++++++++++++--- 1 file changed, 141 insertions(+), 29 deletions(-) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index e8e02de2192e9..7094caf2656ed 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -1,47 +1,159 @@ # Internationalization -This document aims to give an overview of the possibilities for both internationalization and localization when developing with WordPress. +## What is Internationalization? -## PHP +Internationalization is the process to provide multiple language support to software, in this case WordPress. Internationalization is often abbreviated as **i18n**, where 18 stands for the number of letters between the first _i_ and the last _n_. -For years, WordPress has been providing the necessary tools and functions to internationalize plugins and themes. This includes helper functions like `__()` and similar. +Providing i18n support to your plugin and theme allows it to reach the largest possible audience, even without requiring you to provide the additional language translations. When you upload your software to wordpress.org, all JS and PHP files will automatically be parsed. Any detected translation strings are added to translate.wordpress.org to allow the community to translate, ensuring WordPress plugins and themes are available in as many languages as possible. -### Common Methods +For PHP, WordPress has a long established process, see [How to Internationalize Your Plugin](https://developer.wordpress.org/plugins/internationalization/how-to-internationalize-your-plugin/). The release of WordPress 5.0 brings a similar process for translation to JavaScript code. -- `__( 'Hello World', 'my-text-domain' )`: Translate a certain string. -- `_x( 'Block', 'noun', 'my-text-domain' )`: Translate a certain string with some additional context. -- `_e( 'Hello World', 'my-text-domain' )`: Translate and print a certain string. -- `esc_html__( 'Hello World', 'my-text-domain' )`: Translate a certain string and escape it for safe use in HTML output. -- `esc_html_e( 'Hello World', 'my-text-domain' )`: Translate a certain string, escape it for safe use in HTML output, and print it. -- `_n( '%s Comment', '%s Comments', $number, 'my-text-domain' )`: Translate and retrieve the singular or plural form based on the supplied number. - Usually used in combination with `sprintf()` and `number_format_i18n()`. +## How to use i18n in JavaScript -## JavaScript +WordPress 5.0 introduced the wp-i18n JavaScript package that provides the functions needed add translatable strings as you would in PHP. -Historically, `wp_localize_script()` has been used to put server-side PHP data into a properly-escaped native JavaScript object. +First, add **wp-i18n** as a dependency when registering your script: -The new editor introduces a new approach to translating strings for the editor through a new package called `@wordpress/i18n`. +```php + 'myguten-script', + ) ); +} +add_action( 'init', 'myguten_block_load' ); +``` -Depending on your developer workflow, you might want to use WP-CLI's `wp i18n make-pot` command or a build tool for Babel called `@wordpress/babel-plugin-makepot` to create the necessary translation file. The latter approach integrates with Babel to extract the I18N methods. +In your code, you can include the i18n functions. The most common function is **__** which provides translation of a simple string. Here is a basic static block example, this is in a file called `block.js`: -### Common Methods in wp.i18n (May Look Similar) +```js +const { __ } = wp.i18n; +const el = wp.element.createElement; +const { registerBlockType } = wp.blocks; -- `setLocaleData( data: Object, domain: string )`: Creates a new I18N instance providing translation data for a domain. -- `__( 'Hello World', 'my-text-domain' )`: Translate a certain string. -- `_n( '%s Comment', '%s Comments', numberOfComments, 'my-text-domain' )`: Translate and retrieve the singular or plural form based on the supplied number. -- `_x( 'Default', 'block style', 'my-text-domain' )`: Translate a certain string with some additional context. -- `sprintf()`: JavaScript port of the PHP function with the same name. +registerBlockType( 'myguten/simple', { + title: __('Simple Block', 'myguten'), + category: 'widgets', -### Loading Translations + edit: () => { + return el( + 'p', + { style: { color:'red'}, }, + __('Hello World', 'myguten') + ); + }, -WordPress 5.0 introduces a new function called `wp_set_script_translations( 'my-script-handle', 'my-text-domain' )` to load translation files for a given script handle. + save: () => { + return el( + 'p', + { style: { color:'red'}, }, + __('Hello World', 'myguten') + ); + } +}); +``` -You can learn more about it in [the JavaScript I18N dev note](https://make.wordpress.org/core/2018/11/09/new-javascript-i18n-support-in-wordpress/). +In the above example, the function will use the first argument for the string to be translated. The second argument is the text domain which must match the text domain slug specified by your plugin. -## More Resources +Common functions available, these mirror their PHP counterparts are: + +- `__( 'Hello World', 'my-text-domain' )` - Translate a certain string. +- `_n( '%s Comment', '%s Comments', numberOfComments, 'my-text-domain' )` - Translate and retrieve the singular or plural form based on the supplied number. +- `_x( 'Default', 'block style', 'my-text-domain' )` - Translate a certain string with some additional context. + +**Note:** Every string displayed to the user should be wrapped in an i18n function. + +After all strings in your code is wrapped, the final step is to tell WordPress your JavaScript contains translations, using the [wp_set_script_translations()](https://developer.wordpress.org/reference/functions/wp_set_script_translations/) function. + +```php + General and change your site language to Esperanto. This may require you add `define( 'WPLANG', 'eo' );` to your wp-config.php. + +With the language set, you can create a new block which will use the translations. -- [WP-CLI I18N command to generate translation catalogues](https://github.com/wp-cli/i18n-command) -- [Plugin Developer Handbook](https://developer.wordpress.org/plugins/internationalization/) -- [Theme Developer Handbook](https://developer.wordpress.org/themes/internationalization/) From 2a64f30d6e10edbb2a197d95aad85fda29ec270c Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Sun, 17 Feb 2019 21:00:50 -0800 Subject: [PATCH 2/9] Minor edits --- .../developers/internationalization.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index 7094caf2656ed..b752f39c402a2 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -10,7 +10,7 @@ For PHP, WordPress has a long established process, see [How to Internationalize ## How to use i18n in JavaScript -WordPress 5.0 introduced the wp-i18n JavaScript package that provides the functions needed add translatable strings as you would in PHP. +WordPress 5.0 introduced the wp-i18n JavaScript package that provides the functions needed to add translatable strings as you would in PHP. First, add **wp-i18n** as a dependency when registering your script: @@ -20,9 +20,9 @@ First, add **wp-i18n** as a dependency when registering your script: * Plugin Name: Myguten Plugin * Text Domain: myguten */ -function myguten_block() { +function myguten_block_init() { wp_register_script( - 'myguten-block-script', + 'myguten-script', plugins_url( 'block.js', __FILE__ ), array( 'wp-blocks', 'wp-element', 'wp-i18n' ) ); @@ -31,10 +31,10 @@ function myguten_block() { 'editor_script' => 'myguten-script', ) ); } -add_action( 'init', 'myguten_block_load' ); +add_action( 'init', 'myguten_block_init' ); ``` -In your code, you can include the i18n functions. The most common function is **__** which provides translation of a simple string. Here is a basic static block example, this is in a file called `block.js`: +In your code, you can include the i18n functions. The most common function is **__** (a double underscore) which provides translation of a simple string. Here is a basic static block example, this is in a file called `block.js`: ```js const { __ } = wp.i18n; @@ -81,7 +81,7 @@ After all strings in your code is wrapped, the final step is to tell WordPress y // Added in init action // Uses script handle defined in register - wp_set_script_translations( 'myguten-block-script', 'myguten' ); + wp_set_script_translations( 'myguten-script', 'myguten' ); ``` This is all you need to make your plugin JavaScript code translatable. @@ -113,13 +113,13 @@ msgstr "" The `msgid` is the string to be translated, and `msgstr` is the translated string, which in the pot file the msgstr will be empty. -You should copy this file using the language code you are going to translate, in this case Esperanto (eo): +A po file is then created from this template, which is the same format, but the translations filled in. You should copy the file using the language code you are going to translate, this example will use the Esperanto (eo) language: ``` cp myguten.pot myguten-eo.po ``` -You then go through the `.po` file and add the translation to all the `msgstr` +You then go through the `.po` file and add the translation to all the `msgstr` sets: ``` #: block.js:6 From b8727845cbbec27fec4624e67d358359f6a3db28 Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Sun, 17 Feb 2019 22:24:02 -0800 Subject: [PATCH 3/9] Update i18n package documentation Updates with links to expanded section in Gutenberg Handbook Fixes instructions to use wp-cli which is the recommended tool for creating pot files, and po2json to convert the format. --- packages/i18n/README.md | 24 +++++++++++++++++------- 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/packages/i18n/README.md b/packages/i18n/README.md index 6779e866f2453..67f89d35706d7 100644 --- a/packages/i18n/README.md +++ b/packages/i18n/README.md @@ -1,8 +1,8 @@ # Internationalization (i18n) -Internationalization utilities for client-side localization. +Internationalization utilities for client-side localization. See [How to Internationalize Your Plugin](https://developer.wordpress.org/plugins/internationalization/how-to-internationalize-your-plugin/) for server-side documentation. - +For a complete example, see the [Internationalization section of the Gutenberg Handbook](https://wordpress.org/gutenberg/handbook/designers-developers/developers/internationalization.md). ## Installation @@ -23,18 +23,28 @@ sprintf( _n( '%d hat', '%d hats', 4, 'text-domain' ), 4 ); // 4 hats ``` -Note that you will not need to specify [domain](https://codex.wordpress.org/I18n_for_WordPress_Developers#Text_Domains) for the strings. -## Build +## Build and Usage -You can use the [WordPress i18n babel plugin](/packages/babel-plugin-makepot/README.md) to generate a `.pot` file containing all your localized strings. +You can use the [wp-cli utility](https://wp-cli.org/) to generate a `.pot` file containing all your localized strings. -The package also includes a `pot-to-php` script used to generate a php files containing the messages listed in a `.pot` file. This is useful to trick WordPress.org translation strings discovery since at the moment, WordPress.org is not capable of parsing strings directly from JavaScript files. +```sh +wp i18n make-pot ./src myplugin.pot +``` + +Use the [po2json](https://github.com/mikeedwards/po2json) npm module to convert a po file to the proper Jed json format. ```sh -npx pot-to-php languages/myplugin.pot languages/myplugin-translations.php text-domain +po2json myplugin-eo.po myplugin-eo.json -f jed ``` +Use the [wp_set_script_translations](https://developer.wordpress.org/reference/functions/wp_set_script_translations/) function to load the json translation file. + +```php +wp_set_script_translations( 'myplugin-script', 'myplugin', plugin_dir_path( __FILE__ ) . 'languages' ); +``` + + ## API From e533caaded09b32e89e1ebb34ab52425551bc81a Mon Sep 17 00:00:00 2001 From: Pascal Birchler Date: Mon, 18 Feb 2019 06:30:51 -0800 Subject: [PATCH 4/9] Apply suggestions from code review Co-Authored-By: mkaz --- .../developers/internationalization.md | 12 ++++++------ packages/i18n/README.md | 2 +- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index b752f39c402a2..396e2567d16a8 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -4,7 +4,7 @@ Internationalization is the process to provide multiple language support to software, in this case WordPress. Internationalization is often abbreviated as **i18n**, where 18 stands for the number of letters between the first _i_ and the last _n_. -Providing i18n support to your plugin and theme allows it to reach the largest possible audience, even without requiring you to provide the additional language translations. When you upload your software to wordpress.org, all JS and PHP files will automatically be parsed. Any detected translation strings are added to translate.wordpress.org to allow the community to translate, ensuring WordPress plugins and themes are available in as many languages as possible. +Providing i18n support to your plugin and theme allows it to reach the largest possible audience, even without requiring you to provide the additional language translations. When you upload your software to WordPress.org, all JS and PHP files will automatically be parsed. Any detected translation strings are added to [translate.wordpress.org](https://translate.wordpress.org/) to allow the community to translate, ensuring WordPress plugins and themes are available in as many languages as possible. For PHP, WordPress has a long established process, see [How to Internationalize Your Plugin](https://developer.wordpress.org/plugins/internationalization/how-to-internationalize-your-plugin/). The release of WordPress 5.0 brings a similar process for translation to JavaScript code. @@ -86,7 +86,7 @@ After all strings in your code is wrapped, the final step is to tell WordPress y This is all you need to make your plugin JavaScript code translatable. -When you set script translations for a handle WordPress will automatically figure out if a translations file exists on translate.wordpress.org, and if so ensure that it's loaded into wp.i18n before your script runs. With translate.wordpress.org, plugin authors also do not need to worry about setting up their own infrastructure for translations and can rely on a global community with dozens of active locales. Read more about [WordPress Translations](https://make.wordpress.org/meta/handbook/documentation/translations/). +When you set script translations for a handle WordPress will automatically figure out if a translations file exists on translate.wordpress.org, and if so ensure that it's loaded into `wp.i18n` before your script runs. With translate.wordpress.org, plugin authors also do not need to worry about setting up their own infrastructure for translations and can rely on a global community with dozens of active locales. Read more about [WordPress Translations](https://make.wordpress.org/meta/handbook/documentation/translations/). ## Provide Your Own Translations @@ -97,13 +97,13 @@ You can create and ship your own translations with your plugin, if you have suff The translation files must be in the JED 1.x JSON format. To create a JED translation file, first you need to extract the strings from the text. -Using the [wp-cli tool](https://wp-cli.org/), you create a `.pot` file using the following command from within your plugin directory: +Using [WP-CLI](https://wp-cli.org/), you create a `.pot` file using the following command from within your plugin directory: ``` wp i18n make-pot ./ ``` -This will create the file `myguten.pot` a pot file is a template file to be used for translating to different languages. The pot file is made up of translation sets, for example: +This will create the file `myguten.pot` which contains all the translatable strings from your project. A single entry in this POT file might look like this: ``` #: block.js:6 @@ -111,9 +111,9 @@ msgid "Simple Block" msgstr "" ``` -The `msgid` is the string to be translated, and `msgstr` is the translated string, which in the pot file the msgstr will be empty. +Here, `msgid` is the string to be translated, and `msgstr` is the actual translation. In the POT file, `msgstr` will always be empty. -A po file is then created from this template, which is the same format, but the translations filled in. You should copy the file using the language code you are going to translate, this example will use the Esperanto (eo) language: +This POT file can then be used as the template for new translations. You should copy the file using the language code you are going to translate, this example will use the Esperanto (eo) language: ``` cp myguten.pot myguten-eo.po diff --git a/packages/i18n/README.md b/packages/i18n/README.md index 67f89d35706d7..d7a6b01819a71 100644 --- a/packages/i18n/README.md +++ b/packages/i18n/README.md @@ -26,7 +26,7 @@ sprintf( _n( '%d hat', '%d hats', 4, 'text-domain' ), 4 ); ## Build and Usage -You can use the [wp-cli utility](https://wp-cli.org/) to generate a `.pot` file containing all your localized strings. +You can use [WP-CLI](https://wp-cli.org/) to generate a `.pot` file containing all your translatable strings. ```sh wp i18n make-pot ./src myplugin.pot From 1187c707f3d09820da23b233a13ce0c8b7fd2eec Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Mon, 18 Feb 2019 06:44:16 -0800 Subject: [PATCH 5/9] Remove duplicate documentation, just link to Handbook --- packages/i18n/README.md | 23 +---------------------- 1 file changed, 1 insertion(+), 22 deletions(-) diff --git a/packages/i18n/README.md b/packages/i18n/README.md index d7a6b01819a71..833bb30358d2a 100644 --- a/packages/i18n/README.md +++ b/packages/i18n/README.md @@ -2,7 +2,6 @@ Internationalization utilities for client-side localization. See [How to Internationalize Your Plugin](https://developer.wordpress.org/plugins/internationalization/how-to-internationalize-your-plugin/) for server-side documentation. -For a complete example, see the [Internationalization section of the Gutenberg Handbook](https://wordpress.org/gutenberg/handbook/designers-developers/developers/internationalization.md). ## Installation @@ -23,27 +22,7 @@ sprintf( _n( '%d hat', '%d hats', 4, 'text-domain' ), 4 ); // 4 hats ``` - -## Build and Usage - -You can use [WP-CLI](https://wp-cli.org/) to generate a `.pot` file containing all your translatable strings. - -```sh -wp i18n make-pot ./src myplugin.pot -``` - -Use the [po2json](https://github.com/mikeedwards/po2json) npm module to convert a po file to the proper Jed json format. - -```sh -po2json myplugin-eo.po myplugin-eo.json -f jed -``` - -Use the [wp_set_script_translations](https://developer.wordpress.org/reference/functions/wp_set_script_translations/) function to load the json translation file. - -```php -wp_set_script_translations( 'myplugin-script', 'myplugin', plugin_dir_path( __FILE__ ) . 'languages' ); -``` - +For a complete example, see the [Internationalization section of the Gutenberg Handbook](https://wordpress.org/gutenberg/handbook/designers-developers/developers/internationalization/). ## API From b079181b3b814710e2ac2a9daad057a1b14f3027 Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Mon, 18 Feb 2019 07:09:11 -0800 Subject: [PATCH 6/9] Batch of changes from reviews props @swisspiddy --- .../developers/internationalization.md | 36 +++++++++---------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index 396e2567d16a8..926a56a80fd07 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -77,11 +77,10 @@ After all strings in your code is wrapped, the final step is to tell WordPress y ```php General and change your site language to Esperanto. This may require you add `define( 'WPLANG', 'eo' );` to your wp-config.php. +You will need to set your WordPress installation to Esperanto language. Go to Settings > General and change your site language to Esperanto. -With the language set, you can create a new block which will use the translations. +With the language set, create a new post, add the block, and you will see the translations used. From eb217e5391175c0d62d86dab3d6ce09281245fa0 Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Thu, 7 Mar 2019 06:48:26 -0800 Subject: [PATCH 7/9] :shakes-fist-at-whitespace: --- packages/i18n/README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/packages/i18n/README.md b/packages/i18n/README.md index 833bb30358d2a..373ba5849db73 100644 --- a/packages/i18n/README.md +++ b/packages/i18n/README.md @@ -2,7 +2,6 @@ Internationalization utilities for client-side localization. See [How to Internationalize Your Plugin](https://developer.wordpress.org/plugins/internationalization/how-to-internationalize-your-plugin/) for server-side documentation. - ## Installation Install the module: From 47abdbfbe346746594890aa3e27906ffb49ed1e1 Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Fri, 8 Mar 2019 12:02:26 -0800 Subject: [PATCH 8/9] Updates to include full .pot and .po files per @nosolosw review --- .../developers/internationalization.md | 57 +++++++++++++++++-- 1 file changed, 53 insertions(+), 4 deletions(-) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index 926a56a80fd07..b9b998558c39e 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -102,17 +102,40 @@ mkdir languages wp i18n make-pot ./ languages/myguten.pot ``` -This will create the file `myguten.pot` which contains all the translatable strings from your project. A single entry in this POT file might look like this: +This will create the file `myguten.pot` which contains all the translatable strings from your project. ``` +msgid "" +msgstr "" +"Project-Id-Version: Scratch Plugin\n" +"Report-Msgid-Bugs-To: https://wordpress.org/support/plugin/scratch\n" +"Last-Translator: FULL NAME \n" +"Language-Team: LANGUAGE \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"POT-Creation-Date: 2019-03-08T11:26:56-08:00\n" +"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" +"X-Generator: WP-CLI 2.1.0\n" +"X-Domain: myguten\n" + +#. Plugin Name of the plugin +msgid "Scratch Plugin" +msgstr "" + #: block.js:6 msgid "Simple Block" msgstr "" + +#: block.js:13 +#: block.js:21 +msgid "Hello World" +msgstr "" ``` Here, `msgid` is the string to be translated, and `msgstr` is the actual translation. In the POT file, `msgstr` will always be empty. -This POT file can then be used as the template for new translations. You should copy the file using the language code you are going to translate, this example will use the Esperanto (eo) language: +This POT file can then be used as the template for new translations. You should **copy the file** using the language code you are going to translate, this example will use the Esperanto (eo) language: ``` cp myguten.pot myguten-eo.po @@ -120,14 +143,40 @@ cp myguten.pot myguten-eo.po For this simple example, you can simply edit the `.po` file in your editor and add the translation to all the `msgstr` sets. For a larger, more complex set of translation, the [Glotpress](https://glotpress.blog/) and [poedit](https://poedit.net/) tools exist to help. +You need also to add the `Language: eo` parameter. Here is full `myguten-eo.po` translated file + ``` +# Copyright (C) 2019 +# This file is distributed under the same license as the Scratch Plugin plugin. +msgid "" +msgstr "" +"Project-Id-Version: Scratch Plugin\n" +"Report-Msgid-Bugs-To: https://wordpress.org/support/plugin/scratch\n" +"Last-Translator: Marcus Kazmierczak \n" +"Language-Team: Esperanto \n" +"Language: eo\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"POT-Creation-Date: 2019-02-18T07:20:46-08:00\n" +"PO-Revision-Date: 2019-02-18 08:16-0800\n" +"X-Generator: Poedit 2.2.1\n" +"X-Domain: myguten\n" + +#. Plugin Name of the plugin +msgid "Scratch Plugin" +msgstr "Scratch kromprogrameto" + #: block.js:6 msgid "Simple Block" msgstr "Simpla bloko" -``` +#: block.js:13 block.js:21 +msgid "Hello World" +msgstr "Saltuon mundo" +``` -The last step to create the translation file is to convert the `myguten-eo.po` to the JSON format needed. For this, you use the [po2json utility](https://github.com/mikeedwards/po2json) which you can install using npm. It might be easiest to install globally using: `npm install -g po2json`. Once installed, use the following command to convert to JED format: +The last step to create the translation file is to convert the `myguten-eo.po` to the JSON format needed. For this, you can use the [po2json utility](https://github.com/mikeedwards/po2json) which you install using npm. It might be easiest to install globally using: `npm install -g po2json`. Once installed, use the following command to convert to JED format: ``` po2json myguten-eo.po myguten-eo.json -f jed From 8b7020fd3c51b97af5e1bd01dad296edebc7106c Mon Sep 17 00:00:00 2001 From: Marcus Kazmierczak Date: Fri, 8 Mar 2019 12:13:23 -0800 Subject: [PATCH 9/9] Add JSON translation example --- .../developers/internationalization.md | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/docs/designers-developers/developers/internationalization.md b/docs/designers-developers/developers/internationalization.md index b9b998558c39e..190eb3023a7ee 100644 --- a/docs/designers-developers/developers/internationalization.md +++ b/docs/designers-developers/developers/internationalization.md @@ -182,6 +182,32 @@ The last step to create the translation file is to convert the `myguten-eo.po` t po2json myguten-eo.po myguten-eo.json -f jed ``` +This will generate the JSON file `myguten-eo.json` which looks like: + +```json +{ + "domain": "messages", + "locale_data": { + "messages": { + "": { + "domain": "messages", + "lang": "eo" + }, + "Scratch Plugin": [ + "Scratch kromprogrameto" + ], + "Simple Block": [ + "Simpla bloko" + ], + "Hello World": [ + "Saltuon mundo" + ] + } + } +} +``` + + ### Load Translation File The final part is to tell WordPress where it can look to find the translation file. The `wp_set_script_translations` function accepts an optional third argument that is the path it will first check for translations. For example: