Skip to content
FieldUiLocalTask.php 7.92 KiB
Newer Older
<?php

/**
 * @file
 * Contains \Drupal\field_ui\Plugin\Derivative\FieldUiLocalTask.
 */

namespace Drupal\field_ui\Plugin\Derivative;

use Drupal\Core\Entity\EntityManagerInterface;
use Drupal\Component\Plugin\Derivative\DerivativeBase;
use Drupal\Core\Plugin\Discovery\ContainerDerivativeInterface;
use Drupal\Core\Routing\RouteProviderInterface;
use Drupal\Core\StringTranslation\TranslationInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Provides local task definitions for all entity bundles.
 */
class FieldUiLocalTask extends DerivativeBase implements ContainerDerivativeInterface {

  /**
   * The route provider.
   *
   * @var \Drupal\Core\Routing\RouteProviderInterface
   */
  protected $routeProvider;

  /**
   * The entity manager
   *
   * @var \Drupal\Core\Entity\EntityManagerInterface
   */
  protected $entityManager;

  /**
   * The translation manager service.
   *
   * @var \Drupal\Core\StringTranslation\TranslationInterface
   */
  protected $translationManager;

  /**
   * Creates an FieldUiLocalTask object.
   *
   * @param \Drupal\Core\Routing\RouteProviderInterface $route_provider
   *   The route provider.
   * @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager
   *   The entity manager.
   * @param \Drupal\Core\StringTranslation\TranslationInterface $translation_manager
   *   The translation manager.
   */
  public function __construct(RouteProviderInterface $route_provider, EntityManagerInterface $entity_manager, TranslationInterface $translation_manager) {
    $this->routeProvider = $route_provider;
    $this->entityManager = $entity_manager;
    $this->translationManager = $translation_manager;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, $base_plugin_id) {
    return new static(
      $container->get('router.route_provider'),
      $container->get('entity.manager'),
      $container->get('string_translation')
    );
  }

  /**
   * {@inheritdoc}
   */
  public function getDerivativeDefinitions($base_plugin_definition) {
    foreach ($this->entityManager->getDefinitions() as $entity_type_id => $entity_type) {
      if ($entity_type->isFieldable() && $entity_type->hasLinkTemplate('admin-form')) {
        $this->derivatives["overview_$entity_type_id"] = array(
          'route_name' => "field_ui.overview_$entity_type_id",
          'weight' => 1,
          'title' => $this->t('Manage fields'),
          'base_route' => "field_ui.overview_$entity_type_id",
        $this->derivatives["form_display_overview_$entity_type_id"] = array(
          'route_name' => "field_ui.form_display_overview_$entity_type_id",
          'weight' => 2,
          'title' => $this->t('Manage form display'),
          'base_route' => "field_ui.overview_$entity_type_id",
        $this->derivatives["display_overview_$entity_type_id"] = array(
          'route_name' => "field_ui.display_overview_$entity_type_id",
          'weight' => 3,
          'title' => $this->t('Manage display'),
          'base_route' => "field_ui.overview_$entity_type_id",
        $this->derivatives["instance_edit_$entity_type_id"] = array(
          'route_name' => "field_ui.instance_edit_$entity_type_id",
          'base_route' => "field_ui.instance_edit_$entity_type_id",
        $this->derivatives["field_edit_$entity_type_id"] = array(
          'route_name' => "field_ui.field_edit_$entity_type_id",
          'base_route' => "field_ui.instance_edit_$entity_type_id",
        );

        // View and form modes secondary tabs.
        // The same base $path for the menu item (with a placeholder) can be
        // used for all bundles of a given entity type; but depending on
        // administrator settings, each bundle has a different set of view
        // modes available for customisation. So we define menu items for all
        // view modes, and use a route requirement to determine which ones are
        // actually visible for a given bundle.
        $this->derivatives['field_form_display_default_' . $entity_type_id] = array(
          'route_name' => "field_ui.form_display_overview_$entity_type_id",
          'parent_id' => "field_ui.fields:form_display_overview_$entity_type_id",
        $this->derivatives['field_display_default_' . $entity_type_id] = array(
          'route_name' => "field_ui.display_overview_$entity_type_id",
          'parent_id' => "field_ui.fields:display_overview_$entity_type_id",
        foreach ($this->entityManager->getFormModes($entity_type_id) as $form_mode => $form_mode_info) {
          $this->derivatives['field_form_display_' . $form_mode . '_' . $entity_type_id] = array(
            'route_name' => "field_ui.form_display_overview_form_mode_$entity_type_id",
            'route_parameters' => array(
              'form_mode_name' => $form_mode,
            ),
            'parent_id' => "field_ui.fields:form_display_overview_$entity_type_id",
            'weight' => $weight++,
          );
        }

        // One local task for each view mode.
        $weight = 0;
        foreach ($this->entityManager->getViewModes($entity_type_id) as $view_mode => $form_mode_info) {
          $this->derivatives['field_display_' . $view_mode . '_' . $entity_type_id] = array(
            'route_name' => "field_ui.display_overview_view_mode_$entity_type_id",
            'route_parameters' => array(
              'view_mode_name' => $view_mode,
            ),
            'parent_id' => "field_ui.fields:display_overview_$entity_type_id",
            'weight' => $weight++,
          );
        }
      }
    }

    foreach ($this->derivatives as &$entry) {
      $entry += $base_plugin_definition;
    }

    return $this->derivatives;
  }

  /**
   * Alters the base_route definition for field_ui local tasks.
   *
   * @param array $local_tasks
   *   An array of local tasks plugin definitions, keyed by plugin ID.
   */
  public function alterLocalTasks(&$local_tasks) {
    foreach ($this->entityManager->getDefinitions() as $entity_type => $entity_info) {
      if ($entity_info->isFieldable() && $entity_info->hasLinkTemplate('admin-form')) {
        $admin_form = $entity_info->getLinkTemplate('admin-form');
        $local_tasks["field_ui.fields:overview_$entity_type"]['base_route'] = $admin_form;
        $local_tasks["field_ui.fields:form_display_overview_$entity_type"]['base_route'] = $admin_form;
        $local_tasks["field_ui.fields:display_overview_$entity_type"]['base_route'] = $admin_form;
        $local_tasks["field_ui.fields:field_form_display_default_$entity_type"]['base_route'] = $admin_form;
        $local_tasks["field_ui.fields:field_display_default_$entity_type"]['base_route'] = $admin_form;
        foreach ($this->entityManager->getFormModes($entity_type) as $form_mode => $form_mode_info) {
          $local_tasks['field_ui.fields:field_form_display_' . $form_mode . '_' . $entity_type]['base_route'] = $admin_form;
        foreach ($this->entityManager->getViewModes($entity_type) as $view_mode => $form_mode_info) {
          $local_tasks['field_ui.fields:field_display_' . $view_mode . '_' . $entity_type]['base_route'] = $admin_form;
        }
      }
    }
  }

  /**
   * Translates a string to the current language or to a given language.
   *
   * See the t() documentation for details.
   */
  protected function t($string, array $args = array(), array $options = array()) {
    return $this->translationManager->translate($string, $args, $options);
  }

}