dropdown-menu.css 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. [data-component="dropdown-menu-content"],
  2. [data-component="dropdown-menu-sub-content"] {
  3. min-width: 8rem;
  4. overflow: hidden;
  5. border-radius: var(--radius-md);
  6. border: 1px solid var(--border-weak-base);
  7. background-color: var(--surface-raised-stronger-non-alpha);
  8. padding: 4px;
  9. box-shadow: var(--shadow-md);
  10. z-index: 50;
  11. transform-origin: var(--kb-menu-content-transform-origin);
  12. &[data-closed] {
  13. animation: dropdown-menu-close 0.15s ease-out;
  14. }
  15. &[data-expanded] {
  16. animation: dropdown-menu-open 0.15s ease-out;
  17. }
  18. }
  19. [data-component="dropdown-menu-content"],
  20. [data-component="dropdown-menu-sub-content"] {
  21. [data-slot="dropdown-menu-item"],
  22. [data-slot="dropdown-menu-checkbox-item"],
  23. [data-slot="dropdown-menu-radio-item"],
  24. [data-slot="dropdown-menu-sub-trigger"] {
  25. position: relative;
  26. display: flex;
  27. align-items: center;
  28. gap: 8px;
  29. padding: 4px 8px;
  30. border-radius: var(--radius-sm);
  31. cursor: default;
  32. user-select: none;
  33. outline: none;
  34. font-family: var(--font-family-sans);
  35. font-size: var(--font-size-small);
  36. font-weight: var(--font-weight-medium);
  37. line-height: var(--line-height-large);
  38. letter-spacing: var(--letter-spacing-normal);
  39. color: var(--text-strong);
  40. &[data-highlighted] {
  41. background: var(--surface-raised-base-hover);
  42. }
  43. &[data-disabled] {
  44. color: var(--text-weak);
  45. pointer-events: none;
  46. }
  47. }
  48. [data-slot="dropdown-menu-sub-trigger"] {
  49. &[data-expanded] {
  50. background: var(--surface-raised-base-hover);
  51. }
  52. }
  53. [data-slot="dropdown-menu-item-indicator"] {
  54. display: flex;
  55. align-items: center;
  56. justify-content: center;
  57. width: 16px;
  58. height: 16px;
  59. }
  60. [data-slot="dropdown-menu-item-label"] {
  61. flex: 1;
  62. }
  63. [data-slot="dropdown-menu-item-description"] {
  64. font-size: var(--font-size-x-small);
  65. color: var(--text-weak);
  66. }
  67. [data-slot="dropdown-menu-separator"] {
  68. height: 1px;
  69. margin: 4px -4px;
  70. border-top-color: var(--border-weak-base);
  71. }
  72. [data-slot="dropdown-menu-group-label"] {
  73. padding: 4px 8px;
  74. font-family: var(--font-family-sans);
  75. font-size: var(--font-size-x-small);
  76. font-weight: var(--font-weight-medium);
  77. line-height: var(--line-height-large);
  78. letter-spacing: var(--letter-spacing-normal);
  79. color: var(--text-weak);
  80. }
  81. [data-slot="dropdown-menu-arrow"] {
  82. fill: var(--surface-raised-stronger-non-alpha);
  83. }
  84. }
  85. @keyframes dropdown-menu-open {
  86. from {
  87. opacity: 0;
  88. transform: scale(0.96);
  89. }
  90. to {
  91. opacity: 1;
  92. transform: scale(1);
  93. }
  94. }
  95. @keyframes dropdown-menu-close {
  96. from {
  97. opacity: 1;
  98. transform: scale(1);
  99. }
  100. to {
  101. opacity: 0;
  102. transform: scale(0.96);
  103. }
  104. }