UNPKG

@nex-ui/react

Version:

🎉 A beautiful, modern, and reliable React component library.

69 lines (65 loc) • 1.97 kB
"use client"; 'use strict'; var jsxRuntime = require('react/jsx-runtime'); var react = require('react'); var useDefaultProps = require('../utils/useDefaultProps.cjs'); var useStyles = require('../utils/useStyles.cjs'); var useSlot = require('../utils/useSlot.cjs'); var Context = require('../provider/Context.cjs'); var composeClasses = require('../utils/composeClasses.cjs'); var flex = require('../../theme/recipes/flex.cjs'); var getUtilityClass = require('../utils/getUtilityClass.cjs'); const useSlotClasses = ()=>{ const { prefix } = Context.useNexUI(); return react.useMemo(()=>{ const flexRoot = `${prefix}-flex`; const slots = { root: [ 'root' ] }; return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(flexRoot)); }, [ prefix ]); }; const Flex = (inProps)=>{ const props = useDefaultProps.useDefaultProps({ name: 'Flex', props: inProps }); const { gap, children, justify, align, wrap, direction = 'row', inline = false, ...remainingProps } = props; const ownerState = { ...props, direction, inline }; const classes = useSlotClasses(); const style = useStyles.useStyles({ ownerState, name: 'Flex', recipe: flex.flexRecipe }); const [FlexRoot, getFlexRootProps] = useSlot.useSlot({ style, ownerState, elementType: 'div', externalForwardedProps: remainingProps, classNames: classes.root, additionalProps: { sx: { gap, flexDirection: direction, alignItems: align, justifyContent: justify, flexWrap: wrap } } }); return /*#__PURE__*/ jsxRuntime.jsx(FlexRoot, { ...getFlexRootProps(), children: children }); }; Flex.displayName = 'Flex'; exports.Flex = Flex;