|
76 | 76 | } |
77 | 77 | } |
78 | 78 |
|
79 | | -@utility btn-ghost-hover { |
80 | | - @apply bg-neutral-300/80 dark:bg-neutral-700/80; |
| 79 | +@utility btn-link-hover { |
| 80 | + @apply text-blue-500; |
81 | 81 | } |
82 | | -@utility btn-ghost-active { |
83 | | - @apply bg-neutral-400/80 dark:bg-neutral-600/80; |
| 82 | +@utility btn-link-active { |
| 83 | + @apply text-blue-600; |
84 | 84 | } |
85 | | -@utility btn-ghost { |
| 85 | +@utility btn-link { |
86 | 86 | &:hover { |
87 | | - @apply btn-ghost-hover; |
| 87 | + @apply btn-link-hover; |
88 | 88 | } |
89 | 89 | &:active { |
90 | | - @apply btn-ghost-active; |
| 90 | + @apply btn-link-active; |
91 | 91 | } |
| 92 | + @apply cursor-pointer text-em-med transition-colors duration-100 ease-in-out; |
| 93 | +} |
| 94 | + |
| 95 | +@utility btn-base { |
| 96 | + --btn-color: var(--color-primary); |
| 97 | + --btn-focus: var(--color-primary); |
| 98 | + --tw-shadow-color: color-mix(in oklab, var(--btn-color) 50%, transparent); |
| 99 | + |
| 100 | + --btn-hover: color-mix(in oklch, var(--btn-color), black 5%); |
| 101 | + --btn-active: color-mix(in oklch, var(--btn-color), black 10%); |
| 102 | + --btn-border: color-mix(in oklch, var(--btn-color), black 12%); |
| 103 | + @variant dark { |
| 104 | + --btn-hover: color-mix(in oklch, var(--btn-color), white 5%); |
| 105 | + --btn-active: color-mix(in oklch, var(--btn-color), white 10%); |
| 106 | + --btn-border: color-mix(in oklch, var(--btn-color), white 12%); |
| 107 | + } |
| 108 | + |
| 109 | + border-color: var(--btn-border); |
| 110 | + |
92 | 111 | @apply transition-colors duration-100 ease-in-out; |
| 112 | + @apply ring-(--btn-focus) focus:outline-none focus-visible:ring-2 has-focus-visible:ring-2; |
93 | 113 | } |
94 | | -@utility btn-ghost-visible { |
95 | | - @apply btn-ghost-hover; |
| 114 | + |
| 115 | +@utility btn-fill { |
| 116 | + @apply border btn-base shadow-xs; |
| 117 | + |
| 118 | + background-color: var(--btn-color); |
| 119 | + |
| 120 | + &:hover { |
| 121 | + background-color: var(--btn-hover); |
| 122 | + } |
96 | 123 | &:active { |
97 | | - @apply btn-ghost-active; |
| 124 | + background-color: var(--btn-active); |
| 125 | + @apply shadow-none; |
98 | 126 | } |
99 | 127 | } |
100 | 128 |
|
101 | | -@utility btn-primary-hover { |
102 | | - @apply bg-blue-600; |
| 129 | +@utility btn-fill-danger { |
| 130 | + @apply btn-fill text-white; |
| 131 | + --btn-color: var(--color-red-500); |
103 | 132 | } |
104 | | -@utility btn-primary { |
105 | | - @apply bg-primary text-white; |
106 | | - &:hover { |
107 | | - @apply btn-primary-hover; |
| 133 | + |
| 134 | +@utility btn-fill-primary { |
| 135 | + @apply btn-fill text-white; |
| 136 | + --btn-color: var(--color-primary); |
| 137 | + --btn-focus: var(--color-neutral-800); |
| 138 | + @variant dark { |
| 139 | + --btn-focus: var(--color-neutral-100); |
108 | 140 | } |
109 | | - &:active { |
110 | | - @apply bg-blue-700; |
| 141 | +} |
| 142 | + |
| 143 | +@utility btn-fill-neutral { |
| 144 | + @apply btn-fill; |
| 145 | + --btn-color: var(--color-neutral-100); |
| 146 | + @variant dark { |
| 147 | + --btn-color: var(--color-neutral-800); |
111 | 148 | } |
112 | | - @apply transition-colors duration-100 ease-in-out; |
113 | 149 | } |
114 | 150 |
|
115 | | -@utility btn-danger { |
116 | | - @apply bg-red-500 text-white; |
| 151 | +@utility btn-ghost { |
| 152 | + @apply btn-base; |
| 153 | + |
| 154 | + --btn-color: var(--color-neutral-100); |
| 155 | + @variant dark { |
| 156 | + --btn-color: var(--color-neutral-800); |
| 157 | + } |
| 158 | + |
117 | 159 | &:hover { |
118 | | - @apply bg-red-600; |
| 160 | + background-color: var(--btn-hover); |
119 | 161 | } |
120 | 162 | &:active { |
121 | | - @apply bg-red-700; |
| 163 | + background-color: var(--btn-active); |
| 164 | + } |
| 165 | +} |
| 166 | +@utility btn-ghost-hover { |
| 167 | + @apply btn-ghost; |
| 168 | + background-color: var(--btn-hover); |
| 169 | +} |
| 170 | +@utility btn-ghost-active { |
| 171 | + @apply btn-ghost; |
| 172 | + background-color: var(--btn-active); |
| 173 | +} |
| 174 | +@utility btn-ghost-visible { |
| 175 | + @apply btn-ghost-hover; |
| 176 | + &:active { |
| 177 | + @apply btn-ghost-active; |
122 | 178 | } |
123 | 179 | } |
124 | 180 |
|
|
0 commit comments