Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2021 The Chromium Authors. All rights reserved. |
| 3 | * Use of this source code is governed by a BSD-style license that can be |
| 4 | * found in the LICENSE file. |
| 5 | */ |
| 6 | |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 7 | /** |
| 8 | * Design: http://go/cdt-design-button |
| 9 | */ |
Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 10 | * { |
| 11 | margin: 0; |
| 12 | padding: 0; |
| 13 | box-sizing: border-box; |
| 14 | } |
| 15 | |
Alex Rudenko | dc7c959 | 2021-09-30 09:00:55 | [diff] [blame] | 16 | /** |
| 17 | * Reset default UA styles for focused elements. |
| 18 | * The button styles below explicitly implement custom focus styles. |
| 19 | */ |
Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 20 | *:focus, |
Alex Rudenko | dc7c959 | 2021-09-30 09:00:55 | [diff] [blame] | 21 | *:focus-visible, |
| 22 | :host(:focus), |
| 23 | :host(:focus-visible) { |
Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 24 | outline: none; |
| 25 | } |
| 26 | |
Alex Rudenko | e6ba352 | 2021-10-15 06:09:48 | [diff] [blame] | 27 | :host { |
| 28 | display: inline-flex; |
| 29 | flex-direction: row; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 30 | align-items: center; |
Alex Rudenko | e6ba352 | 2021-10-15 06:09:48 | [diff] [blame] | 31 | } |
| 32 | |
Kateryna Prokopenko | cc83004 | 2024-05-03 16:30:46 | [diff] [blame] | 33 | /* This specific nesting is incompatible with what stylelint requires as ordering of the rules. */ |
| 34 | /* stylelint-disable no-descending-specificity */ |
| 35 | |
Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 36 | button { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 37 | --hover-layer-color: var(--sys-color-state-hover-on-subtle); |
| 38 | --active-layer-color: var(--sys-color-state-ripple-neutral-on-subtle); |
Alex Rudenko | 9d873e5 | 2023-05-09 14:26:17 | [diff] [blame] | 39 | --button-border-size: 1px; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 40 | --button-height: var(--sys-size-11); |
| 41 | --button-width: fit-content; |
Ergün Erdoğmuş | 0cd36dc | 2022-05-03 09:54:16 | [diff] [blame] | 42 | |
Alex Rudenko | e4465d1 | 2021-08-09 11:37:37 | [diff] [blame] | 43 | align-items: center; |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 44 | background: transparent; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 45 | border-radius: var(--sys-shape-corner-full); |
Alex Rudenko | cc459b9 | 2021-08-11 13:53:48 | [diff] [blame] | 46 | display: inline-flex; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 47 | position: relative; |
| 48 | font-size: var(--sys-typescale-body4-size); |
| 49 | font-weight: var(--ref-typeface-weight-medium); |
| 50 | line-height: var(--sys-typescale-body4-line-height); |
Alex Rudenko | 9d873e5 | 2023-05-09 14:26:17 | [diff] [blame] | 51 | height: var(--button-height); |
Alex Rudenko | 50b3a3e | 2021-09-29 11:01:46 | [diff] [blame] | 52 | justify-content: center; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 53 | padding: 0 var(--sys-size-6); |
Benedikt Meurer | c635aa8 | 2022-12-13 08:20:57 | [diff] [blame] | 54 | white-space: nowrap; |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 55 | width: var(--button-width); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 56 | |
Kateryna Prokopenko | cc83004 | 2024-05-03 16:30:46 | [diff] [blame] | 57 | &.primary-toggle { |
| 58 | --toggle-color: var(--sys-color-primary-bright); |
| 59 | } |
| 60 | |
| 61 | &.red-toggle { |
| 62 | --toggle-color: var(--sys-color-error-bright); |
| 63 | } |
| 64 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 65 | devtools-icon { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 66 | width: var(--icon-size); |
| 67 | height: var(--icon-size); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 68 | } |
| 69 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 70 | &.toolbar, |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 71 | &.icon, |
| 72 | &.only-icon { |
| 73 | --button-height: 26px; |
| 74 | --button-width: 26px; |
| 75 | --icon-size: var(--sys-size-9); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 76 | |
Kateryna Prokopenko | 556312f | 2024-05-24 09:38:43 | [diff] [blame] | 77 | padding: 0; |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 78 | border: none; |
| 79 | overflow: hidden; |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 80 | |
| 81 | &.small { |
Kateryna Prokopenko | 556312f | 2024-05-24 09:38:43 | [diff] [blame] | 82 | --button-height: var(--sys-size-9); |
| 83 | --button-width: var(--sys-size-9); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 84 | --icon-size: var(--sys-size-8); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 85 | } |
Kateryna Prokopenko | cc83004 | 2024-05-03 16:30:46 | [diff] [blame] | 86 | |
| 87 | &.toggled devtools-icon { |
| 88 | color: var(--toggle-color); /* stylelint-disable-line plugin/use_theme_colors */ |
Kateryna Prokopenko | 17cba89 | 2024-07-26 13:33:56 | [diff] [blame^] | 89 | |
| 90 | &.long-click { |
| 91 | color: var(--icon-default); |
| 92 | } |
| 93 | } |
| 94 | |
| 95 | &.checked devtools-icon { |
| 96 | color: var(--toggle-color); /* stylelint-disable-line plugin/use_theme_colors */ |
| 97 | |
| 98 | &::after { |
| 99 | content: ""; |
| 100 | width: var(--sys-size-3); |
| 101 | height: var(--sys-size-3); |
| 102 | border-radius: var(--sys-shape-corner-full); |
| 103 | background-color: var(--sys-color-primary-bright); |
| 104 | position: absolute; |
| 105 | top: var(--dot-toggle-top); |
| 106 | left: var(--dot-toggle-left); |
| 107 | } |
| 108 | } |
| 109 | |
| 110 | devtools-icon.long-click { |
| 111 | position: absolute; |
| 112 | top: 2px; |
| 113 | left: 3px; |
Kateryna Prokopenko | cc83004 | 2024-05-03 16:30:46 | [diff] [blame] | 114 | } |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 115 | } |
| 116 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 117 | &.primary { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 118 | --hover-layer-color: var(--sys-color-state-hover-on-prominent); |
| 119 | --active-layer-color: var(--sys-color-state-ripple-primary); |
| 120 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 121 | border: var(--button-border-size) solid var(--sys-color-primary); |
| 122 | background: var(--sys-color-primary); |
| 123 | color: var(--sys-color-on-primary); |
| 124 | |
| 125 | devtools-icon { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 126 | color: var(--sys-color-on-primary); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 127 | } |
| 128 | } |
| 129 | |
| 130 | &.tonal { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 131 | border: none; |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 132 | background: var(--sys-color-tonal-container); |
| 133 | color: var(--sys-color-on-tonal-container); |
| 134 | |
| 135 | devtools-icon { |
| 136 | color: var(--sys-color-on-tonal-container); |
| 137 | } |
| 138 | } |
| 139 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 140 | &.primary-toolbar { |
| 141 | devtools-icon { |
| 142 | color: var(--icon-primary); |
| 143 | } |
| 144 | } |
| 145 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 146 | &.text { |
| 147 | border: none; |
| 148 | color: var(--sys-color-primary); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 149 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 150 | devtools-icon { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 151 | color: var(--icon-primary); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 152 | } |
| 153 | } |
| 154 | |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 155 | &.text-with-icon { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 156 | padding-left: var(--sys-size-4); |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 157 | |
| 158 | devtools-icon { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 159 | width: var(--sys-size-9); |
| 160 | height: var(--sys-size-9); |
| 161 | margin-right: var(--sys-size-2); |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 162 | } |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 163 | } |
| 164 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 165 | &.outlined { |
| 166 | border: var(--button-border-size) solid var(--sys-color-tonal-outline); |
| 167 | background: transparent; |
| 168 | color: var(--sys-color-primary); |
| 169 | |
| 170 | devtools-icon { |
| 171 | color: var(--icon-primary); |
| 172 | } |
| 173 | |
| 174 | &.micro { |
| 175 | --button-height: var(--sys-size-7); |
| 176 | |
| 177 | padding: 0 var(--sys-size-5); |
| 178 | font-size: var(--sys-typescale-body4-size); |
| 179 | font-weight: var(--ref-typeface-weight-medium); |
| 180 | line-height: var(--sys-typescale-body4-line-height); |
| 181 | |
| 182 | &:not(.icon):has(devtools-icon) { |
| 183 | padding-left: var(--sys-size-3); |
| 184 | } |
| 185 | |
| 186 | &:not(.icon) devtools-icon { |
| 187 | height: var(--sys-size-6); |
| 188 | width: var(--sys-size-6); |
| 189 | } |
| 190 | } |
| 191 | } |
| 192 | |
| 193 | &:disabled { |
| 194 | pointer-events: none; |
Kateryna Prokopenko | aebb00f | 2024-05-27 15:03:06 | [diff] [blame] | 195 | color: var(--sys-color-state-disabled); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 196 | |
| 197 | &.primary { |
| 198 | border: var(--button-border-size) solid var(--sys-color-state-disabled-container); |
| 199 | background: var(--sys-color-state-disabled-container); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 200 | } |
| 201 | |
| 202 | &.tonal { |
| 203 | border: var(--button-border-size) solid var(--sys-color-state-disabled-container); |
| 204 | background: var(--sys-color-state-disabled-container); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 205 | } |
| 206 | |
| 207 | &.outlined { |
| 208 | border: var(--button-border-size) solid var(--sys-color-state-disabled-container); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 209 | } |
| 210 | |
| 211 | &.toolbar, |
| 212 | &.icon { |
| 213 | background: transparent; |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 214 | } |
| 215 | |
| 216 | devtools-icon { |
Kateryna Prokopenko | 37cf44c | 2024-05-10 10:52:45 | [diff] [blame] | 217 | color: var(--icon-disabled); |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 218 | } |
| 219 | } |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 220 | |
| 221 | &:not(.icon):not(.toolbar).only-icon { |
| 222 | width: 100%; |
| 223 | padding: 0; |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 224 | |
Wolfgang Beyer | 9e87974 | 2024-01-11 10:23:39 | [diff] [blame] | 225 | &.small { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 226 | width: var(--button-height); |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 227 | } |
| 228 | } |
| 229 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 230 | &:focus-visible { |
| 231 | outline: 2px solid var(--sys-color-state-focus-ring); |
| 232 | outline-offset: 2px; |
| 233 | z-index: 999; |
| 234 | |
| 235 | &.toolbar, |
| 236 | &.icon { |
| 237 | outline-offset: -1px; |
Kateryna Prokopenko | 556312f | 2024-05-24 09:38:43 | [diff] [blame] | 238 | |
| 239 | &.small { |
| 240 | outline-offset: -2px; |
| 241 | } |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 242 | } |
Alex Rudenko | 0bd7a1b | 2024-01-04 06:58:33 | [diff] [blame] | 243 | } |
| 244 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 245 | &:has(.spinner) { |
| 246 | padding-left: var(--sys-size-4); |
| 247 | } |
| 248 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 249 | &:hover::after { |
| 250 | content: ""; |
| 251 | height: 100%; |
| 252 | width: 100%; |
| 253 | border-radius: inherit; |
| 254 | position: absolute; |
| 255 | top: 0; |
| 256 | left: 0; |
| 257 | background-color: var(--hover-layer-color); /* stylelint-disable-line plugin/use_theme_colors */ |
| 258 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 259 | &.primary { |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 260 | border: var(--button-border-size) solid color-mix(in sRGB, var(--sys-color-primary), var(--sys-color-state-hover-on-prominent) 6%); |
| 261 | } |
| 262 | |
| 263 | &.tonal { |
| 264 | background: color-mix(in sRGB, var(--sys-color-tonal-container), var(--sys-color-state-hover-on-subtle)); |
| 265 | } |
| 266 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 267 | &.toobar { |
| 268 | devtools-icon { |
| 269 | color: var(--icon-default-hover); |
| 270 | } |
| 271 | } |
| 272 | } |
| 273 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 274 | &:active::before, |
| 275 | &.active::before { |
| 276 | content: ""; |
| 277 | height: 100%; |
| 278 | width: 100%; |
| 279 | border-radius: inherit; |
| 280 | position: absolute; |
| 281 | top: 0; |
| 282 | left: 0; |
| 283 | background-color: var(--active-layer-color); /* stylelint-disable-line plugin/use_theme_colors */ |
| 284 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 285 | &.primary { |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 286 | border: var(--button-border-size) solid color-mix(in sRGB, var(--sys-color-primary), var(--sys-color-state-ripple-primary) 32%); |
| 287 | } |
| 288 | |
| 289 | &.tonal { |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 290 | background: color-mix(in sRGB, var(--sys-color-tonal-container), var(--sys-color-state-ripple-primary) 50%); |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 291 | } |
| 292 | |
| 293 | &.toolbar { |
| 294 | devtools-icon { |
| 295 | color: var(--icon-toggled); |
| 296 | } |
| 297 | } |
| 298 | } |
Alex Rudenko | cc459b9 | 2021-08-11 13:53:48 | [diff] [blame] | 299 | } |
Kateryna Prokopenko | cc83004 | 2024-05-03 16:30:46 | [diff] [blame] | 300 | /* stylelint-enable no-descending-specificity */ |
Alex Rudenko | cc459b9 | 2021-08-11 13:53:48 | [diff] [blame] | 301 | |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 302 | .spinner { |
Riho Isawa | bb8f398 | 2021-11-26 11:58:16 | [diff] [blame] | 303 | display: block; |
| 304 | width: 12px; |
| 305 | height: 12px; |
| 306 | border-radius: 6px; |
Kateryna Prokopenko | 5280530 | 2023-10-09 14:30:18 | [diff] [blame] | 307 | border: 2px solid var(--sys-color-cdt-base-container); |
Riho Isawa | bb8f398 | 2021-11-26 11:58:16 | [diff] [blame] | 308 | animation: spinner-animation 1s linear infinite; |
| 309 | border-right-color: transparent; |
Alex Rudenko | 9d873e5 | 2023-05-09 14:26:17 | [diff] [blame] | 310 | margin-right: 4px; |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 311 | |
Kateryna Prokopenko | 0895c17 | 2024-04-17 09:49:13 | [diff] [blame] | 312 | &.outlined { |
Alex Rudenko | 3aa078e | 2024-01-03 13:52:47 | [diff] [blame] | 313 | border: 2px solid var(--sys-color-primary); |
| 314 | border-right-color: transparent; |
| 315 | } |
| 316 | |
| 317 | &.disabled { |
| 318 | border: 2px solid var(--sys-color-state-disabled); |
| 319 | border-right-color: transparent; |
| 320 | } |
Riho Isawa | bb8f398 | 2021-11-26 11:58:16 | [diff] [blame] | 321 | } |
| 322 | |
| 323 | @keyframes spinner-animation { |
| 324 | from { |
| 325 | transform: rotate(0); |
| 326 | } |
| 327 | |
| 328 | to { |
| 329 | transform: rotate(360deg); |
| 330 | } |
| 331 | } |