button.css 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. [data-component="button"] {
  2. display: inline-flex;
  3. align-items: center;
  4. justify-content: center;
  5. border-style: solid;
  6. border-width: 1px;
  7. border-radius: var(--radius-md);
  8. text-decoration: none;
  9. user-select: none;
  10. cursor: default;
  11. padding: 4px 8px;
  12. white-space: nowrap;
  13. transition-property: background-color, border-color, color, box-shadow, opacity;
  14. transition-duration: var(--transition-duration);
  15. transition-timing-function: var(--transition-easing);
  16. outline: none;
  17. line-height: 20px;
  18. &[data-variant="primary"] {
  19. background-color: var(--button-primary-base);
  20. border-color: var(--border-weak-base);
  21. color: var(--icon-invert-base);
  22. [data-slot="icon-svg"] {
  23. color: var(--icon-invert-base);
  24. }
  25. &:hover:not(:disabled) {
  26. background-color: var(--icon-strong-hover);
  27. }
  28. &:focus:not(:disabled) {
  29. background-color: var(--icon-strong-focus);
  30. }
  31. &:active:not(:disabled) {
  32. background-color: var(--icon-strong-active);
  33. }
  34. &:disabled {
  35. background-color: var(--icon-strong-disabled);
  36. [data-slot="icon-svg"] {
  37. color: var(--icon-invert-base);
  38. }
  39. }
  40. }
  41. &[data-variant="ghost"] {
  42. border-color: transparent;
  43. background-color: transparent;
  44. color: var(--text-strong);
  45. [data-slot="icon-svg"] {
  46. color: var(--icon-base);
  47. }
  48. &:hover:not(:disabled) {
  49. background-color: var(--surface-raised-base-hover);
  50. }
  51. &:focus-visible:not(:disabled) {
  52. background-color: var(--surface-raised-base-hover);
  53. }
  54. &:active:not(:disabled) {
  55. background-color: var(--surface-raised-base-active);
  56. }
  57. &:disabled {
  58. color: var(--text-weak);
  59. cursor: not-allowed;
  60. [data-slot="icon-svg"] {
  61. color: var(--icon-disabled);
  62. }
  63. }
  64. &[data-selected="true"]:not(:disabled) {
  65. background-color: var(--surface-raised-base-hover);
  66. }
  67. &[data-active="true"] {
  68. background-color: var(--surface-raised-base-active);
  69. }
  70. }
  71. &[data-variant="secondary"] {
  72. border: transparent;
  73. background-color: var(--button-secondary-base);
  74. color: var(--text-strong);
  75. box-shadow: var(--shadow-xs-border);
  76. &:hover:not(:disabled) {
  77. background-color: var(--button-secondary-hover);
  78. }
  79. &:focus:not(:disabled) {
  80. background-color: var(--button-secondary-base);
  81. }
  82. &:focus-visible:not(:active) {
  83. background-color: var(--button-secondary-base);
  84. box-shadow: var(--shadow-xs-border-focus);
  85. }
  86. &:focus-visible:active {
  87. box-shadow: none;
  88. }
  89. &:active:not(:disabled) {
  90. background-color: var(--button-secondary-base);
  91. scale: 0.99;
  92. }
  93. &:disabled {
  94. border-color: var(--border-disabled);
  95. background-color: var(--surface-disabled);
  96. color: var(--text-weak);
  97. cursor: not-allowed;
  98. }
  99. [data-slot="icon-svg"] {
  100. color: var(--icon-strong-base);
  101. }
  102. }
  103. &[data-size="small"] {
  104. padding: 2px 8px;
  105. &[data-icon] {
  106. padding: 2px 12px 2px 4px;
  107. }
  108. gap: 4px;
  109. /* text-12-medium */
  110. font-family: var(--font-family-sans);
  111. font-size: var(--font-size-base);
  112. font-style: normal;
  113. font-weight: var(--font-weight-medium);
  114. letter-spacing: var(--letter-spacing-normal);
  115. }
  116. &[data-size="normal"] {
  117. padding: 4px 6px;
  118. &[data-icon] {
  119. padding: 4px 12px 4px 4px;
  120. }
  121. gap: 6px;
  122. /* text-12-medium */
  123. font-family: var(--font-family-sans);
  124. font-size: var(--font-size-small);
  125. font-style: normal;
  126. font-weight: var(--font-weight-medium);
  127. letter-spacing: var(--letter-spacing-normal);
  128. }
  129. &[data-size="large"] {
  130. padding: 6px 12px;
  131. &[data-icon] {
  132. padding: 6px 12px 6px 8px;
  133. }
  134. gap: 4px;
  135. /* text-14-medium */
  136. font-family: var(--font-family-sans);
  137. font-size: 14px;
  138. font-style: normal;
  139. font-weight: var(--font-weight-medium);
  140. letter-spacing: var(--letter-spacing-normal);
  141. }
  142. &:focus {
  143. outline: none;
  144. }
  145. }