You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
3.3 KiB
111 lines
3.3 KiB
<?php |
|
|
|
namespace Drupal\islandora_breadcrumbs; |
|
|
|
use Drupal\Core\Config\ConfigFactoryInterface; |
|
use Drupal\Core\Entity\EntityTypeManagerInterface; |
|
use Drupal\Core\Breadcrumb\Breadcrumb; |
|
use Drupal\Core\Breadcrumb\BreadcrumbBuilderInterface; |
|
use Drupal\Core\Link; |
|
use Drupal\Core\Routing\RouteMatchInterface; |
|
use Drupal\Core\StringTranslation\StringTranslationTrait; |
|
use Drupal\islandora\IslandoraUtils; |
|
|
|
/** |
|
* Provides breadcrumbs for nodes using a configured entity reference field. |
|
*/ |
|
class IslandoraBreadcrumbBuilder implements BreadcrumbBuilderInterface { |
|
use StringTranslationTrait; |
|
|
|
/** |
|
* The configuration. |
|
* |
|
* @var \Drupal\Core\Config\ImmutableConfig |
|
*/ |
|
protected $config; |
|
|
|
/** |
|
* Storage to load nodes. |
|
* |
|
* @var \Drupal\Core\Entity\EntityStorageInterface |
|
*/ |
|
protected $nodeStorage; |
|
|
|
/** |
|
* Islandora utils. |
|
* |
|
* @var \Drupal\islandora\IslandoraUtils |
|
*/ |
|
protected $utils; |
|
|
|
/** |
|
* Constructs a breadcrumb builder. |
|
* |
|
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_manager |
|
* Storage to load nodes. |
|
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory |
|
* The configuration factory. |
|
* @param \Drupal\islandora\IslandoraUtils $utils |
|
* Islandora utils service. |
|
*/ |
|
public function __construct(EntityTypeManagerInterface $entity_manager, ConfigFactoryInterface $config_factory, IslandoraUtils $utils) { |
|
$this->nodeStorage = $entity_manager->getStorage('node'); |
|
$this->config = $config_factory->get('islandora_breadcrumbs.breadcrumbs'); |
|
$this->utils = $utils; |
|
} |
|
|
|
/** |
|
* {@inheritdoc} |
|
*/ |
|
public function applies(RouteMatchInterface $attributes) { |
|
// Using getRawParameters for consistency (always gives a |
|
// node ID string) because getParameters sometimes returns |
|
// a node ID string and sometimes returns a node object. |
|
$nid = $attributes->getRawParameters()->get('node'); |
|
if (!empty($nid)) { |
|
$node = $this->nodeStorage->load($nid); |
|
if (empty($node)) { |
|
return FALSE; |
|
} |
|
foreach ($this->config->get('referenceFields') as $field) { |
|
if ($node->hasField($field)) { |
|
return TRUE; |
|
} |
|
} |
|
} |
|
} |
|
|
|
/** |
|
* {@inheritdoc} |
|
*/ |
|
public function build(RouteMatchInterface $route_match) { |
|
|
|
$nid = $route_match->getRawParameters()->get('node'); |
|
$node = $this->nodeStorage->load($nid); |
|
$breadcrumb = new Breadcrumb(); |
|
$breadcrumb->addCacheableDependency($this->config); |
|
$breadcrumb->addLink(Link::createFromRoute($this->t('Home'), '<front>')); |
|
|
|
$chain = array_reverse($this->utils->findAncestors($node, $this->config->get('referenceFields'), $this->config->get('maxDepth'))); |
|
|
|
// XXX: Handle a looping breadcrumb scenario by filtering the present |
|
// node out and then optionally re-adding it after if set to do so. |
|
$chain = array_filter($chain, function ($link) use ($nid) { |
|
return $link !== $nid; |
|
}); |
|
if ($this->config->get('includeSelf')) { |
|
array_push($chain, $nid); |
|
} |
|
$breadcrumb->addCacheableDependency($node); |
|
|
|
// Add membership chain to the breadcrumb. |
|
foreach ($chain as $chainlink) { |
|
$node = $this->nodeStorage->load($chainlink); |
|
$breadcrumb->addCacheableDependency($node); |
|
$breadcrumb->addLink($node->toLink()); |
|
} |
|
$breadcrumb->addCacheContexts(['route']); |
|
return $breadcrumb; |
|
} |
|
|
|
}
|
|
|