mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-02 03:59:01 +08:00
151 lines
4.9 KiB
TypeScript
151 lines
4.9 KiB
TypeScript
import { unit } from '@ant-design/cssinjs';
|
|
import type { CSSObject } from '@ant-design/cssinjs';
|
|
|
|
import type { StepsToken } from '.';
|
|
import type { GenerateStyle } from '../../theme/internal';
|
|
|
|
const genStepsProgressDotStyle: GenerateStyle<StepsToken, CSSObject> = (token) => {
|
|
const {
|
|
componentCls,
|
|
descriptionMaxWidth,
|
|
lineHeight,
|
|
dotCurrentSize,
|
|
dotSize,
|
|
motionDurationSlow,
|
|
} = token;
|
|
|
|
return {
|
|
[`&${componentCls}-dot, &${componentCls}-dot${componentCls}-small`]: {
|
|
[`${componentCls}-item`]: {
|
|
'&-title': {
|
|
lineHeight,
|
|
},
|
|
|
|
'&-tail': {
|
|
// Math.floor((token.size - token.lineWidth * 3) / 2)
|
|
top: token
|
|
.calc(token.dotSize)
|
|
.sub(token.calc(token.lineWidth).mul(3).equal())
|
|
.div(2)
|
|
.equal(),
|
|
width: '100%',
|
|
marginTop: 0,
|
|
marginBottom: 0,
|
|
marginInline: `${unit(token.calc(descriptionMaxWidth).div(2).equal())} 0`,
|
|
padding: 0,
|
|
|
|
'&::after': {
|
|
width: `calc(100% - ${unit(token.calc(token.marginSM).mul(2).equal())})`,
|
|
height: token.calc(token.lineWidth).mul(3).equal(),
|
|
marginInlineStart: token.marginSM,
|
|
},
|
|
},
|
|
'&-icon': {
|
|
width: dotSize,
|
|
height: dotSize,
|
|
marginInlineStart: token.calc(token.descriptionMaxWidth).sub(dotSize).div(2).equal(),
|
|
paddingInlineEnd: 0,
|
|
lineHeight: unit(dotSize),
|
|
background: 'transparent',
|
|
border: 0,
|
|
|
|
[`${componentCls}-icon-dot`]: {
|
|
position: 'relative',
|
|
float: 'left',
|
|
width: '100%',
|
|
height: '100%',
|
|
borderRadius: 100, // very large number
|
|
transition: `all ${motionDurationSlow}`,
|
|
|
|
/* expand hover area */
|
|
'&::after': {
|
|
position: 'absolute',
|
|
top: token.calc(token.marginSM).mul(-1).equal(),
|
|
insetInlineStart: token
|
|
.calc(dotSize)
|
|
.sub(token.calc(token.controlHeightLG).mul(1.5).equal())
|
|
.div(2)
|
|
.equal(),
|
|
width: token.calc(token.controlHeightLG).mul(1.5).equal(),
|
|
height: token.controlHeight,
|
|
background: 'transparent',
|
|
content: '""',
|
|
},
|
|
},
|
|
},
|
|
|
|
'&-content': {
|
|
width: descriptionMaxWidth,
|
|
},
|
|
[`&-process ${componentCls}-item-icon`]: {
|
|
position: 'relative',
|
|
top: token.calc(dotSize).sub(dotCurrentSize).div(2).equal(),
|
|
width: dotCurrentSize,
|
|
height: dotCurrentSize,
|
|
lineHeight: unit(dotCurrentSize),
|
|
background: 'none',
|
|
marginInlineStart: token
|
|
.calc(token.descriptionMaxWidth)
|
|
.sub(dotCurrentSize)
|
|
.div(2)
|
|
.equal(),
|
|
},
|
|
[`&-process ${componentCls}-icon`]: {
|
|
[`&:first-child ${componentCls}-icon-dot`]: {
|
|
insetInlineStart: 0,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
[`&${componentCls}-vertical${componentCls}-dot`]: {
|
|
[`${componentCls}-item-icon`]: {
|
|
marginTop: token.calc(token.controlHeight).sub(dotSize).div(2).equal(),
|
|
marginInlineStart: 0,
|
|
background: 'none',
|
|
},
|
|
[`${componentCls}-item-process ${componentCls}-item-icon`]: {
|
|
marginTop: token.calc(token.controlHeight).sub(dotCurrentSize).div(2).equal(),
|
|
top: 0,
|
|
insetInlineStart: token.calc(dotSize).sub(dotCurrentSize).div(2).equal(),
|
|
marginInlineStart: 0,
|
|
},
|
|
|
|
// https://github.com/ant-design/ant-design/issues/18354
|
|
[`${componentCls}-item > ${componentCls}-item-container > ${componentCls}-item-tail`]: {
|
|
top: token.calc(token.controlHeight).sub(dotSize).div(2).equal(),
|
|
insetInlineStart: 0,
|
|
margin: 0,
|
|
padding: `${unit(token.calc(dotSize).add(token.paddingXS).equal())} 0 ${unit(
|
|
token.paddingXS,
|
|
)}`,
|
|
|
|
'&::after': {
|
|
marginInlineStart: token.calc(dotSize).sub(token.lineWidth).div(2).equal(),
|
|
},
|
|
},
|
|
|
|
[`&${componentCls}-small`]: {
|
|
[`${componentCls}-item-icon`]: {
|
|
marginTop: token.calc(token.controlHeightSM).sub(dotSize).div(2).equal(),
|
|
},
|
|
[`${componentCls}-item-process ${componentCls}-item-icon`]: {
|
|
marginTop: token.calc(token.controlHeightSM).sub(dotCurrentSize).div(2).equal(),
|
|
},
|
|
|
|
[`${componentCls}-item > ${componentCls}-item-container > ${componentCls}-item-tail`]: {
|
|
top: token.calc(token.controlHeightSM).sub(dotSize).div(2).equal(),
|
|
},
|
|
},
|
|
|
|
[`${componentCls}-item:first-child ${componentCls}-icon-dot`]: {
|
|
insetInlineStart: 0,
|
|
},
|
|
[`${componentCls}-item-content`]: {
|
|
width: 'inherit',
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
export default genStepsProgressDotStyle;
|