@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
69 lines (65 loc) • 1.97 kB
JavaScript
"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;