header-search-wide.pcss.css

Same filename and directory in other branches
  1. 10 core/themes/olivero/css/components/header-search-wide.pcss.css
  2. 9 core/themes/olivero/css/components/header-search-wide.pcss.css

Header Search Wide Block.

File

core/themes/olivero/css/components/header-search-wide.pcss.css

View source
  1. /**
  2. * @file
  3. * Header Search Wide Block.
  4. */
  5. @import "../base/media-queries.pcss.css";
  6. /* Override contextual links so we can position against .site-header. */
  7. .block-search-wide.contextual-region {
  8. position: static;
  9. }
  10. .block-search-wide__wrapper {
  11. position: absolute;
  12. inset-block-start: 100%;
  13. inset-inline-start: calc(-1 * var(--content-left));
  14. display: none;
  15. visibility: hidden;
  16. overflow: hidden;
  17. width: calc(100% + var(--content-left));
  18. max-width: var(--max-bg-color);
  19. height: var(--sp8);
  20. max-height: 0;
  21. margin-block: 0;
  22. margin-inline-start: 0;
  23. margin-inline-end: 0;
  24. padding-block: 0;
  25. padding-inline-start: 0;
  26. padding-inline-end: 0;
  27. transition: all 0.2s;
  28. border-inline-start: solid var(--content-left) var(--color--gray-20);
  29. background: var(--color--black);
  30. &.is-active {
  31. visibility: visible;
  32. max-height: var(--sp8);
  33. }
  34. & form {
  35. display: flex;
  36. grid-column: 1 / 14;
  37. }
  38. & input[type="search"] {
  39. width: calc(100% + var(--sp2));
  40. height: var(--sp8);
  41. padding-block: 0;
  42. padding-inline-start: var(--sp12);
  43. padding-inline-end: 0;
  44. transition: background-size 0.4s;
  45. color: var(--color--white);
  46. border: solid 1px transparent;
  47. box-shadow: none;
  48. font-family: var(--font-serif);
  49. font-size: 32px;
  50. -webkit-appearance: none;
  51. &:focus {
  52. outline: solid 4px transparent;
  53. outline-offset: -4px;
  54. }
  55. }
  56. & .form-item-keys {
  57. flex-grow: 1;
  58. margin: 0;
  59. }
  60. & .form-actions {
  61. display: flex;
  62. margin: 0;
  63. }
  64. & .search-form__submit {
  65. position: relative;
  66. overflow: hidden;
  67. align-self: stretch;
  68. width: 100px;
  69. height: auto;
  70. margin-block: 0;
  71. margin-inline-start: 0;
  72. margin-inline-end: 0;
  73. padding-block: 0;
  74. padding-inline-start: 0;
  75. padding-inline-end: 0;
  76. cursor: pointer;
  77. border-color: transparent;
  78. background-color: transparent;
  79. /*
  80. When in Windows high contrast mode, FF will not output either background
  81. images or SVGs that are nested directly within a element, so we add a .
  82. */
  83. & .icon--search {
  84. position: absolute;
  85. inset-block-start: 0;
  86. inset-inline-end: 0;
  87. display: block;
  88. width: 24px; /* Width of the SVG background image. */
  89. height: 100%;
  90. pointer-events: none;
  91. background-image: url("../../images/search--white.svg");
  92. background-repeat: no-repeat;
  93. background-position: center;
  94. background-size: contain;
  95. &::after {
  96. position: absolute;
  97. inset-block-end: 0;
  98. inset-inline-start: 0;
  99. width: 100%;
  100. height: 0;
  101. content: "";
  102. transition: transform 0.2s;
  103. transform: scaleX(0);
  104. transform-origin: left;
  105. border-block-start: solid var(--sp0-5) var(--color--primary-50);
  106. }
  107. }
  108. &:focus {
  109. outline: solid 4px transparent;
  110. outline-offset: -4px;
  111. box-shadow: none;
  112. & span::after {
  113. transform: scaleX(1);
  114. }
  115. }
  116. }
  117. }
  118. .block-search-wide__container {
  119. max-width: var(--max-width);
  120. padding-inline-end: var(--sp2);
  121. }
  122. .block-search-wide__grid {
  123. display: grid;
  124. grid-template-columns: repeat(var(--grid-col-count), 1fr);
  125. grid-column-gap: var(--grid-gap);
  126. }
  127. /* Override specificity from container-inline.module.css */
  128. .container-inline {
  129. & .block-search-wide__container {
  130. display: block;
  131. }
  132. & .block-search-wide__grid {
  133. display: grid;
  134. }
  135. }
  136. .block-search-wide__button {
  137. position: relative;
  138. display: none;
  139. width: var(--sp3);
  140. height: var(--sp6);
  141. cursor: pointer;
  142. color: var(--color-text-neutral-loud); /* Affects SVG search icon. */
  143. border: 0;
  144. background: transparent;
  145. -webkit-appearance: none;
  146. &:focus {
  147. position: relative;
  148. outline: 0;
  149. &::after {
  150. position: absolute;
  151. top: 50%;
  152. left: 50%;
  153. width: 80%;
  154. height: var(--sp3);
  155. content: "";
  156. transform: translate(-50%, -50%);
  157. border: solid 2px var(--color--primary-50);
  158. border-radius: 4px;
  159. }
  160. }
  161. &[aria-expanded="true"] {
  162. background: var(--color--black);
  163. &:focus::after {
  164. border-color: var(--color--white);
  165. }
  166. & .block-search-wide__button-close {
  167. &::before,
  168. &::after {
  169. position: absolute;
  170. top: 50%;
  171. left: 50%;
  172. width: var(--sp1-5);
  173. height: 0;
  174. content: "";
  175. border-block-start: solid 2px var(--color--white);
  176. }
  177. &::before {
  178. transform: translate(-50%, -50%) rotate(-45deg);
  179. }
  180. &::after {
  181. transform: translate(-50%, -50%) rotate(45deg);
  182. }
  183. }
  184. & svg {
  185. display: none;
  186. }
  187. }
  188. & svg {
  189. margin-inline-start: auto;
  190. margin-inline-end: auto;
  191. }
  192. @media (forced-colors: active) {
  193. background: ButtonFace;
  194. & path {
  195. fill: ButtonText;
  196. }
  197. }
  198. }
  199. /* Provide rudimentary access to site search if JS is disabled. */
  200. html:not(.js) .search-block-form:focus-within .block-search-wide__wrapper {
  201. visibility: visible;
  202. max-height: var(--sp8);
  203. }
  204. /* Necessary to override specificity of transpiled PostCSS properties from default input focus styling. */
  205. [dir] .block-search-wide__wrapper input[type="search"] {
  206. background-color: transparent;
  207. background-image: linear-gradient(var(--color--primary-50));
  208. background-repeat: no-repeat;
  209. background-position: bottom left; /* LTR */
  210. background-size: 0% 10px;
  211. &:focus {
  212. background-size: 100% var(--sp0-5);
  213. }
  214. }
  215. [dir="rtl"] .block-search-wide__wrapper {
  216. & input[type="search"] {
  217. background-position: bottom right;
  218. }
  219. & .search-form__submit .icon--search::after {
  220. transform-origin: right;
  221. }
  222. }
  223. body:not(.is-always-mobile-nav) {
  224. & .block-search-wide__wrapper,
  225. & .block-search-wide__button {
  226. @media (--nav) {
  227. display: block;
  228. }
  229. }
  230. }

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