contacts_events-8.x-1.x-dev/src/TicketHtmlRouteProvider.php

src/TicketHtmlRouteProvider.php
<?php

namespace Drupal\contacts_events;

use Drupal\Core\Entity\EntityTypeInterface;
use Drupal\Core\Entity\Routing\AdminHtmlRouteProvider;
use Symfony\Component\Routing\Route;

/**
 * Provides routes for Ticket entities.
 *
 * @see \Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
 * @see \Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider
 */
class TicketHtmlRouteProvider extends AdminHtmlRouteProvider {

  /**
   * {@inheritdoc}
   */
  public function getRoutes(EntityTypeInterface $entity_type) {
    $collection = parent::getRoutes($entity_type);

    if ($transfer_page_route = $this->getTransferPageRoute($entity_type)) {
      $collection->add("entity.{$entity_type->id()}.transfer_form", $transfer_page_route);
    }

    return $collection;
  }

  /**
   * Gets the transfer page route.
   *
   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
   *   The entity type.
   *
   * @return \Symfony\Component\Routing\Route|null
   *   The generated route, if available.
   */
  protected function getTransferPageRoute(EntityTypeInterface $entity_type) {
    if ($entity_type->id() == 'contacts_ticket' && $entity_type->hasLinkTemplate('transfer-form')) {
      $route = new Route($entity_type->getLinkTemplate('transfer-form'));
      $route->setDefault('_entity_form', $entity_type->id() . '.transfer');
      $route->setDefault('_title', 'Transfer ticket');
      $route->setDefault('entity_type_id', $entity_type->id());
      $route->setOption('_admin_route', TRUE);
      $route->setOption('parameters', [
        'contacts_ticket' => ['type' => 'entity:contacts_ticket'],
      ]);
      $route->setRequirement('_entity_access', $entity_type->id() . '.transfer');

      return $route;
    }

    return NULL;
  }

}

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

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