You are here

public function SupportTicketRouteContext::getRuntimeContexts in Support Ticketing System 8

Gets runtime context values for the given context IDs.

For context-aware plugins to function correctly, all of the contexts that they require must be populated with values. So this method should set a value for each context that it adds. For example:


  // Determine a specific node to pass as context to a block.
  $node = ...

  // Set that specific node as the value of the 'node' context.
  $context = EntityContext::fromEntity($node);
  return ['node' => $context];

On the other hand, there are cases, on which providers no longer are possible to provide context objects, even without the value, so the caller should not expect it.

Parameters

string[] $unqualified_context_ids: The requested context IDs. The context provider must only return contexts for those IDs.

Return value

\Drupal\Core\Plugin\Context\ContextInterface[] The determined available contexts, keyed by the unqualified context_id.

Overrides ContextProviderInterface::getRuntimeContexts

See also

\Drupal\Core\Plugin\Context\ContextProviderInterface:getAvailableContexts()

File

modules/support_ticket/src/ContextProvider/SupportTicketRouteContext.php, line 42
Contains \Drupal\support_ticket\ContextProvider\SupportTicketRouteContext.

Class

SupportTicketRouteContext
Sets the current support ticket as a context on support ticket routes.

Namespace

Drupal\support_ticket\ContextProvider

Code

public function getRuntimeContexts(array $unqualified_context_ids) {
  $result = [];
  $context_definition = new ContextDefinition('entity:support_ticket', NULL, FALSE);
  $value = NULL;
  if (($route_object = $this->routeMatch
    ->getRouteObject()) && ($route_contexts = $route_object
    ->getOption('parameters')) && isset($route_contexts['support_ticket'])) {
    if ($support_ticket = $this->routeMatch
      ->getParameter('support_ticket')) {
      $value = $support_ticket;
    }
  }
  elseif ($this->routeMatch
    ->getRouteName() == 'support_ticket.add') {
    $support_ticket_type = $this->routeMatch
      ->getParameter('support_ticket_type');
    $value = SupportTicket::create(array(
      'type' => $support_ticket_type
        ->id(),
    ));
  }
  $cacheability = new CacheableMetadata();
  $cacheability
    ->setCacheContexts([
    'route',
  ]);
  $context = new Context($context_definition, $value);
  $context
    ->addCacheableDependency($cacheability);
  $result['support_ticket'] = $context;
  return $result;
}