@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
106 lines (102 loc) • 3.35 kB
JavaScript
"use client";
;
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;