tabs.pcss.css

Same filename in this branch
  1. 9 core/themes/olivero/css/components/tabs.pcss.css
Same filename and directory in other branches
  1. 11.x core/themes/olivero/css/components/tabs.pcss.css
  2. 11.x core/themes/claro/css/components/tabs.pcss.css
  3. 10 core/themes/olivero/css/components/tabs.pcss.css
  4. 10 core/themes/claro/css/components/tabs.pcss.css
  5. 8.9.x core/themes/claro/css/components/tabs.pcss.css
/**
 * Tabs.
 */

@import "../base/variables.pcss.css";

:root {
  /**
  * Tabs.
  */
  --tabs-border-radius-size: var(--base-border-radius);
  --tabs--hover-height: 3px;
  --tabs--focus-height: 3px;
  --tabs--active-height: 3px;
  --tabs-link-height: 3rem; /* 48px */
  --tabs-secondary-link-height: 2.5rem; /* 40px */
  --tabs-base-border: 1px solid var(--color-gray-200);
  --tabs-base-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  --tabs-trigger-border: 1px solid rgba(216, 217, 224, 0.8);
  --tabs--hover-bg-color: var(--color-bgblue-active);
}

.tabs-wrapper > nav {
  width: 100%;
}
.tabs {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 0 var(--space-l) 0;
  border: var(--tabs-base-border);
  border-radius: var(--tabs-border-radius-size);
  box-shadow: var(--tabs-base-shadow);
}
[dir="rtl"] .tabs {
  margin: 0 0 var(--space-l) 0;
}

.tabs__tab {
  position: relative;
  border-bottom: var(--tabs-base-border);
  background-color: var(--color-gray-025);
  font-size: var(--font-size-s);
  font-weight: bold;
}
.tabs__tab:last-child {
  border-bottom: 0;
}
.tabs__tab.is-active {
  display: flex;
  justify-content: space-between;
  background-color: var(--color-white);
  box-shadow: var(--tabs-base-shadow);
}

.tabs__link {
  position: relative;
  display: flex;
  overflow: hidden;
  flex-grow: 1;
  align-items: center;
  box-sizing: border-box;
  min-height: var(--tabs-link-height);
  padding: var(--space-s) var(--space-l);
  text-decoration: none;
  color: var(--color-gray-800);
  line-height: 1.2rem;
}
.tabs__link:focus {
  min-height: calc(var(--tabs-link-height) + var(--tabs--focus-height) - 1px);
  margin: -1px;
  padding-left: calc(var(--space-l) - var(--tabs--focus-height) + 1px); /* LTR */
  text-decoration: none;
  color: var(--color-gray-800);
  border: var(--tabs--focus-height) solid var(--color-focus);
  border-radius: var(--tabs-border-radius-size);
  outline: none;
  box-shadow: none;
}
[dir="rtl"] .tabs__link:focus {
  padding-right: calc(var(--space-l) - var(--tabs--focus-height) + 1px);
  padding-left: var(--space-l);
}
.tabs__link:hover {
  text-decoration: none;
  color: var(--color-text);
}
.tabs__link.is-active {
  z-index: 1;
  flex-grow: 1;
  color: var(--color-absolutezero);
}
.tabs__link.is-active:focus {
  margin: -1px 0;
  padding-right: var(--space-l);
  padding-left: var(--space-l);
  border-left: none; /* LTR */
  border-radius: 0;
}
.tabs__link:not(.is-active):focus {
  z-index: 3;
}
[dir="rtl"] .tabs__link.is-active:focus {
  border-right: none;
  border-left: var(--tabs--focus-height) solid var(--color-focus);
}
.tabs__link.is-active:hover {
  color: var(--color-text);
}
/* Active and hover indicator. */
.tabs__tab::before,
.tabs__link::before {
  position: absolute;
  display: block;
  content: "";
}
.tabs__tab.is-active::before {
  z-index: 2;
  top: -1px;
  left: -1px; /* LTR */
  width: var(--tabs--active-height);
  height: calc(100% + 2px);
  border-left: var(--tabs--active-height) solid var(--color-absolutezero); /* LTR */
  border-top-left-radius: var(--tabs-border-radius-size); /* LTR */
}
[dir="rtl"] .tabs__tab.is-active::before {
  right: -1px;
  left: auto;
  border-right: var(--tabs--focus-height) solid var(--color-absolutezero);
  border-left: none;
  border-radius: 0 var(--tabs-border-radius-size) 0 var(--tabs-border-radius-size);
}
.tabs.is-open .tabs__tab.is-active::before {
  border-bottom-left-radius: 0; /* LTR */
}
[dir="rtl"] .tabs.is-open .tabs__tab.is-active::before {
  border-bottom-right-radius: var(--tabs-border-radius-size);
}
.tabs__tab.is-active:focus::before {
  top: calc(var(--tabs--focus-height) * -1);
  height: calc(var(--tabs-link-height) + 2px);
}

.tabs__tab:not(.is-active) {
  display: none;
}
.tabs--secondary .tabs__tab:not(.is-active) {
  display: block;
}
.tabs.is-open > .tabs__tab {
  display: flex;
}

.tabs__trigger {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: var(--tabs-link-height);
  padding-right: 1px;
  text-align: center;
  border-left: var(--tabs-trigger-border); /* LTR */
}
[dir="rtl"] .tabs__trigger {
  border-right: var(--tabs-trigger-border);
  border-left: none;
}
.tabs__trigger:focus {
  padding-right: 0;
  border: var(--tabs--focus-height) solid var(--color-focus);
  border-radius: var(--tabs-border-radius-size);
  box-shadow: none;
}

@media screen and (min-width: 48em) {
  .tabs-wrapper {
    display: flex;
  }

  .tabs-wrapper--secondary {
    position: relative;
  }

  .is-horizontal .tabs {
    flex-direction: row;
    width: auto;
    margin: 0;
    border: 0;
    box-shadow: none;
  }

  .is-horizontal .tabs--secondary {
    overflow: hidden;
    margin: calc(calc(var(--tabs--focus-height) + 3px) * -1) calc(calc(var(--tabs--focus-height) + 3px) * -1) 0;
    padding: calc(var(--tabs--focus-height) + 3px) calc(var(--tabs--focus-height) + 3px) 0;
    border-radius: 0;
  }

  .is-horizontal .tabs--secondary .tabs__tab {
    font-size: var(--font-size-s);
  }

  .is-horizontal .tabs--secondary .tabs__link {
    min-height: var(--tabs-secondary-link-height);
    padding-top: var(--space-xs);
    padding-bottom: var(--space-xs);
  }

  .is-horizontal .tabs--secondary .tabs__link:focus {
    min-height: var(--tabs-secondary-link-height);
  }

  .is-horizontal .tabs--secondary::after {
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    content: "";
    border-bottom: 1px solid var(--color-gray-200);
  }

  .is-horizontal .tabs__tab {
    border-top: none;
    border-bottom: none;
    background: none;
    font-size: var(--font-size-base);
  }

  .is-horizontal .tabs__tab.is-active {
    order: 0;
    background: none;
    box-shadow: none;
  }
  .is-horizontal .tabs__tab.is-active::before {
    content: none;
  }
  .is-horizontal .tabs__tab .tabs__link.is-active::before {
    border-radius: 0;
  }
  .is-horizontal .tabs__trigger {
    display: none;
  }
  .is-horizontal .tabs__tab {
    display: block;
  }

  .is-horizontal .tabs__link {
    padding-right: 2rem;
    padding-left: 2rem;
    border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  }

  .is-horizontal .tabs__link:focus {
    min-height: var(--tabs-link-height);
    margin: 0;
    padding-right: 2rem;
    padding-left: 2rem;
    color: var(--color-text);
    border: none;
    border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
    outline: 2px dotted transparent;
    box-shadow: 0 0 0 2px var(--color-white), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  }
  [dir="rtl"] .is-horizontal .tabs__link:focus {
    border: none;
  }
  .is-horizontal .tabs--primary .tabs__link:focus {
    box-shadow: 0 0 0 2px var(--color-gray-050), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  }

  .is-horizontal .tabs__link:hover {
    color: var(--color-absolutezero-hover);
    background: var(--tabs--hover-bg-color);
  }

  .is-horizontal .tabs__link.is-active::before {
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: var(--tabs--active-height);
    border-right: none;
    border-bottom: var(--tabs--active-height) solid var(--color-absolutezero);
    border-left: none;
  }
}

File

core/themes/claro/css/components/tabs.pcss.css

View source
  1. /**
  2. * Tabs.
  3. */
  4. @import "../base/variables.pcss.css";
  5. :root {
  6. /**
  7. * Tabs.
  8. */
  9. --tabs-border-radius-size: var(--base-border-radius);
  10. --tabs--hover-height: 3px;
  11. --tabs--focus-height: 3px;
  12. --tabs--active-height: 3px;
  13. --tabs-link-height: 3rem; /* 48px */
  14. --tabs-secondary-link-height: 2.5rem; /* 40px */
  15. --tabs-base-border: 1px solid var(--color-gray-200);
  16. --tabs-base-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  17. --tabs-trigger-border: 1px solid rgba(216, 217, 224, 0.8);
  18. --tabs--hover-bg-color: var(--color-bgblue-active);
  19. }
  20. .tabs-wrapper > nav {
  21. width: 100%;
  22. }
  23. .tabs {
  24. display: flex;
  25. flex-direction: column;
  26. width: 100%;
  27. margin: 0 0 var(--space-l) 0;
  28. border: var(--tabs-base-border);
  29. border-radius: var(--tabs-border-radius-size);
  30. box-shadow: var(--tabs-base-shadow);
  31. }
  32. [dir="rtl"] .tabs {
  33. margin: 0 0 var(--space-l) 0;
  34. }
  35. .tabs__tab {
  36. position: relative;
  37. border-bottom: var(--tabs-base-border);
  38. background-color: var(--color-gray-025);
  39. font-size: var(--font-size-s);
  40. font-weight: bold;
  41. }
  42. .tabs__tab:last-child {
  43. border-bottom: 0;
  44. }
  45. .tabs__tab.is-active {
  46. display: flex;
  47. justify-content: space-between;
  48. background-color: var(--color-white);
  49. box-shadow: var(--tabs-base-shadow);
  50. }
  51. .tabs__link {
  52. position: relative;
  53. display: flex;
  54. overflow: hidden;
  55. flex-grow: 1;
  56. align-items: center;
  57. box-sizing: border-box;
  58. min-height: var(--tabs-link-height);
  59. padding: var(--space-s) var(--space-l);
  60. text-decoration: none;
  61. color: var(--color-gray-800);
  62. line-height: 1.2rem;
  63. }
  64. .tabs__link:focus {
  65. min-height: calc(var(--tabs-link-height) + var(--tabs--focus-height) - 1px);
  66. margin: -1px;
  67. padding-left: calc(var(--space-l) - var(--tabs--focus-height) + 1px); /* LTR */
  68. text-decoration: none;
  69. color: var(--color-gray-800);
  70. border: var(--tabs--focus-height) solid var(--color-focus);
  71. border-radius: var(--tabs-border-radius-size);
  72. outline: none;
  73. box-shadow: none;
  74. }
  75. [dir="rtl"] .tabs__link:focus {
  76. padding-right: calc(var(--space-l) - var(--tabs--focus-height) + 1px);
  77. padding-left: var(--space-l);
  78. }
  79. .tabs__link:hover {
  80. text-decoration: none;
  81. color: var(--color-text);
  82. }
  83. .tabs__link.is-active {
  84. z-index: 1;
  85. flex-grow: 1;
  86. color: var(--color-absolutezero);
  87. }
  88. .tabs__link.is-active:focus {
  89. margin: -1px 0;
  90. padding-right: var(--space-l);
  91. padding-left: var(--space-l);
  92. border-left: none; /* LTR */
  93. border-radius: 0;
  94. }
  95. .tabs__link:not(.is-active):focus {
  96. z-index: 3;
  97. }
  98. [dir="rtl"] .tabs__link.is-active:focus {
  99. border-right: none;
  100. border-left: var(--tabs--focus-height) solid var(--color-focus);
  101. }
  102. .tabs__link.is-active:hover {
  103. color: var(--color-text);
  104. }
  105. /* Active and hover indicator. */
  106. .tabs__tab::before,
  107. .tabs__link::before {
  108. position: absolute;
  109. display: block;
  110. content: "";
  111. }
  112. .tabs__tab.is-active::before {
  113. z-index: 2;
  114. top: -1px;
  115. left: -1px; /* LTR */
  116. width: var(--tabs--active-height);
  117. height: calc(100% + 2px);
  118. border-left: var(--tabs--active-height) solid var(--color-absolutezero); /* LTR */
  119. border-top-left-radius: var(--tabs-border-radius-size); /* LTR */
  120. }
  121. [dir="rtl"] .tabs__tab.is-active::before {
  122. right: -1px;
  123. left: auto;
  124. border-right: var(--tabs--focus-height) solid var(--color-absolutezero);
  125. border-left: none;
  126. border-radius: 0 var(--tabs-border-radius-size) 0 var(--tabs-border-radius-size);
  127. }
  128. .tabs.is-open .tabs__tab.is-active::before {
  129. border-bottom-left-radius: 0; /* LTR */
  130. }
  131. [dir="rtl"] .tabs.is-open .tabs__tab.is-active::before {
  132. border-bottom-right-radius: var(--tabs-border-radius-size);
  133. }
  134. .tabs__tab.is-active:focus::before {
  135. top: calc(var(--tabs--focus-height) * -1);
  136. height: calc(var(--tabs-link-height) + 2px);
  137. }
  138. .tabs__tab:not(.is-active) {
  139. display: none;
  140. }
  141. .tabs--secondary .tabs__tab:not(.is-active) {
  142. display: block;
  143. }
  144. .tabs.is-open > .tabs__tab {
  145. display: flex;
  146. }
  147. .tabs__trigger {
  148. display: flex;
  149. flex-shrink: 0;
  150. align-items: center;
  151. justify-content: center;
  152. width: var(--tabs-link-height);
  153. padding-right: 1px;
  154. text-align: center;
  155. border-left: var(--tabs-trigger-border); /* LTR */
  156. }
  157. [dir="rtl"] .tabs__trigger {
  158. border-right: var(--tabs-trigger-border);
  159. border-left: none;
  160. }
  161. .tabs__trigger:focus {
  162. padding-right: 0;
  163. border: var(--tabs--focus-height) solid var(--color-focus);
  164. border-radius: var(--tabs-border-radius-size);
  165. box-shadow: none;
  166. }
  167. @media screen and (min-width: 48em) {
  168. .tabs-wrapper {
  169. display: flex;
  170. }
  171. .tabs-wrapper--secondary {
  172. position: relative;
  173. }
  174. .is-horizontal .tabs {
  175. flex-direction: row;
  176. width: auto;
  177. margin: 0;
  178. border: 0;
  179. box-shadow: none;
  180. }
  181. .is-horizontal .tabs--secondary {
  182. overflow: hidden;
  183. margin: calc(calc(var(--tabs--focus-height) + 3px) * -1) calc(calc(var(--tabs--focus-height) + 3px) * -1) 0;
  184. padding: calc(var(--tabs--focus-height) + 3px) calc(var(--tabs--focus-height) + 3px) 0;
  185. border-radius: 0;
  186. }
  187. .is-horizontal .tabs--secondary .tabs__tab {
  188. font-size: var(--font-size-s);
  189. }
  190. .is-horizontal .tabs--secondary .tabs__link {
  191. min-height: var(--tabs-secondary-link-height);
  192. padding-top: var(--space-xs);
  193. padding-bottom: var(--space-xs);
  194. }
  195. .is-horizontal .tabs--secondary .tabs__link:focus {
  196. min-height: var(--tabs-secondary-link-height);
  197. }
  198. .is-horizontal .tabs--secondary::after {
  199. position: absolute;
  200. bottom: 0;
  201. left: 0;
  202. display: block;
  203. width: 100%;
  204. content: "";
  205. border-bottom: 1px solid var(--color-gray-200);
  206. }
  207. .is-horizontal .tabs__tab {
  208. border-top: none;
  209. border-bottom: none;
  210. background: none;
  211. font-size: var(--font-size-base);
  212. }
  213. .is-horizontal .tabs__tab.is-active {
  214. order: 0;
  215. background: none;
  216. box-shadow: none;
  217. }
  218. .is-horizontal .tabs__tab.is-active::before {
  219. content: none;
  220. }
  221. .is-horizontal .tabs__tab .tabs__link.is-active::before {
  222. border-radius: 0;
  223. }
  224. .is-horizontal .tabs__trigger {
  225. display: none;
  226. }
  227. .is-horizontal .tabs__tab {
  228. display: block;
  229. }
  230. .is-horizontal .tabs__link {
  231. padding-right: 2rem;
  232. padding-left: 2rem;
  233. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  234. }
  235. .is-horizontal .tabs__link:focus {
  236. min-height: var(--tabs-link-height);
  237. margin: 0;
  238. padding-right: 2rem;
  239. padding-left: 2rem;
  240. color: var(--color-text);
  241. border: none;
  242. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  243. outline: 2px dotted transparent;
  244. box-shadow: 0 0 0 2px var(--color-white), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  245. }
  246. [dir="rtl"] .is-horizontal .tabs__link:focus {
  247. border: none;
  248. }
  249. .is-horizontal .tabs--primary .tabs__link:focus {
  250. box-shadow: 0 0 0 2px var(--color-gray-050), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  251. }
  252. .is-horizontal .tabs__link:hover {
  253. color: var(--color-absolutezero-hover);
  254. background: var(--tabs--hover-bg-color);
  255. }
  256. .is-horizontal .tabs__link.is-active::before {
  257. top: auto;
  258. right: 0;
  259. bottom: 0;
  260. left: 0;
  261. width: 100%;
  262. height: var(--tabs--active-height);
  263. border-right: none;
  264. border-bottom: var(--tabs--active-height) solid var(--color-absolutezero);
  265. border-left: none;
  266. }
  267. }

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