We are happy to announce the release of CKEditor 5 v44.2.0.
Release Highlights
🖥️ Enhanced Source Code Editing (⭐)
Introducing new premium feature: Enhanced Source Code Editing. It displays the source code in a dialog and is compatible with all editor types. It offers syntax highlighting, code completion, code folding, and other advanced functionalities. Additionally, it supports both HTML and Markdown formats.
📤 Uploadcare and image optimizer (⭐)
We have integrated the Uploadcare image manager service, enabling you to upload and edit images to their cloud environment. You can upload files from various sources, including local devices, social media, or online drives ensuring rapid uploads. The integration takes care of efficient media delivery with responsive images mechanism, making sure your users will save bandwidth and have faster website loading. You can also optimize images with the built-in image editor which offers a range of features, such as cropping, rotating, flipping, photo filters and more. All this directly from the editor, try it out!
🖼️ Image Merge Fields (⭐)
Image merge fields are a new type of merge fields, dedicated for image placeholders. They maintain all standard image interactions, like styling, resizing or captions (in which you can use merge fields too!) At the same time, they keep all merge fields functionalities, like data previews or document export integration. In the document data, image merge fields are represented like other images, however their src
attribute is set to a respective merge field, for example, src="{{CompanyLogo}}"
, making them easy to post-process!
📝 Track Changes Preview (⭐)
We have added the preview mode that displays a document with all suggestions accepted. Accessible from the track changes dropdown, this modal preview helps check the final content without extensive markers.
😀 Emoji support
They are here! 🎉 🥳 🎊 Insert emojis effortlessly in the editor by typing :
or through a user-friendly emoji picker. This feature enhances the richness of your content by allowing quick access to a wide range of emojis.
⚡ Performance improvements: Part 4
Here comes the final batch of the planned performance improvements in the editor loading speed area, that we worked on through a couple of past releases.
- A new caching mechanism in
Mapper
now handles model-to-view mappings, substantially improving performance for loading and saving data. - Images with specified height and width automatically use
[loading="lazy"]
in the editing area, optimizing the loading time (read more on MDN). This attribute is only applied during editing to enhance the loading efficiency of images, and it does not reflect in the final data output.
We are greatly satisfied with the improved editor loading times. At the same time, we acknowledge some other problematic areas, and we will keep delivering more performance-related improvements in the future.
MINOR BREAKING CHANGES ℹ️
- engine:
Mapper#registerViewToModelLength()
is now deprecated and will be removed in one of the upcoming releases. This method is useful only in obscure and complex converters, where model element, or a group of model elements, are represented very differently in the view. We believe that every feature using a custom view-to-model length callback can be rewritten in a way that this mechanism is no longer necessary. Note: if this method is used, the caching mechanism forMapper
will be turned off which may degrade performance when handling big documents. Note: this method is used by the deprecated legacy lists feature. As a result, you will not experience the performance improvements if you are still using the deprecated legacy lists feature. - image: Starting this release, images that have
[height]
and[width]
attributes set will automatically receive the[loading="lazy"]
attribute in the editing area. This happens only for the content loaded into the editor, the data output produced by the editor remains the same. The reason for this change is to improve user experience in documents that may contain hundreds of images. - list: The
lower-alpha
andupper-alpha
list styles are now upcasted tolower-latin
andupper-latin
styles. - merge-fields: The
MergeFieldsEditing#getLabel()
method will now returnnull
instead of the merge field id if the merge field definition was not found or it did not contain thelabel
property. - basic-styles: Elements which contains the
[style]
attribute withword-wrap: break-word
will not be converted to<code>
. See #17789.
Features
- ai: Comment threads will now be preserved when AI Assistant processes selected content with comments. This can be disabled through the
ai.aiAssistant.preserveComments
flag. Note, that the actual result depends on the response provided by the AI model (AI model has to keep the comments markup in the response). Additionally, the copy-paste comments functionality must be enabled (configured bycomments.copyMarkers
). - ai: The
ai.aiAssistant.removeCommands
configuration now allows removing entire command groups. - ckbox: It is now allowed to specify which files chosen from CKBox are downloadable. Closes #15928. (commit)
- clipboard: Added the ability to detect paste events originating from the editor. Closes #15935. (commit)
- clipboard: Passed information to the downcast converter when clipboard pipeline is used to allow for customization. Closes #17745. (commit)
- clipboard: The
viewToPlainText()
helper will now parse the viewRawElement
instances. Closes #17746. (commit) - emoji: Created the Emoji feature. Closes #17361. (commit)
- image: Added a possibility to break the current block by
InsertImageCommand
with thebreakBlock
flag. Closes #17742. (commit) - list: Allowed to specify which list style types are shown in list type selector dropdown. Closes #17176. (commit)
- list: Added support for the
lower-alpha
andupper-alpha
list type highlighting in the list style properties buttons. Closes #17424. (commit) - mention: Allowed the mention marker to be longer than 1 character. Closes #17744. (commit)
- merge-fields: Introduced the image merge fields.
- merge-fields: Added the
[data-merge-field-name]
attribute in the editing pipeline. - merge-fields: Use the actual merge field value when they are copied from the editor in preview mode other than
$labels
. - source-editing-enhanced: Introduced the Enhanced Source Code Editing feature.
- table: Improve aria attributes in the table and cell align toolbars. Closes #17722. (commit)
- track-changes: Introduced the final document preview for track changes. It allows to display the document with all suggestions accepted in the modal.
- ui: The
.ck-with-instant-tooltip
class may now be used to display the tooltip without the delay. Closes #17743. (commit) - upload: Added support for passing a callback to the
SimpleUploadConfig#headers
property. Closes #15693. (commit) - uploadcare: Introduced the Uploadcare integration.
- utils: Added a
collectStylesheets()
helper function to retrieve style sheets from the provided URLs. (commit)
Bug fixes
- ai: The content generated by the AI Assistant will now be correctly inserted into tables when both "Replace" and "Insert below" actions are used.
- basic-styles: The
Code
feature should not convert element with theword-wrap: break-word
style into the<code>
tag. Closes #17789. (commit) - cloud-services: No longer keep refreshing token if the
cloudServices.tokenUrl
method failed in the initialization of the plugin. Closes #17531. (commit) - comments: Unlinked comment threads created before the editor initialization are now correctly handled and displayed in the comments archive. This error was experienced in asynchronous integrations which are using the
Context
mechanism. - comments: Do not allow editing content source via the source mode in the comments-only mode.
- comments: Introduced the name field tooltip in comments UI.
- editor-classic: Export
ClassicEditorUIView
from package. (commit) - editor-inline: No longer crash while destroying the editor when the editable was manually detached before destroying. Closes #16561. (commit)
- editor-multi-root: No longer crash while destroying the editor when the editable was manually detached before destroying. Closes #16561. (commit)
- image: The insert image via URL dialog can now be submitted by pressing the Enter key. Closes #16902. (commit)
- link: Trailing punctuation is no longer included in an autolinked URL. Closes #14497. (commit)
- list: The list style buttons should show proper list type after clicking list for the first time. (commit)
- list-multi-level: Multi-level lists should work when typing in Japanese.
- merge-fields: Do not automatically convert the merge-fields-like text containing disallowed characters.
- merge-fields: Properly handle block merge fields mixed with text during data upcast and pasting.
- revision-history: The Revision history feature sidebar header height now matches the height of the editor toolbar.
- revision-history: The Revision history feature loading overlay now overlaps images correctly.
- table: Prevent a table corruption when setting editor data with
<th>
cells followingcolspan
rows. Closes #17556, #17404. (commit) - track-changes: Introduced the name field tooltip in suggestions UI.
- typing: Fixed not working two-step caret movement on iOS devices. Closes #17171. (commit)
- ui: Tooltip will no longer show after quickly hovering and moving the mouse away before the tooltip shows. Closes #16949. (commit)
- ui: Destroying another editor instance while a modal is open will no longer unlock page scroll. Closes #17585. (commit)
- utils: Extended
getEnvKeystrokeText()
with option to use it in the context of specified environment which allows to generate keystrokes text for different OS than the host one. (commit) - Treat types as production dependencies. Fixes #17213. (commit)
- Unify TypeScript declaration files. Fixes #17575 and #17533. (commit)
Other changes
- ai: Exported the
AIAssistantUI
class and theAIAssistantConfig
,CommandDefinition
andGroupDefinition
types. - clipboard: Exported the
ViewDocumentPasteEvent
type from the@ckeditor/ckeditor5-clipboard
package. (commit) - comments: Exported the
AddCommentThreadEventData
type. - comments: Activating an annotation now scrolls to the target if it is out of view.
- comments: Fixed the wrong
filter()
callback signature inAnnotationsUIs#activate()
. - engine: Introduced dynamic caching in
Mapper
to improve view-to-model mapping performance, and as a result improve editor data load and data save performance. Closes #17623. (commit) - engine: A new parameter
data
was added for thechange:children
event fired byViewElement
andViewDocumentFragment
when their children change. Thedata
parameter is an object with theindex
property, which says at which index the change happened. Related to #17623. (commit) - engine:
Mapper#registerViewToModelLength()
is now deprecated and will be removed in one of upcoming releases. Note: if this method is used, the caching mechanism forMapper
will be turned off which may degrade performance when handling big documents. Note: this method is used by the deprecated legacy lists feature. See #17623. (commit) - engine: Export
SchemaCompiledItemDefinition
type. Closes #17783. (commit) - engine: Improve performance of the placeholders. (commit)
- engine: Do not store non-document operation with batches. This improves memory efficiency for huge documents. Closes #17678. (commit)
- engine: Improve performance of
Selection#getSelectedBlocks
when selection contains block elements with many blocks inside (such as table). Closes #17629. (commit) - font: Export
ColorSelectorDropdownView
type. Closes #17783. (commit) - image: The
[loading="lazy"]
attribute will be automatically added in editing view to images with theheight
andwidth
attributes set to improve loading performance. (commit) - list: Skip already visited list elements during reconversion and post fixing for better performance. Fixes #17625. (commit)
- merge-fields: The
MergeFieldsEditing#refreshMergeFields()
method is now public and available for external use. - merge-fields: Remove the default values preview mode if there is none or the merge fields has a default value configured.
- merge-fields: Display ellipsis if the merge field name does not fit the dropdown.
- pagination: Do not wait for images with
[width]
and[height]
attributes. - pagination: Do not wait for loading images that have
[width]
and[height]
attributes set when calculating pages. - real-time-collaboration: Export the
Sessions
class. - real-time-collaboration: Changed how errors related to real-time collaboration are handled. Previously, the original error was always logged on the console, and a
realtimecollaborationclient-
error was thrown without information related to the original error. Now, the original error is not logged anymore. Instead, therealtimecollaborationclient-
error includes thedata.originalError
property with the original error message. This way it is possible to save error details through a custom error logging mechanism. Note, that without any custom mechanism, therealtimecollaborationclient-
error will still be unhandled and logged to the console. - real-time-collaboration: The editor now switches to read-only mode if the real-time collaboration client crashes, ensuring that the user cannot further edit the document and no data is accidentally lost.
- ui: Added Enhanced Source Code Editing as a default menu bar item, making it visible in the menu bar when the plugin is present in the editor. (commit)
- ui: Extended the dialog API to support custom keystroke handler options, allowing to override priorities of the keystroke callback and filter keystrokes based on arbitrary criteria. (commit)
- ui: The
ImageInsertUI#registerIntegration
method now supports handling an array of views for a specific integration type. This allows, for example, registering anassetManager
integration with multiple sources likeFacebook
andInstagram
, where each source has its own dedicated button. (commit) - ui: Exported the
DocumentColorCollection
class. Closes #17783. (commit) - utils: Extended key codes with the
End
andHome
keys, enabling the use and display of shortcuts containing these keys in the UI. (commit) - utils: Exported the
add()
function. Closes #17783. (commit)
Released packages
Check out the Versioning policy guide for more information.
Released packages (summary)
New packages:
- @ckeditor/ckeditor5-emoji: v44.2.0
- @ckeditor/ckeditor5-source-editing-enhanced: v44.2.0
- @ckeditor/ckeditor5-uploadcare: v44.2.0
Minor releases (contain minor breaking changes):
- @ckeditor/ckeditor5-engine: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-image: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-list: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-merge-fields: v44.1.0 => v44.2.0
Releases containing new features:
- @ckeditor/ckeditor5-ckbox: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-clipboard: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-code-block: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-core: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-mention: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-paste-from-office: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-source-editing: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-special-characters: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-table: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-ui: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-upload: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-utils: v44.1.0 => v44.2.0
Other releases:
- @ckeditor/ckeditor5-adapter-ckfinder: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-ai: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-alignment: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-autoformat: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-autosave: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-basic-styles: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-block-quote: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-bookmark: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-balloon: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-balloon-block: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-classic: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-decoupled-document: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-inline: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-build-multi-root: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-case-change: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-ckfinder: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-cloud-services: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-collaboration-core: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-comments: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-document-outline: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-easy-image: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-editor-balloon: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-editor-classic: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-editor-decoupled: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-editor-inline: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-editor-multi-root: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-enter: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-essentials: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-export-pdf: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-export-word: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-find-and-replace: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-font: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-format-painter: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-heading: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-highlight: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-horizontal-line: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-html-embed: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-html-support: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-import-word: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-indent: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-language: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-link: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-list-multi-level: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-markdown-gfm: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-media-embed: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-minimap: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-operations-compressor: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-page-break: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-pagination: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-paragraph: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-paste-from-office-enhanced: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-real-time-collaboration: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-remove-format: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-restricted-editing: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-revision-history: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-select-all: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-show-blocks: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-slash-command: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-style: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-template: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-theme-lark: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-track-changes: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-typing: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-undo: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-watchdog: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-widget: v44.1.0 => v44.2.0
- @ckeditor/ckeditor5-word-count: v44.1.0 => v44.2.0
- ckeditor5-collaboration: v44.1.0 => v44.2.0
- ckeditor5-premium-features: v44.1.0 => v44.2.0