class GroupDeleteForm in Context groups 8
Same name and namespace in other branches
- 8.2 src/Form/GroupDeleteForm.php \Drupal\context_groups\Form\GroupDeleteForm
Class GroupDeleteForm.
@package Drupal\context_groups\Form
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait- class \Drupal\Core\Form\ConfirmFormBase implements ConfirmFormInterface- class \Drupal\context_groups\Form\GroupDeleteForm
 
 
- class \Drupal\Core\Form\ConfirmFormBase implements ConfirmFormInterface
Expanded class hierarchy of GroupDeleteForm
2 string references to 'GroupDeleteForm'
File
- src/Form/ GroupDeleteForm.php, line 20 
Namespace
Drupal\context_groups\FormView source
class GroupDeleteForm extends ConfirmFormBase {
  /**
   * Drupal\Core\Entity\EntityTypeManager definition.
   *
   * @var \Drupal\Core\Entity\EntityTypeManager
   */
  protected $entityTypeManager;
  /**
   * The Context module context manager.
   *
   * @var \Drupal\context\ContextManager
   */
  protected $contextManager;
  /**
   * The context group that is being removed.
   *
   * @var array
   */
  protected $contextGroup;
  /**
   * The context from which the context group is being removed.
   *
   * @var Context
   */
  protected $context;
  /**
   * {@inheritdoc}
   */
  public function __construct(EntityTypeManager $entity_type_manager, ContextManager $contextManager) {
    $this->entityTypeManager = $entity_type_manager;
    $this->contextManager = $contextManager;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static($container
      ->get('entity_type.manager'), $container
      ->get('context.manager'));
  }
  /**
   * {@inheritdoc}
   */
  public function getFormId() {
    return 'context-group-delete-form';
  }
  /**
   * {@inheritdoc}
   */
  public function getCancelUrl() {
    // TODO: Implement getCancelUrl() method.
  }
  /**
   * Returns the question to ask the user.
   *
   * @return string
   *   The form question. The page title will be set to this value.
   */
  public function getQuestion() {
    return $this
      ->t('Are you sure you want to remove the "@label" group?', [
      '@label' => $this->contextGroup['label'],
    ]);
  }
  /**
   * {@inheritdoc}
   */
  public function buildForm(array $form, FormStateInterface $form_state, $context = NULL, $context_group = NULL) {
    $this->context = $this->entityTypeManager
      ->getStorage('context')
      ->load($context);
    $group = $this->context
      ->getThirdPartySetting('context_groups', $context_group);
    $this->contextGroup = $group;
    $form = parent::buildForm($form, $form_state);
    // Submit the form with AJAX if possible.
    $form['actions']['submit']['#ajax'] = [
      'callback' => '::submitFormAjax',
    ];
    return $form;
  }
  /**
   * {@inheritdoc}
   */
  public function submitForm(array &$form, FormStateInterface $form_state) {
    $this->context
      ->unsetThirdPartySetting('context_groups', $this->contextGroup['name']);
    // If this group was parent of another group or block, update it's parent.
    // Check groups.
    $list_of_groups = $this->context
      ->getThirdPartySettings('context_groups');
    foreach ($list_of_groups as $group) {
      if ($group['parent'] == $this->contextGroup['name']) {
        $group['parent'] = '';
        $this->context
          ->setThirdPartySetting('context_groups', $group['name'], $group);
      }
    }
    // Check blocks in context.
    $blocks = $this->context
      ->getReactions()
      ->get('blocks');
    $list_of_blocks = $blocks
      ->getBlocks();
    foreach ($list_of_blocks as $uid => $block_plugin) {
      $configuration = $block_plugin
        ->getConfiguration();
      if (isset($configuration['parent_wrapper']['parent']) && $configuration['parent_wrapper']['parent'] == $this->contextGroup['name']) {
        $configuration['parent_wrapper']['parent'] = '';
        $blocks
          ->updateBlock($uid, $configuration);
      }
    }
    $this->context
      ->save();
  }
  /**
   * Handle when the form is submitted trough AJAX.
   *
   * @return AjaxResponse
   *   AjaxResponse object.
   */
  public function submitFormAjax() {
    $contextForm = $this->contextManager
      ->getForm($this->context, 'edit');
    $response = new AjaxResponse();
    $response
      ->addCommand(new CloseModalDialogCommand());
    $response
      ->addCommand(new ReplaceCommand('#context-reactions', $contextForm['reactions']));
    return $response;
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| ConfirmFormBase:: | public | function | Returns a caption for the link which cancels the action. Overrides ConfirmFormInterface:: | 1 | 
| ConfirmFormBase:: | public | function | Returns a caption for the button that confirms the action. Overrides ConfirmFormInterface:: | 20 | 
| ConfirmFormBase:: | public | function | Returns additional text to display as a description. Overrides ConfirmFormInterface:: | 11 | 
| ConfirmFormBase:: | public | function | Returns the internal name used to refer to the confirmation item. Overrides ConfirmFormInterface:: | |
| DependencySerializationTrait:: | protected | property | An array of entity type IDs keyed by the property name of their storages. | |
| DependencySerializationTrait:: | protected | property | An array of service IDs keyed by property name used for serialization. | |
| DependencySerializationTrait:: | public | function | 1 | |
| DependencySerializationTrait:: | public | function | 2 | |
| FormBase:: | protected | property | The config factory. | 1 | 
| FormBase:: | protected | property | The request stack. | 1 | 
| FormBase:: | protected | property | The route match. | |
| FormBase:: | protected | function | Retrieves a configuration object. | |
| FormBase:: | protected | function | Gets the config factory for this form. | 1 | 
| FormBase:: | private | function | Returns the service container. | |
| FormBase:: | protected | function | Gets the current user. | |
| FormBase:: | protected | function | Gets the request object. | |
| FormBase:: | protected | function | Gets the route match. | |
| FormBase:: | protected | function | Gets the logger for a specific channel. | |
| FormBase:: | protected | function | Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: | |
| FormBase:: | public | function | Resets the configuration factory. | |
| FormBase:: | public | function | Sets the config factory for this form. | |
| FormBase:: | public | function | Sets the request stack object to use. | |
| FormBase:: | public | function | Form validation handler. Overrides FormInterface:: | 62 | 
| GroupDeleteForm:: | protected | property | The context from which the context group is being removed. | |
| GroupDeleteForm:: | protected | property | The context group that is being removed. | |
| GroupDeleteForm:: | protected | property | The Context module context manager. | |
| GroupDeleteForm:: | protected | property | Drupal\Core\Entity\EntityTypeManager definition. | |
| GroupDeleteForm:: | public | function | Form constructor. Overrides ConfirmFormBase:: | |
| GroupDeleteForm:: | public static | function | Instantiates a new instance of this class. Overrides FormBase:: | |
| GroupDeleteForm:: | public | function | Returns the route to go to if the user cancels the action. Overrides ConfirmFormInterface:: | |
| GroupDeleteForm:: | public | function | Returns a unique string identifying the form. Overrides FormInterface:: | |
| GroupDeleteForm:: | public | function | Returns the question to ask the user. Overrides ConfirmFormInterface:: | |
| GroupDeleteForm:: | public | function | Form submission handler. Overrides FormInterface:: | |
| GroupDeleteForm:: | public | function | Handle when the form is submitted trough AJAX. | |
| GroupDeleteForm:: | public | function | ||
| LinkGeneratorTrait:: | protected | property | The link generator. | 1 | 
| LinkGeneratorTrait:: | protected | function | Returns the link generator. | |
| LinkGeneratorTrait:: | protected | function | Renders a link to a route given a route name and its parameters. | |
| LinkGeneratorTrait:: | public | function | Sets the link generator service. | |
| LoggerChannelTrait:: | protected | property | The logger channel factory service. | |
| LoggerChannelTrait:: | protected | function | Gets the logger for a specific channel. | |
| LoggerChannelTrait:: | public | function | Injects the logger channel factory. | |
| MessengerTrait:: | protected | property | The messenger. | 29 | 
| MessengerTrait:: | public | function | Gets the messenger. | 29 | 
| MessengerTrait:: | public | function | Sets the messenger. | |
| RedirectDestinationTrait:: | protected | property | The redirect destination service. | 1 | 
| RedirectDestinationTrait:: | protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
| RedirectDestinationTrait:: | protected | function | Returns the redirect destination service. | |
| RedirectDestinationTrait:: | public | function | Sets the redirect destination service. | |
| StringTranslationTrait:: | protected | property | The string translation service. | 1 | 
| StringTranslationTrait:: | protected | function | Formats a string containing a count of items. | |
| StringTranslationTrait:: | protected | function | Returns the number of plurals supported by a given language. | |
| StringTranslationTrait:: | protected | function | Gets the string translation service. | |
| StringTranslationTrait:: | public | function | Sets the string translation service to use. | 2 | 
| StringTranslationTrait:: | protected | function | Translates a string to the current language or to a given language. | |
| UrlGeneratorTrait:: | protected | property | The url generator. | |
| UrlGeneratorTrait:: | protected | function | Returns the URL generator service. | |
| UrlGeneratorTrait:: | public | function | Sets the URL generator service. | |
| UrlGeneratorTrait:: | protected | function | Generates a URL or path for a specific route based on the given parameters. | 
