Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.



Page Properties
hiddentrue
idSTUBDONE

Product Version2021 Winter
Report Note
AssigneeAntje

Resources & Remarks

Modification History

NameDateProduct VersionAction
Antje20 SEP 20212021 WinterPage created.
Agnieszka07 OCT 20212021 WinterrLANG
Antje16 FEB 20222022 Springroles are configurable, but not for architect
Christoph24 FEB 20222022 Springadded Data format support (DOKU-2394)
Agnieszka30 MAR 20222022 SpringrLANG
Christoph06 APR 202202022 Summeradded 3 languages  BUD-1114

@Antje : Peter hat mir zwei links gegeben, über die man in einem installierten System sowohl an die Custom Client Keys als auch die Framework Keys kommt:
https://tacim0921.dms-kddaqa.kdcbslab.dev/litedms/assets/i18n/en.json
https://tacim0921.dms-kddaqa.kdcbslab.dev/litedms/assets/i18n-yuuvis-overwrites/en.json 

Der Cliet läuft in 'litedms' ...

Wenn Du eine gute Idee hast, das als alternativen Zugang zu den Client-Keys unten einzubauen ...


Excerpt

Configure localizations for a custom client built with our libraries or for yuuvis® client as reference implementation.

...

Section
bordertrue


Column

Table of Contents

Table of Contents
exclude(Table of Contents|Read on|Another Tutorial|Another Concept Article|Another interesting Tutorial)

Introduction

This article is written for administrators that will prepare an application based on the reference client for a new language. There are several parts that must be configured in a specific way.

Parts to be localized

If you want to localize an application you have to configure the following files and bring them into the correct place. The user interface showing by the client consists of these parts that have to be maintained differently:

  • The clients are showing static labels coming from the client source project that includes the framework library. Both parts are handling files for each supported language containing keys and the labels showing up for the language the user has set up in the settings. The reference client is delivered with language files for English and German named en.json and de.json. Take the files of one language of the client project as well as of the framework library, create a new language file (e.g. ja.json e.g. for Japanese) and put all keys into that file. Translate the labels and place the new language file beside both existing ones as described below.
    • Configure the main.json configuration file and add the new language so the user can select it in the settings area of the client.
  • The clients are showing dynamic labels (custom labels) as well. These are set up in the language files that support localizing technical names that are given in the configured schemas and forms. These language files are persisted in the config service using specific REST endpoints of the Web-API Gateway. There are two groups of language files. One group contains all globally used technical names that are part of the system schema as well as of the app schemas. After setting up a new environment the language files for resource en= English and de = German are persisted and containing all system-specific technical names like 'system:document' and 'system:folder'. The other group contains the technical names that are configured in a tenant schema if given.
    You need to fetch the one global language file (system) and if given a tenant-specific one, let them be translated for the wished new language and store them as described below.

Subsection(s)

Summary

Custom Client Build with Libraries|Web-API Gateway \(API-WEB\)|Localization)


Introduction

The terms and phrases displayed by a client application based on our libraries such as our yuuvis® Momentum client as reference implementation can be translated into custom languages according to the corresponding needs. For this purpose, each individual technical term used in the background can be mapped to a user-friendly localized term or phrase that will be displayed in the client application instead of the technical term. The built with our libraries allows for the localization of control elements (e.g., buttons or error messages). In order to provide a custom language in the selection list from which the users can select their preferred language, it has to be added to the client's main configuration. Furthermore, labels used in forms can be localized easily during runtime.

Localizing Control Elements

The localization of control elements is realized directly during the build process of the client. JSON files are used as configuration files for the translations. The languages to be offered to users are specified in the client's main configuration.
>> Framework Library Installation and Configuration

Localizing Form Labels ...

The labels displayed in forms (e.g., object metadata forms) are localized by means of JSON configuration files as well. A distinction is made between tenant-specific labels available only in one tenant and global labels available in all tenants. The tenant-specific localization files are managed by users with the access to the admin-controller endpoints of the Web-API Gateway (default: users with the YUUVIS_TENANT_ADMIN role). Their changes are applied only to their own tenant. Users with access to the system-controller endpoints (default: users with the YUUVIS_SYSTEM_INTEGRATOR role) are allowed to manage the global localization files available in all tenants.

Whenever a new tenant is created and provided with its own tenant-specific resources like, e.g., a tenant schema, a tenant-specific localization file also needs to be created. Otherwise the technical terms defined in the technical resource files will be displayed in the forms.

In order to retrieve or import localization files, the corresponding endpoints of the Web-API Gateway (API-WEB) can be used. Alternatively, the administrative graphical user interface of yuuvis® architect allows for a comfortable localization handling.

... by means of Web-API Gateway

The endpoints for the management of localization files provided by the Web-API Gateway (API-WEB) are available only for users with specific administrative roles. Furthermore, the endpoints require the specification of the language for which the localization file should be retrieved/updated. The language has to be specified in ISO norm (e.g., de, en, es, fr, ...) in the request header for GET endpoints and in the request URL for the POST endpoints:

Required PermissionAvailable Endpoints for Localization ManagementDescriptionISO Language SpecificationRange of Application of managed Localization Files

access to admin-controller endpoints of the Web-API Gateway

(default: YUUVIS_TENANT_ADMIN role)

GET /api-web/api/admin/resources/text

Insert excerpt
GET /api-web/api/admin/resources/text
GET /api-web/api/admin/resources/text
nopaneltrue

in the request header Accept-LanguageTenant-specific: available only in the tenant the currently logged-in user belongs to.
POST /api-web/api/admin/resources/text/{locale}

Insert excerpt
POST /api-web/api/admin/resources/text/{locale}
POST /api-web/api/admin/resources/text/{locale}
nopaneltrue

as path parameter

access to system-controller endpoints of the Web-API Gateway

(default: YUUVIS_SYSTEM_INTEGRATOR role)

GET /api-web/api/system/resources/text

Insert excerpt
GET /api-web/api/system/resources/text
GET /api-web/api/system/resources/text
nopaneltrue

in the request header Accept-LanguageGlobal: available for all tenants.
POST /api-web/api/system/resources/text/{locale}

Insert excerpt
POST /api-web/api/system/resources/text/{locale}
POST /api-web/api/system/resources/text/{locale}
nopaneltrue

as path parameter

The endpoints can be called via Swagger-UI.
>> Web-API Gateway Endpoints

Alternatively, they can be called using cURL as shown in the following examples:

Code Block
languagebash
# Management of a global localization file:

# Retrieve the localization file for English language as a JSON response:
curl -X GET "https://mydomain/api-web/api/admin/resources/text" -H "accept: application/json" -H "Accept-Language: en"

# Import or update the localization file for Japanese language: 
curl -X POST "https://mydomain/api-web/api/admin/resources/text/ja" -H "accept: */*" -H "Content-Type: application/json" -d "{all keys that are given}"

# Management of a tenant-specific localization file for the tenant of the logged-in user:

# Retrieve the localization file for English language as a JSON response:
curl -X GET "https://mydomain/api-web/api/admin/resources/text" -H "accept: application/json" -H "Accept-Language: en"

# Import or update the localization file for Japanese language: 
curl -X POST "https://mydomain/api-web/api/admin/resources/text/ja" -H "accept: */*" -H "Content-Type: application/json" -d "{all keys that are given}"


... by means of yuuvis® architect

yuuvis® architect provides a support tool with a graphical user interface for client administrators. Based on the framework library, metadata forms of their client's graphical user interface can be modeled. Furthermore, users can be added or removed from the respective tenant and language settings can be customized.

The Localization tile is available on the dashboard for users with the YUUVIS_TENANT_ADMIN or YUUVIS_SYSTEM_INTEGRATOR roles.
>> Localization

Localizing Terms from Plug-ins

In case you need to extend translations with new keys, please specify translations in the plug-in configuration for each language in your system.
>> Extending Clients with Plug-ins

Language-specific Date, Time and Number Formats

Regardless of the availability of a localization file with language-specific terminology, a library-based client can support language-specific date, time and number formats according to the corresponding rules. The supported languages are listed below. Support for languages not listed below can be implemented by the yuuvis® Momentum development team upon request. As of 2022 Summer, it is not possible to implement the usage of special characters to replace AM and PM in a 12-hour system.

LanguageISO code Example date and timeExample number
Arabicar31 /01 /2022 20:0811,111,111.00
Bengalesebn31/01/2022 08:08 PM1,11,11,111.00
Chinesezh2022/01/31 20:0811,111,111.00 
Dutch (as of 2022 Summer)nl31-01-2022 20:0811.111.111,00
Englishen01/31/2022, 08:08 PM11,111,111.00
Finnish (as of 2022 Summer)fi31.01.2022 20.0811 111 111,00
Frenchfr31/01/2022 20:0811 111 111,00
Germande31.01.2022, 20:0811.111.111,00
German (Switzerland)
(as of 2022 Summer)
de-CH31.01.2022, 20:0811’111’111.00
Hindihi31/03/2022, 08:08 pm1,11,11,111.00
Italianit31/01/2022, 20:0811.111.111,00
Japaneseja2022/01/31 20:0811,111,111.00
Koreanko2022. 01. 31. PM 08:0811,111,111.00
Latvianlv31.01.2022 20:0811 111 111,00
Norwegian (as of 2022 Summer)nb31.01.2022, 20:0811 111 111,00
Polishpl31.01.2022, 20:0811 111 111,00
Portuguesept31/01/2022 20:0811.111.111,00
Russianru31.01.2022, 20:0811 111 111,00
Slovaksk31.01. 2022 20:0811 111 111,00
Spanishes31/01/2022 20:0811.111.111,00
Swedish (as of 2022 Summer)sv2022-01-31 20:0811 111 111,00
Thai (as of 2022 Summer)
th31/01/2022 20:0811,111,111.00
Turkish (as of 2022 Summer)tr31.01.2022 20:0811.111.111,00
Ukrainianuk31.01.2022, 20:0811 111 111,00
Vietnamese (as of 2022 Summer)vn20:08, 31/01/202211.111.111,00

To configure display languages for the client, please refer to this article: Customizing the Main Configuration.

Summary

In client applications built with our libraries, all displayed terms and phrases can be localized for a custom language. While labels for control elements are defined already during the client configuration, the localization of labels in forms is possible at runtime via Web-API Gateway or yuuvis® architect.

Info
iconfalse

Read on

Section


Column
width25%

...

Another Tutorial

...

Web-API Gateway (API-WEB)

Insert excerpt
Web-API Gateway (API-WEB)
Web-API Gateway (API-WEB)
nopaneltrue
 Keep reading


Column
width25%

...

Another Concept Article

...

Localization

Insert excerpt
Localization
Localization
nopaneltrue
 Keep reading


Column
width25%

...

Another interesting Tutorial

...

Custom Client Build with Libraries

Insert excerpt
Custom Client Build with Libraries
Custom Client Build with Libraries
nopaneltrue
 Keep reading