You are here

public function HttpStatusCodeDisplayVariant::build in Page Manager 8.4

Same name and namespace in other branches
  1. 8 src/Plugin/DisplayVariant/HttpStatusCodeDisplayVariant.php \Drupal\page_manager\Plugin\DisplayVariant\HttpStatusCodeDisplayVariant::build()

Builds and returns the renderable array for the display variant.

The variant can contain cacheability metadata for the configuration that was passed in setConfiguration(). In the build() method, this should be added to the render array that is returned.

Return value

array A render array for the display variant.

Overrides VariantInterface::build

File

src/Plugin/DisplayVariant/HttpStatusCodeDisplayVariant.php, line 165

Class

HttpStatusCodeDisplayVariant
Provides a variant that returns a response with an HTTP status code.

Namespace

Drupal\page_manager\Plugin\DisplayVariant

Code

public function build() {
  $status_code = $this->configuration['status_code'];
  if ($status_code == 200) {
    return [];
  }
  elseif (in_array($status_code, self::$redirectCodes, TRUE)) {
    $redirect_location = $this->configuration['redirect_location'];
    $params = $this
      ->getParameterNames($redirect_location);
    $contexts = $this
      ->getContexts();
    foreach ($params as $param) {
      if (!isset($contexts[$param])) {
        continue;
      }

      /** @var \Drupal\Component\Plugin\Context\ContextInterface $context */
      $context = $contexts[$param];
      $value = $this
        ->variableToString($context
        ->getContextValue());
      if ($value === FALSE) {
        continue;
      }
      $redirect_location = str_replace('{' . $param . '}', $value, $redirect_location);
      if ($alias = $this->aliasManager
        ->getAliasByPath($redirect_location)) {
        $redirect_location = $alias;
      }
    }
    $response = new TrustedRedirectResponse($redirect_location, $status_code);
    $response
      ->send();
    exit;
  }
  else {
    throw new HttpException($status_code);
  }
}