import React from 'react' import classnames from 'classnames' import { buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { GlobalProps, globalProps } from '../utilities/globalProps' import { Sizes } from '../types' type FlexProps = { children: React.ReactChild[] | React.ReactNode, className?: string, data?: object, horizontal?: "left" | "center" | "right" | "stretch" | "none", justify?: "start" | "center" | "end" | "around" | "between" | "evenly" | "none", htmlOptions?: {[key: string]: string | number | boolean | Function}, id?: string, inline?: boolean, orientation?: "row" | "column", spacing?: "around" | "between" | "evenly" | "none", reverse?: boolean, vertical?: "top" | "center" | "bottom" | "stretch" | "baseline" | "none", align?: "start" | "center" | "end" | "stretch" | "baseline" | "none", gap?: Sizes | "none", rowGap?: Sizes| "none", columnGap?: Sizes| "none", wrap?: boolean, alignSelf?: "start" | "end" | "center" | "stretch" | "none" } & GlobalProps const Flex = (props: FlexProps) => { const { align = 'none', children, className, data = {}, inline = false, horizontal = 'left', htmlOptions = {}, justify = 'none', orientation = 'row', spacing = 'none', gap = 'none', rowGap = 'none', columnGap = 'none', reverse = false, vertical = 'top', wrap = false, alignSelf = 'none', } = props const orientationClass = orientation !== undefined ? `orientation_${orientation}` : '' const justifyClass = justify !== 'none' ? `justify_content_${justify}` : `justify_content_${horizontal}` const alignClass = align !== 'none' ? `align_items_${align}` : `align_items_${vertical}` const inlineClass = inline === true ? 'inline' : '' const spacingClass = spacing !== undefined ? `spacing_${spacing}` : '' const gapClass = gap !== 'none' ? `gap_${gap}` : '' const rowGapClass = rowGap !== 'none' ? `rowGap_${rowGap}` : '' const columnGapClass = columnGap !== 'none' ? `columnGap_${columnGap}` : '' const wrapClass = wrap === true ? 'wrap' : '' const reverseClass = reverse === true ? 'reverse' : '' const alignSelfClass = alignSelf !== 'none' ? `align_self_${alignSelf}` : '' const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) return (