mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-11 23:00:20 +08:00
172 lines
3.8 KiB
TypeScript
172 lines
3.8 KiB
TypeScript
// deps-lint-skip-all
|
|
import type { CSSObject } from '@ant-design/cssinjs';
|
|
import type { FullToken, GenerateStyle } from '../../theme';
|
|
import { genComponentStyleHook, mergeToken, resetComponent } from '../../theme';
|
|
|
|
export interface ComponentToken {}
|
|
|
|
type AvatarToken = FullToken<'Avatar'> & {
|
|
avatarBg: string;
|
|
avatarColor: string;
|
|
avatarSizeBase: number;
|
|
avatarSizeLG: number;
|
|
avatarSizeSM: number;
|
|
avatarFontSizeBase: number;
|
|
avatarFontSizeLG: number;
|
|
avatarFontSizeSM: number;
|
|
avatarBorderRadius: number;
|
|
avatarGroupOverlapping: number;
|
|
avatarGroupSpace: number;
|
|
avatarGroupBorderColor: string;
|
|
avatarBgColor: string;
|
|
};
|
|
|
|
const genBaseStyle: GenerateStyle<AvatarToken> = token => {
|
|
const {
|
|
antCls,
|
|
componentCls,
|
|
iconCls,
|
|
avatarBg,
|
|
avatarColor,
|
|
avatarSizeBase,
|
|
avatarSizeLG,
|
|
avatarSizeSM,
|
|
avatarFontSizeBase,
|
|
avatarFontSizeLG,
|
|
avatarFontSizeSM,
|
|
avatarBorderRadius,
|
|
lineWidth,
|
|
lineType,
|
|
} = token;
|
|
|
|
// Avatar size style
|
|
const avatarSizeStyle = (size: number, fontSize: number): CSSObject => ({
|
|
width: size,
|
|
height: size,
|
|
lineHeight: `${size - lineWidth * 2}px`,
|
|
borderRadius: '50%',
|
|
|
|
[`${componentCls}-string`]: {
|
|
position: 'absolute',
|
|
left: {
|
|
_skip_check_: true,
|
|
value: '50%',
|
|
},
|
|
transformOrigin: '0 center',
|
|
},
|
|
|
|
[`&${componentCls}-icon`]: {
|
|
fontSize,
|
|
[`> ${iconCls}`]: {
|
|
margin: 0,
|
|
},
|
|
},
|
|
});
|
|
|
|
return {
|
|
[componentCls]: {
|
|
...resetComponent(token),
|
|
position: 'relative',
|
|
display: 'inline-block',
|
|
overflow: 'hidden',
|
|
color: avatarColor,
|
|
whiteSpace: 'nowrap',
|
|
textAlign: 'center',
|
|
verticalAlign: 'middle',
|
|
background: avatarBg,
|
|
border: `${lineWidth}px ${lineType} transparent`,
|
|
|
|
[`&-image`]: {
|
|
background: 'transparent',
|
|
},
|
|
|
|
[`${antCls}-image-img`]: {
|
|
display: 'block',
|
|
},
|
|
|
|
...avatarSizeStyle(avatarSizeBase, avatarFontSizeBase),
|
|
|
|
[`&-lg`]: {
|
|
...avatarSizeStyle(avatarSizeLG, avatarFontSizeLG),
|
|
},
|
|
|
|
[`&-sm`]: {
|
|
...avatarSizeStyle(avatarSizeSM, avatarFontSizeSM),
|
|
},
|
|
|
|
[`&-square`]: {
|
|
borderRadius: avatarBorderRadius,
|
|
},
|
|
|
|
'> img': {
|
|
display: 'block',
|
|
width: '100%',
|
|
height: '100%',
|
|
objectFit: 'cover',
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
const genGroupStyle: GenerateStyle<AvatarToken> = token => {
|
|
const { componentCls, avatarGroupBorderColor, avatarGroupOverlapping, avatarGroupSpace } = token;
|
|
|
|
return {
|
|
[`${componentCls}-group`]: {
|
|
display: 'inline-flex',
|
|
|
|
[`${componentCls}`]: {
|
|
borderColor: avatarGroupBorderColor,
|
|
|
|
[`&:not(:first-child)`]: {
|
|
marginInlineStart: -avatarGroupOverlapping,
|
|
},
|
|
},
|
|
|
|
[`&-popover`]: {
|
|
[`${componentCls} + ${componentCls}`]: {
|
|
marginInlineStart: avatarGroupSpace,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
export default genComponentStyleHook('Avatar', token => {
|
|
const {
|
|
colorTextLightSolid,
|
|
|
|
controlHeight,
|
|
controlHeightLG,
|
|
controlHeightSM,
|
|
|
|
fontSize,
|
|
fontSizeLG,
|
|
fontSizeXL,
|
|
fontSizeHeading3,
|
|
|
|
marginXS,
|
|
colorBorderBg,
|
|
colorTextPlaceholder,
|
|
} = token;
|
|
|
|
const avatarToken = mergeToken<AvatarToken>(token, {
|
|
avatarBg: colorTextPlaceholder,
|
|
avatarColor: colorTextLightSolid,
|
|
|
|
avatarSizeBase: controlHeight,
|
|
avatarSizeLG: controlHeightLG,
|
|
avatarSizeSM: controlHeightSM,
|
|
|
|
avatarFontSizeBase: Math.round((fontSizeLG + fontSizeXL) / 2),
|
|
avatarFontSizeLG: fontSizeHeading3,
|
|
avatarFontSizeSM: fontSize,
|
|
avatarBorderRadius: token.radiusBase,
|
|
avatarGroupOverlapping: marginXS,
|
|
avatarGroupSpace: marginXS,
|
|
avatarGroupBorderColor: colorBorderBg,
|
|
});
|
|
|
|
return [genBaseStyle(avatarToken), genGroupStyle(avatarToken)];
|
|
});
|