Text part language
The text part language feature lets you mark the language of text fragments. This way browsers and screen readers can correctly interpret parts written in different languages.
# Demo
In the demo below, select a text fragment. Next, use the language toolbar dropdown to choose from predefined languages.
This demo presents a limited set of features. Visit the feature-rich editor example to see more in action.
# Additional feature information
The text part language feature is especially useful when your content includes text sections written in different text directions, for example, when the whole content is in English but includes some citations in Arabic.
The text part language feature implements the WCAG 3.1.2 Language of Parts specification.
# Configuring available languages
To modify the list of available languages displayed in the language dropdown use the config.language.textPartLanguage
configuration option.
The example below shows the configuration used for the demo above:
ClassicEditor
.create( document.querySelector( '#editor' ), {
// More of editor's configuration.
// ...
language: {
textPartLanguage: [
{ title: 'Arabic', languageCode: 'ar' },
{ title: 'French', languageCode: 'fr' },
{ title: 'Hebrew', languageCode: 'he' },
{ title: 'Spanish', languageCode: 'es' }
]
}
} )
.then( /* ... */ )
.catch( /* ... */ );
# Installation
The Text part language feature is enabled by default in the superbuild only.
To add this feature to your rich-text editor, install the @ckeditor/ckeditor5-language
package:
npm install --save @ckeditor/ckeditor5-language
And add it to your plugin list configuration:
import { TextPartLanguage } from '@ckeditor/ckeditor5-language';
ClassicEditor
.create( document.querySelector( '#editor' ), {
plugins: [ TextPartLanguage, /* ... */ ],
toolbar: [ 'textPartLanguage', /* ... */ ]
} )
.then( /* ... */ )
.catch( /* ... */ );
Read more about installing plugins.
# Related features
There are other language-related CKEditor 5 features you may want to check:
- UI Language – Set the UI language.
- Spelling and grammar checking – Employ multi-language spell check for flawless content.
# Common API
The TextPartLanguage
plugin registers:
- The
'textPartLanguage'
UI dropdown component implemented by the text part language UI feature. - The
'textPartLanguage'
command implemented by the text part language editing feature.
You can execute the command using the editor.execute()
method:
// Applies the language to the selected text part with the given language code.
editor.execute( 'textPartLanguage', { languageCode: 'es' } );
We recommend using the official CKEditor 5 inspector for development and debugging. It will give you tons of useful information about the state of the editor such as internal data structures, selection, commands, and many more.
# Contribute
The source code of the feature is available on GitHub at https://github.com/ckeditor/ckeditor5/tree/master/packages/ckeditor5-language.
Every day, we work hard to keep our documentation complete. Have you spotted outdated information? Is something missing? Please report it via our issue tracker.