2022-05-09 22:20:07 +08:00
|
|
|
import type { CSSObject } from '@ant-design/cssinjs';
|
2023-05-19 18:26:31 +08:00
|
|
|
import { resetComponent, textEllipsis } from '../../style';
|
2022-11-23 20:22:38 +08:00
|
|
|
import type { FullToken, GenerateStyle } from '../../theme/internal';
|
|
|
|
import { genComponentStyleHook, mergeToken } from '../../theme/internal';
|
2019-03-10 21:04:38 +08:00
|
|
|
|
2023-05-19 18:26:31 +08:00
|
|
|
export interface ComponentToken {
|
2023-07-05 17:49:59 +08:00
|
|
|
/**
|
|
|
|
* @desc 链接横向内间距
|
|
|
|
* @descEN Link horizontal padding
|
|
|
|
*/
|
2023-05-19 18:26:31 +08:00
|
|
|
linkPaddingBlock: number;
|
2023-07-05 17:49:59 +08:00
|
|
|
/**
|
|
|
|
* @desc 链接纵向内间距
|
|
|
|
* @descEN Link vertical padding
|
|
|
|
*/
|
2023-05-19 18:26:31 +08:00
|
|
|
linkPaddingInlineStart: number;
|
|
|
|
}
|
2022-05-17 18:04:24 +08:00
|
|
|
|
2022-04-29 17:23:23 +08:00
|
|
|
interface AnchorToken extends FullToken<'Anchor'> {
|
2022-05-17 18:04:24 +08:00
|
|
|
holderOffsetBlock: number;
|
|
|
|
anchorPaddingBlockSecondary: number;
|
|
|
|
anchorBallSize: number;
|
|
|
|
anchorTitleBlock: number;
|
2022-04-29 17:23:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// ============================== Shared ==============================
|
|
|
|
const genSharedAnchorStyle: GenerateStyle<AnchorToken> = (token): CSSObject => {
|
2022-12-27 17:14:35 +08:00
|
|
|
const {
|
|
|
|
componentCls,
|
|
|
|
holderOffsetBlock,
|
|
|
|
motionDurationSlow,
|
|
|
|
lineWidthBold,
|
|
|
|
colorPrimary,
|
|
|
|
lineType,
|
|
|
|
colorSplit,
|
|
|
|
} = token;
|
2022-04-29 17:23:23 +08:00
|
|
|
|
|
|
|
return {
|
|
|
|
[`${componentCls}-wrapper`]: {
|
2022-05-17 18:04:24 +08:00
|
|
|
marginBlockStart: -holderOffsetBlock,
|
|
|
|
paddingBlockStart: holderOffsetBlock,
|
2022-04-29 17:23:23 +08:00
|
|
|
|
|
|
|
// delete overflow: auto
|
|
|
|
// overflow: 'auto',
|
|
|
|
|
|
|
|
[componentCls]: {
|
|
|
|
...resetComponent(token),
|
|
|
|
position: 'relative',
|
2022-05-17 18:04:24 +08:00
|
|
|
paddingInlineStart: lineWidthBold,
|
2022-04-29 17:23:23 +08:00
|
|
|
|
|
|
|
[`${componentCls}-link`]: {
|
2023-05-19 18:26:31 +08:00
|
|
|
paddingBlock: token.linkPaddingBlock,
|
|
|
|
paddingInline: `${token.linkPaddingInlineStart}px 0`,
|
2022-04-29 17:23:23 +08:00
|
|
|
|
|
|
|
'&-title': {
|
2022-10-28 16:44:19 +08:00
|
|
|
...textEllipsis,
|
2022-04-29 17:23:23 +08:00
|
|
|
position: 'relative',
|
|
|
|
display: 'block',
|
2022-05-17 18:04:24 +08:00
|
|
|
marginBlockEnd: token.anchorTitleBlock,
|
2022-04-29 17:23:23 +08:00
|
|
|
color: token.colorText,
|
2022-05-17 18:04:24 +08:00
|
|
|
transition: `all ${token.motionDurationSlow}`,
|
2022-04-29 17:23:23 +08:00
|
|
|
|
|
|
|
'&:only-child': {
|
|
|
|
marginBlockEnd: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
[`&-active > ${componentCls}-link-title`]: {
|
|
|
|
color: token.colorPrimary,
|
|
|
|
},
|
|
|
|
|
|
|
|
// link link
|
|
|
|
[`${componentCls}-link`]: {
|
2022-05-17 18:04:24 +08:00
|
|
|
paddingBlock: token.anchorPaddingBlockSecondary,
|
2022-04-29 17:23:23 +08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
2023-03-19 23:28:34 +08:00
|
|
|
[`&:not(${componentCls}-wrapper-horizontal)`]: {
|
2022-12-27 17:14:35 +08:00
|
|
|
[componentCls]: {
|
|
|
|
'&::before': {
|
|
|
|
position: 'absolute',
|
2023-05-30 10:37:17 +08:00
|
|
|
insetInlineStart: 0,
|
2022-12-27 17:14:35 +08:00
|
|
|
top: 0,
|
|
|
|
height: '100%',
|
|
|
|
borderInlineStart: `${lineWidthBold}px ${lineType} ${colorSplit}`,
|
|
|
|
content: '" "',
|
|
|
|
},
|
|
|
|
|
|
|
|
[`${componentCls}-ink`]: {
|
|
|
|
position: 'absolute',
|
2023-05-30 10:37:17 +08:00
|
|
|
insetInlineStart: 0,
|
2022-12-27 17:14:35 +08:00
|
|
|
display: 'none',
|
|
|
|
transform: 'translateY(-50%)',
|
|
|
|
transition: `top ${motionDurationSlow} ease-in-out`,
|
|
|
|
width: lineWidthBold,
|
|
|
|
backgroundColor: colorPrimary,
|
|
|
|
|
|
|
|
[`&${componentCls}-ink-visible`]: {
|
|
|
|
display: 'inline-block',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
[`${componentCls}-fixed ${componentCls}-ink ${componentCls}-ink`]: {
|
2022-04-29 17:23:23 +08:00
|
|
|
display: 'none',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-12-27 17:14:35 +08:00
|
|
|
const genSharedAnchorHorizontalStyle: GenerateStyle<AnchorToken> = (token): CSSObject => {
|
|
|
|
const { componentCls, motionDurationSlow, lineWidthBold, colorPrimary } = token;
|
|
|
|
|
|
|
|
return {
|
|
|
|
[`${componentCls}-wrapper-horizontal`]: {
|
|
|
|
position: 'relative',
|
|
|
|
|
|
|
|
'&::before': {
|
|
|
|
position: 'absolute',
|
|
|
|
left: {
|
|
|
|
_skip_check_: true,
|
|
|
|
value: 0,
|
|
|
|
},
|
|
|
|
right: {
|
|
|
|
_skip_check_: true,
|
|
|
|
value: 0,
|
|
|
|
},
|
|
|
|
bottom: 0,
|
|
|
|
borderBottom: `1px ${token.lineType} ${token.colorSplit}`,
|
|
|
|
content: '" "',
|
|
|
|
},
|
|
|
|
|
|
|
|
[componentCls]: {
|
|
|
|
overflowX: 'scroll',
|
|
|
|
position: 'relative',
|
|
|
|
display: 'flex',
|
|
|
|
scrollbarWidth: 'none' /* Firefox */,
|
|
|
|
|
|
|
|
'&::-webkit-scrollbar': {
|
|
|
|
display: 'none' /* Safari and Chrome */,
|
|
|
|
},
|
|
|
|
|
|
|
|
[`${componentCls}-link:first-of-type`]: {
|
|
|
|
paddingInline: 0,
|
|
|
|
},
|
|
|
|
|
|
|
|
[`${componentCls}-ink`]: {
|
|
|
|
position: 'absolute',
|
|
|
|
bottom: 0,
|
|
|
|
transition: `left ${motionDurationSlow} ease-in-out, width ${motionDurationSlow} ease-in-out`,
|
|
|
|
height: lineWidthBold,
|
|
|
|
backgroundColor: colorPrimary,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-04-29 17:23:23 +08:00
|
|
|
// ============================== Export ==============================
|
2023-05-19 18:26:31 +08:00
|
|
|
export default genComponentStyleHook(
|
|
|
|
'Anchor',
|
|
|
|
(token) => {
|
|
|
|
const { fontSize, fontSizeLG, paddingXXS } = token;
|
|
|
|
|
|
|
|
const anchorToken = mergeToken<AnchorToken>(token, {
|
|
|
|
holderOffsetBlock: paddingXXS,
|
|
|
|
anchorPaddingBlockSecondary: paddingXXS / 2,
|
|
|
|
anchorTitleBlock: (fontSize / 14) * 3,
|
|
|
|
anchorBallSize: fontSizeLG / 2,
|
|
|
|
});
|
|
|
|
return [genSharedAnchorStyle(anchorToken), genSharedAnchorHorizontalStyle(anchorToken)];
|
|
|
|
},
|
|
|
|
(token) => ({
|
|
|
|
linkPaddingBlock: token.paddingXXS,
|
|
|
|
linkPaddingInlineStart: token.padding,
|
|
|
|
}),
|
|
|
|
);
|