69 lines
1.6 KiB
TypeScript
69 lines
1.6 KiB
TypeScript
import classNames from '../_util/classNames';
|
|
|
|
import type { FlexProps } from './interface';
|
|
|
|
export const flexWrapValues = ['wrap', 'nowrap', 'wrap-reverse'] as const;
|
|
|
|
export const justifyContentValues = [
|
|
'flex-start',
|
|
'flex-end',
|
|
'start',
|
|
'end',
|
|
'center',
|
|
'space-between',
|
|
'space-around',
|
|
'space-evenly',
|
|
'stretch',
|
|
'normal',
|
|
'left',
|
|
'right',
|
|
] as const;
|
|
|
|
export const alignItemsValues = [
|
|
'center',
|
|
'start',
|
|
'end',
|
|
'flex-start',
|
|
'flex-end',
|
|
'self-start',
|
|
'self-end',
|
|
'baseline',
|
|
'normal',
|
|
'stretch',
|
|
] as const;
|
|
|
|
const genClsWrap = (prefixCls: string, props: FlexProps) => {
|
|
const wrapCls: Record<PropertyKey, boolean> = {};
|
|
flexWrapValues.forEach(cssKey => {
|
|
wrapCls[`${prefixCls}-wrap-${cssKey}`] = props.wrap === cssKey;
|
|
});
|
|
return wrapCls;
|
|
};
|
|
|
|
const genClsAlign = (prefixCls: string, props: FlexProps) => {
|
|
const alignCls: Record<PropertyKey, boolean> = {};
|
|
alignItemsValues.forEach(cssKey => {
|
|
alignCls[`${prefixCls}-align-${cssKey}`] = props.align === cssKey;
|
|
});
|
|
alignCls[`${prefixCls}-align-stretch`] = !props.align && !!props.vertical;
|
|
return alignCls;
|
|
};
|
|
|
|
const genClsJustify = (prefixCls: string, props: FlexProps) => {
|
|
const justifyCls: Record<PropertyKey, boolean> = {};
|
|
justifyContentValues.forEach(cssKey => {
|
|
justifyCls[`${prefixCls}-justify-${cssKey}`] = props.justify === cssKey;
|
|
});
|
|
return justifyCls;
|
|
};
|
|
|
|
function createFlexClassNames(prefixCls: string, props: FlexProps) {
|
|
return classNames({
|
|
...genClsWrap(prefixCls, props),
|
|
...genClsAlign(prefixCls, props),
|
|
...genClsJustify(prefixCls, props),
|
|
});
|
|
}
|
|
|
|
export default createFlexClassNames;
|