import classNames from 'clsx';
import React, { forwardRef } from 'react';
const justifyContentOptions = {
between: 'justify-between',
center: 'justify-center',
start: 'justify-start',
end: 'justify-end',
around: 'justify-around',
};
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',
8: 'space-x-8',
};
interface IHStack {
/** Vertical alignment of children. */
alignItems?: keyof typeof alignItemsOptions
/** Extra class names on the
element. */
className?: string
/** Children */
children?: React.ReactNode
/** Horizontal alignment of children. */
justifyContent?: keyof typeof justifyContentOptions
/** Size of the gap between elements. */
space?: keyof typeof spaces
/** Whether to let the flexbox grow. */
grow?: boolean
/** Extra CSS styles for the
*/
style?: React.CSSProperties
/** Whether to let the flexbox wrap onto multiple lines. */
wrap?: boolean
}
/** Horizontal row of child elements. */
const HStack = forwardRef
((props, ref) => {
const { space, alignItems, grow, justifyContent, wrap, className, ...filteredProps } = props;
return (
);
});
export default HStack;