DomainSwitcherBlock.php in Domain Access 8
Namespace
Drupal\domain\Plugin\BlockFile
domain/src/Plugin/Block/DomainSwitcherBlock.phpView source
<?php
namespace Drupal\domain\Plugin\Block;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Session\AccountInterface;
/**
 * Provides a block that links to all domains.
 *
 * @Block(
 *   id = "domain_switcher_block",
 *   admin_label = @Translation("Domain switcher (for admins and testing)")
 * )
 */
class DomainSwitcherBlock extends DomainBlockBase {
  /**
   * Overrides \Drupal\block\BlockBase::access().
   */
  public function access(AccountInterface $account, $return_as_object = FALSE) {
    $access = AccessResult::allowedIfHasPermissions($account, [
      'administer domains',
      'use domain switcher block',
    ], 'OR');
    return $return_as_object ? $access : $access
      ->isAllowed();
  }
  /**
   * Build the output.
   */
  public function build() {
    /** @var \Drupal\domain\DomainInterface $active_domain */
    $active_domain = \Drupal::service('domain.negotiator')
      ->getActiveDomain();
    $items = [];
    /** @var \Drupal\domain\DomainInterface $domain */
    foreach (\Drupal::entityTypeManager()
      ->getStorage('domain')
      ->loadMultipleSorted() as $domain) {
      $string = $domain
        ->getLink();
      if (!$domain
        ->status()) {
        $string .= '*';
      }
      if ($domain
        ->id() == $active_domain
        ->id()) {
        $string = '<em>' . $string . '</em>';
      }
      $items[] = [
        '#markup' => $string,
      ];
    }
    return [
      '#theme' => 'item_list',
      '#items' => $items,
    ];
  }
}Classes
| Name   | Description | 
|---|---|
| DomainSwitcherBlock | Provides a block that links to all domains. | 
