@nutui/nutui-react
Version:
京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序
95 lines (94 loc) • 4.02 kB
JavaScript
import { _ as __rest } from "./tslib.es6.js";
import React__default, { useContext } from "react";
import { CheckDisabled, CheckChecked, CheckNormal } from "@nutui/icons-react";
import classNames from "classnames";
import RadioGroup__default from "./RadioGroup.js";
import { C as ComponentDefaults } from "./typings.js";
import { u as usePropsValue } from "./use-props-value.js";
const RadioContext = React__default.createContext(null);
const defaultProps = Object.assign(Object.assign({}, ComponentDefaults), { disabled: false, shape: "round", value: "", labelPosition: "right", icon: null, activeIcon: null, onChange: (checked) => {
} });
const Radio = (props) => {
const classPrefix = "nut-radio";
const _a = Object.assign(Object.assign({}, defaultProps), props), { children, className, style, checked, defaultChecked, shape, value, icon, activeIcon, onChange } = _a, others = __rest(_a, ["children", "className", "style", "checked", "defaultChecked", "shape", "value", "icon", "activeIcon", "onChange"]);
let { labelPosition, disabled } = others, rest = __rest(
others,
["labelPosition", "disabled"]
);
let [checkedStatement, setCheckedStatement] = usePropsValue({
value: checked,
defaultValue: defaultChecked,
finalValue: false,
onChange
});
const context = useContext(RadioContext);
if (context) {
checkedStatement = context.value === value;
if (context.labelPosition !== void 0) {
labelPosition = context.labelPosition;
}
if (context.disabled !== void 0) {
disabled = context.disabled;
}
setCheckedStatement = (value2) => {
if (value2) {
context.check(props.value === void 0 ? "" : props.value);
} else {
context.uncheck();
}
};
}
const renderLabel = () => {
return React__default.createElement("div", { className: classNames(`${classPrefix}-label`, {
[`${classPrefix}-label-disabled`]: disabled
}) }, children);
};
const renderButton = () => {
return React__default.createElement("div", { className: classNames(`${classPrefix}-button`, {
[`${classPrefix}-button-active`]: checkedStatement,
[`${classPrefix}-button-disabled`]: disabled
}) }, children);
};
const color = () => {
return {
[`${classPrefix}-icon-disabled`]: disabled,
[`${classPrefix}-icon`]: !checkedStatement,
[`${classPrefix}-icon-checked`]: checkedStatement
};
};
const renderIcon = () => {
const { icon: icon2, activeIcon: activeIcon2 } = props;
if (disabled && !checkedStatement) {
return React__default.createElement(CheckDisabled, { className: classNames(color()) });
}
if (checkedStatement) {
return React__default.isValidElement(activeIcon2) ? React__default.cloneElement(activeIcon2, Object.assign(Object.assign({}, activeIcon2.props), { className: classNames(color()) })) : React__default.createElement(CheckChecked, { className: classNames(color()) });
}
return React__default.isValidElement(icon2) ? React__default.cloneElement(icon2, Object.assign(Object.assign({}, icon2.props), { className: classNames(color()) })) : React__default.createElement(CheckNormal, { className: classNames(color()) });
};
const renderByShape = (shape2) => {
return shape2 === "button" ? renderButton() : React__default.createElement(
React__default.Fragment,
null,
renderIcon(),
renderLabel()
);
};
const renderRadioItem = () => {
return renderByShape(context && context.shape ? context.shape : shape);
};
const handleClick = (e) => {
if (disabled || checkedStatement)
return;
setCheckedStatement(!checkedStatement);
};
return React__default.createElement("div", Object.assign({ className: classNames(classPrefix, {
[`${classPrefix}-reverse`]: labelPosition === "left"
}, className), style, onClick: handleClick }, rest), renderRadioItem());
};
Radio.displayName = "NutRadio";
Radio.Group = RadioGroup__default;
export {
Radio as R,
RadioContext as a
};