mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-19 14:53:16 +08:00
119 lines
3.2 KiB
TypeScript
119 lines
3.2 KiB
TypeScript
// deps-lint-skip-all
|
|
import type { CSSObject } from '@ant-design/cssinjs';
|
|
import type { GenerateStyle, FullToken } from '../../_util/theme';
|
|
import { resetComponent, genComponentStyleHook, mergeToken } from '../../_util/theme';
|
|
|
|
/** Component only token. Which will handle additional calculation of alias token */
|
|
export interface ComponentToken {
|
|
zIndexPopup: number;
|
|
}
|
|
|
|
type BackTopToken = FullToken<'BackTop'> & {
|
|
backTopBackground: string;
|
|
backTopColor: string;
|
|
backTopHoverBackground: string;
|
|
backTopFontSize: number;
|
|
backTopSize: number;
|
|
|
|
// Position
|
|
backTopBlockEnd: number;
|
|
backTopInlineEnd: number;
|
|
backTopInlineEndMD: number;
|
|
backTopInlineEndXS: number;
|
|
};
|
|
|
|
// ============================== Shared ==============================
|
|
const genSharedBackTopStyle: GenerateStyle<BackTopToken, CSSObject> = (token): CSSObject => {
|
|
const { componentCls, backTopFontSize, backTopSize, zIndexPopup } = token;
|
|
|
|
return {
|
|
[componentCls]: {
|
|
...resetComponent(token),
|
|
|
|
position: 'fixed',
|
|
insetInlineEnd: token.backTopInlineEnd,
|
|
insetBlockEnd: token.backTopBlockEnd,
|
|
zIndex: zIndexPopup,
|
|
width: 40,
|
|
height: 40,
|
|
cursor: 'pointer',
|
|
|
|
'&:empty': {
|
|
display: 'none',
|
|
},
|
|
|
|
[`${componentCls}-content`]: {
|
|
width: backTopSize,
|
|
height: backTopSize,
|
|
overflow: 'hidden',
|
|
color: token.backTopColor,
|
|
textAlign: 'center',
|
|
backgroundColor: token.backTopBackground,
|
|
borderRadius: backTopSize,
|
|
transition: `all ${token.motionDurationSlow}`,
|
|
|
|
'&:hover': {
|
|
backgroundColor: token.backTopHoverBackground,
|
|
transition: `all ${token.motionDurationSlow}`,
|
|
},
|
|
},
|
|
|
|
// change to .backtop .backtop-icon
|
|
[`${componentCls}-icon`]: {
|
|
fontSize: backTopFontSize,
|
|
lineHeight: `${backTopSize}px`,
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
const genMediaBackTopStyle: GenerateStyle<BackTopToken> = (token): CSSObject => {
|
|
const { componentCls } = token;
|
|
|
|
return {
|
|
[`@media (max-width: ${token.screenMD}px)`]: {
|
|
[componentCls]: {
|
|
insetInlineEnd: token.backTopInlineEndMD,
|
|
},
|
|
},
|
|
|
|
[`@media (max-width: ${token.screenXS}px)`]: {
|
|
[componentCls]: {
|
|
insetInlineEnd: token.backTopInlineEndXS,
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
// ============================== Export ==============================
|
|
export default genComponentStyleHook<'BackTop'>(
|
|
'BackTop',
|
|
|
|
token => {
|
|
const {
|
|
fontSizeHeading3,
|
|
colorTextSecondary,
|
|
colorTextLightSolid,
|
|
colorText,
|
|
controlHeightLG,
|
|
} = token;
|
|
|
|
const backTopToken = mergeToken<BackTopToken>(token, {
|
|
backTopBackground: colorTextSecondary,
|
|
backTopColor: colorTextLightSolid,
|
|
backTopHoverBackground: colorText,
|
|
backTopFontSize: fontSizeHeading3,
|
|
backTopSize: controlHeightLG,
|
|
|
|
backTopBlockEnd: controlHeightLG * 1.25,
|
|
backTopInlineEnd: controlHeightLG * 2.5,
|
|
backTopInlineEndMD: controlHeightLG * 1.5,
|
|
backTopInlineEndXS: controlHeightLG * 0.5,
|
|
});
|
|
return [genSharedBackTopStyle(backTopToken), genMediaBackTopStyle(backTopToken)];
|
|
},
|
|
token => ({
|
|
zIndexPopup: token.zIndexBase + 10,
|
|
}),
|
|
);
|