mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-11 22:58:33 +08:00
112 lines
3.0 KiB
TypeScript
112 lines
3.0 KiB
TypeScript
import type { CSSObject } from '@ant-design/cssinjs';
|
||
|
||
import type { FullToken, GenerateStyle } from '../../theme/internal';
|
||
import { genStyleHooks, mergeToken } from '../../theme/internal';
|
||
|
||
/** Component only token. Which will handle additional calculation of alias token */
|
||
// biome-ignore lint/suspicious/noEmptyInterface: ComponentToken need to be empty by default
|
||
export interface ComponentToken {}
|
||
|
||
/**
|
||
* @desc Empty 组件的 Token
|
||
* @descEN Token for Empty component
|
||
*/
|
||
interface EmptyToken extends FullToken<'Empty'> {
|
||
/**
|
||
* @desc 空状态图片类名
|
||
* @descEN Class name for empty state image
|
||
*/
|
||
emptyImgCls: string;
|
||
/**
|
||
* @desc 空状态图片高度
|
||
* @descEN Height of empty state image
|
||
*/
|
||
emptyImgHeight: number | string;
|
||
/**
|
||
* @desc 小号空状态图片高度
|
||
* @descEN Height of small empty state image
|
||
*/
|
||
emptyImgHeightSM: number | string;
|
||
/**
|
||
* @desc 中号空状态图片高度
|
||
* @descEN Height of medium empty state image
|
||
*/
|
||
emptyImgHeightMD: number | string;
|
||
}
|
||
|
||
// ============================== Shared ==============================
|
||
const genSharedEmptyStyle: GenerateStyle<EmptyToken> = (token): CSSObject => {
|
||
const { componentCls, margin, marginXS, marginXL, fontSize, lineHeight } = token;
|
||
|
||
return {
|
||
[componentCls]: {
|
||
marginInline: marginXS,
|
||
fontSize,
|
||
lineHeight,
|
||
textAlign: 'center',
|
||
|
||
// 原来 &-image 没有父子结构,现在为了外层承担我们的 hashId,改成父子结构
|
||
[`${componentCls}-image`]: {
|
||
height: token.emptyImgHeight,
|
||
marginBottom: marginXS,
|
||
opacity: token.opacityImage,
|
||
|
||
img: {
|
||
height: '100%',
|
||
},
|
||
|
||
svg: {
|
||
maxWidth: '100%',
|
||
height: '100%',
|
||
margin: 'auto',
|
||
},
|
||
},
|
||
|
||
[`${componentCls}-description`]: {
|
||
color: token.colorTextDescription,
|
||
},
|
||
|
||
// 原来 &-footer 没有父子结构,现在为了外层承担我们的 hashId,改成父子结构
|
||
[`${componentCls}-footer`]: {
|
||
marginTop: margin,
|
||
},
|
||
|
||
'&-normal': {
|
||
marginBlock: marginXL,
|
||
color: token.colorTextDescription,
|
||
|
||
[`${componentCls}-description`]: {
|
||
color: token.colorTextDescription,
|
||
},
|
||
|
||
[`${componentCls}-image`]: {
|
||
height: token.emptyImgHeightMD,
|
||
},
|
||
},
|
||
|
||
'&-small': {
|
||
marginBlock: marginXS,
|
||
color: token.colorTextDescription,
|
||
|
||
[`${componentCls}-image`]: {
|
||
height: token.emptyImgHeightSM,
|
||
},
|
||
},
|
||
},
|
||
};
|
||
};
|
||
|
||
// ============================== Export ==============================
|
||
export default genStyleHooks('Empty', (token) => {
|
||
const { componentCls, controlHeightLG, calc } = token;
|
||
|
||
const emptyToken: EmptyToken = mergeToken<EmptyToken>(token, {
|
||
emptyImgCls: `${componentCls}-img`,
|
||
emptyImgHeight: calc(controlHeightLG).mul(2.5).equal(),
|
||
emptyImgHeightMD: controlHeightLG,
|
||
emptyImgHeightSM: calc(controlHeightLG).mul(0.875).equal(),
|
||
});
|
||
|
||
return [genSharedEmptyStyle(emptyToken)];
|
||
});
|