@yamada-ui/radio
Version:
Yamada UI radio component
350 lines (346 loc) • 11.2 kB
JavaScript
"use client"
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/radio.tsx
var radio_exports = {};
__export(radio_exports, {
Radio: () => Radio
});
module.exports = __toCommonJS(radio_exports);
var import_core = require("@yamada-ui/core");
var import_form_control2 = require("@yamada-ui/form-control");
var import_utils3 = require("@yamada-ui/utils");
var import_react2 = require("react");
// src/radio-context.ts
var import_utils = require("@yamada-ui/utils");
var [RadioGroupProvider, useRadioGroupContext] = (0, import_utils.createContext)({
name: "RadioGroupContext",
strict: false
});
var [RadioCardGroupProvider, useRadioCardGroupContext] = (0, import_utils.createContext)({
name: "RadioCardGroupContext",
strict: false
});
var [RadioCardProvider, useRadioCardContext] = (0, import_utils.createContext)({
name: "RadioCardContext",
errorMessage: `useRadioCardContext returned is 'undefined'. Seems you forgot to wrap the components in "<RadioCard />"`
});
// src/use-radio.ts
var import_form_control = require("@yamada-ui/form-control");
var import_use_focus_visible = require("@yamada-ui/use-focus-visible");
var import_utils2 = require("@yamada-ui/utils");
var import_react = require("react");
var useRadio = ({
id,
...props
}) => {
const uuid = (0, import_react.useId)();
id != null ? id : id = uuid;
const {
id: _id,
name,
isChecked,
checked: checkedProp = isChecked,
defaultIsChecked,
defaultChecked = defaultIsChecked,
value,
onChange: onChangeProp,
...computedProps
} = (0, import_form_control.useFormControlProps)({ id, ...props });
const [
{
"aria-readonly": _ariaReadonly,
disabled,
readOnly,
required,
onBlur: onBlurProp,
onFocus: onFocusProp,
...formControlProps
},
rest
] = (0, import_utils2.splitObject)(computedProps, import_form_control.formControlProperties);
const [focusVisible, setFocusVisible] = (0, import_react.useState)(false);
const [focused, setFocused] = (0, import_react.useState)(false);
const [hovered, setHovered] = (0, import_react.useState)(false);
const [active, setActive] = (0, import_react.useState)(false);
const [checked, setChecked] = (0, import_react.useState)(!!defaultChecked);
const controlled = checkedProp !== void 0;
const resolvedChecked = controlled ? checkedProp : checked;
(0, import_react.useEffect)(() => {
return (0, import_use_focus_visible.trackFocusVisible)(setFocusVisible);
}, []);
const onChange = (0, import_utils2.useCallbackRef)(
(ev) => {
if (readOnly || disabled) {
ev.preventDefault();
return;
}
if (!controlled) setChecked(ev.target.checked);
onChangeProp == null ? void 0 : onChangeProp(ev);
},
[readOnly, disabled, controlled]
);
const onFocus = (0, import_utils2.useCallbackRef)(onFocusProp);
const onBlur = (0, import_utils2.useCallbackRef)(onBlurProp);
const onKeyDown = (0, import_react.useCallback)(
({ key }) => {
if (key === " ") setActive(true);
},
[setActive]
);
const onKeyUp = (0, import_react.useCallback)(
({ key }) => {
if (key === " ") setActive(false);
},
[setActive]
);
const getContainerProps = (0, import_react.useCallback)(
(props2 = {}, ref = null) => ({
...formControlProps,
...props2,
ref,
"data-checked": (0, import_utils2.dataAttr)(resolvedChecked),
"data-focus": (0, import_utils2.dataAttr)(focused),
"data-focus-visible": (0, import_utils2.dataAttr)(focused && focusVisible)
}),
[resolvedChecked, formControlProps, focused, focusVisible]
);
const getIconProps = (0, import_react.useCallback)(
(props2 = {}, ref = null) => ({
...formControlProps,
...props2,
ref,
"aria-hidden": true,
"data-active": (0, import_utils2.dataAttr)(active),
"data-checked": (0, import_utils2.dataAttr)(resolvedChecked),
"data-focus": (0, import_utils2.dataAttr)(focused),
"data-focus-visible": (0, import_utils2.dataAttr)(focused && focusVisible),
"data-hover": (0, import_utils2.dataAttr)(hovered),
onMouseDown: (0, import_utils2.handlerAll)(props2.onMouseDown, () => setActive(true)),
onMouseEnter: (0, import_utils2.handlerAll)(props2.onMouseEnter, () => setHovered(true)),
onMouseLeave: (0, import_utils2.handlerAll)(props2.onMouseLeave, () => setHovered(false)),
onMouseUp: (0, import_utils2.handlerAll)(props2.onMouseUp, () => setActive(false))
}),
[resolvedChecked, active, focused, focusVisible, hovered, formControlProps]
);
const getInputProps = (0, import_react.useCallback)(
(props2 = {}, ref = null) => ({
...formControlProps,
...props2,
id,
ref,
type: "radio",
name,
style: {
border: "0px",
clip: "rect(0px, 0px, 0px, 0px)",
height: "1px",
margin: "-1px",
overflow: "hidden",
padding: "0px",
position: "absolute",
whiteSpace: "nowrap",
width: "1px"
},
"aria-checked": resolvedChecked,
checked: resolvedChecked,
disabled,
readOnly,
required,
value,
onBlur: (0, import_utils2.handlerAll)(props2.onBlur, onBlur, () => setFocused(false)),
onChange: (0, import_utils2.handlerAll)(props2.onChange, onChange),
onFocus: (0, import_utils2.handlerAll)(props2.onFocus, onFocus, () => setFocused(true)),
onKeyDown: (0, import_utils2.handlerAll)(props2.onKeyDown, onKeyDown),
onKeyUp: (0, import_utils2.handlerAll)(props2.onKeyUp, onKeyUp)
}),
[
formControlProps,
id,
name,
value,
required,
disabled,
readOnly,
resolvedChecked,
onChange,
onBlur,
onFocus,
onKeyDown,
onKeyUp
]
);
const getLabelProps = (0, import_react.useCallback)(
(props2 = {}, ref = null) => ({
...formControlProps,
...props2,
ref,
"data-checked": (0, import_utils2.dataAttr)(resolvedChecked),
onMouseDown: (0, import_utils2.handlerAll)(props2.onMouseDown, (ev) => {
ev.preventDefault();
ev.stopPropagation();
}),
onTouchStart: (0, import_utils2.handlerAll)(props2.onTouchStart, (ev) => {
ev.preventDefault();
ev.stopPropagation();
})
}),
[resolvedChecked, formControlProps]
);
return {
active,
checked: resolvedChecked,
focused,
focusVisible,
hovered,
/**
* @deprecated Use `active` instead.
*/
isActive: active,
/**
* @deprecated Use `checked` instead.
*/
isChecked: resolvedChecked,
/**
* @deprecated Use `focused` instead.
*/
isFocused: focused,
/**
* @deprecated Use `focusVisible` instead.
*/
isFocusVisible: focusVisible,
/**
* @deprecated Use `hovered` instead.
*/
isHovered: hovered,
props: rest,
getContainerProps,
getIconProps,
getInputProps,
getLabelProps
};
};
// src/radio.tsx
var import_jsx_runtime = require("react/jsx-runtime");
var Radio = (0, import_react2.forwardRef)(
(props, ref) => {
var _a, _b, _c, _d, _e;
const group = useRadioGroupContext();
const { value: groupValue, ...groupProps } = { ...group };
const control = (0, import_form_control2.useFormControl)(props);
const [styles, mergedProps] = (0, import_core.useComponentMultiStyle)("Radio", {
...groupProps,
...props
});
const {
className,
children,
disabled = (_a = groupProps.disabled) != null ? _a : control.disabled,
gap = "0.5rem",
invalid = (_b = groupProps.invalid) != null ? _b : control.invalid,
label,
readOnly = (_c = groupProps.readOnly) != null ? _c : control.readOnly,
required = (_d = groupProps.required) != null ? _d : control.required,
iconProps,
inputProps,
labelProps,
...computedProps
} = (0, import_core.omitThemeProps)(mergedProps);
(_e = computedProps.checked) != null ? _e : computedProps.checked = computedProps.isChecked;
const checkedProp = groupValue && computedProps.value ? groupValue === computedProps.value : computedProps.checked;
const onChange = groupProps.onChange && computedProps.value ? (0, import_utils3.funcAll)(groupProps.onChange, computedProps.onChange) : computedProps.onChange;
const {
checked,
props: rest,
getContainerProps,
getIconProps,
getInputProps,
getLabelProps
} = useRadio({
...computedProps,
checked: checkedProp,
disabled,
invalid,
readOnly,
required,
onChange
});
const tabIndex = !groupValue ? 0 : checked ? 0 : -1;
return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
import_core.ui.label,
{
className: (0, import_utils3.cx)("ui-radio", className),
...getContainerProps(rest),
__css: {
alignItems: "center",
cursor: "pointer",
display: "inline-flex",
gap,
position: "relative",
verticalAlign: "top",
...styles.container
},
children: [
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_core.ui.input,
{
className: "ui-radio__input",
...getInputProps(
{
...inputProps,
tabIndex
},
ref
)
}
),
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_core.ui.div,
{
className: "ui-radio__icon",
...getIconProps(iconProps),
__css: {
display: "inline-block",
position: "relative",
userSelect: "none",
...styles.icon
}
}
),
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_core.ui.span,
{
className: "ui-radio__label",
...getLabelProps(labelProps),
__css: { ...styles.label },
children: children != null ? children : label
}
)
]
}
);
}
);
Radio.displayName = "Radio";
Radio.__ui__ = "Radio";
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
Radio
});
//# sourceMappingURL=radio.js.map