button.css 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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-sm);
  8. text-decoration: none;
  9. user-select: none;
  10. cursor: default;
  11. outline: none;
  12. &[data-variant="primary"] {
  13. border-color: var(--border-base);
  14. background-color: var(--surface-brand-base);
  15. color: var(--text-on-brand-strong);
  16. &:hover:not(:disabled) {
  17. border-color: var(--border-hover);
  18. background-color: var(--surface-brand-hover);
  19. }
  20. &:focus:not(:disabled) {
  21. border-color: var(--border-focus);
  22. background-color: var(--surface-brand-focus);
  23. }
  24. &:active:not(:disabled) {
  25. border-color: var(--border-active);
  26. background-color: var(--surface-brand-active);
  27. }
  28. &:disabled {
  29. border-color: var(--border-disabled);
  30. background-color: var(--surface-disabled);
  31. color: var(--text-weak);
  32. cursor: not-allowed;
  33. }
  34. }
  35. &[data-variant="ghost"] {
  36. border-color: transparent;
  37. background-color: transparent;
  38. color: var(--text-strong);
  39. &:hover:not(:disabled) {
  40. background-color: var(--surface-raised-base-hover);
  41. }
  42. &:focus:not(:disabled) {
  43. background-color: var(--surface-raised-base-hover);
  44. }
  45. &:active:not(:disabled) {
  46. background-color: var(--surface-raised-base-active);
  47. }
  48. &:disabled {
  49. color: var(--text-weak);
  50. opacity: 0.7;
  51. cursor: not-allowed;
  52. }
  53. }
  54. &[data-variant="secondary"] {
  55. border: transparent;
  56. background-color: var(--button-secondary-base);
  57. color: var(--text-strong);
  58. box-shadow: var(--shadow-xs-border);
  59. &:hover:not(:disabled) {
  60. background-color: var(--button-secondary-hover);
  61. }
  62. &:focus:not(:disabled) {
  63. background-color: var(--button-secondary-base);
  64. }
  65. &:focus-visible:not(:active) {
  66. background-color: var(--button-secondary-base);
  67. box-shadow: var(--shadow-xs-border-focus);
  68. }
  69. &:focus-visible:active {
  70. box-shadow: none;
  71. }
  72. &:active:not(:disabled) {
  73. background-color: var(--button-secondary-base);
  74. scale: 0.99;
  75. transition: all 150ms ease-out;
  76. }
  77. &:disabled {
  78. border-color: var(--border-disabled);
  79. background-color: var(--surface-disabled);
  80. color: var(--text-weak);
  81. cursor: not-allowed;
  82. }
  83. [data-slot="icon"] {
  84. color: var(--icon-strong-base);
  85. }
  86. }
  87. &[data-size="normal"] {
  88. height: 24px;
  89. padding: 0 6px;
  90. &[data-icon] {
  91. padding: 0 8px 0 6px;
  92. }
  93. font-size: var(--font-size-small);
  94. line-height: var(--line-height-large);
  95. gap: 6px;
  96. }
  97. &[data-size="large"] {
  98. height: 32px;
  99. padding: 0 8px;
  100. &[data-icon] {
  101. padding: 0 8px 0 6px;
  102. }
  103. gap: 8px;
  104. /* text-12-medium */
  105. font-family: var(--font-family-sans);
  106. font-size: var(--font-size-small);
  107. font-style: normal;
  108. font-weight: var(--font-weight-medium);
  109. line-height: var(--line-height-large); /* 166.667% */
  110. letter-spacing: var(--letter-spacing-normal);
  111. }
  112. &:focus {
  113. outline: none;
  114. }
  115. }