[wp-meta] [Making WordPress.org] #3875: Javascript Language Files (was: Javascript Language Packs)
Making WordPress.org
noreply at wordpress.org
Thu Oct 18 15:31:07 UTC 2018
#3875: Javascript Language Files
--------------------------------------+-------------------------
Reporter: herregroen | Owner: herregroen
Type: enhancement | Status: assigned
Priority: normal | Milestone:
Component: Translate Site & Plugins | Resolution:
Keywords: |
--------------------------------------+-------------------------
Description changed by herregroen:
Old description:
> Javascript is starting to become increasingly important in core, plugin
> and theme development. Especially in light of the upcoming 5.0 release
> that will include Gutenberg.
>
> When it comes to translations present in PHP we've got a great setup,
> however this currently can't be leveraged for translations in JS without
> some workarounds ( such as generating a PHP file containing all
> translatable strings from JS ).
>
> These workarounds also make it difficult to selectively load only the
> required translations in JavaScript.
>
> Ideally no workarounds would be needed, developers can use `wp.i18n.__`
> in JavaScript just as they would use `__` in PHP with no additional steps
> required. In addition to that end users would only have to load the
> translations they need rather than all translations.
>
> In order to make this happen several steps would have to be taken:
> 1. wordpress.org would need to also parse JS files when generating POT
> files. I believe #3748 is the best way to allow this. A possible
> alternative here would be to use
> [[https://github.com/WordPress/gutenberg/tree/master/packages/babel-
> plugin-makepot|@wordpress/babel-plugin-makepot]] but this would likely
> require more effect to setup on wordpress.org.
> **Action required: resolve #3748.**
> 2. wordpress.org would need to split translations into multiple files
> when building language packs. The simplest way to achieve this would be
> to change the `wporg-gp-customizations` plugin to generate multiple PO
> and MO files. One pair for all translation entries ( possibly only those
> occurring only in PHP files ) and one pair per JS file, each containing
> all translation entries that occur in that file. These files would then
> all be added to the ZIP as is currently already done. From there the
> process could continue as normal.
> **Action required: patch wporg-gp-customizations ( ticket will be created
> ).**
> 3. WordPress installations would download these updated language packs as
> normal. The normal language pack file will still exist and contain all
> the translations it always did preserving full BC. In addition to that
> the JS translations would be present on a file-by-file basis.
> **No action required.**
> 4. WordPress will require a patch so that when a script is enqueued a
> check is done to see if a translation file exists for that specific
> script and, if so, load those translations using `wp_localize_script` and
> ensure a small inline script is added that loads those translations into
> `wp.i18n`. This inline script should always run before the dependant JS
> file is loaded.
> **Action required: patch WordPress Core ( ticket will be created ).**
>
> If all these steps are made I believe we'll be in a situation where:
> - Users will have the fastest experience, loading only the translations
> they need.
> - Site Owners can follow the same update and installation process they're
> used to and have a site that's as fast as possible when it comes to
> translations with the downside of a possible increase in size of language
> packs downloaded.
> - Translators can continue to work exactly as they are, with JS
> translations automatically showing up in their current workflow with full
> access to translator's comments as source JS files will also be scanned.
> - Developers do not need any workarounds and can likewise continue with
> the same processes they are already employing. The only exception here
> would be developers not shipping source files who would need to configure
> their build process to preserve translator's comments.
New description:
Javascript is starting to become increasingly important in core, plugin
and theme development. Especially in light of the upcoming 5.0 release
that will include Gutenberg.
When it comes to translations present in PHP we've got a great setup,
however this currently can't be leveraged for translations in JS without
some workarounds ( such as generating a PHP file containing all
translatable strings from JS ).
These workarounds also make it difficult to selectively load only the
required translations in JavaScript.
Ideally no workarounds would be needed, developers can use `wp.i18n.__` in
JavaScript just as they would use `__` in PHP with no additional steps
required. In addition to that end users would only have to load the
translations they need rather than all translations.
In order to make this happen several steps would have to be taken:
1. wordpress.org would need to also parse JS files when generating POT
files. I believe #3748 is the best way to allow this. A possible
alternative here would be to use
[[https://github.com/WordPress/gutenberg/tree/master/packages/babel-
plugin-makepot|@wordpress/babel-plugin-makepot]] but this would likely
require more effect to setup on wordpress.org.
**Action required: resolve #3748.**
2. wordpress.org would need to split translations into multiple files when
building language packs. The simplest way to achieve this would be to
change the `wporg-gp-customizations` plugin to generate multiple PO and MO
files. One pair for all translation entries ( possibly only those
occurring only in PHP files ) and one file per JS file, each containing
all translation entries that occur in that file. These files would then
all be added to the ZIP as is currently already done. From there the
process could continue as normal.
**Action required: patch wporg-gp-customizations #3876.**
3. WordPress installations would download these updated language packs as
normal. The normal language pack file will still exist and contain all the
translations it always did preserving full BC. In addition to that the JS
translations would be present on a file-by-file basis.
**No action required.**
4. WordPress will require a patch so that when a script is enqueued a
check is done to see if a translation file exists for that specific script
and, if so, load those translations using `wp_localize_script` or
something similar and ensure a small inline script is added that loads
those translations into `wp.i18n`. This inline script should always run
before the dependant JS file is loaded.
**Action required: patch WordPress Core #core45103**
If all these steps are made I believe we'll be in a situation where:
- Users will have the fastest experience, loading only the translations
they need.
- Site Owners can follow the same update and installation process they're
used to and have a site that's as fast as possible when it comes to
translations with the downside of a possible increase in size of language
packs downloaded.
- Translators can continue to work exactly as they are, with JS
translations automatically showing up in their current workflow with full
access to translator's comments as source JS files will also be scanned.
- Developers do not need any workarounds and can likewise continue with
the same processes they are already employing. The only exception here
would be developers not shipping source files who would need to configure
their build process to preserve translator's comments.
--
--
Ticket URL: <https://meta.trac.wordpress.org/ticket/3875#comment:5>
Making WordPress.org <https://meta.trac.wordpress.org/>
Making WordPress.org
More information about the wp-meta
mailing list