ant-design/components/button/style/index.less

196 lines
4.0 KiB
Plaintext
Raw Normal View History

2018-12-07 20:02:01 +08:00
@import '../../style/themes/default';
@import '../../style/mixins/index';
@import './mixin';
2018-12-07 20:02:01 +08:00
@btn-prefix-cls: ~'@{ant-prefix}-btn';
2015-06-09 15:21:44 +08:00
// for compatible
2017-08-04 17:58:32 +08:00
@btn-ghost-color: @text-color;
@btn-ghost-bg: transparent;
@btn-ghost-border: @border-color-base;
2015-06-09 15:21:44 +08:00
// Button styles
// -----------------------------
2015-08-20 16:55:42 +08:00
.@{btn-prefix-cls} {
// 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
2018-11-11 18:51:57 +08:00
line-height: @line-height-base - 0.001;
2015-06-09 15:21:44 +08:00
.btn;
2015-06-11 17:16:32 +08:00
.btn-default;
2015-06-09 15:21:44 +08:00
// 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 {
display: inline-block;
pointer-events: none;
}
2015-06-09 15:21:44 +08:00
&-primary {
.btn-primary;
2015-06-12 19:41:30 +08:00
2015-08-20 16:55:42 +08:00
.@{btn-prefix-cls}-group &:not(:first-child):not(:last-child) {
2015-07-09 10:56:28 +08:00
border-right-color: @btn-group-border;
border-left-color: @btn-group-border;
&:disabled {
border-color: @btn-default-border;
}
2015-06-09 15:21:44 +08:00
}
2015-08-20 16:55:42 +08:00
.@{btn-prefix-cls}-group &:first-child {
2015-06-09 15:21:44 +08:00
&:not(:last-child) {
2015-07-09 10:56:28 +08:00
border-right-color: @btn-group-border;
&[disabled] {
border-right-color: @btn-default-border;
}
2015-06-09 15:21:44 +08:00
}
}
.@{btn-prefix-cls}-group &:last-child:not(:first-child),
.@{btn-prefix-cls}-group & + & {
2015-07-09 10:56:28 +08:00
border-left-color: @btn-group-border;
&[disabled] {
border-left-color: @btn-default-border;
}
2015-07-08 16:21:04 +08:00
}
2015-06-09 15:21:44 +08:00
}
&-ghost {
.btn-ghost;
}
2015-11-30 18:26:44 +08:00
&-dashed {
.btn-dashed;
}
&-danger {
.btn-danger;
}
&-round {
.btn-round(@btn-prefix-cls);
}
2015-11-26 19:32:55 +08:00
&-circle,
&-circle-outline {
2015-08-20 16:55:42 +08:00
.btn-circle(@btn-prefix-cls);
2015-06-09 15:21:44 +08:00
}
&::before {
position: absolute;
top: -1px;
right: -1px;
bottom: -1px;
left: -1px;
z-index: 1;
display: none;
background: @component-background;
border-radius: inherit;
opacity: 0.35;
2018-12-07 20:02:01 +08:00
transition: opacity 0.2s;
pointer-events: none;
content: '';
}
2017-04-15 14:57:05 +08:00
.@{iconfont-css-prefix} {
2018-12-07 20:02:01 +08:00
transition: margin-left 0.3s @ease-in-out;
2018-12-26 18:48:47 +08:00
// Follow icon blur under windows. Change the render.
// https://github.com/ant-design/ant-design/issues/13924
&.@{iconfont-css-prefix}-plus,
&.@{iconfont-css-prefix}-minus {
> svg {
shape-rendering: optimizeSpeed;
}
}
2017-04-15 14:57:05 +08:00
}
&&-loading {
position: relative;
pointer-events: none;
}
&&-loading::before {
display: block;
}
&&-loading:not(&-circle):not(&-circle-outline):not(&-icon-only) {
2015-12-28 13:49:58 +08:00
padding-left: 29px;
.@{iconfont-css-prefix}:not(:last-child) {
2016-04-12 12:17:03 +08:00
margin-left: -14px;
2015-12-28 13:49:58 +08:00
}
2015-07-29 22:23:55 +08:00
}
&-sm&-loading:not(&-circle):not(&-circle-outline):not(&-icon-only) {
2015-12-28 13:49:58 +08:00
padding-left: 24px;
.@{iconfont-css-prefix} {
2016-04-12 12:17:03 +08:00
margin-left: -17px;
2015-07-29 22:23:55 +08:00
}
}
2015-06-09 15:21:44 +08:00
&-group {
2015-08-20 16:55:42 +08:00
.btn-group(@btn-prefix-cls);
2015-06-09 15:21:44 +08:00
}
2015-09-27 16:30:35 +08:00
&:not(&-circle):not(&-circle-outline)&-icon-only {
2017-11-27 14:41:17 +08:00
padding-right: 8px;
padding-left: 8px;
}
2017-03-05 20:12:36 +08:00
// http://stackoverflow.com/a/21281554/3040605
&:focus > span,
&:active > span {
position: relative;
}
2015-09-27 16:30:35 +08:00
// To ensure that a space will be placed between character and `Icon`.
2015-11-26 19:32:55 +08:00
> .@{iconfont-css-prefix} + span,
> span + .@{iconfont-css-prefix} {
2017-10-17 11:40:37 +08:00
margin-left: 8px;
2015-09-27 16:30:35 +08:00
}
&-background-ghost {
color: @component-background;
2017-08-04 17:58:32 +08:00
background: transparent !important;
border-color: @component-background;
}
&-background-ghost&-primary {
.button-variant-ghost(@btn-primary-bg);
2017-03-18 16:33:55 +08:00
}
&-background-ghost&-danger {
.button-variant-ghost(@btn-danger-color);
}
&-two-chinese-chars::first-letter {
2018-12-07 20:02:01 +08:00
letter-spacing: 0.34em;
}
&-two-chinese-chars > *:not(.@{iconfont-css-prefix}) {
2018-12-07 20:02:01 +08:00
margin-right: -0.34em;
letter-spacing: 0.34em;
}
&-block {
width: 100%;
}
2018-09-10 11:22:26 +08:00
// https://github.com/ant-design/ant-design/issues/12681
&:empty {
vertical-align: top;
}
}
a.@{btn-prefix-cls} {
line-height: @btn-height-base - 2px;
&-lg {
line-height: @btn-height-lg - 2px;
}
&-sm {
line-height: @btn-height-sm - 2px;
}
}