UNPKG

bridebook-ui-library

Version:
207 lines (167 loc) 7.87 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _immutable = require('immutable'); var _component = require('react-pure-render/component'); var _component2 = _interopRequireDefault(_component); var _lib = require('react-bootstrap/lib/'); var _utils = require('./utils'); var _objectAssign = require('object-assign'); var _objectAssign2 = _interopRequireDefault(_objectAssign); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var CheckboxesGroup = function (_Component) { _inherits(CheckboxesGroup, _Component); function CheckboxesGroup() { _classCallCheck(this, CheckboxesGroup); return _possibleConstructorReturn(this, (CheckboxesGroup.__proto__ || Object.getPrototypeOf(CheckboxesGroup)).apply(this, arguments)); } _createClass(CheckboxesGroup, [{ key: 'isOtherFieldEnabled', // Todo: Similar method is in Dropdown class, abstract it. value: function isOtherFieldEnabled(value) { var otherField = this.props.otherField; if (value !== null && value !== undefined) { if ('string' === typeof otherField && otherField.length > 1) { return value[otherField] === true; } } return false; } }, { key: 'onCheckboxChange', value: function onCheckboxChange(event) { var _props = this.props, updateAction = _props.updateAction, value = _props.value, field = _props.field, otherField = _props.otherField, otherFieldName = _props.otherFieldName, maxSelected = _props.maxSelected; var _event$target = event.target, name = _event$target.name, checked = _event$target.checked; // Currently value is a plain object, but in future refactoring // we should switch to immutables. So operations inside of this function // are performed on Map, but then converted back to JS. var result = new _immutable.Map((0, _utils.maybeCreateEmptyObject)(value)); // const result = objectAssign({}, value); var currentChecboxState = result.get(name); if (maxSelected === undefined || maxSelected === null) { result = result.set(name, checked); } else if ((0, _utils.numCheckboxesChecked)(result) < maxSelected) { result = result.set(name, checked); } else if (currentChecboxState === true) { result = result.set(name, false); } if (name === otherField && !checked) { result = result.set(otherFieldName, ''); } updateAction({ target: { name: field, value: result.toJS() } }); } }, { key: 'onInputChange', value: function onInputChange(event) { var _props2 = this.props, updateAction = _props2.updateAction, value = _props2.value, field = _props2.field, otherFieldName = _props2.otherFieldName; var inputValue = event.target.value; var result = (0, _objectAssign2.default)({}, value); result[otherFieldName] = inputValue; updateAction({ target: { name: field, value: result } }); } }, { key: 'render', value: function render() { var _props3 = this.props, children = _props3.children, heading = _props3.heading, note = _props3.note, value = _props3.value, maxSelected = _props3.maxSelected, otherFieldName = _props3.otherFieldName, otherFieldPlaceholder = _props3.otherFieldPlaceholder, xs = _props3.xs, sm = _props3.sm, _props3$headingXs = _props3.headingXs, headingXs = _props3$headingXs === undefined ? 12 : _props3$headingXs, _props3$inputsXs = _props3.inputsXs, inputsXs = _props3$inputsXs === undefined ? 12 : _props3$inputsXs; var disabled = false; var otherFieldEnabled = this.isOtherFieldEnabled(value); var otherFieldValue = value[otherFieldName]; if ('number' === typeof maxSelected) { disabled = (0, _utils.numCheckboxesChecked)(value) >= maxSelected; } if (value === null || value === undefined) { throw new Error('Checkboxes:error missing value'); } var items = children.map(_utils.nodeToJs).map((0, _utils.composeItemData)({ action: this.onCheckboxChange.bind(this), value: value })); var checkboxes = items.map((0, _utils.setDisabled)(disabled)).map(_utils.createCheckbox); return _react2.default.createElement( _lib.Col, { xs: xs, sm: sm }, _react2.default.createElement( _lib.Row, null, heading && _react2.default.createElement( _lib.Col, { xs: headingXs }, ' ', _react2.default.createElement( 'h3', null, heading ), ' ' ), note && _react2.default.createElement( _lib.Col, { className: 'group-note', xs: headingXs }, note ), _react2.default.createElement( _lib.Col, { xs: inputsXs, className: 'form-inline' }, checkboxes, otherFieldEnabled && _react2.default.createElement('input', { className: 'form-control', onChange: this.onInputChange.bind(this), placeholder: otherFieldPlaceholder, type: 'text', value: otherFieldValue }) ) ) ); } }]); return CheckboxesGroup; }(_component2.default); CheckboxesGroup.propTypes = { updateAction: _react.PropTypes.func.isRequired, children: _react.PropTypes.node.isRequired, heading: _react.PropTypes.string.isRequired, note: _react.PropTypes.string, field: _react.PropTypes.string.isRequired, value: _react.PropTypes.object.isRequired, maxSelected: _react.PropTypes.number, otherField: _react.PropTypes.string, otherFieldName: _react.PropTypes.string, otherFieldPlaceholder: _react.PropTypes.string, xs: _react.PropTypes.number.isRequired, sm: _react.PropTypes.number, inputsXs: _react.PropTypes.number, headingXs: _react.PropTypes.number, disabled: _react.PropTypes.bool }; exports.default = CheckboxesGroup; //# sourceMappingURL=checkboxes.react.js.map