public function ContextBlockPageVariant::build in Context 8.4
Same name and namespace in other branches
- 8 src/Plugin/DisplayVariant/ContextBlockPageVariant.php \Drupal\context\Plugin\DisplayVariant\ContextBlockPageVariant::build()
- 8.0 src/Plugin/DisplayVariant/ContextBlockPageVariant.php \Drupal\context\Plugin\DisplayVariant\ContextBlockPageVariant::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/ ContextBlockPageVariant.php, line 119
Class
- ContextBlockPageVariant
- Provides a page display variant that decorates the main content with blocks.
Namespace
Drupal\context\Plugin\DisplayVariantCode
public function build() {
$build = [
'#cache' => [
'tags' => [
'context_block_page',
$this
->getPluginId(),
],
],
];
// Place main content block, it will be removed by the reactions if a main
// content block has been manually placed.
$build['content']['system_main'] = $this->mainContent;
// Execute each block reaction and let them modify the page build.
foreach ($this->contextManager
->getActiveReactions('blocks') as $reaction) {
$build = $reaction
->execute($build, $this->title, $this->mainContent);
}
// Execute each block reaction and check if default block should be included
// in page build.
foreach ($this->contextManager
->getActiveReactions('blocks') as $reaction) {
if ($reaction
->includeDefaultBlocks()) {
$build_block_layout = $this
->getBuildFromBlockLayout();
// Only merge at block level, not underneath,
// else, unexpected consequences will arise.
$regions = $this->themeManager
->getActiveTheme()
->getRegions();
foreach ($regions as $region_key) {
if (empty($build[$region_key])) {
$build[$region_key] = [];
}
if (empty($build_block_layout[$region_key])) {
$build_block_layout[$region_key] = [];
}
$build[$region_key] += $build_block_layout[$region_key];
}
// Merge bubbleable cache data now.
BubbleableMetadata::createFromRenderArray($build)
->merge(BubbleableMetadata::createFromRenderArray($build_block_layout))
->applyTo($build);
// Remove main content as it can added from core block layout or context
// without the other knowing.
foreach (Element::children($build) as $region_key) {
foreach ($build[$region_key] as $blockId) {
if (isset($blockId['#plugin_id']) && $blockId['#plugin_id'] == 'system_main_block') {
unset($build['content']['system_main']);
break;
}
}
}
// Remove systems messages block if it's added via context.
foreach ($build as $block) {
if (array_key_exists('system_messages_block', $block)) {
unset($build['content']['messages']);
break;
}
}
return $build;
}
}
return $build;
}