react-jsonschema-form-conditionals
Version:
Extension of react-jsonschema-form with conditional field support
153 lines (113 loc) • 6.01 kB
JavaScript
;
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; }; }();
exports.default = applyRules;
var _react = require("react");
var _react2 = _interopRequireDefault(_react);
var _propTypes = require("prop-types");
var _propTypes2 = _interopRequireDefault(_propTypes);
var _utils = require("./utils");
var _rulesRunner = require("./rulesRunner");
var _rulesRunner2 = _interopRequireDefault(_rulesRunner);
var _actions = require("./actions");
var _validateAction = require("./actions/validateAction");
var _validateAction2 = _interopRequireDefault(_validateAction);
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; }
function applyRules(schema, uiSchema, rules, Engine) {
var extraActions = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
if ((0, _utils.isDevelopment)()) {
var propTypes = {
Engine: _propTypes2.default.func.isRequired,
rules: _propTypes2.default.arrayOf(_propTypes2.default.shape({
conditions: _propTypes2.default.object.isRequired,
order: _propTypes2.default.number,
event: _propTypes2.default.oneOfType([_propTypes2.default.shape({
type: _propTypes2.default.string.isRequired
}), _propTypes2.default.arrayOf(_propTypes2.default.shape({
type: _propTypes2.default.string.isRequired
}))])
})).isRequired,
extraActions: _propTypes2.default.object
};
_propTypes2.default.checkPropTypes(propTypes, { rules: rules, Engine: Engine, extraActions: extraActions }, "props", "react-jsonschema-form-manager");
rules.reduce(function (agg, _ref) {
var event = _ref.event;
return agg.concat(event);
}, []).forEach(function (_ref2) {
var type = _ref2.type,
params = _ref2.params;
// Find associated action
var action = extraActions[type] ? extraActions[type] : _actions.DEFAULT_ACTIONS[type];
if (action === undefined) {
(0, _utils.toError)("Rule contains invalid action \"" + type + "\"");
return;
}
(0, _validateAction2.default)(action, params, schema, uiSchema);
});
}
var runRules = (0, _rulesRunner2.default)(schema, uiSchema, rules, Engine, extraActions);
return function (FormComponent) {
var FormWithConditionals = function (_Component) {
_inherits(FormWithConditionals, _Component);
function FormWithConditionals(props) {
_classCallCheck(this, FormWithConditionals);
var _this = _possibleConstructorReturn(this, (FormWithConditionals.__proto__ || Object.getPrototypeOf(FormWithConditionals)).call(this, props));
_this.handleChange = _this.handleChange.bind(_this);
_this.updateConf = _this.updateConf.bind(_this);
var _this$props$formData = _this.props.formData,
formData = _this$props$formData === undefined ? {} : _this$props$formData;
_this.state = { schema: schema, uiSchema: uiSchema, formData: formData };
_this.updateConf(formData);
return _this;
}
_createClass(FormWithConditionals, [{
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
this.updateConf(nextProps.formData);
}
}, {
key: "updateConf",
value: function updateConf(formData) {
var _this2 = this;
return runRules(formData).then(function (conf) {
var newConf = JSON.stringify(conf);
var oldConf = JSON.stringify(_this2.state);
if (newConf !== oldConf) {
_this2.setState(conf);
}
return conf;
});
}
}, {
key: "handleChange",
value: function handleChange(change) {
var formData = change.formData;
var updTask = this.updateConf(formData);
var onChange = this.props.onChange;
if (onChange) {
updTask.then(function (conf) {
var updChange = Object.assign({}, change, conf);
onChange(updChange);
});
}
}
}, {
key: "render",
value: function render() {
// Assignment order is important
var formConf = Object.assign({}, this.props, this.state, {
onChange: this.handleChange
});
return _react2.default.createElement(FormComponent, formConf);
}
}]);
return FormWithConditionals;
}(_react.Component);
return FormWithConditionals;
};
}