@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
64 lines (60 loc) • 1.91 kB
JavaScript
"use client";
;
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 divider = require('../../theme/recipes/divider.cjs');
var getUtilityClass = require('../utils/getUtilityClass.cjs');
const useSlotClasses = (ownerState)=>{
const { prefix } = Context.useNexUI();
return react.useMemo(()=>{
const dividerRoot = `${prefix}-divider`;
const { orientation } = ownerState;
const slots = {
root: [
'root',
orientation && `orientation-${orientation}`
]
};
return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(dividerRoot));
}, [
ownerState,
prefix
]);
};
const Divider = (inProps)=>{
const props = useDefaultProps.useDefaultProps({
name: 'Divider',
props: inProps
});
const { role = 'separator', orientation = 'horizontal', ...remainingProps } = props;
const ownerState = {
...props,
orientation
};
const classes = useSlotClasses(ownerState);
const style = useStyles.useStyles({
ownerState,
name: 'Divider',
recipe: divider.dividerRecipe
});
const [DividerRoot, getDividerRootProps] = useSlot.useSlot({
ownerState,
style,
elementType: 'hr',
externalForwardedProps: remainingProps,
classNames: classes.root,
a11y: {
role
}
});
return /*#__PURE__*/ jsxRuntime.jsx(DividerRoot, {
...getDividerRootProps()
});
};
Divider.displayName = 'Divider';
exports.Divider = Divider;