This tutorial explains how to translate sites that are built with the Advanced Custom Fields (ACF) plugin and WPML. All you need to do is configure WPML to translate the related custom fields groups. Then, you will be able to translate ACF’s fields, including the repeater fields and flexible fields.
One of the most important features of WPML’s integration with Advanced Custom Fields plugin is the ability to translate the repeater fields. The following image displays how this is easily done using WPML’s Advanced Translation Editor.
- Requirements and installation
- Making the ACF fields translatable
- Translating the fields
- Translating ACF user interface
- Translating other parts of the interface
- How to handle images and other post object fields
- Known Issues
If you are a site owner working with a developer, ask them to check and set up the requirements listed in this section. For you, the Translating the fields section is the most important one.
You need the following plugins installed and activated on your site:
- The ACF plugin (latest free or pro version)
- A recent version of WPML, including the String Translation and Translation Management add-ons.
- The Advanced Custom Fields Multilingual (ACFML) plugin (version 1.1 or higher). ACFML is a bridge plugin that makes WPML and Advanced Custom Fields plugin compatible.
WPML’s Getting Started Guide will help you in setting up WPML in a few minutes. You might want to refer to some of its subtopics later on, such as Theme and Plugin Localization and String Translation pages. We recommend that you keep this guide open while following this tutorial.
The setup of the ACFML plugin is simple. You can download the plugin on the WPML site, from the Download section of your Account page. There is no user interface or any specific settings – the plugin works in the background.
The ACF documentation will provide you with all the information needed to set it up and use it.
For a better translation experience, activate WPML Advanced Translation Editor. You can do this on the WPML -> Settings page, in the How to translate posts and pages section. There, select the Use WPML’s Advanced Translation Editor option for the new content and click Save.
Setting the custom fields translation preference from the Field Group screen is introduced in ACFML version 1.1. If you have set the translation preference for your custom field(s) using an older version of ACFML, you will see a red tooltip icon next to that field. It indicates that the translation preference of that fields needs to be reviewed. Otherwise, the default value (Don’t translate) will be set.
Before translating any custom fields using WPML, including the ones created with ACF, you need to select appropriate translation options for them.
You can set the translation preference for each field that you create in the Field Group from the Translation preferences section. There are four translation preferences for custom fields translation
- Don’t translate: The field is ignored and no translation is performed or available for it.
- Copy: The value of the field is copied from the one in the original language.
- Copy once: The value of the custom field is copied to the secondary language in the initial translation process. The custom fields that use the copy-once action will not appear on the Translation Editor screen. However, the user can change the custom field value of the secondary language to be different from the default language using the post editing screen.
- Translate: Allows you to translate the field values.
You can also set the translation preference from:
- The Multilingual Content Setup box when editing post and pages.
- The WPML Settings page, under the Custom Field Translation section.
Setting the translation preference for repeater fields is similar to setting the translation preference for simple fields. We recommend setting the translation preference of the main repeater field to Copy.
When adding values to any number of subfields on the post/page editing screen, WPML automatically applies the translation preference of the subfield that you have set on the fields group editing page to all the subfields on the page or a post.
On the post/page editing screen, go to the Multilingual Content Setup box and click Show system fields.
Set the fields that correspond to the repeater field name with an underscore at the beginning to Copy.
Now that we have set the translation preferences for our custom fields, it is time to translate the custom fields values (texts).
- Create a post in the default language and add values to the custom fields.
- Publish the post or a page.
- In the Language section, click the plus icon. You will be taken to the Advanced Translation Editor page. The post content along with the custom field values are available for translation.
- Click the Translate automatically button to add the machine translation. Review the translation and make sure that it is accurate.
- Click the Finish button then Complete to publish the translation.
To learn how to send the content to be translated by others, visit our page about how to translate your WordPress site.
Besides being able to translate the values of ACF fields that are shown on the front-end, WPML allows you to also translate the ACF user interface. This means that when translators are translating posts and pages that feature ACF fields, the labels and options for those fields will appear in that specific language. This can help to make the translator’s work easier and more convenient.
It is not necessary to translate Field Groups unless you want to translate the field labels (Field Label, Field Name, Instructions, Default Value, Placeholder Text, etc.)
You should only need to translate Field Groups in certain cases. For example, if on the front-end, you want to display different field labels for different languages.
To translate the Field Group, follow the steps below:
- Set the “Field Groups (acf-field-group)” post type to be translatable by navigating to WPML -> Settings and scroll to the Post Types Translation section.
- To translate the Field Group, navigate to Custom Fields -> Field Groups and click on the Edit link of the field group you want to translate.
- In the language box, turn off using the “Use WPML’s Translation Editor” option. Then, choose the “This Field Group” option and click the Apply button.
- In the Language meta-box, select the Duplicate checkbox for the different languages you want to translate your field group into and then click the Duplicate button.
- Click on the pencil icon to edit text in the fields for different languages.
- Now, you can edit the text in this group, for the other language(s). To keep your field groups consistent for all the languages of the site, you should only edit the label and descriptions of the fields and not add new fields or change their Field Name values. If you do any changes like this to the fields, you should do so for all your site’s languages. Once you complete adding the translated texts to the field group, click the Update button to save the changes.
- If you navigate to the secondary language post editing page you will see the field labels translated.
So far, we talked about translating the field groups and fields. Like any other WordPress plugin, ACF has its own user interface which includes text. To have a fully localized WordPress admin, you can also translate the ACF’s interface.
Like many other WordPress plugins, ACF comes with its own translations. Before you translate ACF’s interface, check with the author to see if the translation in your language is already available.
To translate ACF’s interface, follow the steps below:
- Go to the WPML -> Theme and plugins localization page.
- Under the Strings in the plugins section, you will see a list of plugins installed on your website. Select the Advanced Custom Fields plugin and click the Scan the selected plugins for strings button. WPML will scan ACF’s code and locate all translatable strings.
- After the scan is complete, navigate to WPML -> String Translation page and choose the “acf” text domain from the “Select strings within domain:” drop-down menu then click the Search button. This loads all the ACF strings that are available for translation.
- To translate a string, click on the translations link, add your translated content, tick the Translation is complete check-box then Save.
- When you are done, the ACF’s user interface will all appear fully localized.
If you constructed a Field Group with a field pointing to an existing post or custom post type (including images and other kinds of attachments), make sure post/post attachments are translated before you start adding them to the ACF field group.
For example, let’s assume you have added a Gallery field to the field group. You are going to add some photos to this gallery under your post.
Before translating your post along with its gallery field, make sure every image in the gallery is translated. Even though you want to have the same images in the translated post, you should go to the WPML -> Media page and make sure that all the images included in the gallery are translated.
Without translating objects such as images, posts and other kinds of post types, you will experience some minor problems, though your site will be working. Translated posts will be associated with objects in the original language, which is allowed. On the front-end, posts will display correct relations, however, on the post edit screen, you will see these fields as empty.
- Untranslated post object and page link fields do not show on the back-end of the duplicated post despite the fact that the post is associated with the correct value for the post object and page link custom fields in the database.
Please note that this is not a bug and it does not affect the functionality. Read more about this scenario on our dedicated FAQ page.
- Is it possible to hide ACFML field annotations?
Yes. To each translated field, ACFML adds information about the value in the original language. If you want to remove that information you can add the following line to your site’s wp-config.php file:
define( 'ACFML_HIDE_FIELD_ANNOTATIONS', true );
This feature is supported in ACFML since the 1.1 version.
If you need help using WPML with Advanced Custom Fields, please head over to our technical forum.