UNPKG

@nex-ui/react

Version:

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

106 lines (102 loc) • 3.35 kB
"use client"; 'use strict'; var jsxRuntime = require('react/jsx-runtime'); var react = require('react'); var hooks = require('@nex-ui/hooks'); var CheckboxGroupContext = require('./CheckboxGroupContext.cjs'); 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 checkbox = require('../../theme/recipes/checkbox.cjs'); var getUtilityClass = require('../utils/getUtilityClass.cjs'); const useSlotClasses = (ownerState)=>{ const { prefix } = Context.useNexUI(); const { orientation } = ownerState; return react.useMemo(()=>{ const dividerRoot = `${prefix}-checkbox-group`; const slots = { root: [ 'root', orientation ] }; return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(dividerRoot)); }, [ prefix, orientation ]); }; const CheckboxGroup = (inProps)=>{ const props = useDefaultProps.useDefaultProps({ name: 'CheckboxGroup', props: inProps }); const { name, children, disabled, onValueChange, size, color, radius, value, role = 'group', orientation = 'horizontal', defaultValue = [], ...remainingProps } = props; const [values, setValues] = hooks.useControlledState(value, defaultValue, onValueChange); const ownerState = { ...props, orientation, value: values }; const classes = useSlotClasses(ownerState); const styles = useStyles.useStyles({ name: 'CheckboxGroup', ownerState, recipe: checkbox.checkboxGroupRecipe }); const [CheckboxGroupRoot, getCheckboxGroupRootProps] = useSlot.useSlot({ ownerState, elementType: 'div', style: styles, classNames: classes.root, externalForwardedProps: remainingProps, a11y: { role } }); const ctx = react.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 ? values.includes(value) : false; } }), [ color, disabled, name, radius, setValues, size, values ]); return /*#__PURE__*/ jsxRuntime.jsx(CheckboxGroupRoot, { ...getCheckboxGroupRootProps(), children: /*#__PURE__*/ jsxRuntime.jsx(CheckboxGroupContext.CheckboxGroupProvider, { value: ctx, children: children }) }); }; CheckboxGroup.displayName = 'CheckboxGroup'; exports.CheckboxGroup = CheckboxGroup;