editor_note-8.x-1.x-dev/src/Hook/EntityHook.php

src/Hook/EntityHook.php
<?php

namespace Drupal\editor_note\Hook;

use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Entity\FieldableEntityInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\editor_note\EditorNoteHelperService;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Drupal\field\Entity\FieldConfig;

/**
 * Be aware of some entity hooks to perform actions on editor note.
 */
class EntityHook implements ContainerInjectionInterface {

  /**
   * Editor Note helper service.
   *
   * @var EditorNoteHelperService
   */
  protected $editorNoteHelper;

  /**
   * The entity reference selection handler plugin manager.
   *
   * @var EntityTypeManagerInterface
   */
  protected $entityTypeManager;

  /**
   * Constructor.
   *
   * @param EditorNoteHelperService $editor_note_helper
   *   Helper service object.
   * @param EntityTypeManagerInterface $entity_type_manager
   *   EntityTypeManager object.
   */
  public function __construct(
    EditorNoteHelperService $editor_note_helper,
    EntityTypeManagerInterface $entity_type_manager) {
    $this->editorNoteHelper = $editor_note_helper;
    $this->entityTypeManager = $entity_type_manager;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static(
      $container->get('editor_note.helper'),
      $container->get('entity_type.manager')
    );
  }

  /**
   * Save Editor Note on entity insert.
   *
   * @param EntityInterface $entity
   *   Entity object.
   *
   * @see editor_note_entity_insert
   */
  public function onEntityInsert(EntityInterface $entity) {
    if (!$entity instanceof FieldableEntityInterface) {
      return;
    }
    $field_definitions = $entity->getFieldDefinitions();
    foreach ($field_definitions as $field_name => $field_definition) {
      if ($field_definition->getType() === 'editor_note_item') {
        $note_value = $entity->get($field_name)->value;
        if (empty($note_value)) {
          return;
        }
        // Create Editor Note entity.
        $this->editorNoteHelper->createNote($entity, $field_name, $note_value);
      }
    }
  }

  /**
   * Delete Editor Note on entity delete.
   *
   * @param EntityInterface $entity
   *   Entity object.
   *
   * @see editor_note_entity_delete
   */
  public function onEntityDelete(EntityInterface $entity) {
    $notes = $this->entityTypeManager->getStorage('editor_note')->loadByProperties([
      'bundle' => $entity->bundle(),
      'entity_id' => $entity->id(),
    ]);
    foreach ($notes as $note) {
      $note->delete();
    }
  }

  /**
   * Delete Editor Note on user deletion.
   *
   * @param EntityInterface $entity
   *   Entity object.
   *
   * @see editor_note_entity_user_delete
   */
  public function onUserDelete(EntityInterface $entity) {
    $notes = $this->entityTypeManager->getStorage('editor_note')->loadByProperties([
      'uid' => $entity->id(),
    ]);
    foreach ($notes as $note) {
      $note->delete();
    }
  }

  /**
   * Reassign Editor Note on user cancel.
   *
   * @param AccountInterface $account
   *   User object.
   *
   * @see editor_note_user_cancel
   */
  public function onUserCancel(AccountInterface $account) {
    $notes = $this->entityTypeManager->getStorage('editor_note')->loadByProperties([
      'uid' => $account->id(),
    ]);
    foreach ($notes as $note) {
      // Assign to anonymous user.
      $note->set('uid', 0);
      $note->save();
    }
  }

  /**
   * Delete on Editor Note revisions on entity revision delete.
   *
   * @param EntityInterface $entity
   *   Entity object.
   *
   * @see editor_note_entity_revision_delete
   */
  public function onEntityRevisionDelete(EntityInterface $entity) {
    $notes = $this->entityTypeManager->getStorage('editor_note')->loadByProperties([
      'bundle' => $entity->bundle(),
      'entity_id' => $entity->id(),
      'revision_id' => $entity->getRevisionId(),
    ]);
    foreach ($notes as $note) {
      $note->delete();
    }
  }

  /**
   * Delete Editor Note on field delete.
   *
   * @param FieldConfig $field
   *   The field being purged.
   *
   * @see editor_note_field_purge_field
   */
  public function onFieldDelete(FieldConfig $field) {
    $entities = $this->entityTypeManager->getStorage('editor_note')->loadByProperties([
      'bundle' => $field->getTargetBundle(),
      'field_machine_name' => $field->getName(),
    ]);

    foreach ($entities as $entity) {
      $entity->delete();
    }
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc