import classNames from 'classnames';
import React from 'react';

const justifyContentOptions = {
  between: 'justify-between',
  center: 'justify-center',
  start: 'justify-start',
  end: 'justify-end',
};

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?: 'top' | 'bottom' | 'center' | 'start',
  /** Extra class names on the <div> element. */
  className?: string,
  /** Horizontal alignment of children. */
  justifyContent?: 'between' | 'center' | 'start' | 'end',
  /** Size of the gap between elements. */
  space?: 0.5 | 1 | 1.5 | 2 | 3 | 4 | 6 | 8,
  /** Whether to let the flexbox grow. */
  grow?: boolean,
  /** Extra CSS styles for the <div> */
  style?: React.CSSProperties
}

/** Horizontal row of child elements. */
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;