UNPKG

@nex-ui/react

Version:

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

154 lines (151 loc) • 4.92 kB
"use client"; import { jsxs, jsx } from 'react/jsx-runtime'; import { useMemo, useId } from 'react'; import { useControlledState } from '@nex-ui/hooks'; import { isString } from '@nex-ui/utils'; import { CheckboxGroupProvider } from './CheckboxGroupContext.mjs'; 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 { checkboxGroupRecipe } from '../../theme/recipes/checkbox.mjs'; import { getUtilityClass } from '../utils/getUtilityClass.mjs'; const useSlotClasses = (ownerState)=>{ const { prefix } = useNexUI(); const { orientation, classes } = ownerState; return useMemo(()=>{ const dividerRoot = `${prefix}-checkbox-group`; const slots = { root: [ 'root', `orientation-${orientation}` ], label: [ 'label' ], wrapper: [ 'wrapper' ] }; return composeClasses(slots, getUtilityClass(dividerRoot), classes); }, [ prefix, orientation, classes ]); }; const useSlotAriaProps = (ownerState)=>{ const id = useId(); const { slotProps, label, role = 'group', 'aria-labelledby': labelledBy } = ownerState; const stringLabel = isString(label); const labelId = slotProps?.label?.id || (stringLabel ? id : undefined); return useMemo(()=>({ root: { role, 'aria-labelledby': labelledBy ?? labelId }, label: { id: labelId } }), [ role, labelledBy, labelId ]); }; const CheckboxGroup = (inProps)=>{ const props = useDefaultProps({ name: 'CheckboxGroup', props: inProps }); const { name, children, disabled, slotProps, onValueChange, color, radius, value, label, size, orientation = 'horizontal', defaultValue = [], ...remainingProps } = props; const [values, setValues] = useControlledState(value, defaultValue, onValueChange); const ownerState = { ...props, orientation, value: values }; const classes = useSlotClasses(ownerState); const slotAriaProps = useSlotAriaProps(ownerState); const styles = useStyles({ name: 'CheckboxGroup', ownerState, recipe: checkboxGroupRecipe }); const [CheckboxGroupRoot, getCheckboxGroupRootProps] = useSlot({ ownerState, elementType: 'div', style: styles.root, classNames: classes.root, externalForwardedProps: remainingProps, a11y: slotAriaProps.root }); const [CheckboxGroupLabel, getCheckboxGroupLabelProps] = useSlot({ ownerState, elementType: 'h3', classNames: classes.label, style: styles.label, externalSlotProps: slotProps?.label, a11y: slotAriaProps.label }); const [CheckboxGroupWrapper, getCheckboxGroupWrapperProps] = useSlot({ ownerState, elementType: 'div', classNames: classes.wrapper, style: styles.wrapper, externalSlotProps: slotProps?.wrapper }); const ctx = useMemo(()=>({ disabled, name, size, color, radius, toggleValue: (value)=>{ // istanbul ignore next if (disabled) { return; } let newValues; if (values.includes(value)) { newValues = values.filter((existingValue)=>existingValue !== value); } else { newValues = [ ...values, value ]; } setValues(newValues); }, isChecked: (value)=>{ return value !== undefined ? values.includes(value) : false; } }), [ color, disabled, name, radius, setValues, size, values ]); return /*#__PURE__*/ jsxs(CheckboxGroupRoot, { ...getCheckboxGroupRootProps(), children: [ label ? /*#__PURE__*/ jsx(CheckboxGroupLabel, { ...getCheckboxGroupLabelProps(), children: label }) : null, /*#__PURE__*/ jsx(CheckboxGroupWrapper, { ...getCheckboxGroupWrapperProps(), children: /*#__PURE__*/ jsx(CheckboxGroupProvider, { value: ctx, children: children }) }) ] }); }; CheckboxGroup.displayName = 'CheckboxGroup'; export { CheckboxGroup };