Localizing App
A multi-language feature allows you to show all your app's text in different languages.
FlutterFlow allows you to translate all your app's text in one go using Google Translate or manually change the text if you’d prefer. You can also translate predefined messages such as permission messages, authentication snackbar messages, etc.
Adding multi-language support can be crucial to your app. For example, if you have an app that tells non-English users to perform the exercise steps in English, they won't understand and prefer to use another app (which might be mediocre but available in the user’s language). Adding a Multi-Language feature to your app helps you succeed globally.
Add multi-language support
To add multi-language support to your project:
- Click on the Setting and Integrations from the Navigation Menu (left side of your screen).
- Under the Project Setup section, select Languages.
- Click on the + Add Language button. This will open the Select Language popup.
- Search for the language that you want to support and click on it. Similarly, add other languages.
- Now, inside the Primary Language dropdown, click on the Unset. This will open a popup, click continue and choose your base language. (A language that is shown when the current device language is not supported by your app.)
- (Optional) Inside the Display Language dropdown, select the language that you want to display while building your app in App Builder.
- Find the Translation section below and click on the Translate All button. This will open a new popup, click on Translate. This will translate all your app's text into supported languages using Google Translate.
- Go through all of your app's text (non-translated/translated) that are grouped by page name.
- Now, click on the Select Page or Component from the Navigation Menu (left side of your screen).
- Select any page, find the language dropdown above the canvas, try changing it to other languages, and see the translated text appear on the canvas.
Changing the primary language after translating all of your text will clear the existing translations for other languages.
Here's how it looks when you run your app on a real device/emulator and try changing the device language:
Changing app language manually
Instead of showing your app's text based on the user's device language, you can let users choose the language of the app.
For example, when the app starts, you may present a language selection screen or start the app with any default language, such as English and then allow users to later change the language from the settings menu.
Let's build a simple example of changing the app language on a button click which looks like the following visual:
Changing the app language manually includes the following steps:
1. Building a page
You can skip this step if you have already built your page.
To build a page:
- Create a page and add the Column widget.
- Add a Text Widget that shows some texts.
- Add a Button to change the language and add some padding around it.
2. Translating app content
Translate your app content as per the instructions here.
3. Add Set App Language [Action]
Using this Action, you can change the language of your app.
- This action is only visible when you added a multi-language feature to your app.
- This action is limited to only your app and does not change your device language.
Follow the steps below to define Set App Language Action to any widget.
- Select widget from the widget tree or from the canvas area.
- Select Actions from the Properties panel (the right menu)
- Click + Add Action button
- Choose a gesture from the dropdown among On Tap, On Double Tap, or On Long Press
- Select the Action Type as Set App Language*.*
- Set Language Source to Select Language.
- From the Language dropdown, select the language that you want to set.
Managing app text translation
Managing your app's text translation includes updating the translated text (produced by Google Translate) or running a Google Translate on the new or existing text (with slight modification) on a specific page.
There are two ways you can manage the app text translation:
Inside Language Settings
The Language Settings page lists all your app's text grouped by page name. You can use the Language Settings page when you want to manage the text in bulk.
To manage the app text translation inside the language settings page:
- Click on the Setting and Integrations from the Navigation Menu (left side of your screen).
- Under the Project Setup section, select Languages.
- Scroll down to the Translation section, find and click on the page name that contains the text you want to manage. This will show a list of texts on a page.
- Find your text:
- To manually add/update translation, directly make changes inside the box under the language column and mark the text as Fixed.
- To Google Translate a new or existing text (with slight modification), click on the Translate Page and then click Translate.
The Translate Page button will create a translation for all the texts on a page. If you don't want any text (with your own translation) to be overridden by Google Translate results, make sure you mark them as Fixed.
Inside App Builder
While building your app, you can translate or update the translation for the individual text right inside the app builder.
To manage the app text translation inside the App Builder:
- Click on the Select Page or Component from the Navigation Menu (left side of your screen).
- Select your Page and then select the widget (e.g., Text, TextField, etc.)
- Move to Property Editor and click on the Globe icon () for the property you would like to add a translation. This will open a new panel.
- To manually add/update translation, directly make changes inside the box under the language name.
- To Google Translate a new or existing text (with slight modification), click on the Google Translate button and then click Translate.
Translating predefined messages
FlutterFlow allows you to manage the translation for predefined messages, such as permission messages and snackbar messages.
There are two types of messages you can translate:
iOS Permission Messages
iOS permission messages are the messages that iOS users will see when prompted to grant permissions to your app (such as a camera or photo library access).
To add translations for the iOS permission messages:
- Click on the Setting and Integrations from the Navigation Menu (left side of your screen).
- Under the Project Setup section, select Languages.
- Scroll down to the Translation section and click on the iOS Permissions Messages to open the section.
- Inside the Permission Message section (e.g., Camera Permission Message, Photo Library Permission Message, etc.), enter your message for the base language. You can get an idea of what to write using the hint available inside the box.
- Now, there are two ways you can add translation:
- To Google Translate your message, click on the Translate Message button (top right side of the current section) and then click Translate.
- To manually add translations, directly add your translated messages under the language name and mark the permission message as Fixed.
- The permission messages are displayed based on the feature you have added to your app. For example, the Camera and Photo Library Permission messages are shown when you have a page with a Button that has Upload Photo/Video action added to it.
- If you don't want any messages (with your own translation) to be overridden by Google Translate results, make sure you mark them as Fixed.
Preset Snackbar Messages
Preset Snackbar Messages are ones we show for a certain action inside the Snackbar.
To add translations for the preset snackbar messages:
- Click on the Setting and Integrations from the Navigation Menu (left side of your screen).
- Under the Project Setup section, select Languages.
- Scroll down to the Translation section and click on the Preset Snackbar Messages to open the section.
- Inside the Message section (e.g., Authentication Message, Upload Media Message, etc.), enter your message for the base language. You can get an idea of what to write using the hint available inside the box.
- Now, there are two ways you can add translation:
- To Google Translate your message, click on the Translate Message button (top right side of the current section) and then click Translate.
- To manually add translations, directly add your translated messages under the language name and mark the permission message as Fixed.
Retrieving language related data
While building a multi-language app, sometimes you may need language-related data such as current language code or a specific language-related text.
In FlutterFlow, you can get the following two types of language-related data:
Current language code
The Current language code gives you the ISO language code for the current app language, such as en, de, fr, etc.
Let's build an example of showing the current language code in a Text widget.
To retrieve the current language code:
- Add the Column > Text widget to your app.
- Move to the property panel and click on the Set from Variable text.
- Select Source as Internationalization and Available Options as the Current Language Code.
- (Optional) Set the Default Variable Value if you wish to.
- Click Confirm.
- Add Button widgets with an action to change the language. To change the language manually, find the instructions here.
Language dependent text
Sometimes you might want to store/process a text that is dependent on the current app language—for example, showing/storing the nation/country flag or name based on the current app language.
Let's build an example of showing the nation/country flag in a Text widget.
To show the language-dependent text:
- Add the Column > Text widget to your app.
- Move to the property panel and click on the Set from Variable text.
- Select Source as Internationalization and Available Options as the Language Dependent Text.
- Click on the language name to open the section and enter your text inside the Value input box.
- Similarly, enter a value for other languages as well.
- (Optional) Set the default value if you wish to.
- Click Confirm.
- Add Button widgets with an action to change the language. To change the language manually, find the instructions here.
You can also use our in built component LanguageSelector widget to allow the user the set the language of your app from a language dropdown.