tabs.css 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. [data-component="tabs"] {
  2. width: 100%;
  3. height: 100%;
  4. display: flex;
  5. flex-direction: column;
  6. background-color: var(--background-stronger);
  7. overflow: clip;
  8. [data-slot="tabs-list"] {
  9. height: 48px;
  10. width: 100%;
  11. position: relative;
  12. display: flex;
  13. align-items: center;
  14. overflow-x: auto;
  15. /* Hide scrollbar */
  16. scrollbar-width: none;
  17. -ms-overflow-style: none;
  18. &::-webkit-scrollbar {
  19. display: none;
  20. }
  21. /* After element to fill remaining space */
  22. &::after {
  23. content: "";
  24. display: block;
  25. flex-grow: 1;
  26. height: 100%;
  27. border-bottom: 1px solid var(--border-weak-base);
  28. background-color: var(--background-base);
  29. }
  30. &:empty::after {
  31. display: none;
  32. }
  33. }
  34. [data-slot="tabs-trigger-wrapper"] {
  35. position: relative;
  36. height: 100%;
  37. display: flex;
  38. align-items: center;
  39. gap: 12px;
  40. color: var(--text-base);
  41. /* text-14-medium */
  42. font-family: var(--font-family-sans);
  43. font-size: 14px;
  44. font-style: normal;
  45. font-weight: var(--font-weight-medium);
  46. line-height: var(--line-height-large); /* 142.857% */
  47. letter-spacing: var(--letter-spacing-normal);
  48. white-space: nowrap;
  49. flex-shrink: 0;
  50. max-width: 280px;
  51. border-bottom: 1px solid var(--border-weak-base);
  52. border-right: 1px solid var(--border-weak-base);
  53. background-color: var(--background-base);
  54. [data-slot="tabs-trigger"] {
  55. display: flex;
  56. align-items: center;
  57. justify-content: center;
  58. padding: 14px 24px 14px 12px;
  59. outline: none;
  60. min-width: 0;
  61. overflow: hidden;
  62. text-overflow: ellipsis;
  63. &:focus-visible {
  64. outline: none;
  65. box-shadow: none;
  66. }
  67. }
  68. [data-slot="tabs-trigger-close-button"] {
  69. display: flex;
  70. align-items: center;
  71. justify-content: center;
  72. }
  73. [data-component="icon-button"] {
  74. margin: -0.25rem;
  75. }
  76. &:disabled {
  77. pointer-events: none;
  78. color: var(--text-weaker);
  79. }
  80. &:focus-visible {
  81. outline: none;
  82. box-shadow: none;
  83. }
  84. &:has([data-hidden]) {
  85. [data-slot="tabs-trigger-close-button"] {
  86. opacity: 0;
  87. }
  88. &:hover {
  89. [data-slot="tabs-trigger-close-button"] {
  90. opacity: 1;
  91. }
  92. }
  93. }
  94. &:has([data-selected]) {
  95. color: var(--text-strong);
  96. background-color: transparent;
  97. border-bottom-color: transparent;
  98. [data-slot="tabs-trigger-close-button"] {
  99. opacity: 1;
  100. }
  101. }
  102. &:hover:not(:disabled):not([data-selected]) {
  103. color: var(--text-strong);
  104. }
  105. &:has([data-slot="tabs-trigger-close-button"]) {
  106. padding-right: 12px;
  107. [data-slot="tabs-trigger"] {
  108. padding-right: 0;
  109. }
  110. }
  111. }
  112. [data-slot="tabs-content"] {
  113. overflow-y: auto;
  114. flex: 1;
  115. /* Hide scrollbar */
  116. scrollbar-width: none;
  117. -ms-overflow-style: none;
  118. &::-webkit-scrollbar {
  119. display: none;
  120. }
  121. &:focus-visible {
  122. outline: none;
  123. }
  124. }
  125. &[data-variant="alt"] {
  126. [data-slot="tabs-list"] {
  127. padding-left: 24px;
  128. padding-right: 24px;
  129. gap: 12px;
  130. border-bottom: 1px solid var(--border-weak-base);
  131. background-color: transparent;
  132. &::after {
  133. border: none;
  134. background-color: transparent;
  135. }
  136. &:empty::after {
  137. display: none;
  138. }
  139. }
  140. [data-slot="tabs-trigger-wrapper"] {
  141. border: none;
  142. color: var(--text-base);
  143. background-color: transparent;
  144. border-bottom-width: 2px;
  145. border-bottom-style: solid;
  146. border-bottom-color: transparent;
  147. gap: 4px;
  148. /* text-14-regular */
  149. font-family: var(--font-family-sans);
  150. font-size: var(--font-size-base);
  151. font-style: normal;
  152. font-weight: var(--font-weight-regular);
  153. line-height: var(--line-height-x-large); /* 171.429% */
  154. letter-spacing: var(--letter-spacing-normal);
  155. [data-slot="tabs-trigger"] {
  156. height: 100%;
  157. padding: 4px;
  158. background-color: transparent;
  159. border-bottom-width: 2px;
  160. border-bottom-color: transparent;
  161. }
  162. [data-slot="tabs-trigger-close-button"] {
  163. display: flex;
  164. align-items: center;
  165. justify-content: center;
  166. }
  167. [data-component="icon-button"] {
  168. width: 16px;
  169. height: 16px;
  170. margin: 0;
  171. }
  172. &:has([data-selected]) {
  173. color: var(--text-strong);
  174. background-color: transparent;
  175. border-bottom-color: var(--icon-strong-base);
  176. }
  177. &:hover:not(:disabled):not([data-selected]) {
  178. color: var(--text-strong);
  179. }
  180. &:has([data-slot="tabs-trigger-close-button"]) {
  181. padding-right: 0;
  182. [data-slot="tabs-trigger"] {
  183. padding-right: 0;
  184. }
  185. }
  186. }
  187. /* [data-slot="tabs-content"] { */
  188. /* } */
  189. }
  190. &[data-variant="pill"][data-orientation="horizontal"] {
  191. background-color: transparent;
  192. [data-slot="tabs-list"] {
  193. height: auto;
  194. padding: 6px 0;
  195. gap: 4px;
  196. background-color: var(--background-base);
  197. &::after {
  198. display: none;
  199. }
  200. }
  201. [data-slot="tabs-trigger-wrapper"] {
  202. height: 32px;
  203. border: none;
  204. border-radius: var(--radius-sm);
  205. background-color: transparent;
  206. gap: 0;
  207. /* text-13-medium */
  208. font-family: var(--font-family-sans);
  209. font-size: var(--font-size-small);
  210. font-style: normal;
  211. font-weight: var(--font-weight-medium);
  212. line-height: var(--line-height-large);
  213. letter-spacing: var(--letter-spacing-normal);
  214. [data-slot="tabs-trigger"] {
  215. height: 100%;
  216. width: 100%;
  217. padding: 0 12px;
  218. background-color: transparent;
  219. }
  220. &:hover:not(:disabled) {
  221. background-color: var(--surface-raised-base-hover);
  222. color: var(--text-strong);
  223. }
  224. &:has([data-selected]) {
  225. background-color: var(--surface-raised-base-active);
  226. color: var(--text-strong);
  227. &:hover:not(:disabled) {
  228. background-color: var(--surface-raised-base-active);
  229. }
  230. }
  231. }
  232. }
  233. &[data-variant="pill"][data-orientation="horizontal"][data-scope="filetree"] {
  234. [data-slot="tabs-list"] {
  235. height: 48px;
  236. padding-inline: 12px;
  237. gap: 8px;
  238. align-items: center;
  239. }
  240. [data-slot="tabs-trigger-wrapper"] {
  241. height: 26px;
  242. border-radius: 6px;
  243. color: var(--text-weak);
  244. &:not(:has([data-selected])):hover:not(:disabled) {
  245. color: var(--text-base);
  246. }
  247. &:has([data-selected]) {
  248. color: var(--text-strong);
  249. }
  250. }
  251. }
  252. &[data-orientation="vertical"] {
  253. flex-direction: row;
  254. [data-slot="tabs-list"] {
  255. flex-direction: column;
  256. width: auto;
  257. height: 100%;
  258. overflow-x: hidden;
  259. overflow-y: auto;
  260. padding: 8px;
  261. gap: 4px;
  262. background-color: var(--background-base);
  263. border-right: 1px solid var(--border-weak-base);
  264. &::after {
  265. display: none;
  266. }
  267. }
  268. [data-slot="tabs-trigger-wrapper"] {
  269. width: 100%;
  270. height: 32px;
  271. border: none;
  272. border-radius: 8px;
  273. background-color: transparent;
  274. [data-slot="tabs-trigger"] {
  275. height: 100%;
  276. padding: 0 8px;
  277. gap: 8px;
  278. justify-content: flex-start;
  279. }
  280. &:hover:not(:disabled) {
  281. background-color: var(--surface-raised-base-hover);
  282. }
  283. &:has([data-selected]) {
  284. background-color: var(--surface-raised-base-active);
  285. color: var(--text-strong);
  286. }
  287. }
  288. [data-slot="tabs-content"] {
  289. overflow-x: auto;
  290. overflow-y: auto;
  291. }
  292. &[data-variant="alt"] {
  293. [data-slot="tabs-list"] {
  294. padding: 8px;
  295. gap: 4px;
  296. border: none;
  297. &::after {
  298. display: none;
  299. }
  300. }
  301. [data-slot="tabs-trigger-wrapper"] {
  302. height: 32px;
  303. border: none;
  304. border-radius: 8px;
  305. [data-slot="tabs-trigger"] {
  306. border: none;
  307. padding: 0 8px;
  308. gap: 8px;
  309. justify-content: flex-start;
  310. }
  311. &:hover:not(:disabled) {
  312. background-color: var(--surface-raised-base-hover);
  313. }
  314. &:has([data-selected]) {
  315. background-color: var(--surface-raised-base-hover);
  316. color: var(--text-strong);
  317. }
  318. }
  319. }
  320. &[data-variant="settings"] {
  321. [data-slot="tabs-list"] {
  322. width: 200px;
  323. min-width: 200px;
  324. padding: 12px;
  325. gap: 0;
  326. background-color: var(--background-base);
  327. border-right: 1px solid var(--border-weak-base);
  328. &::after {
  329. display: none;
  330. }
  331. }
  332. [data-slot="tabs-section-title"] {
  333. width: 100%;
  334. padding: 0 0 0 4px;
  335. font-family: var(--font-family-sans);
  336. font-size: var(--font-size-small);
  337. font-weight: var(--font-weight-medium);
  338. color: var(--text-weak);
  339. }
  340. [data-slot="tabs-trigger-wrapper"] {
  341. height: 32px;
  342. border: none;
  343. border-radius: var(--radius-md);
  344. /* text-14-medium */
  345. font-family: var(--font-family-sans);
  346. font-size: var(--font-size-base);
  347. font-weight: var(--font-weight-medium);
  348. line-height: var(--line-height-large);
  349. [data-slot="tabs-trigger"] {
  350. border: none;
  351. padding: 0 8px;
  352. gap: 12px;
  353. justify-content: flex-start;
  354. width: 100%;
  355. height: 100%;
  356. }
  357. [data-component="icon"] {
  358. color: var(--icon-base);
  359. }
  360. &:hover:not(:disabled) {
  361. background-color: var(--surface-raised-base-hover);
  362. }
  363. &:has([data-selected]) {
  364. background-color: var(--surface-raised-base-active);
  365. color: var(--text-strong);
  366. [data-component="icon"] {
  367. color: var(--icon-strong-base);
  368. }
  369. &:hover:not(:disabled) {
  370. background-color: var(--surface-raised-base-active);
  371. }
  372. }
  373. }
  374. [data-slot="tabs-content"] {
  375. background-color: var(--surface-raised-stronger-non-alpha);
  376. }
  377. }
  378. }
  379. }