soapbox/app/soapbox/components/ui/hstack/hstack.tsx

55 wiersze
1.2 KiB
TypeScript

import classNames from 'classnames';
import React from 'react';
const justifyContentOptions = {
between: 'justify-between',
center: 'justify-center',
};
const alignItemsOptions = {
top: 'items-start',
bottom: 'items-end',
center: 'items-center',
start: 'items-start',
};
const spaces = {
'0.5': 'space-x-0.5',
1: 'space-x-1',
1.5: 'space-x-1.5',
2: 'space-x-2',
3: 'space-x-3',
4: 'space-x-4',
6: 'space-x-6',
};
interface IHStack {
alignItems?: 'top' | 'bottom' | 'center' | 'start',
className?: string,
justifyContent?: 'between' | 'center',
space?: 0.5 | 1 | 1.5 | 2 | 3 | 4 | 6,
grow?: boolean,
style?: React.CSSProperties
}
const HStack: React.FC<IHStack> = (props) => {
const { space, alignItems, grow, justifyContent, className, ...filteredProps } = props;
return (
<div
{...filteredProps}
className={classNames('flex', {
// @ts-ignore
[alignItemsOptions[alignItems]]: typeof alignItems !== 'undefined',
// @ts-ignore
[justifyContentOptions[justifyContent]]: typeof justifyContent !== 'undefined',
// @ts-ignore
[spaces[space]]: typeof space !== 'undefined',
'flex-grow': grow,
}, className)}
/>
);
};
export default HStack;