UNPKG

5.97 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5var _typeof = require("@babel/runtime/helpers/typeof");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports["default"] = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
16var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
18var React = _interopRequireWildcard(require("react"));
19
20var _classnames = _interopRequireDefault(require("classnames"));
21
22var _useMergedState3 = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
23
24var _radio = _interopRequireDefault(require("./radio"));
25
26var _configProvider = require("../config-provider");
27
28var _SizeContext = _interopRequireDefault(require("../config-provider/SizeContext"));
29
30var _context = require("./context");
31
32var _getDataOrAriaProps = _interopRequireDefault(require("../_util/getDataOrAriaProps"));
33
34function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
36function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
38var RadioGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
39 var _React$useContext = React.useContext(_configProvider.ConfigContext),
40 getPrefixCls = _React$useContext.getPrefixCls,
41 direction = _React$useContext.direction;
42
43 var size = React.useContext(_SizeContext["default"]);
44
45 var _useMergedState = (0, _useMergedState3["default"])(props.defaultValue, {
46 value: props.value
47 }),
48 _useMergedState2 = (0, _slicedToArray2["default"])(_useMergedState, 2),
49 value = _useMergedState2[0],
50 setValue = _useMergedState2[1];
51
52 var onRadioChange = function onRadioChange(ev) {
53 var lastValue = value;
54 var val = ev.target.value;
55
56 if (!('value' in props)) {
57 setValue(val);
58 }
59
60 var onChange = props.onChange;
61
62 if (onChange && val !== lastValue) {
63 onChange(ev);
64 }
65 };
66
67 var renderGroup = function renderGroup() {
68 var _classNames;
69
70 var customizePrefixCls = props.prefixCls,
71 _props$className = props.className,
72 className = _props$className === void 0 ? '' : _props$className,
73 options = props.options,
74 optionType = props.optionType,
75 _props$buttonStyle = props.buttonStyle,
76 buttonStyle = _props$buttonStyle === void 0 ? 'outline' : _props$buttonStyle,
77 disabled = props.disabled,
78 children = props.children,
79 customizeSize = props.size,
80 style = props.style,
81 id = props.id,
82 onMouseEnter = props.onMouseEnter,
83 onMouseLeave = props.onMouseLeave;
84 var prefixCls = getPrefixCls('radio', customizePrefixCls);
85 var groupPrefixCls = "".concat(prefixCls, "-group");
86 var childrenToRender = children; // 如果存在 options, 优先使用
87
88 if (options && options.length > 0) {
89 var optionsPrefixCls = optionType === 'button' ? "".concat(prefixCls, "-button") : prefixCls;
90 childrenToRender = options.map(function (option) {
91 if (typeof option === 'string') {
92 // 此处类型自动推导为 string
93 return /*#__PURE__*/React.createElement(_radio["default"], {
94 key: option,
95 prefixCls: optionsPrefixCls,
96 disabled: disabled,
97 value: option,
98 checked: value === option
99 }, option);
100 } // 此处类型自动推导为 { label: string value: string }
101
102
103 return /*#__PURE__*/React.createElement(_radio["default"], {
104 key: "radio-group-value-options-".concat(option.value),
105 prefixCls: optionsPrefixCls,
106 disabled: option.disabled || disabled,
107 value: option.value,
108 checked: value === option.value,
109 style: option.style
110 }, option.label);
111 });
112 }
113
114 var mergedSize = customizeSize || size;
115 var classString = (0, _classnames["default"])(groupPrefixCls, "".concat(groupPrefixCls, "-").concat(buttonStyle), (_classNames = {}, (0, _defineProperty2["default"])(_classNames, "".concat(groupPrefixCls, "-").concat(mergedSize), mergedSize), (0, _defineProperty2["default"])(_classNames, "".concat(groupPrefixCls, "-rtl"), direction === 'rtl'), _classNames), className);
116 return /*#__PURE__*/React.createElement("div", (0, _extends2["default"])({}, (0, _getDataOrAriaProps["default"])(props), {
117 className: classString,
118 style: style,
119 onMouseEnter: onMouseEnter,
120 onMouseLeave: onMouseLeave,
121 id: id,
122 ref: ref
123 }), childrenToRender);
124 };
125
126 return /*#__PURE__*/React.createElement(_context.RadioGroupContextProvider, {
127 value: {
128 onChange: onRadioChange,
129 value: value,
130 disabled: props.disabled,
131 name: props.name
132 }
133 }, renderGroup());
134});
135
136var _default = /*#__PURE__*/React.memo(RadioGroup);
137
138exports["default"] = _default;
\No newline at end of file