TinyMCE 7.6.0

These are the Tiny Cloud and TinyMCE Enterprise release notes. For information on the latest community version of TinyMCE, see the TinyMCE Changelog.

Overview

TinyMCE 7.6.0 was released for TinyMCE Enterprise and Tiny Cloud on Wednesday, December 11th, 2024. These release notes provide an overview of the changes for TinyMCE 7.6.0, including:

New Premium plugin

The following new Premium plugin was released alongside TinyMCE 7.6.0.

Image Optimizer (Powered by Uploadcare)

TinyMCE 7.6.0 introduces the Image Optimizer (Powered by Uploadcare) plugin.

The Image Optimizer plugin offers a range of powerful features for image hosting, serving, and editing. These include responsive image delivery, automatic image format selection, automatic compression, and non-destructive image transformations and adjustments, all powered by Uploadcare.

For information on the Image Optimizer (Powered by Uploadcare) plugin, see Image Optimizer (Powered by Uploadcare).

Accompanying Premium plugin changes

The following premium plugin updates were released alongside TinyMCE 7.6.0.

Accessibility Checker

The TinyMCE 7.6.0 release includes an accompanying release of the Accessibility Checker premium plugin.

Accessibility Checker Premium plugin includes the following fixes and improvements.

Introduced a new live region for screen readers to improve accessibility checker dialog announcements

Previously, an issue was identified where screen reader announcements for the accessibility dialog were inconsistent across different browsers. This inconsistency resulted in a poor user experience with screen readers and accessibility dialogs.

In TinyMCE 7.6.0, this issue has been resolved by adding a dedicated hidden screen reader section within the dialog structure, ensuring more consistent and accurate announcements across browsers.

Add detailed issue description to accessibility checker

An issue was identified where users relying on screen readers did not receive sufficient context about the current content when navigating the accessibility checker. This limitation could cause confusion and make it challenging for users to understand or resolve accessibility issues effectively.

To address this, TinyMCE 7.6.0 introduces a new section that clearly displays the content type and includes a snippet of the content. This enhancement provides users with better context and improves the overall navigation experience. By offering more comprehensive indicators, this update ensures screen reader users can efficiently identify and address accessibility issues within the content.

Improve editor content highlighting when using accessibility checker

Previously, an issue involving the accessibility checker was identified where the content area highlights did not properly meet accessibility standards. This issue caused users with vision impairments to encounter difficulty in identifying the currently focused element.

In TinyMCE 7.6.0, this issue has been resolved by unifying the color palette to meet accessibility color contrast standards, ensuring that all users can easily locate the currently focused element.

For information on the Accessibility Checker plugin, see: Accessibility Checker.

Checklist

The TinyMCE 7.6.0 release includes an accompanying release of the Checklist premium plugin.

Checklist Premium plugin includes the following fix.

Checklist items were unresponsive in center or right alignments

In previous versions of TinyMCE, an issue was identified where users could not check checklist items when they were center or right aligned. This occurred because the logic for detecting clicks relied on the left-most position of the <li> element, which remains unchanged regardless of text alignment.

As a result, clicks in center or right alignments would fail the logic check, leaving the items unresponsive.

TinyMCE 7.6.0 addresses this issue. Now, the logic compares the click position against the left-most position of the aligned text, rather than the parent <li> element. This adjustment ensures that clicks are properly registered regardless of alignment, restoring expected functionality across all alignment settings.

For information on the Checklist plugin, see: Checklist.

Comments

The TinyMCE 7.6.0 release includes an accompanying release of the Comments premium plugin.

Comments includes the following fixes and improvements.

The commentAuthor property is now included in reply events of the event log.

In previous versions of the tinycomments plugin, the commentAuthor property was missing from 'reply' events within the event log, which led to incomplete tracking of user interactions when retrieving data through the getEventLog() API.

TinyMCE 7.6.0 addresses this issue. Now, the commentAuthor property is included in 'reply' events in the event log.

For more information on the getEventLog, see getEventLog.

Allow mentions in comments dropdown to flow freely outside of the editor container

An issue was identified where the mentions in comments dropdown didn’t freely expand to the available space alongside mentions in the editor. This was due to the dropdown being restricted within the sidebar area.

In TinyMCE 7.6.0, this issue has been resolved by allowing the mentions in comments dropdown to expand outside the sidebar area, making full use of the available space outside the editor and improving the overall user experience.

Reduced the amount of scrolling when changing between conversations in the sidebar.

Previously, the scrolling behavior for comment cards was inconsistent. When scrolling from top to bottom, the scrolling would stop at the top of a comment card, whereas scrolling from bottom to top would stop at the bottom of a comment card. This inconsistency could cause confusion when navigating through comments in the sidebar.

In TinyMCE 7.6.0, the sidebar scrolling behavior has been updated to ensure consistency. When a conversation is selected and is either partially or completely out of view, the sidebar now scrolls to position the top of the selected conversation just below the top of the sidebar.

An exception does apply if the selected conversation is already partially visible, with the top in view but the bottom out of view, and the comment card’s height is smaller than the scrollable container. In this scenario, the sidebar will scroll to position the bottom of the selected card near the bottom of the container.

Scroll to show action buttons when replying/editing a comment.

Previously, if a selected conversation card was positioned near the bottom of the sidebar, the reply/edit input field would be below the bottom of the sidebar resulting in the comment input field not being visible to the user.

TinyMCE 7.6.0 addresses this issue. Now, the sidebar scrolls to display the comment input field if the selected conversation card is positioned near the bottom of the sidebar. This ensures that the comment input field is always visible to the user.

Pressing Shift+Enter in Mentions in Comments dropdown should accept the active menu item

In previous versions of TinyMCE, the Shift+Enter key was not properly handled when used with mentions in comments. This led to a new line being inserted while the mentions dropdown remained open, resulting in inconsistent behavior compared to mentions within the editor.

In TinyMCE 7.6.0, mentions in comments now handle the Shift+Enter key by inserting the highlighted user into the comment text area and closing the dropdown, ensuring consistent functionality across the editor and comment areas.

Adjust tinycomments UI font size to match the editor UI font size

Previously, the Comments plugin used a 14px font size for the comment body, which was inconsistent with the 16px font size used in the rest of the Comments Sidebar and the editor UI.

This issue has been resolved in TinyMCE 7.6.0 by setting the comment body font size to 16px, ensuring font size consistency between the Comments plugin and the editor UI.

Editor Focus after Deleting a Comment

Previously, the focus behaviour in the comments sidebar was observed to be inconsistent. When a user deleted a comment, the focus exited the comments sidebar and returned to the editor instead of returning to the conversation card. This also occurred when a new comment was created inside an existing conversation, and when an entire new conversation was created.

In TinyMCE 7.6.0, the focus behaviour has now been improved in the following situations:

  • Deleting a comment now returns the focus to the conversation card that contained the deleted comment.

  • Creating a new comment within an existing conversation now brings the focus to the corresponding conversation card.

  • Starting a new conversation now brings the focus to the newly created conversation card.

Added tooltips to conversation and comment kebab menus

In previous versions of Comments, the kebab menu button in the comments sidebar was missing a tooltip for users relying on assistive technologies.

TinyMCE 7.6.0 addresses this issue, by adding an aria-label with the description "Comment Actions" to the sidebar comment menu button, ensuring a tooltip is displayed on hover. This update improves accessibility and aligns the user experience across different menu buttons.

The caret in comment textarea returned to its previous location before closing the mentions menu by selecting with the mouse.

Previously, when closing the Mentions dropdown in a Comment textarea by clicking away, the caret would revert to its previous position, disregarding the user’s mouse-click location. This issue occurred because the logic for handling caret positioning did not account for mouse interactions, resulting in a disjointed and confusing user experience.

In TinyMCE 7.6.0 this issue was addressed. Now, the caret now accurately reflects the user’s intended position when the Mentions dropdown is closed via a mouse-click.

For information on the Comments plugin, see: Introduction to Tiny Comments.

Enhanced Code Editor

The TinyMCE 7.6.0 release includes an accompanying release of the Enhanced Code Editor premium plugin.

Enhanced Code Editor Premium plugin includes the following fix.

Spelling error in tooltip for fullscreen toggle button

The tooltip for the fullscreen toggle button was incorrectly labeled as Fullsceen. TinyMCE 7.6.0 addresses this issue which has now been corrected to Fullscreen.

For information on the Enhanced Code Editor plugin, see: Enhanced Code Editor.

Accompanying Enhanced Skins & Icon Packs changes

The TinyMCE 7.6.0 release includes an accompanying release of the Enhanced Skins & Icon Packs.

Enhanced Skins & Icon Packs

The Enhanced Skins & Icon Packs release includes the following updates:

The Enhanced Skins & Icon Packs were rebuilt to pull in the changes also incorporated into the default TinyMCE 7.6.0 skin, Oxide.

For information on using Enhanced Skins & Icon Packs, see: Enhanced Skins & Icon Packs.

Improvements

TinyMCE 7.6.0 also includes the following improvements:

Base64 data was not properly decoded due to unhandled URL-encoded characters.

Previously, URL-encoded characters were not properly handled during base64 data decoding. This issue caused images to appear broken when using a base64 string as a source with URL-encoded characters.

In TinyMCE 7.6.0, this issue has been resolved by implementing logic to decode URL-encoded characters before processing the base64 string. As a result, images using base64 strings as a source will now appear correctly, even if URL-encoded characters are included.

The latin list style type is now recognized as an alias for the alpha list style type.

Previously, TinyMCE did not recognize lower-latin and upper-latin list style types, causing UI issues when importing documents with such lists.

In TinyMCE 7.6.0, this issue has been resolved. The editor now recognizes lower-latin and upper-latin as aliases for lower-alpha and upper-alpha, respectively, ensuring the correct list type is highlighted in the Numbered List dropdown.

Additions

TinyMCE 7.6.0 also includes the following additions:

Add Labels and Groups for Context Toolbar Buttons

The release of TinyMCE 7.6.0 introduces the ability to organize context toolbar buttons into groups with optional labels or titles. This enhancement improves toolbar usability by enabling clearer categorization of buttons.

The items object structure now supports defining groups with an optional name property for titles or a label property for identifying the group. This feature allows developers to create more intuitive and accessible toolbars by visually segmenting functionality.

Example of a context toolbar configuration with groups and labels:

Example
items: [
  {
    name: 'Formatting', // Optional, used as the group's title
    items: [ 'bold', 'italic' ] // Array of registered button names
  },
  {
    label: 'History', // Optional, used as a label for the group
    items: [ 'undo', 'redo' ] // Array of registered button names
  },
]

For more details on configuring context toolbar groups and labels, see: Context Toolbar.

New back function in ContextFormApi to go back to the previous toolbar.

TinyMCE 7.6.0 introduces the back function in the ContextFormApi, enabling users to navigate back to the previous toolbar. This enhancement fulfills the need for a back button in context forms, providing a seamless way to return to the previous toolbar configuration when required.

Example: Using the back function in a context form
tinymce.init({
  selector: "textarea",
  setup: (ed) => {
    ed.ui.registry.addContextToolbar('toolbar-with-back-example', {
      items: 'form-with-back-example undo redo',
      position: 'node',
      scope: 'node',
      predicate: (node) => node.nodeName.toLowerCase() === 'p'
    });
    ed.ui.registry.addContextForm('form-with-back-example', {
      type: 'contextsizeinputform',
      launch: {
        type: 'contextformtogglebutton',
        icon: 'resize',
        tooltip: 'ABC'
      },
      initValue: () => ({ width: '100', height: '200' }),
      onInput: (formApi) => console.log(`input.${JSON.stringify(formApi.getValue())}`),
      commands: [
        {
          type: 'contextformbutton',
          icon: 'chevron-left',
          tooltip: 'Back',
          align: 'start',
          onAction: (formApi) => formApi.back()
        }
      ]
    });
  }
});

For more details on the back function, see Context Form - ContextFormApi.

New QuickbarInsertImage command that is executed by the quickimage button.

The Quickbars Plugin now allows integrators to overwrite the QuickbarInsertImage command, enabling customization of the quickimage button’s behavior.

Example of how to override the QuickbarInsertImage command:
tinymce.init({
  selector: 'textarea',
  plugins: 'quickbars',
  toolbar: false,
  setup: (editor) => {
    editor.addCommand('QuickbarInsertImage', () => { // Add a custom command to the editor named "QuickbarInsertImage"
      const input = document.createElement('input'); // Create a new <input> element for file selection
      input.type = 'file'; // Set the input type to "file" for uploading files
      input.accept = 'image/*'; // Restrict the input to accept only image files
      input.onchange = (e) => { // Add an event listener to handle the file selection event
        const file = (e.target).files?.[0]; // Get the selected file from the input element
        if (file) {
          console.log(file);
        }
      };
      input.click();
    });
  }
});

New onSetup function for context forms

A new onSetup API has been introduced for context forms, enabling integrators to execute a function when the form is rendered and handle cleanup when it is closed. This enhancement addresses the previous limitation of not being able to detect or trigger actions during the lifecycle of context forms. The onSetup API streamlines lifecycle management by supporting initialization at form rendering and providing a return function for cleanup, enhancing integration with plugins and applications.

For more details on the onSetup function, see Context Form.

Added placeholder support for context form input fields

A new placeholder option has been introduced to the context form API, addressing the need for inline guidance within input fields. This feature enables developers to specify placeholder text that appears inside input fields until the field has a value. By providing contextual hints, this enhancement improves usability and enhances the user experience.

Example: Using a placeholder in a context form input field
tinymce.init({
  selector: 'textarea',
  setup: (editor) => {
    editor.ui.registry.addContextForm('my-form', {
      predicate: () => true,
      placeholder: 'Placeholder goes here...',
      commands: []
    });
  },
});

For more details on the placeholder option, see Context Form.

New disabled option for disabling all user interactions

A new disabled option has been introduced to TinyMCE in version 7.6.0. This option allows integrators to disable all user interactions with the editor, including cursor placement, content modifications, and UI components. When set to true, the editor behaves similarly to the readonly mode changes introduced in TinyMCE 7.4.0 but ensures complete non-interactivity.

Example disabling all user interactions with the editor
tinymce.init({
  selector: 'textarea',  // Specify the target HTML element
  disabled: true         // Disables all interactions with the editor
});

For more information on the disabled option, see Disabled option.

Bug fixes

TinyMCE 7.6.0 also includes the following bug fixes:

Image selection was removed when calling nodeChanged while having focus inside the editor UI.

Previously, executing a nodeChange event while an image was selected caused the image to lose its resize handles. This issue disrupted the user experience, requiring users to re-select the image to resize it.

TinyMCE 7.6.0 addresses this issue. Now, resize handles are only removed when focus moves out of the editor or its UI components.

As a result, the resize handles remain visible during nodeChange events, improving usability.

Tooltip would not show for group toolbar button.

Previously, an issue was identified where tooltips were not displayed when hovering over toolbar group buttons. This was due to replacing the title attribute with an aria-label attribute in TinyMCE 7.0.0 without implementing the custom tooltip behavior for the toolbar group buttons.

In TinyMCE 7.6.0, this issue has been resolved by applying the custom tooltip behavior to the toolbar group buttons, ensuring that tooltips are now displayed on hover.

Numbered table context menu not properly applying changes

Previously, there was an issue where changes to the row type in numbered tables were not properly applied. This occurred because the action of modifying the row type from a contentEditable="false" cell was being deliberately blocked.

In TinyMCE 7.6.0, this issue has been resolved by removing the restriction on changing the row type from a contentEditable="false" cell. As a result, changes to the row type are now correctly applied.

The samp format was being applied as a block level format, instead of an inline format.

Previously, an issue was identified where the samp (Sample) format was incorrectly applied as a block-level format instead of an inline format. This caused the entire element to receive the samp format and be placed on a new line, rather than just the selected text receiving the format.

In TinyMCE 7.6.0, this issue has been resolved by registering the samp format as an inline format. This ensures that elements with the samp format are treated as inline elements, maintaining the intended content flow.

Removed title attribute from dialog tree elements as they already have a tooltip.

Previously, an issue was identified with tooltips for tree structures where multiple tooltip systems displayed the same text simultaneously:

  1. The browser’s native tooltip, triggered by the title attribute, displayed the text.

  2. TinyMCE’s custom tooltip functionality also displayed the text.

As a consequence, this caused two tooltips with identical content to appear at the same time, leading to a confusing user experience, where the desired behavior was to show only the custom tooltip provided by TinyMCE.

In TinyMCE 7.6.0, this issue has been resolved. The title attribute is now automatically removed when the custom tooltip is applied, ensuring that only the custom tooltip is displayed.

Fixed CSS Bundling for Skin UI Content CSS

In self-hosted React setups, image resize handles were not displayed when using bundled TinyMCE editors. This issue impacted the usability of features such as image resizing.

The root cause was a misconfiguration of resource keys for the CSS bundling JS files and CSS loading logic in TinyMCE core. As a result, bundled editors failed to load the necessary styles, causing the resize handles to remain hidden.

This issue affected TinyMCE versions earlier than 7.1.0.

TinyMCE 7.6.0 resolves this issue by updating the stylesheetLoader to correctly load the ui/default/content.css stylesheet, ensuring that image resize handles are displayed as expected.

Incorrect translation of Cut Column and Copy Column in Hebrew

An issue was identified where the Hebrew translations for Cut Column and Copy Column in the table plugin were incorrect.

TinyMCE 7.6.0 addresses this issue by providing the correct Hebrew translations for these operations.

Known issues

This section describes issues that users of TinyMCE 7.6.0 may encounter and possible workarounds for these issues.

There is one known issue in TinyMCE 7.6.0.

Missing translations for "Solution" for all languages in the Accessibility Checker

In TinyMCE 7.6.0, the "Solution" translation is missing for all languages in the Accessibility Checker. This issue affects the "Solution" section of the Accessibility Checker, where the "Solution" text is not displayed in the user’s selected language.

Status: Currently under investigation.