Skip to content

Commit

Permalink
refactor: Timeline support css var (ant-design#45831)
Browse files Browse the repository at this point in the history
  • Loading branch information
JarvisArt authored Nov 13, 2023
1 parent 98639ba commit ca25149
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 37 deletions.
10 changes: 7 additions & 3 deletions components/timeline/Timeline.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import { devUseWarning } from '../_util/warning';
import { ConfigContext } from '../config-provider';
// CSSINJS
import useStyle from './style';
import useCSSVar from './style/cssVar';
import useCSSVarCls from '../config-provider/hooks/useCSSVarCls';
import type { TimelineItemProps } from './TimelineItem';
import TimelineItem from './TimelineItem';
import TimelineItemList from './TimelineItemList';
Expand Down Expand Up @@ -41,14 +43,16 @@ const Timeline: CompoundedComponent = (props) => {
}

// Style
const [wrapSSR, hashId] = useStyle(prefixCls);
const [, hashId] = useStyle(prefixCls);
const rootCls = useCSSVarCls(prefixCls);
const wrapCSSVar = useCSSVar(rootCls);

const mergedItems: TimelineItemProps[] = useItems(items, children);

return wrapSSR(
return wrapCSSVar(
<TimelineItemList
{...restProps}
className={classNames(timeline?.className, className)}
className={classNames(timeline?.className, className, rootCls)}
style={{ ...timeline?.style, ...style }}
prefixCls={prefixCls}
direction={direction}
Expand Down
4 changes: 4 additions & 0 deletions components/timeline/style/cssVar.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
import { genCSSVarRegister } from '../../theme/internal';
import { prepareComponentToken } from '.';

export default genCSSVarRegister('Timeline', prepareComponentToken);
79 changes: 45 additions & 34 deletions components/timeline/style/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import type { CSSObject } from '@ant-design/cssinjs';
import { unit } from '@ant-design/cssinjs';
import { resetComponent } from '../../style';
import type { FullToken, GenerateStyle } from '../../theme/internal';
import type { FullToken, GenerateStyle, GetDefaultToken } from '../../theme/internal';
import { genComponentStyleHook, mergeToken } from '../../theme/internal';

export interface ComponentToken {
Expand Down Expand Up @@ -38,7 +39,7 @@ interface TimelineToken extends FullToken<'Timeline'> {
}

const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
const { componentCls } = token;
const { componentCls, calc } = token;

return {
[componentCls]: {
Expand All @@ -57,9 +58,9 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
'&-tail': {
position: 'absolute',
insetBlockStart: token.itemHeadSize,
insetInlineStart: (token.itemHeadSize - token.tailWidth) / 2,
height: `calc(100% - ${token.itemHeadSize}px)`,
borderInlineStart: `${token.tailWidth}px ${token.lineType} ${token.tailColor}`,
insetInlineStart: calc(calc(token.itemHeadSize).sub(token.tailWidth)).div(2).equal(),
height: `calc(100% - ${unit(token.itemHeadSize)})`,
borderInlineStart: `${unit(token.tailWidth)} ${token.lineType} ${token.tailColor}`,
},

'&-pending': {
Expand All @@ -78,7 +79,7 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
width: token.itemHeadSize,
height: token.itemHeadSize,
backgroundColor: token.dotBg,
border: `${token.dotBorderWidth}px ${token.lineType} transparent`,
border: `${unit(token.dotBorderWidth)} ${token.lineType} transparent`,
borderRadius: '50%',

'&-blue': {
Expand All @@ -104,8 +105,8 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {

'&-head-custom': {
position: 'absolute',
insetBlockStart: token.itemHeadSize / 2,
insetInlineStart: token.itemHeadSize / 2,
insetBlockStart: calc(token.itemHeadSize).div(2).equal(),
insetInlineStart: calc(token.itemHeadSize).div(2).equal(),
width: 'auto',
height: 'auto',
marginBlockStart: 0,
Expand All @@ -119,8 +120,11 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {

'&-content': {
position: 'relative',
insetBlockStart: -(token.fontSize * token.lineHeight - token.fontSize) + token.lineWidth,
marginInlineStart: token.margin + token.itemHeadSize,
insetBlockStart: calc(calc(token.fontSize).mul(token.lineHeight).sub(token.fontSize))
.mul(-1)
.add(token.lineWidth)
.equal(),
marginInlineStart: calc(token.margin).add(token.itemHeadSize).equal(),
marginInlineEnd: 0,
marginBlockStart: 0,
marginBlockEnd: 0,
Expand All @@ -133,7 +137,7 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
},

[`> ${componentCls}-item-content`]: {
minHeight: token.controlHeightLG * 1.2,
minHeight: calc(token.controlHeightLG).mul(1.2).equal(),
},
},
},
Expand All @@ -147,24 +151,24 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
},

'&-head': {
marginInlineStart: `-${token.marginXXS}px`,
marginInlineStart: calc(token.marginXXS).mul(-1).equal(),

'&-custom': {
marginInlineStart: token.tailWidth / 2,
marginInlineStart: calc(token.tailWidth).div(2).equal(),
},
},

'&-left': {
[`${componentCls}-item-content`]: {
insetInlineStart: `calc(50% - ${token.marginXXS}px)`,
width: `calc(50% - ${token.marginSM}px)`,
insetInlineStart: `calc(50% - ${unit(token.marginXXS)})`,
width: `calc(50% - ${unit(token.marginSM)})`,
textAlign: 'start',
},
},

'&-right': {
[`${componentCls}-item-content`]: {
width: `calc(50% - ${token.marginSM}px)`,
width: `calc(50% - ${unit(token.marginSM)})`,
margin: 0,
textAlign: 'end',
},
Expand All @@ -177,11 +181,13 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
[`${componentCls}-item-tail,
${componentCls}-item-head,
${componentCls}-item-head-custom`]: {
insetInlineStart: `calc(100% - ${(token.itemHeadSize + token.tailWidth) / 2}px)`,
insetInlineStart: `calc(100% - ${unit(
calc(calc(token.itemHeadSize).add(token.tailWidth)).div(2).equal(),
)})`,
},

[`${componentCls}-item-content`]: {
width: `calc(100% - ${token.itemHeadSize + token.marginXS}px)`,
width: `calc(100% - ${unit(calc(token.itemHeadSize).add(token.marginXS).equal())})`,
},
},
},
Expand All @@ -190,8 +196,8 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
${componentCls}-item-last
${componentCls}-item-tail`]: {
display: 'block',
height: `calc(100% - ${token.margin}px)`,
borderInlineStart: `${token.tailWidth}px dotted ${token.tailColor}`,
height: `calc(100% - ${unit(token.margin)})`,
borderInlineStart: `${unit(token.tailWidth)} dotted ${token.tailColor}`,
},

[`&${componentCls}-reverse
Expand All @@ -204,27 +210,30 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
[`${componentCls}-item-tail`]: {
insetBlockStart: token.margin,
display: 'block',
height: `calc(100% - ${token.margin}px)`,
borderInlineStart: `${token.tailWidth}px dotted ${token.tailColor}`,
height: `calc(100% - ${unit(token.margin)})`,
borderInlineStart: `${unit(token.tailWidth)} dotted ${token.tailColor}`,
},

[`${componentCls}-item-content`]: {
minHeight: token.controlHeightLG * 1.2,
minHeight: calc(token.controlHeightLG).mul(1.2).equal(),
},
},

[`&${componentCls}-label`]: {
[`${componentCls}-item-label`]: {
position: 'absolute',
insetBlockStart: -(token.fontSize * token.lineHeight - token.fontSize) + token.tailWidth,
width: `calc(50% - ${token.marginSM}px)`,
insetBlockStart: calc(calc(token.fontSize).mul(token.lineHeight).sub(token.fontSize))
.mul(-1)
.add(token.tailWidth)
.equal(),
width: `calc(50% - ${unit(token.marginSM)})`,
textAlign: 'end',
},

[`${componentCls}-item-right`]: {
[`${componentCls}-item-label`]: {
insetInlineStart: `calc(50% + ${token.marginSM}px)`,
width: `calc(50% - ${token.marginSM}px)`,
insetInlineStart: `calc(50% + ${unit(token.marginSM)})`,
width: `calc(50% - ${unit(token.marginSM)})`,
textAlign: 'start',
},
},
Expand All @@ -243,6 +252,14 @@ const genTimelineStyle: GenerateStyle<TimelineToken, CSSObject> = (token) => {
};

// ============================== Export ==============================
export const prepareComponentToken: GetDefaultToken<'Timeline'> = (token) => ({
tailColor: token.colorSplit,
tailWidth: token.lineWidthBold,
dotBorderWidth: token.wireframe ? token.lineWidthBold : token.lineWidth * 3,
dotBg: token.colorBgContainer,
itemPaddingBottom: token.padding * 1.25,
});

export default genComponentStyleHook(
'Timeline',
(token) => {
Expand All @@ -254,11 +271,5 @@ export default genComponentStyleHook(

return [genTimelineStyle(timeLineToken)];
},
(token) => ({
tailColor: token.colorSplit,
tailWidth: token.lineWidthBold,
dotBorderWidth: token.wireframe ? token.lineWidthBold : token.lineWidth * 3,
dotBg: token.colorBgContainer,
itemPaddingBottom: token.padding * 1.25,
}),
prepareComponentToken,
);

0 comments on commit ca25149

Please sign in to comment.