UNPKG

react-jsonschema-form-semantic

Version:

A simple React component capable of building HTML forms out of a JSON schema. Uses React Semantic UI (css not bundled)

111 lines (92 loc) 3.86 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require("babel-runtime/helpers/extends"); var _extends3 = _interopRequireDefault(_extends2); var _objectWithoutProperties2 = require("babel-runtime/helpers/objectWithoutProperties"); var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2); var _react = require("react"); var _react2 = _interopRequireDefault(_react); var _propTypes = require("prop-types"); var _propTypes2 = _interopRequireDefault(_propTypes); var _utils = require("../../utils"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function StringField(props) { var schema = props.schema, name = props.name, uiSchema = props.uiSchema, idSchema = props.idSchema, formData = props.formData, required = props.required, disabled = props.disabled, readonly = props.readonly, autofocus = props.autofocus, onChange = props.onChange, onBlur = props.onBlur, onFocus = props.onFocus, _props$registry = props.registry, registry = _props$registry === undefined ? (0, _utils.getDefaultRegistry)() : _props$registry, rawErrors = props.rawErrors; var title = schema.title, format = schema.format; var widgets = registry.widgets, formContext = registry.formContext; var enumOptions = (0, _utils.isSelect)(schema) && (0, _utils.optionsList)(schema); var defaultWidget = format || (enumOptions ? "select" : "text"); var _getUiOptions = (0, _utils.getUiOptions)(uiSchema), _getUiOptions$widget = _getUiOptions.widget, widget = _getUiOptions$widget === undefined ? defaultWidget : _getUiOptions$widget, _getUiOptions$placeho = _getUiOptions.placeholder, placeholder = _getUiOptions$placeho === undefined ? "" : _getUiOptions$placeho, options = (0, _objectWithoutProperties3.default)(_getUiOptions, ["widget", "placeholder"]); var Widget = (0, _utils.getWidget)(schema, widget, widgets); return _react2.default.createElement(Widget, { options: (0, _extends3.default)({}, options, { enumOptions: enumOptions }), schema: schema, id: idSchema && idSchema.$id, label: title === undefined ? name : title, value: formData, onChange: onChange, onBlur: onBlur, onFocus: onFocus, required: required, disabled: disabled, readonly: readonly, formContext: formContext, autofocus: autofocus, registry: registry, placeholder: placeholder, rawErrors: rawErrors }); } if (process.env.NODE_ENV !== "production") { StringField.propTypes = { schema: _propTypes2.default.object.isRequired, uiSchema: _propTypes2.default.object.isRequired, idSchema: _propTypes2.default.object, onChange: _propTypes2.default.func.isRequired, onBlur: _propTypes2.default.func, onFocus: _propTypes2.default.func, formData: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.number]), registry: _propTypes2.default.shape({ widgets: _propTypes2.default.objectOf(_propTypes2.default.oneOfType([_propTypes2.default.func, _propTypes2.default.object])).isRequired, fields: _propTypes2.default.objectOf(_propTypes2.default.func).isRequired, definitions: _propTypes2.default.object.isRequired, formContext: _propTypes2.default.object.isRequired }), formContext: _propTypes2.default.object.isRequired, required: _propTypes2.default.bool, disabled: _propTypes2.default.bool, readonly: _propTypes2.default.bool, autofocus: _propTypes2.default.bool, rawErrors: _propTypes2.default.arrayOf(_propTypes2.default.string) }; } StringField.defaultProps = { uiSchema: {}, disabled: false, readonly: false, autofocus: false }; exports.default = StringField;