ckeditor5.post_update.php
Same filename in other branches
Post update functions for CKEditor 5.
File
-
core/
modules/ ckeditor5/ ckeditor5.post_update.php
View source
<?php
/**
* @file
* Post update functions for CKEditor 5.
*/
use Drupal\ckeditor5\HTMLRestrictions;
use Drupal\Core\Config\Entity\ConfigEntityUpdater;
use Drupal\editor\Entity\Editor;
/**
* Updates text formats that has alignment shown as individual buttons.
*/
function ckeditor5_post_update_alignment_buttons(&$sandbox = []) {
$config_entity_updater = \Drupal::classResolver(ConfigEntityUpdater::class);
$callback = function (Editor $editor) {
// Only try to update editors using CKEditor 5.
if ($editor->getEditor() !== 'ckeditor5') {
return FALSE;
}
$needs_update = FALSE;
// Only update if the editor is using the non-dropdown buttons.
$settings = $editor->getSettings();
$old_alignment_buttons_to_types = [
'alignment:left' => 'left',
'alignment:right' => 'right',
'alignment:center' => 'center',
'alignment:justify' => 'justify',
];
if (is_array($settings['toolbar']['items'])) {
foreach ($old_alignment_buttons_to_types as $button => $type) {
if (in_array($button, $settings['toolbar']['items'], TRUE)) {
$settings['toolbar']['items'] = array_values(array_diff($settings['toolbar']['items'], [
$button,
]));
$settings['plugins']['ckeditor5_alignment']['enabled_alignments'][] = $type;
if (!in_array('alignment', $settings['toolbar']['items'], TRUE)) {
$settings['toolbar']['items'][] = 'alignment';
}
// Flag this display as needing to be updated.
$needs_update = TRUE;
}
}
}
if ($needs_update) {
$editor->setSettings($settings);
}
return $needs_update;
};
$config_entity_updater->update($sandbox, 'editor', $callback);
}
/**
* The image toolbar item changed from `uploadImage` to `drupalInsertImage`.
*/
function ckeditor5_post_update_image_toolbar_item(&$sandbox = []) {
$config_entity_updater = \Drupal::classResolver(ConfigEntityUpdater::class);
$callback = function (Editor $editor) {
// Only try to update editors using CKEditor 5.
if ($editor->getEditor() !== 'ckeditor5') {
return FALSE;
}
$needs_update = FALSE;
// Only update if the editor is using the `uploadImage` toolbar item.
$settings = $editor->getSettings();
if (is_array($settings['toolbar']['items']) && in_array('uploadImage', $settings['toolbar']['items'], TRUE)) {
// Replace `uploadImage` with `drupalInsertImage`.
$settings['toolbar']['items'] = str_replace('uploadImage', 'drupalInsertImage', $settings['toolbar']['items']);
// `<img data-entity-uuid data-entity-type>` are implicitly supported when
// uploads are enabled as the attributes are necessary for upload
// functionality. If uploads aren't enabled, these attributes must still
// be supported to ensure existing content that may have them (despite
// uploads being disabled) remains editable. In this use case, the
// attributes are added to the `ckeditor5_sourceEditing` allowed tags.
if (!$editor->getImageUploadSettings()['status']) {
// Add `sourceEditing` toolbar item if it does not already exist.
if (!in_array('sourceEditing', $settings['toolbar']['items'], TRUE)) {
$settings['toolbar']['items'][] = '|';
$settings['toolbar']['items'][] = 'sourceEditing';
// @see \Drupal\ckeditor5\Plugin\CKEditor5Plugin\SourceEditing::defaultConfiguration()
$settings['plugins']['ckeditor5_sourceEditing'] = [
'allowed_tags' => [],
];
}
// Update configuration.
$settings['plugins']['ckeditor5_sourceEditing']['allowed_tags'] = HTMLRestrictions::fromString(implode(' ', $settings['plugins']['ckeditor5_sourceEditing']['allowed_tags']))->merge(HTMLRestrictions::fromString('<img data-entity-uuid data-entity-type>'))
->toCKEditor5ElementsArray();
}
$needs_update = TRUE;
}
if ($needs_update) {
$editor->setSettings($settings);
}
return $needs_update;
};
$config_entity_updater->update($sandbox, 'editor', $callback);
}
Functions
Title | Deprecated | Summary |
---|---|---|
ckeditor5_post_update_alignment_buttons | Updates text formats that has alignment shown as individual buttons. | |
ckeditor5_post_update_image_toolbar_item | The image toolbar item changed from `uploadImage` to `drupalInsertImage`. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.