UNPKG

@alifd/meet-react

Version:

Fusion Mobile React UI System Component

139 lines (138 loc) 6.71 kB
"use strict"; exports.__esModule = true; exports.default = void 0; var _babelRuntimeJsxStyleTransform = require("@alifd/babel-runtime-jsx-style-transform"); var _tslib = require("tslib"); var _classnames = _interopRequireDefault(require("classnames")); var _react = _interopRequireWildcard(require("react")); var _meetReactComponentOne = require("@alifd/meet-react-component-one"); var _utils = require("../utils"); var _tree = require("../utils/tree"); var _view = _interopRequireDefault(require("../view")); var _radio = _interopRequireDefault(require("./radio")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } var getInitValue = function (props) { var ret = []; if ('value' in props) { ret = props.value; } else if (!(0, _utils.isUndef)(props.defaultValue)) { ret = props.defaultValue; } return ret; }; var RadioGroup = function (props, ref) { var _props$size = props.size, size = _props$size === void 0 ? 'medium' : _props$size, _props$prefix = props.prefix, prefix = _props$prefix === void 0 ? 'mt-' : _props$prefix, _props$direction = props.direction, direction = _props$direction === void 0 ? 'ver' : _props$direction, children = props.children, groupDisabled = props.disabled, defaultValue = props.defaultValue, value = props.value, readOnly = props.readOnly, onChange = props.onChange, className = props.className, isPreview = props.isPreview, renderPreview = props.renderPreview, previewClassNameProp = props.previewClassName, previewStyle = props.previewStyle, dataSource = props.dataSource, labelAlign = props.labelAlign, others = (0, _tslib.__rest)(props, ["size", "prefix", "direction", "children", "disabled", "defaultValue", "value", "readOnly", "onChange", "className", "isPreview", "renderPreview", "previewClassName", "previewStyle", "dataSource", "labelAlign"]); var _useState = (0, _react.useState)(getInitValue(props)), groupValue = _useState[0], setGroupValue = _useState[1]; var isControlled = ('value' in props); var previewClassName = (0, _classnames.default)(previewClassNameProp, prefix + "form-item-input--preview-" + size); var groupCls = (0, _classnames.default)(prefix + "radio-group", prefix + "radio-group--" + direction, prefix + "radio-group--" + labelAlign + "-" + size, className); (0, _react.useEffect)(function () { var newValue = getInitValue(props); if (isControlled) { setGroupValue(newValue); } }, [value, groupValue]); var handleChange = function (selected, radioValue, e, isDisabled) { if (!isDisabled && !readOnly) { if (!isControlled) { setGroupValue(radioValue); } if (selected && (0, _utils.isFunction)(onChange)) { onChange(radioValue, e); } } }; var content; var ds = dataSource; if (!ds && _react.Children.count(children) > 0) { ds = (0, _utils.getDataSourceFromChildren)(children); } if ((0, _utils.isValidArray)(ds)) { content = ds.map(function (item, index) { var _classNames; var itemData = { style: {}, value: null, checked: false, label: '', text: '', disabled: false, size: size }; var itemOnClick = item.onClick, itemOnChange = item.onChange, itemClassName = item.className, itemLabel = item.label, itemText = item.text, itemRest = (0, _tslib.__rest)(item, ["onClick", "onChange", "className", "label", "text"]); if ((0, _utils.isString)(item) || (0, _utils.isNumber)(item)) { itemData.value = item; } else { itemData = Object.assign(Object.assign({}, itemData), itemRest); } var isDisabled = groupDisabled || itemData.disabled; var label = itemLabel || itemText || itemData.value; var isLast = index === ds.length - 1; return /*#__PURE__*/(0, _react.createElement)(_radio.default, _extends({}, itemData, { key: "radio_" + index, className: (0, _classnames.default)(itemClassName, (_classNames = {}, _classNames[prefix + "radio-item--" + direction + "-" + size] = !isLast, _classNames)), disabled: isDisabled, checked: itemData.checked || itemData.value === groupValue, onChange: function (selected, e) { if ((0, _utils.isFunction)(itemOnChange)) { itemOnChange(selected, e); } handleChange(selected, itemData.value, e, isDisabled); }, onClick: itemOnClick }), label); }); } if (isPreview) { var arr = (0, _tree.getItemsFromDataSource)(ds, groupValue); var previewItem = {}; if ((0, _utils.isValidArray)(arr)) { previewItem = arr[0]; } if ((0, _utils.isFunction)(renderPreview)) { return /*#__PURE__*/(0, _react.createElement)(_view.default, { className: previewClassName, style: (0, _babelRuntimeJsxStyleTransform.rpx2vw4style)(previewStyle) }, renderPreview(previewItem)); } return /*#__PURE__*/(0, _react.createElement)(_meetReactComponentOne.Text, { className: previewClassName, style: (0, _babelRuntimeJsxStyleTransform.rpx2vw4style)(previewStyle) }, previewItem.label || previewItem.text); } return /*#__PURE__*/(0, _react.createElement)(_view.default, _extends({ ref: ref, className: groupCls }, others), content); }; RadioGroup.displayName = 'Radio.Group'; var _default = exports.default = /*#__PURE__*/(0, _react.forwardRef)(RadioGroup);