tabs.pcss.css 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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-lightgray);
  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: #e6ecf8;
  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-whitesmoke-light);
  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-davysgrey);
  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-davysgrey);
  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. .is-horizontal .tabs {
  172. flex-direction: row;
  173. width: auto;
  174. margin: 0;
  175. border: 0;
  176. box-shadow: none;
  177. }
  178. .is-horizontal .tabs--secondary {
  179. overflow: hidden;
  180. margin: calc(calc(var(--tabs--focus-height) + 3px) * -1) calc(calc(var(--tabs--focus-height) + 3px) * -1) 0;
  181. padding: calc(var(--tabs--focus-height) + 3px) calc(var(--tabs--focus-height) + 3px) 0;
  182. border-radius: 0;
  183. }
  184. .is-horizontal .tabs--secondary .tabs__tab {
  185. font-size: var(--font-size-s);
  186. }
  187. .is-horizontal .tabs--secondary .tabs__link {
  188. min-height: var(--tabs-secondary-link-height);
  189. padding-top: var(--space-xs);
  190. padding-bottom: var(--space-xs);
  191. }
  192. .is-horizontal .tabs--secondary .tabs__link:focus {
  193. min-height: var(--tabs-secondary-link-height);
  194. }
  195. .is-horizontal .tabs--secondary::after {
  196. position: absolute;
  197. bottom: 0;
  198. left: 0;
  199. display: block;
  200. width: 100%;
  201. content: "";
  202. border-bottom: 1px solid var(--color-lightgray);
  203. }
  204. .is-horizontal .tabs__tab {
  205. border-top: none;
  206. border-bottom: none;
  207. background: none;
  208. font-size: var(--font-size-base);
  209. }
  210. .is-horizontal .tabs__tab.is-active {
  211. order: 0;
  212. background: none;
  213. box-shadow: none;
  214. }
  215. .is-horizontal .tabs__tab.is-active::before {
  216. content: none;
  217. }
  218. .is-horizontal .tabs__tab .tabs__link.is-active::before {
  219. border-radius: 0;
  220. }
  221. .is-horizontal .tabs__trigger {
  222. display: none;
  223. }
  224. .is-horizontal .tabs__tab {
  225. display: block;
  226. }
  227. .is-horizontal .tabs__link {
  228. padding-right: 2rem;
  229. padding-left: 2rem;
  230. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  231. }
  232. .is-horizontal .tabs__link:focus {
  233. min-height: var(--tabs-link-height);
  234. margin: 0;
  235. padding-right: 2rem;
  236. padding-left: 2rem;
  237. color: var(--color-text);
  238. border: none;
  239. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  240. outline: 2px dotted transparent;
  241. box-shadow: 0 0 0 2px var(--color-white), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  242. }
  243. [dir="rtl"] .is-horizontal .tabs__link:focus {
  244. border: none;
  245. }
  246. .is-horizontal .tabs--primary .tabs__link:focus {
  247. box-shadow: 0 0 0 2px var(--color-whitesmoke), 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  248. }
  249. .is-horizontal .tabs__link:hover {
  250. color: var(--color-absolutezero-hover);
  251. background: var(--tabs--hover-bg-color);
  252. }
  253. .is-horizontal .tabs__link.is-active::before {
  254. top: auto;
  255. right: 0;
  256. bottom: 0;
  257. left: 0;
  258. width: 100%;
  259. height: var(--tabs--active-height);
  260. border-right: none;
  261. border-bottom: var(--tabs--active-height) solid var(--color-absolutezero);
  262. border-left: none;
  263. }
  264. }