The comments feature makes it possible to add comments to any part of rich-text content in CKEditor 5, including text and block elements such as embedded media or images.
Commented content is marked as highlighted and a corresponding comment balloon is displayed in the sidebar or inline. Comments can be added, edited, deleted and replied to, allowing the users to collaborate on the same document directly in the rich-text editor.
Comment threads can be displayed in a sidebar or as inline balloons. See the Comments display mode guide to learn how to configure the display mode.
This sample automatically switches between display modes according to the screen size. Resize the window and observe how the editor changes its appearance.
A comments-only mode is available, too, if you want to limit the user permissions and only allow them to add comments to the document, but not edit it directly.
# Use as a standalone plugin
The comments plugin does not require real-time collaboration to work. If you prefer a more traditional approach with asynchronous document editing, comments can be added to CKEditor 5 just like any other plugin.
To learn how to integrate comments as a standalone plugin, refer to the Integrating comments with your application guide.
# Use with real-time collaboration
If you are using the real-time collaboration feature, refer to the Real-time collaboration features integration guide.
# Comments markup
Comments are always attached to some place in the document. To make sure that they will not be lost, the comments plugin adds some special markup to the document:
> editor.getData(); <- '<p>They are <comment id="b39dd790" type="start"></comment>awesome<comment id="b39dd790" type="end"></comment>.</p>'
The position of a comment in the content is marked with a custom
<comment> tag. Separate elements for the beginning and the end of a comment are used to make it easier to process the content (e.g. before rendering it on your website).
Note that if your application filters HTML content, for example to prevent XSS, make sure to leave the
<comment> tags in place when saving the content in the database. The comment markup is necessary for further editing sessions.
So, with the example content above, to display the document on your website the
<comment> tags may be removed:
<p>They are awesome.</p>
When launching the editor, though, make sure to include them in the HTML:
<div id="container"> <div id="editor"> <p>They are <comment id="b39dd790" type="start"></comment>awesome<comment id="b39dd790" type="end"></comment>.</p> </div> <div id="sidebar"></div> </div>
# Why is there no comments data in content?
Note that markers only store comment thread IDs. Why do they not include any content?
The reason is security. If you stored the whole comment discussion with the editor content, a malicious user could edit it, including comments written by other authors. It would be very hard to check which changes in the comments the user has done when saving data. You would need to analyze the whole content of the document and compare it to the previous version. Considering that both content and comments could change at the same time and they are mixed, it would be a hard task to be sure that only authorized changes were introduced. For these reasons, adapter integration is the recommended one.
However, if you want to save your content together with the comments data, check A simple “load and save” integration guide which should help you.
# Characters limit
For technical reasons, each comment in the thread has a character limit set to 4000 characters. Note that comment content is stored in the HTML format, so the HTML tags (which are invisible for the user) use up some characters. Nevertheless, the 4000 characters limit allows you to create a really long comment and should be sufficient for any use case. If the limit is exceeded, the user interface will prevent the user from submitting the comment.
# Comments feature customization
The comments feature is highly customizable. Please refer to the Annotation customization section to learn more.