Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. HtmlRenderer.php

function HtmlRenderer::invokePageAttachmentHooks

Invokes the page attachment hooks.

@internal

Parameters

array &$page: A #type 'page' render array, for which the page attachment hooks will be invoked and to which the results will be added.

Throws

\LogicException

See also

hook_page_attachments()

hook_page_attachments_alter()

1 call to HtmlRenderer::invokePageAttachmentHooks()
HtmlRenderer::prepare in core/lib/Drupal/Core/Render/MainContent/HtmlRenderer.php
Prepares the HTML body: wraps the main content in #type 'page'.

File

core/lib/Drupal/Core/Render/MainContent/HtmlRenderer.php, line 305

Class

HtmlRenderer
Default main content renderer for HTML requests.

Namespace

Drupal\Core\Render\MainContent

Code

public function invokePageAttachmentHooks(array &$page) {
    // Modules can add attachments.
    $attachments = [];
    $this->moduleHandler
        ->invokeAllWith('page_attachments', function (callable $hook, string $module) use (&$attachments) {
        $hook($attachments);
    });
    if (array_diff(array_keys($attachments), [
        '#attached',
        '#cache',
    ]) !== []) {
        throw new \LogicException('Only #attached and #cache may be set in hook_page_attachments().');
    }
    // Modules and themes can alter page attachments.
    $this->moduleHandler
        ->alter('page_attachments', $attachments);
    $this->themeManager
        ->alter('page_attachments', $attachments);
    if (array_diff(array_keys($attachments), [
        '#attached',
        '#cache',
    ]) !== []) {
        throw new \LogicException('Only #attached and #cache may be set in hook_page_attachments_alter().');
    }
    // Merge the attachments onto the $page render array.
    $page = $this->renderer
        ->mergeBubbleableMetadata($page, $attachments);
}
RSS feed
Powered by Drupal