@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
63 lines (60 loc) • 1.87 kB
JavaScript
"use client";
import { jsx } from 'react/jsx-runtime';
import { useMemo } from 'react';
import { useDialog } from './DialogContext.mjs';
import { useDefaultProps } from '../utils/useDefaultProps.mjs';
import { useStyles } from '../utils/useStyles.mjs';
import { useSlot } from '../utils/useSlot.mjs';
import { ModalBody } from '../modal/ModalBody.mjs';
import { useNexUI } from '../provider/Context.mjs';
import { composeClasses } from '../utils/composeClasses.mjs';
import { dialogBodyRecipe } from '../../theme/recipes/dialog.mjs';
import { getUtilityClass } from '../utils/getUtilityClass.mjs';
const useSlotClasses = ()=>{
const { prefix } = useNexUI();
return useMemo(()=>{
const prefixClassName = `${prefix}-dialog-body`;
const slots = {
root: [
'root'
]
};
return composeClasses(slots, getUtilityClass(prefixClassName));
}, [
prefix
]);
};
const DialogBody = (inProps)=>{
const { scroll } = useDialog();
const props = useDefaultProps({
name: 'DialogBody',
props: inProps
});
const { children, ...remainingProps } = props;
const ownerState = {
...props
};
const style = useStyles({
ownerState: {
...ownerState,
scroll
},
name: 'DialogBody',
recipe: dialogBodyRecipe
});
const classes = useSlotClasses();
const [DialogBodyRoot, getDialogBodyRootProps] = useSlot({
ownerState,
style,
elementType: ModalBody,
classNames: classes.root,
externalForwardedProps: remainingProps,
shouldForwardComponent: false
});
return /*#__PURE__*/ jsx(DialogBodyRoot, {
...getDialogBodyRootProps(),
children: children
});
};
DialogBody.displayName = 'DialogBody';
export { DialogBody };