1. 8.5.x core/modules/action/src/ActionAddForm.php
  2. 8.0.x core/modules/action/src/ActionAddForm.php
  3. 8.1.x core/modules/action/src/ActionAddForm.php
  4. 8.2.x core/modules/action/src/ActionAddForm.php
  5. 8.3.x core/modules/action/src/ActionAddForm.php
  6. 8.4.x core/modules/action/src/ActionAddForm.php
  7. 8.6.x core/modules/action/src/ActionAddForm.php

Namespace

Drupal\action

File

core/modules/action/src/ActionAddForm.php
View source
<?php

namespace Drupal\action;

use Drupal\Component\Utility\Crypt;
use Drupal\Core\Action\ActionManager;
use Drupal\Core\Entity\EntityStorageInterface;
use Drupal\Core\Form\FormStateInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Provides a form for action add forms.
 */
class ActionAddForm extends ActionFormBase {

  /**
   * The action manager.
   *
   * @var \Drupal\Core\Action\ActionManager
   */
  protected $actionManager;

  /**
   * Constructs a new ActionAddForm.
   *
   * @param \Drupal\Core\Entity\EntityStorageInterface $storage
   *   The action storage.
   * @param \Drupal\Core\Action\ActionManager $action_manager
   *   The action plugin manager.
   */
  public function __construct(EntityStorageInterface $storage, ActionManager $action_manager) {
    parent::__construct($storage);
    $this->actionManager = $action_manager;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static($container
      ->get('entity.manager')
      ->getStorage('action'), $container
      ->get('plugin.manager.action'));
  }

  /**
   * {@inheritdoc}
   *
   * @param string $action_id
   *   The hashed version of the action ID.
   */
  public function buildForm(array $form, FormStateInterface $form_state, $action_id = NULL) {

    // In \Drupal\action\Form\ActionAdminManageForm::buildForm() the action
    // are hashed. Here we have to decrypt it to find the desired action ID.
    foreach ($this->actionManager
      ->getDefinitions() as $id => $definition) {
      $key = Crypt::hashBase64($id);
      if ($key === $action_id) {
        $this->entity
          ->setPlugin($id);

        // Derive the label and type from the action definition.
        $this->entity
          ->set('label', $definition['label']);
        $this->entity
          ->set('type', $definition['type']);
        break;
      }
    }
    return parent::buildForm($form, $form_state);
  }

}

Classes

Namesort descending Description
ActionAddForm Provides a form for action add forms.