UNPKG

@nex-ui/react

Version:

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

62 lines (59 loc) • 1.8 kB
"use client"; import { jsx } from 'react/jsx-runtime'; import { useMemo } from 'react'; import { useDefaultProps } from '../utils/useDefaultProps.mjs'; import { useStyles } from '../utils/useStyles.mjs'; import { useSlot } from '../utils/useSlot.mjs'; import { useNexUI } from '../provider/Context.mjs'; import { composeClasses } from '../utils/composeClasses.mjs'; import { dividerRecipe } from '../../theme/recipes/divider.mjs'; import { getUtilityClass } from '../utils/getUtilityClass.mjs'; const useSlotClasses = (ownerState)=>{ const { prefix } = useNexUI(); return useMemo(()=>{ const dividerRoot = `${prefix}-divider`; const { orientation } = ownerState; const slots = { root: [ 'root', orientation && `orientation-${orientation}` ] }; return composeClasses(slots, getUtilityClass(dividerRoot)); }, [ ownerState, prefix ]); }; const Divider = (inProps)=>{ const props = useDefaultProps({ name: 'Divider', props: inProps }); const { role = 'separator', orientation = 'horizontal', ...remainingProps } = props; const ownerState = { ...props, orientation }; const classes = useSlotClasses(ownerState); const style = useStyles({ ownerState, name: 'Divider', recipe: dividerRecipe }); const [DividerRoot, getDividerRootProps] = useSlot({ ownerState, style, elementType: 'hr', externalForwardedProps: remainingProps, classNames: classes.root, a11y: { role } }); return /*#__PURE__*/ jsx(DividerRoot, { ...getDividerRootProps() }); }; Divider.displayName = 'Divider'; export { Divider };