govuk_publishing_components 24.19.0 → 24.20.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/govuk_publishing_components/components/layout-super-navigation-header.js +71 -0
  3. data/app/assets/javascripts/govuk_publishing_components/lib/trigger-event.js +13 -2
  4. data/app/assets/stylesheets/govuk_publishing_components/_all_components.scss +1 -0
  5. data/app/assets/stylesheets/govuk_publishing_components/_all_components_print.scss +1 -0
  6. data/app/assets/stylesheets/govuk_publishing_components/components/_layout-super-navigation-header.scss +125 -0
  7. data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_typography.scss +9 -0
  8. data/app/assets/stylesheets/govuk_publishing_components/components/print/_layout-super-navigation-header.scss +3 -0
  9. data/app/views/govuk_publishing_components/components/_govspeak.html.erb +2 -0
  10. data/app/views/govuk_publishing_components/components/_layout_for_public.html.erb +17 -12
  11. data/app/views/govuk_publishing_components/components/_layout_super_navigation_header.html.erb +121 -0
  12. data/app/views/govuk_publishing_components/components/docs/govspeak.yml +9 -0
  13. data/app/views/govuk_publishing_components/components/docs/layout_super_navigation_header.yml +22 -0
  14. data/config/locales/ar.yml +8 -0
  15. data/config/locales/az.yml +8 -0
  16. data/config/locales/be.yml +8 -0
  17. data/config/locales/bg.yml +8 -0
  18. data/config/locales/bn.yml +8 -0
  19. data/config/locales/cs.yml +8 -0
  20. data/config/locales/cy.yml +8 -0
  21. data/config/locales/da.yml +8 -0
  22. data/config/locales/de.yml +8 -0
  23. data/config/locales/dr.yml +8 -0
  24. data/config/locales/el.yml +8 -0
  25. data/config/locales/en.yml +85 -0
  26. data/config/locales/es-419.yml +8 -0
  27. data/config/locales/es.yml +8 -0
  28. data/config/locales/et.yml +8 -0
  29. data/config/locales/fa.yml +8 -0
  30. data/config/locales/fi.yml +8 -0
  31. data/config/locales/fr.yml +8 -0
  32. data/config/locales/gd.yml +8 -0
  33. data/config/locales/gu.yml +8 -0
  34. data/config/locales/he.yml +8 -0
  35. data/config/locales/hi.yml +8 -0
  36. data/config/locales/hr.yml +8 -0
  37. data/config/locales/hu.yml +8 -0
  38. data/config/locales/hy.yml +8 -0
  39. data/config/locales/id.yml +8 -0
  40. data/config/locales/is.yml +8 -0
  41. data/config/locales/it.yml +8 -0
  42. data/config/locales/ja.yml +8 -0
  43. data/config/locales/ka.yml +8 -0
  44. data/config/locales/kk.yml +8 -0
  45. data/config/locales/ko.yml +8 -0
  46. data/config/locales/lt.yml +8 -0
  47. data/config/locales/lv.yml +8 -0
  48. data/config/locales/ms.yml +8 -0
  49. data/config/locales/mt.yml +8 -0
  50. data/config/locales/nl.yml +8 -0
  51. data/config/locales/no.yml +8 -0
  52. data/config/locales/pa-pk.yml +8 -0
  53. data/config/locales/pa.yml +8 -0
  54. data/config/locales/pl.yml +8 -0
  55. data/config/locales/ps.yml +8 -0
  56. data/config/locales/pt.yml +8 -0
  57. data/config/locales/ro.yml +8 -0
  58. data/config/locales/ru.yml +8 -0
  59. data/config/locales/si.yml +8 -0
  60. data/config/locales/sk.yml +8 -0
  61. data/config/locales/sl.yml +8 -0
  62. data/config/locales/so.yml +8 -0
  63. data/config/locales/sq.yml +8 -0
  64. data/config/locales/sr.yml +8 -0
  65. data/config/locales/sv.yml +8 -0
  66. data/config/locales/sw.yml +8 -0
  67. data/config/locales/ta.yml +8 -0
  68. data/config/locales/th.yml +8 -0
  69. data/config/locales/tk.yml +8 -0
  70. data/config/locales/tr.yml +8 -0
  71. data/config/locales/uk.yml +8 -0
  72. data/config/locales/ur.yml +8 -0
  73. data/config/locales/uz.yml +8 -0
  74. data/config/locales/vi.yml +8 -0
  75. data/config/locales/zh-hk.yml +8 -0
  76. data/config/locales/zh-tw.yml +8 -0
  77. data/config/locales/zh.yml +8 -0
  78. data/lib/govuk_publishing_components/version.rb +1 -1
  79. metadata +6 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3ccd720a9e54c8d5037c7d3878adf5ed2ba18b876f632447d451f1ca8a0ffd6e
4
- data.tar.gz: a13272a73cbdcd36bfd42c312da9d568a89ed705cb27c923d424f91c6d163769
3
+ metadata.gz: 50a7296ca62da87133989dc55c692649132efeee4d4a2eedbb253291ea489459
4
+ data.tar.gz: 026f82dfb2d8b86abd040d5a69ccae280190e345247404e7621aeea89f30eca2
5
5
  SHA512:
6
- metadata.gz: f2405f9f3a73b35945f495505b4e88485aa00698eff3f2e8afbbd1e6e5c800542335b93f02758014a03537ad7936ea8e882459f0d791a8355c47c410c306234c
7
- data.tar.gz: 3d8d34f91ea142e1597d87a939c6db2e69bb81780506b58ffe34e0cbb56eb3df425b66cedb1d00e1a00848ebc64c7ace9fab1809728ebfa7bab9ca880d18d9a7
6
+ metadata.gz: 45190fd0137cd36e04523ce5d97783cda446256a4089646b317404a410be28f7e6c96798ec9d5a56fdd130cbfa0f47630ade875dfe8af61a2b9c52f0111f4abb
7
+ data.tar.gz: bc733b83f05ba2520729a23ecb56788bc8552ef082babc9b0743317cf0808fefc7baab2199dfa1fb77e168b4c38cf72d8b9068e38e67889682b088b2b707641f
@@ -0,0 +1,71 @@
1
+ //= require govuk/vendor/polyfills/Element/prototype/classList.js
2
+
3
+ window.GOVUK = window.GOVUK || {}
4
+ window.GOVUK.Modules = window.GOVUK.Modules || {};
5
+
6
+ (function (Modules) {
7
+ function SuperNavigationToggle ($module) {
8
+ this.$module = $module
9
+
10
+ this.showMenuText = $module.getAttribute('data-text-for-show-menu')
11
+ this.hideMenuText = $module.getAttribute('data-text-for-hide-menu')
12
+ this.buttonText = $module.getAttribute('data-text-for-button')
13
+
14
+ this.$button = this.setupButton($module)
15
+
16
+ this.$menu = document.getElementById(this.$button.getAttribute('aria-controls'))
17
+
18
+ this.syncStatus()
19
+ }
20
+
21
+ SuperNavigationToggle.prototype.setupButton = function (target) {
22
+ var menuHeading = target.getAttribute('aria-labelledby')
23
+ var adjacentTo = target.querySelector('#' + menuHeading)
24
+ var buttonText = document.createTextNode(this.buttonText)
25
+
26
+ var button = document.createElement('button')
27
+ button.type = 'button'
28
+ button.className = 'govuk-header__menu-button gem-c-layout-super-navigation-header__menu-button'
29
+ button.setAttribute('aria-controls', 'super-navigation-menu')
30
+ button.setAttribute('aria-label', this.showMenuText)
31
+ button.setAttribute('aria-expanded', false)
32
+
33
+ button.appendChild(buttonText)
34
+ adjacentTo.insertAdjacentElement('beforebegin', button)
35
+
36
+ return button
37
+ }
38
+
39
+ SuperNavigationToggle.prototype.syncStatus = function () {
40
+ this.status = this.$button.getAttribute('aria-expanded') === 'true' ? 'open' : 'closed'
41
+ }
42
+
43
+ SuperNavigationToggle.prototype.closeMenu = function () {
44
+ this.$menu.classList.remove('gem-c-layout-super-navigation-header__items--open')
45
+
46
+ this.$button.classList.remove('govuk-header__menu-button--open')
47
+ this.$button.setAttribute('aria-expanded', false)
48
+ this.$button.setAttribute('aria-label', this.showMenuText)
49
+ }
50
+
51
+ SuperNavigationToggle.prototype.openMenu = function () {
52
+ this.$menu.classList.add('gem-c-layout-super-navigation-header__items--open')
53
+
54
+ this.$button.classList.add('govuk-header__menu-button--open')
55
+ this.$button.setAttribute('aria-expanded', true)
56
+ this.$button.setAttribute('aria-label', this.hideMenuText)
57
+ }
58
+
59
+ SuperNavigationToggle.prototype.handleToggle = function () {
60
+ if (this.status === 'open') this.closeMenu()
61
+ if (this.status === 'closed') this.openMenu()
62
+
63
+ this.syncStatus()
64
+ }
65
+
66
+ SuperNavigationToggle.prototype.init = function () {
67
+ this.$button.addEventListener('click', this.handleToggle.bind(this))
68
+ }
69
+
70
+ Modules.SuperNavigationToggle = SuperNavigationToggle
71
+ })(window.GOVUK.Modules)
@@ -4,9 +4,16 @@
4
4
 
5
5
  window.GOVUK.triggerEvent = function (element, eventName, parameters) {
6
6
  var params = parameters || {}
7
- params.bubbles = true
8
- params.cancelable = true
9
7
  var event
8
+ var keyCode = params.keyCode
9
+
10
+ if (!Object.prototype.hasOwnProperty.call(params, 'bubbles')) {
11
+ params.bubbles = true
12
+ }
13
+
14
+ if (!Object.prototype.hasOwnProperty.call(params, 'cancelable')) {
15
+ params.cancelable = true
16
+ }
10
17
 
11
18
  if (typeof window.CustomEvent === 'function') {
12
19
  event = new window.CustomEvent(eventName, params)
@@ -15,6 +22,10 @@
15
22
  event.initCustomEvent(eventName, params.bubbles, params.cancelable, params.detail)
16
23
  }
17
24
 
25
+ if (keyCode) {
26
+ event.keyCode = keyCode
27
+ }
28
+
18
29
  element.dispatchEvent(event)
19
30
  }
20
31
  }(window))
@@ -49,6 +49,7 @@ $govuk-new-link-styles: true;
49
49
  @import "components/layout-for-admin";
50
50
  @import "components/layout-for-public";
51
51
  @import "components/layout-header";
52
+ @import "components/layout-super-navigation-header";
52
53
  @import "components/lead-paragraph";
53
54
  @import "components/metadata";
54
55
  @import "components/modal-dialogue";
@@ -8,6 +8,7 @@
8
8
  @import "components/print/contents-list";
9
9
  @import "components/print/govspeak-html-publication";
10
10
  @import "components/print/govspeak";
11
+ @import "components/print/layout-super-navigation-header";
11
12
  @import "components/print/step-by-step-nav-header";
12
13
  @import "components/print/step-by-step-nav";
13
14
  @import "components/print/textarea";
@@ -0,0 +1,125 @@
1
+ $search-icon-size: 20px;
2
+
3
+ .gem-c-layout-super-navigation-header {
4
+ background: govuk-colour("black");
5
+ position: relative;
6
+ }
7
+
8
+ .gem-c-layout-super-navigation-header__header-logo {
9
+ height: govuk-spacing(6);
10
+ padding-top: govuk-spacing(3);
11
+ padding-bottom: govuk-spacing(3);
12
+
13
+ @include govuk-media-query($from: "desktop") {
14
+ display: block;
15
+ float: left;
16
+ }
17
+ }
18
+
19
+ .gem-c-layout-super-navigation-header__content {
20
+ @include govuk-media-query($from: "desktop") {
21
+ display: block;
22
+ float: right;
23
+ }
24
+ }
25
+
26
+ .gem-c-layout-super-navigation-header__items {
27
+ list-style: none;
28
+ margin: 0;
29
+ padding: 0 0 govuk-spacing(1) 0;
30
+
31
+ @include govuk-media-query($from: "desktop") {
32
+ padding: 0;
33
+ }
34
+ }
35
+
36
+ .gem-c-layout-super-navigation-header__item {
37
+ margin-right: 0;
38
+ padding: govuk-spacing(1) 0;
39
+
40
+ @include govuk-media-query($from: "desktop") {
41
+ float: left;
42
+ padding: 0;
43
+ }
44
+ }
45
+
46
+ .gem-c-layout-super-navigation-header__item-link {
47
+ display: block;
48
+ padding: govuk-spacing(3) 0;
49
+ position: relative;
50
+
51
+ @include govuk-media-query($from: "desktop") {
52
+ padding: govuk-spacing(4);
53
+ width: auto;
54
+ }
55
+
56
+ &:focus {
57
+ z-index: 1;
58
+ }
59
+ }
60
+
61
+ // Special search link
62
+ .gem-c-layout-super-navigation-header__item--search {
63
+ border-bottom: 0;
64
+ }
65
+
66
+ .gem-c-layout-super-navigation-header__item-link--search {
67
+ @include govuk-media-query($from: "desktop") {
68
+ background-color: $govuk-link-colour;
69
+ display: inherit;
70
+ width: govuk-spacing(4);
71
+
72
+ &:hover {
73
+ background-color: $govuk-link-hover-colour;
74
+ }
75
+
76
+ &:focus {
77
+ background-color: $govuk-focus-colour;
78
+ }
79
+ }
80
+ }
81
+
82
+ .gem-c-layout-super-navigation-header__item-link-text--search {
83
+ @include govuk-media-query($from: "desktop") {
84
+ @include govuk-visually-hidden;
85
+ }
86
+ }
87
+
88
+ .gem-c-layout-super-navigation-header__item-link-icon--search {
89
+ display: none;
90
+
91
+ @include govuk-media-query($from: "desktop") {
92
+ display: block;
93
+ height: $search-icon-size;
94
+ width: $search-icon-size;
95
+ }
96
+ }
97
+
98
+ .gem-c-layout-super-navigation-header__menu-button {
99
+ @include govuk-font($size: 19, $weight: bold, $line-height: 20px);
100
+ border-left: 1px solid govuk-colour("mid-grey");
101
+ border-right: 1px solid govuk-colour("mid-grey");
102
+ padding: govuk-spacing(4);
103
+ top: 0;
104
+
105
+ &:focus {
106
+ border-left-color: $govuk-focus-colour;
107
+ border-right-color: $govuk-focus-colour;
108
+ }
109
+ }
110
+
111
+ .js-enabled .gem-c-layout-super-navigation-header__items {
112
+ display: none;
113
+
114
+ @include govuk-media-query($from: "desktop") {
115
+ display: block;
116
+ }
117
+ }
118
+
119
+ .js-enabled .gem-c-layout-super-navigation-header__items--open {
120
+ display: block;
121
+ }
122
+
123
+ .gem-c-layout-super-navigation-header__dropdown-menu {
124
+ display: none;
125
+ }
@@ -99,3 +99,12 @@
99
99
  font-weight: inherit;
100
100
  }
101
101
  }
102
+
103
+ .gem-c-govspeak--inverse {
104
+ color: govuk-colour('white');
105
+
106
+ a {
107
+ @include govuk-link-common;
108
+ @include govuk-link-style-inverse;
109
+ }
110
+ }
@@ -0,0 +1,3 @@
1
+ .gem-c-super-navigation-header a:after {
2
+ content: " ( " attr(href) " ) ";
3
+ }
@@ -1,10 +1,12 @@
1
1
  <%
2
+ inverse ||= false
2
3
  direction_class = "direction-#{direction}" if local_assigns.include?(:direction)
3
4
  disable_youtube_expansions = local_assigns.fetch(:disable_youtube_expansions) if local_assigns.include?(:disable_youtube_expansions)
4
5
 
5
6
  classes = []
6
7
  classes << direction_class if direction_class
7
8
  classes << "disable-youtube" if disable_youtube_expansions
9
+ classes << "gem-c-govspeak--inverse" if inverse
8
10
  %>
9
11
 
10
12
  <div class="gem-c-govspeak govuk-govspeak <%= classes.join(" ") %>" data-module="govspeak">
@@ -1,14 +1,15 @@
1
1
  <%
2
- omit_feedback_form ||= false
3
2
  emergency_banner ||= nil
4
3
  full_width ||= false
5
4
  global_bar ||= nil
6
- product_name ||= nil
7
5
  html_lang ||= "en"
8
6
  layout_helper = GovukPublishingComponents::Presenters::PublicLayoutHelper.new(local_assigns)
9
7
  logo_link ||= "/"
10
8
  navigation_items ||= []
9
+ omit_feedback_form ||= false
11
10
  omit_header ||= false
11
+ product_name ||= nil
12
+ show_explore_header ||= false
12
13
  show_search = local_assigns.include?(:show_search) ? local_assigns[:show_search] : true
13
14
  title ||= "GOV.UK - The best place to find government services and information"
14
15
 
@@ -75,16 +76,20 @@
75
76
  <%= render "govuk_publishing_components/components/cookie_banner" %>
76
77
 
77
78
  <% unless omit_header %>
78
- <%= render "govuk_publishing_components/components/layout_header", {
79
- search: show_search,
80
- logo_link: logo_link,
81
- navigation_items: navigation_items,
82
- product_name: product_name,
83
-
84
- # The (blue) bottom border needs to be underneath the emergency banner -
85
- # so it has been turned off and added in manually.
86
- remove_bottom_border: true,
87
- } %>
79
+ <% if show_explore_header %>
80
+ <%= render "govuk_publishing_components/components/layout_super_navigation_header" %>
81
+ <% else %>
82
+ <%= render "govuk_publishing_components/components/layout_header", {
83
+ search: show_search,
84
+ logo_link: logo_link,
85
+ navigation_items: navigation_items,
86
+ product_name: product_name,
87
+
88
+ # The (blue) bottom border needs to be underneath the emergency banner -
89
+ # so it has been turned off and added in manually.
90
+ remove_bottom_border: true,
91
+ } %>
92
+ <% end %>
88
93
  <% end %>
89
94
 
90
95
  <%= raw(emergency_banner) %>
@@ -0,0 +1,121 @@
1
+ <%
2
+ logo_link = "https://www.gov.uk/"
3
+ logo_link_title = t("components.layout_super_navigation_header.logo_link_title")
4
+ logo_text = t("components.layout_super_navigation_header.logo_text")
5
+ navigation_links = t("components.layout_super_navigation_header.navigation_links")
6
+ navigation_menu_heading = t("components.layout_super_navigation_header.navigation_menu_heading")
7
+ popular_links = t("components.layout_super_navigation_header.popular_links")
8
+ popular_links_heading = t("components.layout_super_navigation_header.popular_links_heading")
9
+ search_text= t("components.layout_super_navigation_header.search_text")
10
+ %>
11
+ <header role="banner" class="gem-c-layout-super-navigation-header">
12
+ <div class="gem-c-layout-super-navigation-header__container govuk-width-container govuk-clearfix">
13
+ <div class="gem-c-layout-super-navigation-header__header-logo">
14
+ <a class="govuk-header__link govuk-header__link--homepage"
15
+ data-module="gem-track-click"
16
+ data-track-action="homeHeader"
17
+ data-track-category="homeLinkClicked"
18
+ href="<%= logo_link %>"
19
+ id="logo"
20
+ title="<%= logo_link_title %>">
21
+ <span class="govuk-header__logotype">
22
+ <svg aria-hidden="true"
23
+ class="govuk-header__logotype-crown gem-c-layout-super-navigation-header__logotype-crown"
24
+ focusable="false"
25
+ height="30"
26
+ viewBox="0 0 132 97"
27
+ xmlns="http://www.w3.org/2000/svg"
28
+ width="36">
29
+ <path fill="currentColor"
30
+ fill-rule="evenodd"
31
+ d="M25 30.2c3.5 1.5 7.7-.2 9.1-3.7 1.5-3.6-.2-7.8-3.9-9.2-3.6-1.4-7.6.3-9.1 3.9-1.4 3.5.3 7.5 3.9 9zM9 39.5c3.6 1.5 7.8-.2 9.2-3.7 1.5-3.6-.2-7.8-3.9-9.1-3.6-1.5-7.6.2-9.1 3.8-1.4 3.5.3 7.5 3.8 9zM4.4 57.2c3.5 1.5 7.7-.2 9.1-3.8 1.5-3.6-.2-7.7-3.9-9.1-3.5-1.5-7.6.3-9.1 3.8-1.4 3.5.3 7.6 3.9 9.1zm38.3-21.4c3.5 1.5 7.7-.2 9.1-3.8 1.5-3.6-.2-7.7-3.9-9.1-3.6-1.5-7.6.3-9.1 3.8-1.3 3.6.4 7.7 3.9 9.1zm64.4-5.6c-3.6 1.5-7.8-.2-9.1-3.7-1.5-3.6.2-7.8 3.8-9.2 3.6-1.4 7.7.3 9.2 3.9 1.3 3.5-.4 7.5-3.9 9zm15.9 9.3c-3.6 1.5-7.7-.2-9.1-3.7-1.5-3.6.2-7.8 3.7-9.1 3.6-1.5 7.7.2 9.2 3.8 1.5 3.5-.3 7.5-3.8 9zm4.7 17.7c-3.6 1.5-7.8-.2-9.2-3.8-1.5-3.6.2-7.7 3.9-9.1 3.6-1.5 7.7.3 9.2 3.8 1.3 3.5-.4 7.6-3.9 9.1zM89.3 35.8c-3.6 1.5-7.8-.2-9.2-3.8-1.4-3.6.2-7.7 3.9-9.1 3.6-1.5 7.7.3 9.2 3.8 1.4 3.6-.3 7.7-3.9 9.1zM69.7 17.7l8.9 4.7V9.3l-8.9 2.8c-.2-.3-.5-.6-.9-.9L72.4 0H59.6l3.5 11.2c-.3.3-.6.5-.9.9l-8.8-2.8v13.1l8.8-4.7c.3.3.6.7.9.9l-5 15.4v.1c-.2.8-.4 1.6-.4 2.4 0 4.1 3.1 7.5 7 8.1h.2c.3 0 .7.1 1 .1.4 0 .7 0 1-.1h.2c4-.6 7.1-4.1 7.1-8.1 0-.8-.1-1.7-.4-2.4V34l-5.1-15.4c.4-.2.7-.6 1-.9zM66 92.8c16.9 0 32.8 1.1 47.1 3.2 4-16.9 8.9-26.7 14-33.5l-9.6-3.4c1 4.9 1.1 7.2 0 10.2-1.5-1.4-3-4.3-4.2-8.7L108.6 76c2.8-2 5-3.2 7.5-3.3-4.4 9.4-10 11.9-13.6 11.2-4.3-.8-6.3-4.6-5.6-7.9 1-4.7 5.7-5.9 8-.5 4.3-8.7-3-11.4-7.6-8.8 7.1-7.2 7.9-13.5 2.1-21.1-8 6.1-8.1 12.3-4.5 20.8-4.7-5.4-12.1-2.5-9.5 6.2 3.4-5.2 7.9-2 7.2 3.1-.6 4.3-6.4 7.8-13.5 7.2-10.3-.9-10.9-8-11.2-13.8 2.5-.5 7.1 1.8 11 7.3L80.2 60c-4.1 4.4-8 5.3-12.3 5.4 1.4-4.4 8-11.6 8-11.6H55.5s6.4 7.2 7.9 11.6c-4.2-.1-8-1-12.3-5.4l1.4 16.4c3.9-5.5 8.5-7.7 10.9-7.3-.3 5.8-.9 12.8-11.1 13.8-7.2.6-12.9-2.9-13.5-7.2-.7-5 3.8-8.3 7.1-3.1 2.7-8.7-4.6-11.6-9.4-6.2 3.7-8.5 3.6-14.7-4.6-20.8-5.8 7.6-5 13.9 2.2 21.1-4.7-2.6-11.9.1-7.7 8.8 2.3-5.5 7.1-4.2 8.1.5.7 3.3-1.3 7.1-5.7 7.9-3.5.7-9-1.8-13.5-11.2 2.5.1 4.7 1.3 7.5 3.3l-4.7-15.4c-1.2 4.4-2.7 7.2-4.3 8.7-1.1-3-.9-5.3 0-10.2l-9.5 3.4c5 6.9 9.9 16.7 14 33.5 14.8-2.1 30.8-3.2 47.7-3.2z">
32
+ </path>
33
+ <image class="govuk-header__logotype-crown-fallback-image"
34
+ height="30"
35
+ src="<%= asset_path('govuk-logotype-crown.png') %>"
36
+ width="36"
37
+ xlink:href="">
38
+ </image>
39
+ </svg>
40
+ <span class="govuk-header__logotype-text">
41
+ <%= logo_text %>
42
+ </span>
43
+ </span>
44
+ </a>
45
+ </div>
46
+ <nav
47
+ aria-labelledby="super-navigation-menu-heading"
48
+ class="gem-c-layout-super-navigation-header__content"
49
+ data-module="super-navigation-toggle"
50
+ data-text-for-button="Menu"
51
+ data-text-for-show-menu="Show navigation menu"
52
+ data-text-for-hide-menu="Hide navigation menu"
53
+ >
54
+ <h2 id="super-navigation-menu-heading" class="govuk-visually-hidden"><%= navigation_menu_heading %></h2>
55
+ <ul id="super-navigation-menu" class="gem-c-layout-super-navigation-header__items">
56
+ <% navigation_links.each do | link | %>
57
+ <li class="govuk-header__navigation-item gem-c-layout-super-navigation-header__item">
58
+ <a class="govuk-header__link gem-c-layout-super-navigation-header__item-link" href="<%= link[:href] %>">
59
+ <%= link[:label] %>
60
+ </a>
61
+ <% if link[:menu_contents].present? or link[:footer_links].present? %>
62
+ <div class="gem-c-layout-super-navigation-header__dropdown-menu">
63
+ <% if link[:menu_contents].present? %>
64
+ <ul class="govuk-list">
65
+ <% link[:menu_contents].each do | item | %>
66
+ <li class="gem-c-layout-super-navigation-header__dropdown-list-item">
67
+ <a class="govuk-link gem-c-layout-super-navigation-header__dropdown-list-item-link" href="<%= item[:href] %>">
68
+ <%= item[:label] %>
69
+ </a>
70
+ <%= tag.p item[:description], class: "govuk-body-s gem-c-layout-super-navigation-header__dropdown-list-item-description" if item[:description].present? %>
71
+ </li>
72
+ <% end %>
73
+ </ul>
74
+ <% end %>
75
+ <% if link[:footer_links].present? %>
76
+ <ul class="govuk-list">
77
+ <% link[:footer_links].each do | item | %>
78
+ <li class="gem-c-layout-super-navigation-header__dropdown-list-item">
79
+ <a class="govuk-link gem-c-layout-super-navigation-header__dropdown-list-item-link" href="<%= item[:href] %>">
80
+ <%= item[:label] %>
81
+ </a>
82
+ </li>
83
+ <% end %>
84
+ </ul>
85
+ <% end %>
86
+ </div>
87
+ <% end %>
88
+ </li>
89
+ <% end %>
90
+ <li class="govuk-header__navigation-item gem-c-layout-super-navigation-header__item gem-c-layout-super-navigation-header__item--search">
91
+ <a class="govuk-header__link gem-c-layout-super-navigation-header__item-link gem-c-layout-super-navigation-header__item-link--search" href="/search">
92
+ <span class="gem-c-layout-super-navigation-header__item-link-text--search"><%= search_text %></span>
93
+ <svg class="gem-c-layout-super-navigation-header__item-link-icon--search" width="27" height="27" viewBox="0 0 27 27" fill="none" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false">
94
+ <circle cx="10.0161" cy="10.0161" r="8.51613" stroke="currentColor" stroke-width="3" />
95
+ <line x1="15.8668" y1="16.3587" x2="25.4475" y2="25.9393" stroke="currentColor" stroke-width="3" />
96
+ </svg>
97
+ </a>
98
+ <div class="gem-c-layout-super-navigation-header__dropdown-menu">
99
+ <form id="search" action="/search" method="get" role="search" aria-label="Site-wide">
100
+ <%= render "govuk_publishing_components/components/search", {
101
+ inline_label: false,
102
+ label_text: raw("<h2 class=\"govuk-heading-m\">#{search_text}</h2>"),
103
+ size: "large",
104
+ } %>
105
+ </form>
106
+ <h2 class="govuk-heading-m"><%= popular_links_heading %></h2>
107
+ <ul class="govuk-list">
108
+ <% popular_links.each do | popular_link | %>
109
+ <li class="gem-c-layout-super-navigation-header__dropdown-list-item">
110
+ <a class="govuk-link gem-c-layout-super-navigation-header__dropdown-list-item-link" href="<%= popular_link[:href] %>">
111
+ <%= popular_link[:label] %>
112
+ </a>
113
+ </li>
114
+ <% end %>
115
+ </ul>
116
+ </div>
117
+ </li>
118
+ </ul>
119
+ </nav>
120
+ </div>
121
+ </header>