ant-design/style/components/button.less
2016-03-12 00:13:05 +08:00

125 lines
2.2 KiB
Plaintext

@import "../mixins/index";
@btn-prefix-cls: ~"@{css-prefix}btn";
// Button styles
// -----------------------------
.@{btn-prefix-cls} {
.btn;
.btn-default;
&-primary {
.btn-primary;
.@{btn-prefix-cls}-group &:not(:first-child):not(:last-child) {
border-right-color: @btn-group-border;
border-left-color: @btn-group-border;
}
.@{btn-prefix-cls}-group &:first-child {
&:not(:last-child) {
border-right-color: @btn-group-border;
&[disabled] {
border-right-color: @btn-default-border;
}
}
}
.@{btn-prefix-cls}-group &:last-child:not(:first-child),
.@{btn-prefix-cls}-group & + .@{btn-prefix-cls} {
border-left-color: @btn-group-border;
&[disabled] {
border-left-color: @btn-default-border;
}
}
}
&-ghost {
.btn-ghost;
}
&-dashed {
.btn-dashed;
}
&-circle,
&-circle-outline {
.btn-circle(@btn-prefix-cls);
}
&-circle-outline {
.btn-circle-outline;
}
&:after {
font-family: anticon;
content: "\e6a1";
position: absolute;
opacity: 0;
visibility: hidden;
transition: opacity 0.5s ease;
}
&&-loading {
padding-left: 29px;
pointer-events: none;
opacity: 0.75;
&:after {
.animation(loadingCircle 1s infinite linear);
height: 12px;
line-height: 12px;
left: 10px;
top: 50%;
margin-top: -6px;
opacity: 1;
visibility: visible;
}
> .anticon {
display: none;
& + span {
margin-left: 0;
}
}
}
&-sm&-loading {
padding-left: 24px;
&:after {
left: 7px;
}
}
&-group {
.btn-group(@btn-prefix-cls);
}
// To ensure that a space will be placed between character and `Icon`.
> .@{iconfont-css-prefix} + span,
> span + .@{iconfont-css-prefix} {
margin-left: 0.5em;
}
&-clicked:before {
content: '';
position: absolute;
top: -1px;
left: -1px;
bottom: -1px;
right: -1px;
border-radius: inherit;
border: 0 solid @primary-color;
opacity: 0.4;
animation: buttonEffect 0.32s ease forwards;
}
}
@keyframes buttonEffect {
to {
opacity: 0;
top: -5px;
left: -5px;
bottom: -5px;
right: -5px;
border-width: 5px;
}
}