Internationalize Mobile Apps
Introduction
This internationalization guide explains how to give your end-user an easy way to change their mobile application's language. The user can do so directly on their Android or iOS device.
This guide shows one of the ways to change the language on a native app. You can also apply this guide's mechanism to all offline PWA profiles. Please note that this guide's mechanism does not change the localization of an application because it depends on the settings of the device.
While this guide gives your end-user the ability to switch their app's language, translation is a different issue. Translating native apps and PWAs actually works the same as it does for web apps. To learn more about app translation, see Translating Your App Content.
Prerequisites
Before starting this guide, make sure you have completed the following prerequisites:
- 
Install Mendix Studio Pro 9.14.0 or above 
- 
Complete the Prerequisites of your app per its type 
- 
Make sure your Nanoflow Commons module is up to date 
- 
Read the Language Menu guide to understand the basics of the Mendix Language menu 
- 
Set up the required languages in Studio Pro—this tutorial has been configured with three languages as below:   
Setting up the Language Change Mechanism
Internationalization with Mendix's mobile apps is fairly simple. You will use two nanoflow actions to set up most of your language change mechanism.
This guide requires the following nanoflow actions:
- Clear cached session data – This action clears saved session data from the local storage for offline native app and PWAs. This nanoflow action is only compatible with Studio Pro 9.14 and above. Therefore, please use Studio Pro 9.14.0 or above.
- Reload – This action reloads web and native apps.
Adding the Module and Microflow
You can either add a new module to your existing app, or create a new Studio Pro app using a Blank Native Mobile App template and then adding a new module to it. Either way, your setup will begin with the same step and continue on accordingly:
- Add a new module ChangeLanguage to your app.
- Add a new microflow ACT_Language_ChangeUserLangRuntime to your ChangeLanguage module and configure it as such:
- 
Add a parameter called LanguageCode of data type String.
- 
Retrieve the language that was selected by the user on the app: - 
This can be done by using a Retrieve object activity. 
- 
Select the source as Databaseand entitySystem.Language.
- 
As you need only one language, select range as Firstand pass the XPath constraint as[Code=$LanguageCode].
- 
Name this retrieved object SelectedLanguage. 
- 
Your microflow should look like this:   
 
- 
- 
To set the selected language, you need to change the language for the current user: - 
Call a Change object activity. 
- 
Select the Input as currentUser (System.User).
- 
In the Action section, Commit should be set to Yesand Refresh to client set toNo.
- 
For Member, select System.User_Language.
- 
For the value of that member, set it as the object retrieved earlier: $SelectedLanguage.
- 
Your microflow should look like this:   
 
- 
 
- 
Your microflow ACT_Language_ChangeUserLangRuntime is now ready to be called from a nanoflow which you will configure in the following section.
Adding the Nanoflow
Add a new nanoflow ACT_Language_ChangeUserLangDevice to your module and configure it like this:
- 
Add a parameter called SelectedLanguage of data type Objectand entitySystem.Language. This parameter will be the new app language as selected by the user.
- 
Make a microflow call to ACT_Language_ChangeUserLangRuntime, the microflow you made previously. 
- 
In that microflow call, click Edit parameter value, select Expression, and write $SelectedLanguage/Codeas the expression. This microflow call now sets the language as selected by the user.
- 
Now the cached session needs to be cleared from local storage. Simply call a nanoflow action Clear cached session data. 
- 
To load the new language, you must refresh the app. This can be done by calling a nanoflow action Reload. 
- 
Your nanoflow should look like this:   
Adding the Native Page
Add a new native page Language_Overview to your ChangeLanguage module, then do the following:
- Add a title called Select language, as the selected language in Studio Pro is English. You can use a Text widget, but anything with a string value is fine.
- Then underneath the title, add a native List View by simply dragging from the toolbox to list all the available languages on the app. Configure it this way:
- In the Data source tab, Type should be Database, Entity should beSystem.Language.
- In the General tab, On click should be configured to call a nanoflow ACT_Language_ChangeUserLangDevice.
- Click on the OK button.
- You should get a dialog box asking Do you want to automatically fill the contents of the list view? Select Yes.
 
- You should get a dialog box asking Do you want to automatically fill the contents of the list view? Select 
- List View should be populated with two fields: {Code}and{Description}. Delete the{Code}field.
 
- In the Data source tab, Type should be 
- Ensure the caption of the {Description}field in ListView is not empty. It should be mapped to the attributeSystem.Language.Descriptionwith the{1}variable and be used as well.
- Change to the second language in Studio Pro by going to menu Language > Current Language > <second_language>.
- Add a translation of the title in a second language if not available.
- Ensure again that the caption of the {Description}field in ListView is not empty. It should be mapped to the attributeSystem.Language.Descriptionand be used as well.
- Repeat the above steps to add a translation for the third language as well.
- Set Language_Overview as the default home page of the Native mobile navigation profile:
- Open Navigation in the App Explorer.
- Click the Native mobile tab.
- Set Language_Overview as the default home page.
 
Testing Language Switching
Now it is time to see the app in action. If you are using a PWA, you can simply test in a web browser.
To test your native app, locally deploy and view the app on the Make It Native 9 app:
- 
Follow the steps in Downloading and Installing the Make It Native App to view your app in Mendix's Make It Native testing app. 
- 
Once the app is running, you should be able to see the native Language_Overview page:   
- 
To change the language, do the following: - 
Tap Dutch, Netherlands. 
- 
The app should be reloaded automatically. 
- 
You should be able to see the title in the Dutch language:   
 
- 
Congratulations, you just implemented internationalization in your native app! Your users will appreciate the power of multiple languages at their fingertips. For more information about languages and Mendix, see the Read More section below.
Read More
- Using Translatable Validation Messages
- Language Menu: gives more information on translating the languages of different Mendix UI elements
- Change Language by Clicking a Link: explanations and ideas in the Mendix Community for refreshing the page when the language is changed
- Anonymous User Journey: a discussion in the Mendix Community about switching languages for anonymous end-users