In this exercise you'll learn how easy it is to enable localization for your UI5 application.
In your existing UI5 application you've used hard-coded text values. That's OK if you'd like to implement a fast proof of concept. In your productive application no hard-coded text should be used, however, because it would be displayed regardless of the actual browser language the user has configured. Your goal is to build an enterprise-ready application which includes localization features, such as text translation. UI5 comes with a huge set of localization features out of the box, which are enabled by default. To benefit from these features, you need to replace all occurrences of hard-coded text in your UI5 application. Luckily, there's only one occurrence 😃 However, it's good practice to start directly with localization in mind instead of refactoring many places in your application afterwards.
-
Open the
Sensors.view.xml
located underSensorManager/webapp/view/
. -
Replace the
noDataText
value with the i18n keynoSensorDataText
.
<f:GridList id="sensorsList"
items="{path: 'sensorModel>/sensors', sorter: {path:'customer', group:true, descending: false}}"
noDataText="{i18n>noSensorDataText}">
- Add the newly introduced i18n key also to your
i18n.properties
file, which is located underSensorManager/webapp/i18n/
, and by the way, let's also pick a better title.
SensorManager/webapp/i18n/i18n.properties
title=Keep Cool Inc. Sensor Manager
appTitle=Sensor Manager
appDescription=The sensor manager
noSensorDataText=No Sensor Data
distanceLabel=Distance
distanceUnit=km
msgSensorDataLoaded=All sensors online!
msgFilterAll=All
msgFilterCold=Cold
msgFilterWarm=Warm
msgFilterHot=Too Hot
toolTipSelectCustomer=Select Customer
titleSelectCustomer=Select Customers
titleSensorStatus=Sensor Status
cardTitle=Customer: {0}
locationLabel=Location
cardSubTitle={0}: {1}, {2}: {3}{4}
temperatureUnit=°C
Your UI5 application is prepared for localization. No matter which browser language is configured, your UI5 application currently displays the texts of the i18n.properties
file.
Let's provide new language files for English and German.
-
Go to folder
SensorManager/webapp/i18n/
and right-click. -
In the popup, click
New File
. -
Enter
i18n_en.properties
as file name. -
Repeat Steps 1 and 2.
-
Enter
i18n_de.properties
as file name. -
Open
i18n_en.properties
and paste the following content:
SensorManager/webapp/i18n/i18n_en.properties
title=Keep Cool Inc. Sensor Manager
appTitle=Sensor Manager
appDescription=The sensor
noSensorDataText=No Sensor Data
distanceLabel=Distance
distanceUnit=km
msgSensorDataLoaded=All sensors online!
msgFilterAll=All
msgFilterCold=Cold
msgFilterWarm=Warm
msgFilterHot=Too Hot
toolTipSelectCustomer=Select Customer
titleSelectCustomer=Select Customers
titleSensorStatus=Sensor Status
cardTitle=Customer: {0}
locationLabel=Location
cardSubTitle={0}: {1}, {2}: {3}{4}
temperatureUnit=°C
- Open
i18n_de.properties
and paste the following content:
SensorManager/webapp/i18n/i18n_de.properties
title=Keep Cool Inc. Sensor Verwalter
appTitle=Sensor Verwalter
appDescription=Der Sensor Verwalter
noSensorDataText=Keine Sensordaten
distanceLabel=Distanz
distanceUnit=km
msgSensorDataLoaded=Alle Sensoren aktiv!
msgFilterAll=Alle
msgFilterCold=Kalt
msgFilterWarm=Warm
msgFilterHot=Zu Heiß
toolTipSelectCustomer=Wähle den Kunden
titleSelectCustomer=Wähle die Kunden
titleSensorStatus=Sensor Status
cardTitle=Kunde: {0}
locationLabel=Ort
cardSubTitle={0}: {1}, {2}: {3}{4}
temperatureUnit=°C
- Depending on the browser language you've configured, you'd now be able to see different text on your user interface.
- If your browser language is English, the content of
i18n_en.properties
is used. - If your browser language is German, the content of
i18n_de.properties
is used. - For any other language, the content of
i18n.properties
is used.
- If your browser language is English, the content of
Usually, only the i18n.properties
file is maintained by developers. The language-dependent files will be filled by native speakers or translators. As an application developer, you can configure which languages are supported by your application, and which language is your default (aka fallback) language. In this session English will be the default language, and additionally German should be supported.
-
Open the
manifest.json
located underSensorManager/webapp
. -
Go to section
sap.ui5
/models
/i18n
. Here, add two new configurations inside your settings object.- Add the property
supportedLocales
and assign the locales for German and English["de", "en"]
- Add the property
fallbackLocale
and assign the English locale"en"
- Add the property
SensorManager/webapp/manifest.json
"i18n": {
"type": "sap.ui.model.resource.ResourceModel",
"settings": {
"bundleName": "keepcool.SensorManager.i18n.i18n",
"supportedLocales": ["de", "en"],
"fallbackLocale": "en"
}
}
-
Let's see if your UI5 application is able to start in English and German! Switch to the browser tab with an opened application preview and reload the page. The UI5 application should start in English or in German, depending on your browser language.
-
UI5 provides a URL parameter to simulate another browser language. Add
?sap-ui-language=de
to the URL shown in your browser. UI5 should now start in German regardless of the language you have configured as your browser language. -
You can simulate any other language, e.g. English. Add
?sap-ui-language=en
to the URL shown in your browser. UI5 should now start in English regardless of the language you have configured as your browser language. -
Let's try to start the application in another language, e.g Hindi. Add
?sap-ui-language=hi
to the URL shown in your browser. UI5 should now start in English, because you have configured English as your fallback locale.
If you'd like to support Hindi, or any other language of your choice, feel free to repeat the steps described in Exercise 4.2 Add New Languages with your desired language.
Yay! You've accomplished successfully Exercise 4 - Introduce Localization.
Continue to Exercise 5 - Improve Visualization.
- Localization: https://ui5.sap.com/#/topic/91f217c46f4d1014b6dd926db0e91070
- Supported Locales and Fallback: https://ui5.sap.com/#/topic/ec753bc539d748f689e3ac814e129563