Code Coverage
 
Lines
Branches
Paths
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 20
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
PreprocessViewsView
0.00% covered (danger)
0.00%
0 / 20
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 2
42
0.00% covered (danger)
0.00%
0 / 1
 __construct
0.00% covered (danger)
0.00%
0 / 1
n/a
0 / 0
n/a
0 / 0
0.00% covered (danger)
0.00%
0 / 1
2
 preprocessViewsView
0.00% covered (danger)
0.00%
0 / 19
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 1
30
1<?php
2
3declare(strict_types=1);
4
5namespace Drupal\display_builder_views\Hook;
6
7use Drupal\Core\Entity\EntityTypeManagerInterface;
8use Drupal\Core\Hook\Attribute\Hook;
9use Drupal\Core\Plugin\Context\Context;
10use Drupal\Core\Plugin\Context\ContextDefinition;
11use Drupal\Core\Plugin\Context\EntityContext;
12use Drupal\ui_patterns\Element\ComponentElementBuilder;
13use Symfony\Component\DependencyInjection\Attribute\Autowire;
14
15/**
16 * Hook implementations for the display_builder_views module.
17 */
18class PreprocessViewsView {
19
20  public function __construct(
21    protected EntityTypeManagerInterface $entityTypeManager,
22    #[Autowire('@ui_patterns.component_element_builder')]
23    protected ComponentElementBuilder $componentElementBuilder,
24  ) {}
25
26  /**
27   * Implements hook_preprocess_HOOK() for 'views_view'.
28   *
29   * @param array $variables
30   *   An associative array containing the variables to pass to the template.
31   */
32  #[Hook('preprocess_views_view')]
33  public function preprocessViewsView(array &$variables): void {
34    $view = $variables['view'];
35    $extenders = $view->getDisplay()->getExtenders();
36
37    if (!isset($extenders['display_builder'])) {
38      return;
39    }
40
41    $extender = $extenders['display_builder'];
42    $sources = $extender->getSources();
43
44    // We fallback on normal View if Display Builder is empty or disabled!
45    if (empty($sources) || !$extender->getProfile()) {
46      return;
47    }
48
49    // Inject the view in context to be available by our UI Patterns source
50    // plugins.
51    $contexts = [];
52    $view_entity = $this->entityTypeManager->getStorage('view')->load($view->id());
53    $contexts['ui_patterns_views:view_entity'] = EntityContext::fromEntity($view_entity);
54    $contexts['ui_patterns_views:view'] = new Context(new ContextDefinition('any'), $view);
55    $contexts['ui_patterns_views:rows'] = new Context(new ContextDefinition('any'), $variables['rows'] ?? []);
56    // @todo pass all variables for each source, find a way to do it sooner than
57    // in this preprocess if possible.
58    $contexts['ui_patterns_views:variables'] = new Context(new ContextDefinition('any'), $variables);
59
60    $fake_build = [];
61
62    foreach ($sources as $source) {
63      $fake_build = $this->componentElementBuilder->buildSource($fake_build, 'content', [], $source, $contexts);
64    }
65
66    // Init the variable to render in views-view.html.twig.
67    // @see \Drupal\display_builder_views\Plugin\views\display_extender\DisplayExtender::preExecute()
68    $variables['content'] = $fake_build['#slots']['content'] ?? [];
69    $variables['content']['#cache'] = $fake_build['#cache'] ?? [];
70  }
71
72}

Branches

Below are the source code lines that represent each code branch as identified by Xdebug. Please note a branch is not necessarily coterminous with a line, a line may contain multiple branches and therefore show up more than once. Please also be aware that some branches may be implicit rather than explicit, e.g. an if statement always has an else as part of its logical flow even if you didn't write one.

PreprocessViewsView->preprocessViewsView
33  public function preprocessViewsView(array &$variables): void {
34    $view = $variables['view'];
35    $extenders = $view->getDisplay()->getExtenders();
36
37    if (!isset($extenders['display_builder'])) {
38      return;
41    $extender = $extenders['display_builder'];
42    $sources = $extender->getSources();
43
44    // We fallback on normal View if Display Builder is empty or disabled!
45    if (empty($sources) || !$extender->getProfile()) {
45    if (empty($sources) || !$extender->getProfile()) {
46      return;
51    $contexts = [];
52    $view_entity = $this->entityTypeManager->getStorage('view')->load($view->id());
53    $contexts['ui_patterns_views:view_entity'] = EntityContext::fromEntity($view_entity);
54    $contexts['ui_patterns_views:view'] = new Context(new ContextDefinition('any'), $view);
55    $contexts['ui_patterns_views:rows'] = new Context(new ContextDefinition('any'), $variables['rows'] ?? []);
56    // @todo pass all variables for each source, find a way to do it sooner than
57    // in this preprocess if possible.
58    $contexts['ui_patterns_views:variables'] = new Context(new ContextDefinition('any'), $variables);
59
60    $fake_build = [];
61
62    foreach ($sources as $source) {
62    foreach ($sources as $source) {
62    foreach ($sources as $source) {
63      $fake_build = $this->componentElementBuilder->buildSource($fake_build, 'content', [], $source, $contexts);
62    foreach ($sources as $source) {
63      $fake_build = $this->componentElementBuilder->buildSource($fake_build, 'content', [], $source, $contexts);
64    }
65
66    // Init the variable to render in views-view.html.twig.
67    // @see \Drupal\display_builder_views\Plugin\views\display_extender\DisplayExtender::preExecute()
68    $variables['content'] = $fake_build['#slots']['content'] ?? [];
69    $variables['content']['#cache'] = $fake_build['#cache'] ?? [];
70  }