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