UNPKG

@nex-ui/react

Version:

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

64 lines (60 loc) • 1.91 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 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;