import type { CSSObject } from '../../_util/cssinjs'; import type { StepsToken } from '.'; import type { GenerateStyle } from '../../theme/internal'; const genStepsProgressStyle: GenerateStyle = token => { const { antCls, componentCls } = token; return { [`&${componentCls}-with-progress`]: { [`${componentCls}-item`]: { paddingTop: token.paddingXXS, [`&-process ${componentCls}-item-container ${componentCls}-item-icon ${componentCls}-icon`]: { color: token.processIconColor, }, }, [`&${componentCls}-vertical > ${componentCls}-item `]: { paddingInlineStart: token.paddingXXS, [`> ${componentCls}-item-container > ${componentCls}-item-tail`]: { top: token.marginXXS, insetInlineStart: token.stepsIconSize / 2 - token.lineWidth + token.paddingXXS, }, }, [`&, &${componentCls}-small`]: { [`&${componentCls}-horizontal ${componentCls}-item:first-child`]: { paddingBottom: token.paddingXXS, paddingInlineStart: token.paddingXXS, }, }, [`&${componentCls}-small${componentCls}-vertical > ${componentCls}-item > ${componentCls}-item-container > ${componentCls}-item-tail`]: { insetInlineStart: token.stepsSmallIconSize / 2 - token.lineWidth + token.paddingXXS, }, [`&${componentCls}-label-vertical`]: { [`${componentCls}-item ${componentCls}-item-tail`]: { top: token.margin - 2 * token.lineWidth, }, }, [`${componentCls}-item-icon`]: { position: 'relative', [`${antCls}-progress`]: { position: 'absolute', insetBlockStart: (token.stepsIconSize - token.stepsProgressSize - token.lineWidth * 2) / 2, insetInlineStart: (token.stepsIconSize - token.stepsProgressSize - token.lineWidth * 2) / 2, }, }, }, }; }; export default genStepsProgressStyle;