button.css 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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: 6px;
  8. text-decoration: none;
  9. user-select: none;
  10. &[data-variant="primary"] {
  11. border-color: var(--border-base);
  12. background-color: var(--surface-brand-base);
  13. color: var(--text-on-brand-strong);
  14. &:hover:not(:disabled) {
  15. border-color: var(--border-hover);
  16. background-color: var(--surface-brand-hover);
  17. }
  18. &:active:not(:disabled) {
  19. border-color: var(--border-active);
  20. background-color: var(--surface-brand-active);
  21. }
  22. &:focus:not(:disabled) {
  23. border-color: var(--border-focus);
  24. background-color: var(--surface-brand-focus);
  25. }
  26. }
  27. &[data-variant="secondary"] {
  28. border-color: var(--border-weak-base);
  29. background-color: var(--button-secondary-base);
  30. color: var(--text-strong);
  31. box-shadow: var(--shadow-xs);
  32. &:hover:not(:disabled) {
  33. border-color: var(--border-hover);
  34. background-color: var(--surface-hover);
  35. }
  36. &:active:not(:disabled) {
  37. border-color: var(--border-active);
  38. background-color: var(--surface-active);
  39. }
  40. &:focus:not(:disabled) {
  41. border-color: var(--border-focus);
  42. background-color: var(--surface-focus);
  43. }
  44. }
  45. &[data-variant="ghost"] {
  46. border-color: transparent;
  47. background-color: transparent;
  48. color: var(--text-strong);
  49. &:hover:not(:disabled) {
  50. background-color: var(--surface-hover);
  51. }
  52. &:active:not(:disabled) {
  53. border-color: var(--border-active);
  54. background-color: var(--surface-active);
  55. }
  56. &:focus:not(:disabled) {
  57. border-color: var(--border-focus);
  58. background-color: var(--surface-focus);
  59. }
  60. }
  61. &[data-size="normal"] {
  62. padding: 0 6px 0 6px;
  63. font-size: var(--font-size-small);
  64. line-height: var(--line-height-large);
  65. gap: calc(var(--spacing) * 0.5);
  66. }
  67. &[data-size="large"] {
  68. height: 32px;
  69. padding: 0 8px 0 6px;
  70. gap: 8px;
  71. font-family: var(--font-family-sans);
  72. font-size: var(--font-size-base);
  73. font-style: normal;
  74. font-weight: var(--font-weight-medium);
  75. line-height: var(--line-height-large); /* 171.429% */
  76. letter-spacing: var(--letter-spacing-normal);
  77. }
  78. &:disabled {
  79. border-color: var(--border-disabled);
  80. background-color: var(--surface-disabled);
  81. color: var(--text-weak);
  82. cursor: not-allowed;
  83. }
  84. &:focus {
  85. outline: none;
  86. }
  87. }