Saving data without suggestions
# Track changes data plugin
Sometimes your application may need to save editor data with all the suggestions accepted or discarded. Common cases include document preview or printing.
To enable this you will need to use the TrackChangesData
plugin. It is available in the track changes package. Import it and add to your build:
Then you can use the track changes data plugin API to get the editor data with all the suggestions accepted or discarded:
Note that this method is asynchronous (it returns a promise that resolves with the editor data).
# Configuring track changes data plugin
In most common cases, there is no need for any configuration regarding the track changes data plugin. However, there are some circumstances when an additional effort needs to be made in order to run track changes data plugin.
In general, the track changes data plugin uses a temporary editor instance to load the current data, accept or discard the suggestions and then get the editor data.
This may raise some issues in the following scenarios:
- if some actions are performed after the editor is initialized (for example, load some kind of data for your custom plugins),
- if you use your own, custom editor class, whose API is different from
ClassicEditor
.
In these cases, you can provide your own callback as a configuration parameter for the track changes data plugin:
Two parameters are passed to the callback:
config
- the editor config that should be used to initialize the editor.createElement
- a function that creates a DOM element, should you need one (or more) to initialize your editor. The DOM elements created by this function are hidden and will be cleared after the plugin finishes its work.
The callback should return a promise that resolves with the editor instance.
An example of a callback using multi-root editor, that requires passing multiple roots in the first parameter of the .create()
method.
Every day, we work hard to keep our documentation complete. Have you spotted an outdated information? Is something missing? Please report it via our issue tracker.