2017-10-26 07:18:08 +00:00
|
|
|
@import "../../style/themes/default";
|
|
|
|
@import "../../style/mixins/index";
|
|
|
|
@import "./mixin";
|
|
|
|
|
|
|
|
@btn-prefix-cls: ~"@{ant-prefix}-btn";
|
|
|
|
|
2018-07-17 13:16:22 +00:00
|
|
|
// for compatible
|
2017-10-26 07:18:08 +00:00
|
|
|
@btn-ghost-color: @text-color;
|
|
|
|
@btn-ghost-bg: transparent;
|
|
|
|
@btn-ghost-border: @border-color-base;
|
|
|
|
|
|
|
|
// Button styles
|
|
|
|
// -----------------------------
|
|
|
|
.@{btn-prefix-cls} {
|
2018-11-14 13:33:56 +00:00
|
|
|
// Fixing https://github.com/ant-design/ant-design/issues/12978
|
|
|
|
// It is a render problem of chrome, which is only happened in the codesandbox demo
|
|
|
|
// 0.001px solution works and I don't why
|
|
|
|
line-height: @line-height-base - 0.001;
|
2017-10-26 07:18:08 +00:00
|
|
|
.btn;
|
|
|
|
.btn-default;
|
|
|
|
|
|
|
|
// Make sure that the target of Button's click event always be `button`
|
|
|
|
// Ref: https://github.com/ant-design/ant-design/issues/7034
|
|
|
|
> i,
|
|
|
|
> span {
|
|
|
|
pointer-events: none;
|
2018-11-14 13:33:56 +00:00
|
|
|
display: inline-block;
|
2017-10-26 07:18:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
&-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;
|
|
|
|
|
|
|
|
&:disabled {
|
|
|
|
border-color: @btn-default-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 & + & {
|
|
|
|
border-left-color: @btn-group-border;
|
|
|
|
&[disabled] {
|
|
|
|
border-left-color: @btn-default-border;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&-ghost {
|
|
|
|
.btn-ghost;
|
|
|
|
}
|
|
|
|
|
|
|
|
&-dashed {
|
|
|
|
.btn-dashed;
|
|
|
|
}
|
|
|
|
|
|
|
|
&-danger {
|
|
|
|
.btn-danger;
|
|
|
|
}
|
|
|
|
|
|
|
|
&-circle,
|
|
|
|
&-circle-outline {
|
|
|
|
.btn-circle(@btn-prefix-cls);
|
|
|
|
}
|
|
|
|
|
|
|
|
&:before {
|
|
|
|
position: absolute;
|
|
|
|
top: -1px;
|
|
|
|
left: -1px;
|
|
|
|
bottom: -1px;
|
|
|
|
right: -1px;
|
|
|
|
background: #fff;
|
|
|
|
opacity: 0.35;
|
2018-12-09 11:30:35 +00:00
|
|
|
content: "";
|
2017-10-26 07:18:08 +00:00
|
|
|
border-radius: inherit;
|
|
|
|
z-index: 1;
|
|
|
|
transition: opacity .2s;
|
|
|
|
pointer-events: none;
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.@{iconfont-css-prefix} {
|
|
|
|
transition: margin-left .3s @ease-in-out;
|
|
|
|
}
|
|
|
|
|
|
|
|
&&-loading:before {
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
&&-loading:not(&-circle):not(&-circle-outline):not(&-icon-only) {
|
|
|
|
padding-left: 29px;
|
|
|
|
pointer-events: none;
|
|
|
|
position: relative;
|
|
|
|
.@{iconfont-css-prefix} {
|
|
|
|
margin-left: -14px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&-sm&-loading:not(&-circle):not(&-circle-outline):not(&-icon-only) {
|
|
|
|
padding-left: 24px;
|
|
|
|
.@{iconfont-css-prefix} {
|
|
|
|
margin-left: -17px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&-group {
|
|
|
|
.btn-group(@btn-prefix-cls);
|
|
|
|
}
|
|
|
|
|
|
|
|
&:not(&-circle):not(&-circle-outline)&-icon-only {
|
|
|
|
padding-left: 8px;
|
|
|
|
padding-right: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
// http://stackoverflow.com/a/21281554/3040605
|
|
|
|
&:focus > span,
|
|
|
|
&:active > span {
|
|
|
|
position: relative;
|
|
|
|
}
|
|
|
|
|
|
|
|
// To ensure that a space will be placed between character and `Icon`.
|
|
|
|
> .@{iconfont-css-prefix} + span,
|
|
|
|
> span + .@{iconfont-css-prefix} {
|
2018-01-15 10:54:26 +00:00
|
|
|
margin-left: 8px;
|
2017-10-26 07:18:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
&-background-ghost {
|
|
|
|
background: transparent !important;
|
|
|
|
border-color: #fff;
|
|
|
|
color: #fff;
|
|
|
|
}
|
|
|
|
|
|
|
|
&-background-ghost&-primary {
|
2018-02-05 05:50:04 +00:00
|
|
|
.button-variant-ghost(@btn-primary-bg);
|
2017-10-26 07:18:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
&-background-ghost&-danger {
|
|
|
|
.button-variant-ghost(@btn-danger-color);
|
|
|
|
}
|
2018-01-15 10:54:26 +00:00
|
|
|
|
|
|
|
&-two-chinese-chars:first-letter {
|
|
|
|
letter-spacing: .34em;
|
|
|
|
}
|
|
|
|
|
2018-11-14 13:33:56 +00:00
|
|
|
&-two-chinese-chars > *:not(.@{iconfont-css-prefix}) {
|
2018-01-15 10:54:26 +00:00
|
|
|
letter-spacing: .34em;
|
|
|
|
margin-right: -.34em;
|
|
|
|
}
|
2017-10-26 07:18:08 +00:00
|
|
|
|
2018-09-05 13:28:54 +00:00
|
|
|
&-block {
|
|
|
|
width: 100%;
|
2017-10-26 07:18:08 +00:00
|
|
|
}
|
2018-11-14 13:33:56 +00:00
|
|
|
|
|
|
|
// https://github.com/ant-design/ant-design/issues/12681
|
|
|
|
&:empty {
|
|
|
|
vertical-align: top;
|
|
|
|
}
|
2017-10-26 07:18:08 +00:00
|
|
|
}
|
2018-01-15 10:54:26 +00:00
|
|
|
|
|
|
|
a.@{btn-prefix-cls} {
|
|
|
|
line-height: @btn-height-base - 2px;
|
|
|
|
&-lg {
|
|
|
|
line-height: @btn-height-lg - 2px;
|
|
|
|
}
|
|
|
|
&-sm {
|
|
|
|
line-height: @btn-height-sm - 2px;
|
|
|
|
}
|
|
|
|
}
|