@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
154 lines (151 loc) • 4.92 kB
JavaScript
"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 };