accordion.css 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. [data-component="accordion"] {
  2. display: flex;
  3. flex-direction: column;
  4. align-items: flex-start;
  5. gap: 0px;
  6. align-self: stretch;
  7. [data-slot="accordion-item"] {
  8. width: 100%;
  9. display: flex;
  10. flex-direction: column;
  11. align-items: flex-start;
  12. gap: 0px;
  13. align-self: stretch;
  14. overflow: clip;
  15. [data-slot="accordion-header"] {
  16. width: 100%;
  17. display: flex;
  18. align-items: center;
  19. margin: 0;
  20. padding: 0;
  21. [data-slot="accordion-trigger"] {
  22. width: 100%;
  23. display: flex;
  24. height: 32px;
  25. padding: 8px 12px;
  26. justify-content: space-between;
  27. align-items: center;
  28. align-self: stretch;
  29. cursor: default;
  30. user-select: none;
  31. background-color: var(--surface-base);
  32. border: 1px solid var(--border-weak-base);
  33. overflow: clip;
  34. color: var(--text-strong);
  35. transition: background-color 0.15s ease;
  36. /* text-12-regular */
  37. font-family: var(--font-family-sans);
  38. font-size: var(--font-size-small);
  39. font-style: normal;
  40. font-weight: var(--font-weight-regular);
  41. line-height: var(--line-height-large); /* 166.667% */
  42. letter-spacing: var(--letter-spacing-normal);
  43. &:hover {
  44. background-color: var(--surface-base);
  45. }
  46. &:focus-visible {
  47. outline: none;
  48. }
  49. &[data-disabled] {
  50. cursor: not-allowed;
  51. }
  52. }
  53. }
  54. &[data-expanded] {
  55. margin-top: 8px;
  56. margin-bottom: 8px;
  57. [data-slot="accordion-trigger"] {
  58. border-top-left-radius: var(--radius-md);
  59. border-top-right-radius: var(--radius-md);
  60. }
  61. [data-slot="accordion-content"] {
  62. border: 1px solid var(--border-weak-base);
  63. border-top: none;
  64. border-bottom-left-radius: var(--radius-md);
  65. border-bottom-right-radius: var(--radius-md);
  66. }
  67. [data-slot="accordion-item"]:has(+ &) {
  68. &[data-closed] {
  69. border-bottom-left-radius: var(--radius-md);
  70. border-bottom-right-radius: var(--radius-md);
  71. [data-slot="accordion-trigger"] {
  72. border-bottom-left-radius: var(--radius-md);
  73. border-bottom-right-radius: var(--radius-md);
  74. }
  75. }
  76. margin-bottom: 8px;
  77. }
  78. & + [data-slot="accordion-item"] {
  79. margin-top: 8px;
  80. [data-slot="accordion-trigger"] {
  81. border-top-left-radius: var(--radius-md);
  82. border-top-right-radius: var(--radius-md);
  83. }
  84. }
  85. }
  86. &[data-closed] + &[data-closed] {
  87. [data-slot="accordion-trigger"] {
  88. border-top: none;
  89. }
  90. }
  91. &:first-child {
  92. margin-top: 0px;
  93. &[data-closed] {
  94. [data-slot="accordion-trigger"] {
  95. border-top-left-radius: var(--radius-md);
  96. border-top-right-radius: var(--radius-md);
  97. }
  98. }
  99. }
  100. &:last-child {
  101. margin-bottom: 0px;
  102. &[data-closed] {
  103. [data-slot="accordion-trigger"] {
  104. border-bottom-left-radius: var(--radius-md);
  105. border-bottom-right-radius: var(--radius-md);
  106. }
  107. }
  108. }
  109. [data-slot="accordion-content"] {
  110. overflow: hidden;
  111. width: 100%;
  112. /* animation: slideUp 250ms cubic-bezier(0.87, 0, 0.13, 1); */
  113. /**/
  114. /* &[data-expanded] { */
  115. /* animation: slideDown 250ms cubic-bezier(0.87, 0, 0.13, 1); */
  116. /* } */
  117. }
  118. }
  119. }
  120. @keyframes slideDown {
  121. from {
  122. height: 0;
  123. }
  124. to {
  125. height: var(--kb-accordion-content-height);
  126. }
  127. }
  128. @keyframes slideUp {
  129. from {
  130. height: var(--kb-accordion-content-height);
  131. }
  132. to {
  133. height: 0;
  134. }
  135. }