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', stretch: 'items-stretch', }; const spaces = { [0.5]: 'space-x-0.5', 1: 'space-x-1', 1.5: 'space-x-1.5', 2: 'space-x-2', 2.5: 'space-x-2.5', 3: 'space-x-3', 4: 'space-x-4', 5: 'space-x-5', 6: 'space-x-6', 8: 'space-x-8', }; interface IHStack extends Pick, 'onClick'> { /** 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 /** HTML element to use for container. */ element?: keyof JSX.IntrinsicElements, /** 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, justifyContent, className, grow, element = 'div', wrap, ...filteredProps } = props; const Elem = element as 'div'; return ( ); }); export default HStack;