checkbox.css 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. [data-component="checkbox"] {
  2. display: flex;
  3. align-items: var(--checkbox-align, center);
  4. gap: 12px;
  5. cursor: default;
  6. [data-slot="checkbox-checkbox-input"] {
  7. position: absolute;
  8. width: 1px;
  9. height: 1px;
  10. padding: 0;
  11. margin: -1px;
  12. overflow: hidden;
  13. clip: rect(0, 0, 0, 0);
  14. white-space: nowrap;
  15. border-width: 0;
  16. }
  17. [data-slot="checkbox-checkbox-control"] {
  18. display: flex;
  19. align-items: center;
  20. justify-content: center;
  21. width: 16px;
  22. height: 16px;
  23. padding: 2px;
  24. margin-top: var(--checkbox-offset, 0px);
  25. aspect-ratio: 1;
  26. flex-shrink: 0;
  27. border-radius: var(--radius-sm);
  28. border: 1px solid var(--border-weak-base);
  29. transition:
  30. border-color 220ms var(--tool-motion-ease, cubic-bezier(0.22, 1, 0.36, 1)),
  31. background-color 220ms var(--tool-motion-ease, cubic-bezier(0.22, 1, 0.36, 1)),
  32. box-shadow 220ms var(--tool-motion-ease, cubic-bezier(0.22, 1, 0.36, 1));
  33. /* background-color: var(--surface-weak); */
  34. }
  35. [data-slot="checkbox-checkbox-indicator"] {
  36. display: flex;
  37. align-items: center;
  38. justify-content: center;
  39. width: 100%;
  40. height: 100%;
  41. color: var(--icon-base);
  42. opacity: 0;
  43. transform: scale(0.9);
  44. transition:
  45. opacity 180ms var(--tool-motion-ease, cubic-bezier(0.22, 1, 0.36, 1)),
  46. transform 220ms var(--tool-motion-ease, cubic-bezier(0.22, 1, 0.36, 1));
  47. }
  48. /* [data-slot="checkbox-checkbox-content"] { */
  49. /* } */
  50. [data-slot="checkbox-checkbox-label"] {
  51. user-select: none;
  52. color: var(--text-base);
  53. /* text-12-regular */
  54. font-family: var(--font-family-sans);
  55. font-size: var(--font-size-small);
  56. font-style: normal;
  57. font-weight: var(--font-weight-regular);
  58. line-height: var(--line-height-large); /* 166.667% */
  59. letter-spacing: var(--letter-spacing-normal);
  60. }
  61. [data-slot="checkbox-checkbox-description"] {
  62. color: var(--text-base);
  63. font-family: var(--font-family-sans);
  64. font-size: 12px;
  65. font-weight: var(--font-weight-regular);
  66. line-height: var(--line-height-normal);
  67. letter-spacing: var(--letter-spacing-normal);
  68. }
  69. [data-slot="checkbox-checkbox-error"] {
  70. color: var(--text-error);
  71. font-family: var(--font-family-sans);
  72. font-size: 12px;
  73. font-weight: var(--font-weight-regular);
  74. line-height: var(--line-height-normal);
  75. letter-spacing: var(--letter-spacing-normal);
  76. }
  77. &:hover:not([data-disabled], [data-readonly]) [data-slot="checkbox-checkbox-control"] {
  78. border-color: var(--border-hover);
  79. background-color: var(--surface-hover);
  80. }
  81. &:not([data-readonly]) [data-slot="checkbox-checkbox-input"]:focus-visible + [data-slot="checkbox-checkbox-control"] {
  82. border-color: var(--border-focus);
  83. box-shadow: var(--shadow-xs-border-focus);
  84. }
  85. &[data-checked] [data-slot="checkbox-checkbox-control"],
  86. &[data-indeterminate] [data-slot="checkbox-checkbox-control"] {
  87. border-color: var(--border-base);
  88. background-color: var(--surface-weak);
  89. }
  90. &[data-checked]:hover:not([data-disabled], [data-readonly]) [data-slot="checkbox-checkbox-control"],
  91. &[data-indeterminate]:hover:not([data-disabled]) [data-slot="checkbox-checkbox-control"] {
  92. border-color: var(--border-hover);
  93. background-color: var(--surface-hover);
  94. }
  95. &[data-checked] [data-slot="checkbox-checkbox-indicator"],
  96. &[data-indeterminate] [data-slot="checkbox-checkbox-indicator"] {
  97. opacity: 1;
  98. transform: scale(1);
  99. }
  100. &[data-disabled] {
  101. cursor: not-allowed;
  102. }
  103. &[data-disabled] [data-slot="checkbox-checkbox-control"] {
  104. border-color: var(--border-disabled);
  105. background-color: var(--surface-disabled);
  106. }
  107. &[data-invalid] [data-slot="checkbox-checkbox-control"] {
  108. border-color: var(--border-error);
  109. }
  110. &[data-readonly] {
  111. cursor: default;
  112. pointer-events: none;
  113. }
  114. }