-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Internationalization and localization: translating templates and template parts #27402
Comments
This solution could also be applied to block patterns. |
No real feedback, but just throwing this here: I can imagine this having a major impact on phase 4 of Gutenberg in the long term roadmap. I agree i18n and i10n for templates and template parts is an issue to be tackled, but I'm not sure when and how... |
It certainly will.
I had assumed that the ability to translate a theme's content was already a pre-requisite to hosting the theme on wordpress.org. |
Just over a year has passed since I wrote this proposal. Disappointed that no-one's attempted to review it. Rather than enabling support for extracting and translating strings from HTML files and writing new HTML files for each required locale it would appear that the current method uses a convoluted process of implementing strings in patterns which are written in PHP. See Twenty Twenty Two for an example. In my opinion patterns can also be written in translatable HTML. It would contain the translatable Example
The |
Is your feature request related to a problem? Please describe.
This Feature request contains a proposal for internationalising and localising Gutenberg's Full Site Editing templates and template parts directly from the HTML files.
Describe the solution you'd like
WordPress is a multilingual CMS, used in countries all over the world where English is not the main language.
There is a requirement for
Full Site Editing themes to be Internationalized and Localised
This solution proposes a method whereby the template and template parts are localized statically and delivered from locale specific folders.
Current solution
In WordPress/Gutenberg there are two ways to indicate text that should be translated and to deliver translations to the end user. One is the PHP route, the other JavaScript. The general process followed by each is:
Internationalization (i18n) is the manual process of indicating which strings are translatable. This is done by wrapping strings in particular functions.
Extraction is the automated process of preparing the strings for translation. Modern WordPress plugins use
makepot
andmakejson
to extract the strings.Translation is performed offline, producing lookup tables of source language to target language translations. Note: The developer can provide context and hints that help the translator decide the localised version.
Localization (l10n) is the process of delivering the translated version to the end user. Both PHP and Javascript code use the appropriate lookup table at run time.
Full Site Editing proposal
In Full Site Editing, templates and template parts are constructed as Gutenberg blocks and HTML. eg Extract from a template part file, written in US English.
We need new processes to handle these HTML files.
Assumptions
Therefore:
The new process would be:
Proposed solution
I have developed a prototype to test with my experimental theme called Fizzie. The solution uses a number of routines, which are currently run in batch. For testing purposes it’s semi automated; run on demand.
Running the routine generates two locale specific versions:
The prototype is part of my oik-i18n plugin. See bobbingwide/oik-i18n/issues/7 – FSE – Can we internationalize .html files without requiring any special markup?
Testing the process
With the bbboing version, just about every word in each translatable string is partially obfuscated using a repeatable process. The target output is reasonably easy to recognise. Here’s a screen capture from my test template ( i18n-test.html ) used in the test page called “I18n test”.
Changes to template loading logic
In order to test the results I needed to edit the code to load the templates and template files from the locale specific folders.
Note: The extracted and translated files are also in the languages folder, but take no part in the run time processing. In the final solution updating the
.mo
language file would trigger the localization process.Since the logic to synchronize the Site Editor’s content with the template files is under going a lot of change at present, I only tested the logic to load template parts. I did this by updating my block override function called
fizzie_render_block_core_template_part()
. It ignores the synchronized content and loads the template part from the selected locale. It assumes the localized part exists.What needs to be done?
This solution is not without its challenges. Take for instance this sample of rich text.
What strings would you present to the translator? Would it be “Written by:”, “using” and “Gutenberg”? or the whole inner content of the paragraph?
One of the problems with granular string extraction is losing the context for the translation. Another is white space.
Should the translator be given the chance to translate the whole of some rich text, rather than the snippets between tags?
In order to answer questions like this a number of activities will need to be performed, the first of which is to document the requirements. This should take into account each of the different target users, their languages and any other relevant cultural needs or customs.
Regarding implementation, there will be many areas affected:
.mo
file.But before any of this is done, we should agree in principal the way forward with regard to i18n and l10n:
My preference is for 1.
References
Related Gutenberg issues:
There are also issues that are more closely related to values which vary between sites:
URLs, post IDs, etc, rather than translatable text strings
eg
These are relevant only if we have to consider how to handle rich text content that includes links and inline images.
The text was updated successfully, but these errors were encountered: