class Editor

Same name in this branch
  1. 8.9.x core/modules/editor/src/Entity/Editor.php \Drupal\editor\Entity\Editor
  2. 8.9.x core/modules/editor/src/Annotation/Editor.php \Drupal\editor\Annotation\Editor
Same name in other branches
  1. 9 core/modules/quickedit/src/Plugin/InPlaceEditor/Editor.php \Drupal\quickedit\Plugin\InPlaceEditor\Editor
  2. 9 core/modules/editor/src/Entity/Editor.php \Drupal\editor\Entity\Editor
  3. 9 core/modules/editor/src/Annotation/Editor.php \Drupal\editor\Annotation\Editor
  4. 9 core/modules/editor/src/Plugin/InPlaceEditor/Editor.php \Drupal\editor\Plugin\InPlaceEditor\Editor
  5. 10 core/modules/editor/src/Entity/Editor.php \Drupal\editor\Entity\Editor
  6. 10 core/modules/editor/src/Annotation/Editor.php \Drupal\editor\Annotation\Editor
  7. 11.x core/modules/editor/src/Entity/Editor.php \Drupal\editor\Entity\Editor
  8. 11.x core/modules/editor/src/Annotation/Editor.php \Drupal\editor\Annotation\Editor
  9. 11.x core/modules/editor/src/Attribute/Editor.php \Drupal\editor\Attribute\Editor
  10. 10 core/modules/editor/src/Attribute/Editor.php \Drupal\editor\Attribute\Editor

Defines the formatted text in-place editor.

Plugin annotation


@InPlaceEditor(
  id = "editor"
)

Hierarchy

Expanded class hierarchy of Editor

39 string references to 'Editor'
CKEditor::buildConfigurationForm in core/modules/ckeditor/src/Plugin/Editor/CKEditor.php
Form constructor.
ContentTranslationTestBase::setupUsers in core/modules/content_translation/tests/src/Functional/ContentTranslationTestBase.php
Creates and activates translator, editor and admin users.
ContentTranslationTestBase::setupUsers in core/modules/content_translation/src/Tests/ContentTranslationTestBase.php
Creates and activates translator, editor and admin users.
demo_umami.info.yml in core/profiles/demo_umami/demo_umami.info.yml
core/profiles/demo_umami/demo_umami.info.yml
DrupalImage::settingsForm in core/modules/ckeditor/src/Plugin/CKEditorPlugin/DrupalImage.php

... See full list

File

core/modules/editor/src/Plugin/InPlaceEditor/Editor.php, line 18

Namespace

Drupal\editor\Plugin\InPlaceEditor
View source
class Editor extends PluginBase implements InPlaceEditorInterface {
    
    /**
     * {@inheritdoc}
     */
    public function isCompatible(FieldItemListInterface $items) {
        $field_definition = $items->getFieldDefinition();
        // This editor is incompatible with multivalued fields.
        if ($field_definition->getFieldStorageDefinition()
            ->getCardinality() != 1) {
            return FALSE;
        }
        elseif ($editor = editor_load($items[0]->format)) {
            $definition = \Drupal::service('plugin.manager.editor')->getDefinition($editor->getEditor());
            if ($definition['supports_inline_editing'] === TRUE) {
                return TRUE;
            }
        }
        return FALSE;
    }
    
    /**
     * {@inheritdoc}
     */
    public function getMetadata(FieldItemListInterface $items) {
        $format_id = $items[0]->format;
        $metadata['format'] = $format_id;
        $metadata['formatHasTransformations'] = $this->textFormatHasTransformationFilters($format_id);
        return $metadata;
    }
    
    /**
     * Returns whether the text format has transformation filters.
     *
     * @param int $format_id
     *   A text format ID.
     *
     * @return bool
     */
    protected function textFormatHasTransformationFilters($format_id) {
        $format = FilterFormat::load($format_id);
        return (bool) count(array_intersect([
            FilterInterface::TYPE_TRANSFORM_REVERSIBLE,
            FilterInterface::TYPE_TRANSFORM_IRREVERSIBLE,
        ], $format->getFiltertypes()));
    }
    
    /**
     * {@inheritdoc}
     */
    public function getAttachments() {
        $user = \Drupal::currentUser();
        $user_format_ids = array_keys(filter_formats($user));
        $manager = \Drupal::service('plugin.manager.editor');
        $definitions = $manager->getDefinitions();
        // Filter the current user's formats to those that support inline editing.
        $formats = [];
        foreach ($user_format_ids as $format_id) {
            if ($editor = editor_load($format_id)) {
                $editor_id = $editor->getEditor();
                if (isset($definitions[$editor_id]['supports_inline_editing']) && $definitions[$editor_id]['supports_inline_editing'] === TRUE) {
                    $formats[] = $format_id;
                }
            }
        }
        // Get the attachments for all text editors that the user might use.
        $attachments = $manager->getAttachments($formats);
        // Also include editor.module's formatted text editor.
        $attachments['library'][] = 'editor/quickedit.inPlaceEditor.formattedText';
        return $attachments;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
Editor::getAttachments public function Returns the attachments for this editor. Overrides InPlaceEditorInterface::getAttachments
Editor::getMetadata public function Generates metadata that is needed specifically for this editor. Overrides InPlaceEditorInterface::getMetadata
Editor::isCompatible public function Checks whether this in-place editor is compatible with a given field. Overrides InPlaceEditorInterface::isCompatible
Editor::textFormatHasTransformationFilters protected function Returns whether the text format has transformation filters.
PluginBase::$configuration protected property Configuration information passed into the plugin.
PluginBase::$pluginDefinition protected property The plugin implementation definition.
PluginBase::$pluginId protected property The plugin_id.
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.
PluginBase::__construct public function Constructs a \Drupal\Component\Plugin\PluginBase object. 6

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.