philomena/assets/css/elements/_button.scss
2024-04-30 09:25:23 +02:00

142 lines
2.8 KiB
SCSS

@mixin button-type($type) {
.button--#{$type} {
color: var(--#{$type}-link-color) !important;
border-color: var(--#{$type}-border-color);
background: var(--#{$type}-dark-color);
&.button--important {
color: var(--text-color) !important;
background: var(--#{$type}-color);
box-shadow: 0 -1px var(--#{$type}-dark-color) inset;
}
&:hover {
background: var(--#{$type}-muted-color) !important;
}
}
.button__group--#{$type} {
border-color: var(--#{$type}-color);
background: var(--#{$type}-dark-color);
& a {
color: var(--#{$type}-link-color);
&:hover {
@include animated-transition;
color: var(--text-color);
background: var(--#{$type}-color);
}
}
}
}
.button {
@include animated-transition;
display: flex;
flex: 0 1 auto;
width: fit-content;
font-weight: bold;
font-size: var(--font-size);
background: var(--primary-dark-color);
color: var(--text-color);
border: 1px solid var(--primary-border-color);
border-radius: var(--border-radius-inner);
padding: 0 var(--padding-small);
overflow: hidden;
line-height: var(--button-height);
align-items: center;
&:hover {
@include animated-transition;
background: var(--primary-muted-color);
cursor: pointer;
}
}
.button > i {
margin-right: var(--padding-small);
}
.button--important {
background: var(--primary-color);
box-shadow: 0 -1px var(--primary-dark-color) inset;
}
.button__row {
@extend .flex__row;
& > button {
margin-right: var(--padding-small);
}
}
.button__group {
@extend .flex__row;
border: 1px solid var(--secondary-color);
border-radius: var(--border-radius-inner);
margin-right: var(--padding-normal);
background: var(--secondary-dark-color);
line-height: var(--button-group-height);
&:last-child {
margin: 0;
}
}
.button__group--tall {
line-height: var(--button-group-tall-height)
}
.button__group--small {
line-height: var(--button-group-small-height)
}
.button__group .button {
border: 0;
border-right: var(--secondary-color);
&:last-child {
border-right: 0;
}
}
.button__group--single {
@extend .button__group;
margin-right: 0;
}
.button__group--standalone {
@extend .button__group;
}
.button__group--standalone a {
@include animated-transition;
font-weight: bold;
padding: 0 var(--padding-small);
&:hover {
@include animated-transition;
background: var(--secondary-muted-color);
}
}
.button--borderless {
border-width: 0;
}
.block__header__buttons .button {
color: var(--link-color);
border-width: 0 !important;
background: 0;
&:hover {
background: var(--primary-muted-color);
}
}
@include button-type(success);
@include button-type(warning);
@include button-type(danger);
@include button-type(information);
@include button-type(special);