2022-06-27 14:25:59 +08:00
|
|
|
import type { FullToken, GenerateStyle } from '../../theme';
|
|
|
|
import { genComponentStyleHook } from '../../theme';
|
2022-05-04 22:00:39 +08:00
|
|
|
|
|
|
|
/** Component only token. Which will handle additional calculation of alias token */
|
|
|
|
export interface ComponentToken {
|
|
|
|
// Component token here
|
|
|
|
}
|
|
|
|
|
|
|
|
interface SpaceToken extends FullToken<'Space'> {
|
|
|
|
// Custom token here
|
|
|
|
}
|
|
|
|
|
|
|
|
const genSpaceStyle: GenerateStyle<SpaceToken> = token => {
|
|
|
|
const { componentCls } = token;
|
|
|
|
|
|
|
|
return {
|
|
|
|
[componentCls]: {
|
|
|
|
display: 'inline-flex',
|
|
|
|
'&-rtl': {
|
|
|
|
direction: 'rtl',
|
|
|
|
},
|
|
|
|
'&-vertical': {
|
|
|
|
flexDirection: 'column',
|
|
|
|
},
|
|
|
|
'&-align': {
|
|
|
|
flexDirection: 'column',
|
|
|
|
'&-center': {
|
|
|
|
alignItems: 'center',
|
|
|
|
},
|
|
|
|
'&-start': {
|
|
|
|
alignItems: 'flex-start',
|
|
|
|
},
|
|
|
|
'&-end': {
|
|
|
|
alignItems: 'flex-end',
|
|
|
|
},
|
|
|
|
'&-baseline': {
|
|
|
|
alignItems: 'flex-baseline',
|
|
|
|
},
|
2022-07-19 17:51:35 +08:00
|
|
|
'&-stretch': {
|
|
|
|
alignItems: 'stretch',
|
|
|
|
},
|
2022-05-04 22:00:39 +08:00
|
|
|
},
|
|
|
|
[`${componentCls}-space-item`]: {
|
|
|
|
'&:empty': {
|
|
|
|
display: 'none',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
// ============================== Export ==============================
|
|
|
|
export default genComponentStyleHook('Space', token => [genSpaceStyle(token)]);
|