UNPKG

@age/quantum

Version:
117 lines (97 loc) 5.27 kB
"use strict"; 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;