The CE.SDK editor includes an internationalization API that facilitates locale configuration management during runtime.
I18N Configuration#
- Setting the Locale: The language of the user interface is now set using the cesdk.i18n.setLocale()API after creating the CreativeEditorSDK instance. The CE.SDK currently ships with locales for Englishenand Germande. Additional languages will be available in the future. Until then, or if you want to provide custom wording and translations, you can provide your own translations using thecesdk.i18n.setTranslations()API, as described in the next paragraph.
  // Set the initial locale using the new API  instance.i18n.setLocale('fr');- 
Translation Configuration: Translations should now be set using the cesdk.i18n.setTranslations()API after creating the CreativeEditorSDK instance, instead of the deprecatedi18nconfiguration option. Since the CE.SDK supports maintaining multiple locales at the same time, the first key in the map must always be the locale the translation is targeting. In this example, we change the back-button label for the locales'fr'and'it'.Please note that the fallback locale is 'en'. So, with this configuration, the complete user interface would be English except for the back-button. Also, if you want to change a single label for one of our shipped translations, you do not have to add all keys, but only the one you want to override.A detailed overview of all available keys can be found in form of predefined language files inside assets/i18n. You can download the English version from our CDN here: en.json
// Set initial translations using the new APIinstance.i18n.setTranslations({  fr: {    'common.back': 'Retour',    'meta.currentLanguage': 'Français'  },  it: {    'common.back': 'Indietro',    'meta.currentLanguage': 'Italiano'  }});- Under the special key meta.currentLanguage, you should provide a short label for your provided language. This will be used to display the language in the language select dropdown of the editor customization panel.
'meta.currentLanguage': 'Français'Here’s the full code:
const config = {  license: 'mtLT-_GJwMhE7LDnO8KKEma7qSuzWuDxiKuQcxHKmz3fjaXWY2lT3o3Z2VdL5twm',  userId: 'guides-user',  ui: {    elements: {}  }};I18N API#
Internationalisation can also be handled during runtime with a complementary set of APIs.
- cesdk.i18n.getLocale(): stringreturns the currently set locale string, e.g.- "en"for our default english locale.
const currentLocale = instance.i18n.getLocale();console.log({ currentLocale }); // Output: "fr"- cesdk.i18n.setLocale(locale: string)updates the locale to the string passed in as- localeparameter. This is either one of our predefined strings (- "en"for english or- "de"for german) or any additionally configured locales.
instance.i18n.setLocale('it');const updatedLocale = instance.i18n.getLocale();console.log({ updatedLocale }); // Output: "it"- cesdk.i18n.setTranslations(definition: { [locale: string]: object })adds an object with translations to CE.SDK. This should be used instead of the deprecated- i18nconfiguration option.
instance.i18n.setTranslations({  hr: {    'common.back': 'Poništi',    'meta.currentLanguage': 'Hrvatski'  },  sv: {    'common.back': 'Ångra',    'meta.currentLanguage': 'Svenska'  }});- cesdk.i18n.listLocales(options?: { matcher?: string }): string[]returns an array of all available locale strings that have translations loaded. Optionally accepts a wildcard pattern to filter locales.
const availableLocales = instance.i18n.listLocales({ matcher: '*' });console.log('Available locales:', availableLocales);