@age/quantum
Version:
Catho react components
117 lines (97 loc) • 5.27 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _shared = require("../shared");
var _theme = require("../shared/theme");
var _Radio = _interopRequireDefault(require("./Radio"));
var _RadioButton = _interopRequireDefault(require("./RadioButton"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
var Group = (0, _styledComponents.default)(_shared.FieldGroup).attrs({
role: 'radiogroup'
}).withConfig({
displayName: "RadioGroup__Group",
componentId: "wxgvgz-0"
})(["position:relative;"]);
var RadioGroup = function RadioGroup(_ref) {
var type = _ref.type,
children = _ref.children,
error = _ref.error,
inline = _ref.inline,
name = _ref.name,
onChange = _ref.onChange,
options = _ref.options,
value = _ref.value,
theme = _ref.theme,
rest = _objectWithoutProperties(_ref, ["type", "children", "error", "inline", "name", "onChange", "options", "value", "theme"]);
var commonProps = {
name: name,
error: Boolean(error),
onChange: onChange,
inline: inline
};
var radioOptions = options.map(function (option) {
return Object.assign({}, option, _objectSpread({
key: option.value,
checked: option.value === value ? true : undefined
}, commonProps));
});
var items = _react.default.Children.map(children, function (child) {
return _react.default.cloneElement(child, _objectSpread({
checked: child.props.value === value ? true : undefined
}, commonProps));
}) || radioOptions.map(function (props) {
return type === 'button' ? _react.default.createElement(_RadioButton.default, props) : _react.default.createElement(_Radio.default, props);
});
return _react.default.createElement(Group, rest, items, error && _react.default.createElement(_shared.ErrorMessage, {
theme: theme
}, error));
};
RadioGroup.Radio = _Radio.default;
RadioGroup.Button = _RadioButton.default;
RadioGroup.propTypes = {
type: _propTypes.default.oneOf(['radio', 'button']),
options: _propTypes.default.arrayOf(_propTypes.default.shape({
label: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.node]),
value: _propTypes.default.string.isRequired,
disabled: _propTypes.default.bool
})),
children: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.element), _propTypes.default.element]),
inline: _propTypes.default.bool,
onChange: _propTypes.default.func,
/** Initialize RadioGroup with a value */
value: _propTypes.default.string,
name: _propTypes.default.string.isRequired,
error: _propTypes.default.string,
theme: _propTypes.default.shape({
colors: _propTypes.default.object,
spacing: _propTypes.default.object
})
};
/**
* Group for Radio components.
*/
RadioGroup.defaultProps = {
type: 'radio',
children: undefined,
error: undefined,
inline: false,
onChange: function onChange() {},
options: [],
value: undefined,
theme: {
colors: _theme.colors,
spacing: _theme.spacing
}
};
var _default = RadioGroup;
exports.default = _default;