Skip to content

Latest commit

 

History

History
77 lines (50 loc) · 1.97 KB

README.md

File metadata and controls

77 lines (50 loc) · 1.97 KB

bpmn-js i18n Example

This example shows how to easily translate the strings displayed in bpmn-js to another language.

Screenshot

Usage Summary

The custom translation function is provided as an additional module when bpmn-js is instantiated. The default translation implementation is thereby overwritten.

var customTranslate = {
  translate: [ 'value', require('./custom-translate/custom-translate') ]
};

var modeler = new BpmnModeler({
  // ...
  additionalModules: [
    customTranslate
  ]
});

You can use your own implementation for translation. The function has two arguments (a template string and an optional object with replacements) and must return the translated string. The example provides two main functionalities: translating and replacing template strings.

Translating a string:

var translations = {
  'Append': 'Anhängen'
};

//...

translate('Append'); // Returns 'Anhängen'

Translating a template string:

var translations = {
  'Append {element}': '{element} anhängen'
};

//...

translate('Append {element}', {element: 'Gateway'}); // Returns 'Gateway anhängen'

A list of all available template strings of bpmn-js can be found here.

Building the Project

You need a NodeJS development stack with npm installed to build the project.

To install all project dependencies execute

npm install

Build the application (including bpmn-js) using browserify via

npm run all

You may also spawn a development setup by executing

npm run dev

Both tasks generate the distribution ready client-side modeler application with internationalization into the dist folder.

Serve the application locally or via a web server (nginx, apache, embedded).