202 lines
6.2 KiB
CSS
202 lines
6.2 KiB
CSS
@layer vuetify-components {
|
|
.v-icon-btn {
|
|
border-color: rgba(var(--v-border-color), var(--v-border-opacity));
|
|
border-style: solid;
|
|
border-width: 0;
|
|
}
|
|
.v-icon-btn--border {
|
|
border-width: thin;
|
|
box-shadow: none;
|
|
}
|
|
.v-icon-btn {
|
|
border-radius: 50%;
|
|
}
|
|
.v-icon-btn:hover > .v-icon-btn__overlay {
|
|
opacity: calc(var(--v-hover-opacity) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
.v-icon-btn:focus-visible > .v-icon-btn__overlay {
|
|
opacity: calc(var(--v-focus-opacity) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
@supports not selector(:focus-visible) {
|
|
.v-icon-btn:focus > .v-icon-btn__overlay {
|
|
opacity: calc(var(--v-focus-opacity) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
}
|
|
.v-icon-btn--active > .v-icon-btn__overlay, .v-icon-btn[aria-haspopup=menu][aria-expanded=true] > .v-icon-btn__overlay {
|
|
opacity: calc(var(--v-activated-opacity) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
.v-icon-btn--active:hover > .v-icon-btn__overlay, .v-icon-btn[aria-haspopup=menu][aria-expanded=true]:hover > .v-icon-btn__overlay {
|
|
opacity: calc((var(--v-activated-opacity) + var(--v-hover-opacity)) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
.v-icon-btn--active:focus-visible > .v-icon-btn__overlay, .v-icon-btn[aria-haspopup=menu][aria-expanded=true]:focus-visible > .v-icon-btn__overlay {
|
|
opacity: calc((var(--v-activated-opacity) + var(--v-focus-opacity)) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
@supports not selector(:focus-visible) {
|
|
.v-icon-btn--active:focus > .v-icon-btn__overlay, .v-icon-btn[aria-haspopup=menu][aria-expanded=true]:focus > .v-icon-btn__overlay {
|
|
opacity: calc((var(--v-activated-opacity) + var(--v-focus-opacity)) * var(--v-theme-overlay-multiplier));
|
|
}
|
|
}
|
|
.v-icon-btn--variant-plain, .v-icon-btn--variant-outlined, .v-icon-btn--variant-text, .v-icon-btn--variant-tonal {
|
|
background: transparent;
|
|
color: inherit;
|
|
}
|
|
.v-icon-btn--variant-plain {
|
|
opacity: 0.62;
|
|
}
|
|
.v-icon-btn--variant-plain:focus, .v-icon-btn--variant-plain:hover {
|
|
opacity: 1;
|
|
}
|
|
.v-icon-btn--variant-plain .v-icon-btn__overlay {
|
|
display: none;
|
|
}
|
|
.v-icon-btn--variant-elevated, .v-icon-btn--variant-flat {
|
|
background: rgb(var(--v-theme-surface));
|
|
color: inherit;
|
|
}
|
|
.v-icon-btn--variant-elevated {
|
|
box-shadow: 0px 1px 2px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity, 0.3)), 0px 1px 3px 1px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity, 0.15));
|
|
--v-elevation-overlay: color-mix(in srgb, var(--v-elevation-overlay-color) 2%, transparent);
|
|
}
|
|
.v-icon-btn--variant-flat {
|
|
box-shadow: 0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity, 0.3)), 0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity, 0.15));
|
|
--v-elevation-overlay: color-mix(in srgb, var(--v-elevation-overlay-color) 0%, transparent);
|
|
}
|
|
.v-icon-btn--variant-outlined {
|
|
border: thin solid currentColor;
|
|
}
|
|
.v-icon-btn--variant-text .v-icon-btn__overlay {
|
|
background: currentColor;
|
|
}
|
|
.v-icon-btn--variant-tonal .v-icon-btn__underlay {
|
|
background: currentColor;
|
|
opacity: var(--v-activated-opacity);
|
|
border-radius: inherit;
|
|
top: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
left: 0;
|
|
pointer-events: none;
|
|
}
|
|
.v-icon-btn .v-icon-btn__underlay {
|
|
position: absolute;
|
|
}
|
|
.v-icon-btn {
|
|
align-items: center;
|
|
cursor: pointer;
|
|
display: inline-flex;
|
|
flex: none;
|
|
font-size: 0.875rem;
|
|
font-weight: 500;
|
|
line-height: normal;
|
|
height: var(--v-icon-btn-height);
|
|
justify-content: center;
|
|
outline: none;
|
|
position: relative;
|
|
transition-property: width, height, transform;
|
|
transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
|
|
vertical-align: middle;
|
|
width: var(--v-icon-btn-width);
|
|
}
|
|
@supports selector(:focus-visible) {
|
|
.v-icon-btn::after {
|
|
pointer-events: none;
|
|
border: 2px solid currentColor;
|
|
border-radius: inherit;
|
|
opacity: 0;
|
|
transition: opacity 0.2s ease-in-out;
|
|
}
|
|
.v-icon-btn::after {
|
|
content: "";
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
.v-icon-btn:focus-visible::after {
|
|
opacity: calc(0.25 * var(--v-theme-overlay-multiplier));
|
|
}
|
|
}
|
|
.v-icon-btn--disabled, .v-icon-btn--loading, .v-icon-btn--readonly {
|
|
pointer-events: none;
|
|
}
|
|
.v-icon-btn--disabled {
|
|
opacity: 0.26;
|
|
}
|
|
.v-icon-btn--start {
|
|
margin-inline-end: 8px;
|
|
}
|
|
.v-icon-btn--end {
|
|
margin-inline-start: 8px;
|
|
}
|
|
.v-icon-btn__content {
|
|
align-items: center;
|
|
justify-content: center;
|
|
display: inline-flex;
|
|
transition: inherit;
|
|
transition-property: transform;
|
|
transform: rotate(var(--v-icon-btn-rotate, 0deg));
|
|
}
|
|
.v-icon-btn--loading .v-icon-btn__content {
|
|
opacity: 0;
|
|
}
|
|
.v-icon-btn__content .v-icon {
|
|
transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
|
|
transition-property: opacity, font-size, width, height;
|
|
transform-origin: center;
|
|
}
|
|
.v-icon-btn__loader {
|
|
align-items: center;
|
|
display: flex;
|
|
height: 100%;
|
|
justify-content: center;
|
|
left: 0;
|
|
position: absolute;
|
|
top: 0;
|
|
width: 100%;
|
|
}
|
|
.v-icon-btn__overlay,
|
|
.v-icon-btn__underlay {
|
|
border-radius: inherit;
|
|
pointer-events: none;
|
|
}
|
|
.v-icon-btn__overlay,
|
|
.v-icon-btn__underlay {
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
.v-icon-btn__overlay {
|
|
background-color: currentColor;
|
|
opacity: 0;
|
|
transition: opacity 0.2s ease-in-out;
|
|
}
|
|
.v-icon-btn--active:not(:hover) .v-icon-btn__overlay {
|
|
--v-activated-opacity: 0;
|
|
}
|
|
}
|
|
@layer vuetify-final.trumps {
|
|
@media (forced-colors: active) {
|
|
.v-icon-btn:focus-visible {
|
|
outline: 2px solid;
|
|
outline-offset: 2px;
|
|
}
|
|
.v-icon-btn:not(.v-icon-btn--active):hover, .v-icon-btn:not(.v-icon-btn--active):focus {
|
|
color: highlight;
|
|
}
|
|
.v-icon-btn--active:not(.v-icon-btn--disabled), .v-icon-btn--active:not(.v-icon-btn--disabled)[class*=bg-] {
|
|
outline-color: canvastext;
|
|
background: highlight;
|
|
color: highlighttext;
|
|
}
|
|
.v-icon-btn--disabled {
|
|
color: graytext;
|
|
}
|
|
.v-icon-btn__overlay, .v-icon-btn__underlay,
|
|
.v-icon-btn .v-icon {
|
|
forced-color-adjust: preserve-parent-color;
|
|
}
|
|
}
|
|
} |