mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-16 01:41:02 +08:00
bffdf0dee5
* feat: next-empty finish * fix: add comment and remove type Co-authored-by: zengguhao.zgh <zengguhao.zgh@alibaba-inc.com>
172 lines
3.5 KiB
TypeScript
172 lines
3.5 KiB
TypeScript
// deps-lint-skip-all
|
||
import { CSSObject } from '@ant-design/cssinjs';
|
||
import {
|
||
DerivativeToken,
|
||
useStyleRegister,
|
||
useToken,
|
||
UseComponentStyleResult,
|
||
GenerateStyle,
|
||
} from '../../_util/theme';
|
||
|
||
/** Component only token. Which will handle additional calculation of alias token */
|
||
export interface ComponentToken {}
|
||
|
||
interface EmptyToken extends DerivativeToken, ComponentToken {
|
||
emptyCls: string;
|
||
emptyImgCls: string;
|
||
|
||
emptyFontSize: number;
|
||
|
||
white: string;
|
||
}
|
||
|
||
const genEmptyImgStyle = (token: EmptyToken): CSSObject => {
|
||
const { emptyImgCls } = token;
|
||
const emptyImgDefaultCls = `${emptyImgCls}-default`;
|
||
const emptyImgSimpleCls = `${emptyImgCls}-simple`;
|
||
|
||
return {
|
||
// FIX ME have not theme
|
||
// just light, lost dark theme
|
||
[emptyImgDefaultCls]: {
|
||
'&-ellipse': {
|
||
fill: '#f5f5f5',
|
||
fillOpacity: '0.8',
|
||
},
|
||
|
||
'&-path': {
|
||
'&-1': {
|
||
fill: '#aeb8c2',
|
||
},
|
||
|
||
'&-2': {
|
||
fill: "url('#linearGradient-1')",
|
||
},
|
||
|
||
'&-3': {
|
||
fill: '#f5f5f7',
|
||
},
|
||
|
||
'&-4': {
|
||
fill: '#dce0e6',
|
||
},
|
||
|
||
'&-5': {
|
||
fill: '#dce0e6',
|
||
},
|
||
},
|
||
|
||
'&-g': {
|
||
// FIX ME @white
|
||
fill: token.white,
|
||
},
|
||
},
|
||
[emptyImgSimpleCls]: {
|
||
'&-ellipse': {
|
||
fill: '#f5f5f5',
|
||
},
|
||
|
||
'&-g': {
|
||
stroke: '#d9d9d9',
|
||
},
|
||
|
||
'&-path': {
|
||
fill: '#fafafa',
|
||
},
|
||
},
|
||
};
|
||
};
|
||
|
||
// ============================== Shared ==============================
|
||
const genSharedEmptyStyle: GenerateStyle<EmptyToken> = (token): CSSObject => {
|
||
const { emptyCls } = token;
|
||
|
||
return {
|
||
[emptyCls]: {
|
||
// FIX ME
|
||
margin: '0 8px',
|
||
// @empty-font-size
|
||
fontSize: token.emptyFontSize,
|
||
// '@line-height-base'
|
||
lineHeight: token.lineHeight,
|
||
textAlign: 'center',
|
||
|
||
// 原来 &-image 没有父子结构,现在为了外层承担我们的hashId,改成父子结果
|
||
[`${emptyCls}-image`]: {
|
||
// FIX ME
|
||
height: '100px',
|
||
// FIX ME
|
||
marginBottom: '8px',
|
||
|
||
img: {
|
||
height: '100%',
|
||
},
|
||
|
||
svg: {
|
||
height: '100%',
|
||
margin: 'auto',
|
||
},
|
||
},
|
||
|
||
// 原来 &-footer 没有父子结构,现在为了外层承担我们的hashId,改成父子结果
|
||
[`${emptyCls}-footer`]: {
|
||
// FIX ME
|
||
marginTop: '16px',
|
||
},
|
||
|
||
'&-normal': {
|
||
// FIX ME
|
||
margin: '32px 0',
|
||
// '@disabled-color'
|
||
color: token.colorTextDisabled,
|
||
|
||
[`${emptyCls}-image`]: {
|
||
// FIX ME
|
||
height: '40px',
|
||
},
|
||
},
|
||
|
||
'&-small': {
|
||
// FIX ME
|
||
margin: '8px 0',
|
||
color: '@disabled-color',
|
||
|
||
[`${emptyCls}-image`]: {
|
||
// FIX ME
|
||
height: '35px',
|
||
},
|
||
},
|
||
|
||
...genEmptyImgStyle(token),
|
||
},
|
||
};
|
||
};
|
||
|
||
// ============================== Export ==============================
|
||
export default function useStyle(prefixCls: string): UseComponentStyleResult {
|
||
const [theme, token, hashId] = useToken();
|
||
|
||
return [
|
||
useStyleRegister({ theme, token, hashId, path: [prefixCls] }, () => {
|
||
const { Empty } = token;
|
||
|
||
const emptyFontSize = token.fontSizeBase;
|
||
|
||
const emptyToken: EmptyToken = {
|
||
...token,
|
||
|
||
emptyCls: `.${prefixCls}`,
|
||
emptyImgCls: `.${prefixCls}-img`,
|
||
|
||
emptyFontSize,
|
||
white: '#fff',
|
||
|
||
...Empty,
|
||
};
|
||
|
||
return [genSharedEmptyStyle(emptyToken), genEmptyImgStyle(emptyToken)];
|
||
}),
|
||
hashId,
|
||
];
|
||
}
|