UNPKG

@yamada-ui/radio

Version:

Yamada UI radio component

350 lines (346 loc) • 11.2 kB
"use client" "use strict"; 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