page.html.twig

Same filename in this branch
  1. main core/profiles/demo_umami/themes/umami/templates/layout/page.html.twig
  2. main core/themes/olivero/templates/layout/page.html.twig
  3. main core/themes/stable9/templates/layout/page.html.twig
  4. main core/themes/claro/templates/page.html.twig
  5. main core/themes/starterkit_theme/templates/layout/page.html.twig
  6. main core/modules/system/templates/page.html.twig
Same filename and directory in other branches
  1. 10 core/profiles/demo_umami/themes/umami/templates/layout/page.html.twig
  2. 10 core/themes/olivero/templates/layout/page.html.twig
  3. 10 core/themes/stable9/templates/layout/page.html.twig
  4. 10 core/themes/claro/templates/page.html.twig
  5. 10 core/themes/starterkit_theme/templates/layout/page.html.twig
  6. 11.x core/profiles/demo_umami/themes/umami/templates/layout/page.html.twig
  7. 11.x core/themes/olivero/templates/layout/page.html.twig
  8. 11.x core/themes/stable9/templates/layout/page.html.twig
  9. 11.x core/themes/claro/templates/page.html.twig
  10. 11.x core/themes/starterkit_theme/templates/layout/page.html.twig
  11. 11.x core/modules/system/templates/page.html.twig
  12. 10 core/modules/system/templates/page.html.twig
  13. 9 core/profiles/demo_umami/themes/umami/templates/layout/page.html.twig
  14. 9 core/themes/olivero/templates/layout/page.html.twig
  15. 9 core/themes/stable9/templates/layout/page.html.twig
  16. 9 core/themes/seven/templates/page.html.twig
  17. 9 core/themes/claro/templates/page.html.twig
  18. 9 core/themes/bartik/templates/page.html.twig
  19. 9 core/themes/stable/templates/layout/page.html.twig
  20. 9 core/themes/starterkit_theme/templates/layout/page.html.twig
  21. 9 core/themes/classy/templates/layout/page.html.twig
  22. 9 core/modules/system/templates/page.html.twig
  23. 8.9.x core/profiles/demo_umami/themes/umami/templates/layout/page.html.twig
  24. 8.9.x core/themes/seven/templates/page.html.twig
  25. 8.9.x core/themes/claro/templates/page.html.twig
  26. 8.9.x core/themes/bartik/templates/page.html.twig
  27. 8.9.x core/themes/stable/templates/layout/page.html.twig
  28. 8.9.x core/themes/classy/templates/layout/page.html.twig
  29. 8.9.x core/modules/system/templates/page.html.twig
  30. 11.x core/themes/admin/templates/page/page.html.twig

Gin's theme implementation to display a single Drupal page.

The doctype, html, head, and body tags are not in this template. Instead they can be found in the html.html.twig template normally located in the core/modules/system directory.

Available variables:

General utility variables:

  • base_path: The base URL path of the Drupal installation. Will usually be "/" unless you have installed Drupal in a sub-directory.
  • is_front: A flag indicating if the current page is the front page.
  • logged_in: A flag indicating if the user is registered and signed in.
  • is_admin: A flag indicating if the user has permission to access administration pages.

Site identity:

  • front_page: The URL of the front page. Use this instead of base_path when linking to the front page. This includes the language domain or prefix.

Page content (in order of occurrence in the default page.html.twig):

  • node: Fully loaded node, if there is an automatically-loaded node associated with the page and the node ID is the second argument in the page's path (e.g. node/12345 and node/12345/revisions, but not comment/reply/12345).

Regions:

  • page.header: Items for the header region.
  • page.pre_content: Items for the pre-content region.
  • page.breadcrumb: Items for the breadcrumb region.
  • page.highlighted: Items for the highlighted region.
  • page.help: Dynamic help text, mostly for admin pages.
  • page.content: The main content of the current page.

See also

template_preprocess_page()

html.html.twig

3 theme calls to page.html.twig
ElementInfoManagerTest::providerTestGetInfoElementPlugin in core/tests/Drupal/Tests/Core/Render/ElementInfoManagerTest.php
Provides tests data for testGetInfoElementPlugin().
ElementInfoManagerTest::testGetInfoElementPlugin in core/tests/Drupal/Tests/Core/Render/ElementInfoManagerTest.php
Tests the getInfo() method when render element plugins are used.
Page::getInfo in core/lib/Drupal/Core/Render/Element/Page.php
Returns the element properties for this element.

File

core/themes/admin/templates/page/page.html.twig

View source
  1. {#
  2. /**
  3. * @file
  4. * Gin's theme implementation to display a single Drupal page.
  5. *
  6. * The doctype, html, head, and body tags are not in this template. Instead
  7. * they can be found in the html.html.twig template normally located in the
  8. * core/modules/system directory.
  9. *
  10. * Available variables:
  11. *
  12. * General utility variables:
  13. * - base_path: The base URL path of the Drupal installation. Will usually be
  14. * "/" unless you have installed Drupal in a sub-directory.
  15. * - is_front: A flag indicating if the current page is the front page.
  16. * - logged_in: A flag indicating if the user is registered and signed in.
  17. * - is_admin: A flag indicating if the user has permission to access
  18. * administration pages.
  19. *
  20. * Site identity:
  21. * - front_page: The URL of the front page. Use this instead of base_path when
  22. * linking to the front page. This includes the language domain or prefix.
  23. *
  24. * Page content (in order of occurrence in the default page.html.twig):
  25. * - node: Fully loaded node, if there is an automatically-loaded node
  26. * associated with the page and the node ID is the second argument in the
  27. * page's path (e.g. node/12345 and node/12345/revisions, but not
  28. * comment/reply/12345).
  29. *
  30. * Regions:
  31. * - page.header: Items for the header region.
  32. * - page.pre_content: Items for the pre-content region.
  33. * - page.breadcrumb: Items for the breadcrumb region.
  34. * - page.highlighted: Items for the highlighted region.
  35. * - page.help: Dynamic help text, mostly for admin pages.
  36. * - page.content: The main content of the current page.
  37. *
  38. * @see template_preprocess_page()
  39. * @see html.html.twig
  40. */
  41. #}
  42. {% set page_title_block = active_admin_theme ~ '_page_title' %}
  43. {% set local_actions_block = active_admin_theme ~ '_local_actions' %}
  44. {% if active_navigation %}
  45. <header class="region gin--navigation-top-bar--offset {{ gin_form_actions_class }}">
  46. <div class="layout-container region-sticky__items">
  47. <div class="region-sticky__items__inner">
  48. {{ page.header[page_title_block] }}
  49. {% if not active_navigation %}
  50. {{ page.content[local_actions_block] }}
  51. {% endif %}
  52. {{ gin_form_actions }}
  53. </div>
  54. </div>
  55. </header>
  56. {% else %}
  57. <div class="gin-secondary-toolbar layout-container">
  58. <div class="gin-breadcrumb-wrapper">
  59. {% if route_name == 'entity.node.canonical' %}
  60. <div class="region region-breadcrumb gin-region-breadcrumb">
  61. <nav class="breadcrumb" role="navigation" aria-labelledby="system-breadcrumb">
  62. <h2 id="system-breadcrumb" class="visually-hidden">{{ 'Breadcrumb'|t }}</h2>
  63. <ol class="breadcrumb__list">
  64. <li class="breadcrumb__item">
  65. {% if entity_edit_url and entity_title %}
  66. <a class="breadcrumb__link gin-back-to-admin" href="{{ entity_edit_url }}">{{ 'Edit %title'|t({ '%title': entity_title }) }}</a>
  67. {% else %}
  68. <a class="breadcrumb__link gin-back-to-admin" href="{{ path('system.admin_content') }}">{{ 'Back to Administration'|t }}</a>
  69. {% endif %}
  70. </li>
  71. </ol>
  72. </nav>
  73. </div>
  74. {% else %}
  75. {{ page.breadcrumb }}
  76. {% endif %}
  77. </div>
  78. </div>
  79. <div class="region-sticky-watcher"></div>
  80. <header class="region region-sticky {{ gin_form_actions_class }}">
  81. <div class="layout-container region-sticky__items">
  82. <div class="region-sticky__items__inner">
  83. {{ page.header[page_title_block] }}
  84. {% if not active_navigation %}
  85. {{ page.content[local_actions_block] }}
  86. {% endif %}
  87. {{ gin_form_actions }}
  88. </div>
  89. </div>
  90. </header>
  91. <div class="sticky-shadow"></div>
  92. {% endif %}
  93. <div class="content-header clearfix">
  94. <div class="layout-container">
  95. {{ page.header|without(page_title_block) }}
  96. </div>
  97. </div>
  98. <div class="layout-container">
  99. {{ page.pre_content }}
  100. <main class="page-content clearfix" role="main">
  101. <div class="visually-hidden"><a id="main-content" tabindex="-1"></a></div>
  102. {{ page.highlighted }}
  103. {% if page.help %}
  104. <div class="help">
  105. {{ page.help }}
  106. </div>
  107. {% endif %}
  108. {{ page.content|without(local_actions_block) }}
  109. </main>
  110. </div>

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.