@qvant/qui-max
Version:
A Vue 3 Design system for Web.
156 lines • 4.55 kB
CSS
@keyframes q-button-icon-rotating {
0% {
transform: rotateZ(0deg);
}
100% {
transform: rotateZ(360deg);
}
}
.q-button {
--box-shadow-default: 4px 4px 8px rgb(var(--color-rgb-blue) / 40%),
1px 1px 3px rgb(var(--color-rgb-blue) / 40%);
--box-shadow-pressed: 1px 1px 3px rgb(var(--color-rgb-blue) / 40%);
--color-rgb-gray: 29 29 27;
--button-main-bg: transparent;
--icon-size: 24px;
--border-width: 1px;
display: inline-block;
flex-shrink: 0;
padding: calc(12.5px - var(--border-width)) 40px;
font-size: 12px;
font-weight: 700;
line-height: 15px;
text-align: center;
text-transform: uppercase;
white-space: nowrap;
vertical-align: middle;
cursor: pointer;
background: var(--button-main-bg);
border: var(--border-width) solid transparent;
border-radius: var(--border-radius-base);
outline: none;
box-shadow: var(--box-shadow-default);
appearance: none;
}
.q-button + .q-button {
margin-left: 16px;
}
.q-button:focus {
outline: none;
}
.q-button__spinner-icon {
position: absolute;
top: calc(50% - var(--icon-size) / 2);
left: calc(50% - var(--icon-size) / 2);
font-size: var(--icon-size);
transform-origin: calc(var(--icon-size) / 2);
animation: q-button-icon-rotating 2s linear infinite;
}
.q-button_theme_primary {
--button-active-color: rgb(var(--color-rgb-white) / 64%);
--button-hover-active-bg: var(--color-primary);
--button-main-bg: var(--gradient-primary);
--button-hover-color: var(--color-tertiary-white);
/* stylelint-disable length-zero-no-unit */
--border-width: 0px;
color: var(--color-tertiary-white);
}
.q-button_theme_primary.focus-visible {
background: var(--color-primary-darker);
}
.q-button_theme_secondary {
--button-active-color: var(--color-primary-darker);
--button-hover-active-bg: var(--color-tertiary-gray);
--button-main-bg: var(--color-tertiary-gray-light);
--button-hover-color: var(--color-primary);
color: var(--color-primary);
}
.q-button_theme_secondary.focus-visible {
border-color: var(--color-primary);
}
.q-button_theme_secondary.focus-visible:active {
border-color: var(--color-primary-darker);
}
.q-button_theme_link {
--button-active-color: var(--color-primary);
--button-hover-color: rgb(var(--color-rgb-gray) / 96%);
padding: 0;
font-size: 14px;
font-weight: var(--font-weight-base);
line-height: 18px;
color: var(--color-primary-blue);
text-transform: initial;
border-radius: var(--border-radius-base);
box-shadow: none;
}
.q-button_theme_link.focus-visible {
text-decoration: underline;
}
.q-button_theme_link.focus-visible.q-button_type_icon {
text-decoration: underline;
border: 1px solid;
}
.q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):hover, .q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):active {
background: var(--button-hover-active-bg);
}
.q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):hover {
color: var(--button-hover-color);
}
.q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):active {
color: var(--button-active-color);
}
.q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):active:not(.q-button:not(.q-button.q-button_loading, .q-button.q-button_disabled):active.q-button_theme_link) {
box-shadow: var(--box-shadow-pressed);
}
.q-button_type_icon {
width: 40px;
height: 40px;
padding: calc(8px - var(--border-width)) 7px;
font-size: var(--icon-size);
}
.q-button_disabled {
color: rgb(var(--color-rgb-gray)/64%);
cursor: not-allowed;
}
.q-button_disabled:not(.q-button_disabled.q-button_theme_link) {
background: var(--color-tertiary-gray);
box-shadow: var(--box-shadow-pressed);
}
.q-button_loading {
position: relative;
cursor: progress;
background: var(--button-main-bg);
}
.q-button_loading:not(.q-button_loading.q-button_theme_link) {
color: var(--button-active-color);
box-shadow: var(--box-shadow-default);
}
.q-button_loading.q-button_theme_link {
color: var(--color-primary-blue);
}
.q-button_loading .q-button__inner {
visibility: hidden;
}
.q-button_circle {
border-radius: 50%;
}
.q-button_size_small {
--icon-size: 16px;
padding: calc(8px - var(--border-width)) 20px;
font-size: 10px;
line-height: 12px;
}
.q-button_size_small.q-button_type_icon {
width: 24px;
height: 24px;
padding: calc(4px - var(--border-width)) 3px;
}
.q-button_size_small.q-button_theme_link {
padding: 0;
font-size: 12px;
font-weight: 500;
line-height: 18px;
}
.q-button_full-width {
width: 100%;
}