react-form
Advanced tools
Comparing version 1.1.6 to 1.2.0
@@ -42,3 +42,4 @@ 'use strict'; | ||
onSubmit: noop, | ||
postSubmit: noop | ||
postSubmit: noop, | ||
component: 'div' | ||
}; | ||
@@ -218,8 +219,10 @@ | ||
var children = props.children, | ||
rest = _objectWithoutProperties(props, ['children']); | ||
var component = props.component, | ||
children = props.children, | ||
rest = _objectWithoutProperties(props, ['component', 'children']); | ||
var resolvedChild = typeof children === 'function' ? children(rest) : children; | ||
var RootEl = component; | ||
return _react2.default.createElement( | ||
'div', | ||
RootEl, | ||
{ className: 'ReactForm' }, | ||
@@ -272,2 +275,2 @@ resolvedChild | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/form.js"],"names":["noop","reop","d","FormDefaultProps","loadState","defaultValues","preValidate","validate","onValidationFail","onChange","saveState","willUnmount","preSubmit","onSubmit","postSubmit","createClass","displayName","childContextTypes","formAPI","PropTypes","object","getChildContext","getAPI","getDefaultProps","getInitialState","props","values","mergedValues","clone","touched","errors","nestedErrors","componentWillMount","emitChange","state","componentWillReceiveProps","setFormState","componentWillUnmount","setValue","field","value","noTouch","set","getValue","fallback","val","get","setNestedError","getError","setTouched","getTouched","dirty","addValue","removeValue","index","fieldValue","slice","swapValues","destIndex","fieldValues","setAllTouched","resetForm","submitForm","e","preventDefault","preSubmitValues","newState","silent","setState","initial","removeNestedErrorValues","cleanErrors","render","children","rest","resolvedChild","err","isObject","resolved","mapValues","found","pickBy","Object","keys","length","undefined","isArray","map","find","recurse","path","i","key"],"mappings":"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","file":"form.js","sourcesContent":["import React from 'react'\nimport _ from './utils'\n\nconst noop = () => {}\nconst reop = d => d\n\nexport const FormDefaultProps = {\n  loadState: noop,\n  defaultValues: {},\n  preValidate: reop,\n  validate: () => null,\n  onValidationFail: noop,\n  onChange: noop,\n  saveState: noop,\n  willUnmount: noop,\n  preSubmit: reop,\n  onSubmit: noop,\n  postSubmit: noop\n}\n\nexport default React.createClass({\n  displayName: 'Form',\n  childContextTypes: {\n    formAPI: React.PropTypes.object\n  },\n  getChildContext () {\n    return {\n      formAPI: this.getAPI()\n    }\n  },\n  // Lifecycle\n  getDefaultProps () {\n    return FormDefaultProps\n  },\n  getInitialState () {\n    const {\n      defaultValues,\n      values,\n      loadState\n    } = this.props\n    const mergedValues = {\n      ..._.clone(defaultValues),\n      ..._.clone(values)\n    }\n\n    return loadState(this.props, this) || {\n      values: mergedValues,\n      touched: {},\n      errors: this.validate(mergedValues),\n      nestedErrors: {}\n    }\n  },\n  componentWillMount () {\n    this.emitChange(this.state, true)\n  },\n  componentWillReceiveProps (props) {\n    if (props.values === this.props.values) {\n      return\n    }\n\n    this.setFormState({\n      values: _.clone(props.values) || {}\n    }, true)\n  },\n  componentWillUnmount () {\n    this.props.willUnmount(this.state, this.props, this)\n  },\n\n  // API\n  setValue (field, value, noTouch) {\n    const state = this.state\n    const values = _.set(state.values, field, value)\n    // Also set touched since the value is changing\n    if (noTouch) {\n      return this.setFormState({values})\n    }\n    const touched = _.set(state.touched, field)\n    this.setFormState({values, touched})\n  },\n  getValue (field, fallback) {\n    const state = this.state\n    const val = _.get(state.values, field)\n    return typeof val !== 'undefined' ? val : fallback\n  },\n  setNestedError (field, value = true) {\n    const nestedErrors = _.set(this.state.nestedErrors, field, value)\n    this.setFormState({nestedErrors})\n  },\n  getError (field) {\n    return _.get(this.state.errors, field)\n  },\n  setTouched (field, value = true) {\n    const touched = _.set(this.state.touched, field, value)\n    this.setFormState({touched})\n  },\n  getTouched (field) {\n    const state = this.state\n    if (this.state.dirty === true || this.props.touched === true) {\n      return true\n    }\n    return _.get(state.touched, field)\n  },\n  addValue (field, value) {\n    const state = this.state\n    const values = _.set(state.values, field, [\n      ..._.get(state.values, field, []),\n      value\n    ])\n    this.setFormState({values})\n  },\n  removeValue (field, index) {\n    const state = this.state\n    const fieldValue = _.get(state.values, field, [])\n    const values = _.set(state.values, field, [\n      ...fieldValue.slice(0, index),\n      ...fieldValue.slice(index + 1)\n    ])\n    this.setFormState({values})\n  },\n  swapValues (field, index, destIndex) {\n    const state = this.state\n    const fieldValues = _.get(state.values, field, [])\n    const values = _.set(state.values, field, [\n      ...fieldValues.slice(0, index),\n      fieldValues[destIndex],\n      ...fieldValues.slice(index + 1, destIndex),\n      fieldValues[index],\n      ...fieldValues.slice(destIndex + 1)\n    ])\n    this.setFormState({values})\n  },\n  setAllTouched (dirty = true, state) {\n    this.setFormState({\n      ...state,\n      dirty: !!dirty\n    })\n  },\n  resetForm () {\n    return this.setFormState(this.getInitialState())\n  },\n  submitForm (e) {\n    e && e.preventDefault && e.preventDefault(e)\n    const state = this.state\n    const errors = this.validate(state.values, state, this.props)\n    if (errors) {\n      if (!state.dirty) {\n        this.setAllTouched(true, {errors})\n      }\n      return this.props.onValidationFail(state.values, state, this.props, this)\n    }\n    const preSubmitValues = this.props.preSubmit(state.values, state, this.props, this)\n    this.props.onSubmit(preSubmitValues, state, this.props, this)\n    this.props.postSubmit(preSubmitValues, state, this.props, this)\n  },\n\n  // Utils\n  getAPI () {\n    return {\n      setValue: this.setValue,\n      getValue: this.getValue,\n      setNestedError: this.setNestedError,\n      getError: this.getError,\n      setTouched: this.setTouched,\n      getTouched: this.getTouched,\n      addValue: this.addValue,\n      removeValue: this.removeValue,\n      swapValues: this.swapValues,\n      setAllTouched: this.setAllTouched,\n      resetForm: this.resetForm,\n      submitForm: this.submitForm\n    }\n  },\n  setFormState (newState, silent) {\n    if (newState && newState.values && !newState.errors) {\n      newState.values = this.props.preValidate(newState.values, newState, this.props, this)\n      newState.errors = this.validate(newState.values, newState, this.props)\n    }\n    this.setState(newState, () => {\n      this.props.saveState(this.state, this.props, this)\n      if (!silent) {\n        this.emitChange(this.state, this.props)\n      }\n    })\n  },\n  emitChange (state, initial) {\n    this.props.onChange(state, this.props, initial, this)\n  },\n  validate (values, state, props) {\n    const errors = this.props.validate(\n      removeNestedErrorValues(values, this.state ? this.state.nestedErrors : {}),\n      state,\n      props,\n      this\n    )\n    return cleanErrors(errors)\n  },\n  // Render\n  render () {\n    const props = {\n      ...this.props,\n      ...this.state,\n      ...this.getAPI()\n    }\n    const { children, ...rest } = props\n    const resolvedChild = typeof children === 'function' ? children(rest) : children\n    return (\n      <div className='ReactForm'>{resolvedChild}</div>\n    )\n  }\n})\n\n// Utils\n\nfunction cleanErrors (err) {\n  if (_.isObject(err)) {\n    const resolved = _.mapValues(err, cleanErrors)\n    const found = _.pickBy(resolved, d => d)\n    return Object.keys(found).length ? resolved : undefined\n  }\n  if (_.isArray(err)) {\n    const resolved = err.map(cleanErrors)\n    const found = resolved.find(d => d)\n    return found ? resolved : undefined\n  }\n  return err\n}\n\nfunction removeNestedErrorValues (value, nestedErrors) {\n  const recurse = (value, path = []) => {\n    if (_.get(nestedErrors, path)) {\n      return undefined\n    }\n    if (_.isObject(value)) {\n      return _.mapValues(value, (d, i) => {\n        return recurse(d, [...path, i])\n      })\n    }\n    if (_.isArray(value)) {\n      return value.map((d, key) => {\n        return recurse(d, [...path, key])\n      })\n    }\n    return value\n  }\n  return recurse(value)\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/form.js"],"names":["noop","reop","d","FormDefaultProps","loadState","defaultValues","preValidate","validate","onValidationFail","onChange","saveState","willUnmount","preSubmit","onSubmit","postSubmit","component","createClass","displayName","childContextTypes","formAPI","PropTypes","object","getChildContext","getAPI","getDefaultProps","getInitialState","props","values","mergedValues","clone","touched","errors","nestedErrors","componentWillMount","emitChange","state","componentWillReceiveProps","setFormState","componentWillUnmount","setValue","field","value","noTouch","set","getValue","fallback","val","get","setNestedError","getError","setTouched","getTouched","dirty","addValue","removeValue","index","fieldValue","slice","swapValues","destIndex","fieldValues","setAllTouched","resetForm","submitForm","e","preventDefault","preSubmitValues","newState","silent","setState","initial","removeNestedErrorValues","cleanErrors","render","children","rest","resolvedChild","RootEl","err","isObject","resolved","mapValues","found","pickBy","Object","keys","length","undefined","isArray","map","find","recurse","path","i","key"],"mappings":"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","file":"form.js","sourcesContent":["import React from 'react'\nimport _ from './utils'\n\nconst noop = () => {}\nconst reop = d => d\n\nexport const FormDefaultProps = {\n  loadState: noop,\n  defaultValues: {},\n  preValidate: reop,\n  validate: () => null,\n  onValidationFail: noop,\n  onChange: noop,\n  saveState: noop,\n  willUnmount: noop,\n  preSubmit: reop,\n  onSubmit: noop,\n  postSubmit: noop,\n  component: 'div'\n}\n\nexport default React.createClass({\n  displayName: 'Form',\n  childContextTypes: {\n    formAPI: React.PropTypes.object\n  },\n  getChildContext () {\n    return {\n      formAPI: this.getAPI()\n    }\n  },\n  // Lifecycle\n  getDefaultProps () {\n    return FormDefaultProps\n  },\n  getInitialState () {\n    const {\n      defaultValues,\n      values,\n      loadState\n    } = this.props\n    const mergedValues = {\n      ..._.clone(defaultValues),\n      ..._.clone(values)\n    }\n\n    return loadState(this.props, this) || {\n      values: mergedValues,\n      touched: {},\n      errors: this.validate(mergedValues),\n      nestedErrors: {}\n    }\n  },\n  componentWillMount () {\n    this.emitChange(this.state, true)\n  },\n  componentWillReceiveProps (props) {\n    if (props.values === this.props.values) {\n      return\n    }\n\n    this.setFormState({\n      values: _.clone(props.values) || {}\n    }, true)\n  },\n  componentWillUnmount () {\n    this.props.willUnmount(this.state, this.props, this)\n  },\n\n  // API\n  setValue (field, value, noTouch) {\n    const state = this.state\n    const values = _.set(state.values, field, value)\n    // Also set touched since the value is changing\n    if (noTouch) {\n      return this.setFormState({values})\n    }\n    const touched = _.set(state.touched, field)\n    this.setFormState({values, touched})\n  },\n  getValue (field, fallback) {\n    const state = this.state\n    const val = _.get(state.values, field)\n    return typeof val !== 'undefined' ? val : fallback\n  },\n  setNestedError (field, value = true) {\n    const nestedErrors = _.set(this.state.nestedErrors, field, value)\n    this.setFormState({nestedErrors})\n  },\n  getError (field) {\n    return _.get(this.state.errors, field)\n  },\n  setTouched (field, value = true) {\n    const touched = _.set(this.state.touched, field, value)\n    this.setFormState({touched})\n  },\n  getTouched (field) {\n    const state = this.state\n    if (this.state.dirty === true || this.props.touched === true) {\n      return true\n    }\n    return _.get(state.touched, field)\n  },\n  addValue (field, value) {\n    const state = this.state\n    const values = _.set(state.values, field, [\n      ..._.get(state.values, field, []),\n      value\n    ])\n    this.setFormState({values})\n  },\n  removeValue (field, index) {\n    const state = this.state\n    const fieldValue = _.get(state.values, field, [])\n    const values = _.set(state.values, field, [\n      ...fieldValue.slice(0, index),\n      ...fieldValue.slice(index + 1)\n    ])\n    this.setFormState({values})\n  },\n  swapValues (field, index, destIndex) {\n    const state = this.state\n    const fieldValues = _.get(state.values, field, [])\n    const values = _.set(state.values, field, [\n      ...fieldValues.slice(0, index),\n      fieldValues[destIndex],\n      ...fieldValues.slice(index + 1, destIndex),\n      fieldValues[index],\n      ...fieldValues.slice(destIndex + 1)\n    ])\n    this.setFormState({values})\n  },\n  setAllTouched (dirty = true, state) {\n    this.setFormState({\n      ...state,\n      dirty: !!dirty\n    })\n  },\n  resetForm () {\n    return this.setFormState(this.getInitialState())\n  },\n  submitForm (e) {\n    e && e.preventDefault && e.preventDefault(e)\n    const state = this.state\n    const errors = this.validate(state.values, state, this.props)\n    if (errors) {\n      if (!state.dirty) {\n        this.setAllTouched(true, {errors})\n      }\n      return this.props.onValidationFail(state.values, state, this.props, this)\n    }\n    const preSubmitValues = this.props.preSubmit(state.values, state, this.props, this)\n    this.props.onSubmit(preSubmitValues, state, this.props, this)\n    this.props.postSubmit(preSubmitValues, state, this.props, this)\n  },\n\n  // Utils\n  getAPI () {\n    return {\n      setValue: this.setValue,\n      getValue: this.getValue,\n      setNestedError: this.setNestedError,\n      getError: this.getError,\n      setTouched: this.setTouched,\n      getTouched: this.getTouched,\n      addValue: this.addValue,\n      removeValue: this.removeValue,\n      swapValues: this.swapValues,\n      setAllTouched: this.setAllTouched,\n      resetForm: this.resetForm,\n      submitForm: this.submitForm\n    }\n  },\n  setFormState (newState, silent) {\n    if (newState && newState.values && !newState.errors) {\n      newState.values = this.props.preValidate(newState.values, newState, this.props, this)\n      newState.errors = this.validate(newState.values, newState, this.props)\n    }\n    this.setState(newState, () => {\n      this.props.saveState(this.state, this.props, this)\n      if (!silent) {\n        this.emitChange(this.state, this.props)\n      }\n    })\n  },\n  emitChange (state, initial) {\n    this.props.onChange(state, this.props, initial, this)\n  },\n  validate (values, state, props) {\n    const errors = this.props.validate(\n      removeNestedErrorValues(values, this.state ? this.state.nestedErrors : {}),\n      state,\n      props,\n      this\n    )\n    return cleanErrors(errors)\n  },\n  // Render\n  render () {\n    const props = {\n      ...this.props,\n      ...this.state,\n      ...this.getAPI()\n    }\n    const { component, children, ...rest } = props\n    const resolvedChild = typeof children === 'function' ? children(rest) : children\n    const RootEl = component\n    return (\n      <RootEl className='ReactForm'>{resolvedChild}</RootEl>\n    )\n  }\n})\n\n// Utils\n\nfunction cleanErrors (err) {\n  if (_.isObject(err)) {\n    const resolved = _.mapValues(err, cleanErrors)\n    const found = _.pickBy(resolved, d => d)\n    return Object.keys(found).length ? resolved : undefined\n  }\n  if (_.isArray(err)) {\n    const resolved = err.map(cleanErrors)\n    const found = resolved.find(d => d)\n    return found ? resolved : undefined\n  }\n  return err\n}\n\nfunction removeNestedErrorValues (value, nestedErrors) {\n  const recurse = (value, path = []) => {\n    if (_.get(nestedErrors, path)) {\n      return undefined\n    }\n    if (_.isObject(value)) {\n      return _.mapValues(value, (d, i) => {\n        return recurse(d, [...path, i])\n      })\n    }\n    if (_.isArray(value)) {\n      return value.map((d, key) => {\n        return recurse(d, [...path, key])\n      })\n    }\n    return value\n  }\n  return recurse(value)\n}\n"]} |
{ | ||
"name": "react-form", | ||
"version": "1.1.6", | ||
"version": "1.2.0", | ||
"description": "React Form is a lightweight framework and utility for building powerful forms in React applications.", | ||
@@ -5,0 +5,0 @@ "license": "MIT", |
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.reactForm = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ | ||
"use strict";function _interopRequireDefault(t){return t&&t.__esModule?t:{default:t}}function _objectWithoutProperties(t,e){var s={};for(var r in t)e.indexOf(r)>=0||Object.prototype.hasOwnProperty.call(t,r)&&(s[r]=t[r]);return s}function _toConsumableArray(t){if(Array.isArray(t)){for(var e=0,s=Array(t.length);e<t.length;e++)s[e]=t[e];return s}return Array.from(t)}function cleanErrors(t){if(_utils2.default.isObject(t)){var e=_utils2.default.mapValues(t,cleanErrors),s=_utils2.default.pickBy(e,function(t){return t});return Object.keys(s).length?e:void 0}if(_utils2.default.isArray(t)){var r=t.map(cleanErrors),a=r.find(function(t){return t});return a?r:void 0}return t}function removeNestedErrorValues(t,e){var s=function t(s){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];if(!_utils2.default.get(e,r))return _utils2.default.isObject(s)?_utils2.default.mapValues(s,function(e,s){return t(e,[].concat(_toConsumableArray(r),[s]))}):_utils2.default.isArray(s)?s.map(function(e,s){return t(e,[].concat(_toConsumableArray(r),[s]))}):s};return s(t)}Object.defineProperty(exports,"__esModule",{value:!0}),exports.FormDefaultProps=void 0;var _extends=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var s=arguments[e];for(var r in s)Object.prototype.hasOwnProperty.call(s,r)&&(t[r]=s[r])}return t},_react=require("react"),_react2=_interopRequireDefault(_react),_utils=require("./utils"),_utils2=_interopRequireDefault(_utils),noop=function(){},reop=function(t){return t},FormDefaultProps=exports.FormDefaultProps={loadState:noop,defaultValues:{},preValidate:reop,validate:function(){return null},onValidationFail:noop,onChange:noop,saveState:noop,willUnmount:noop,preSubmit:reop,onSubmit:noop,postSubmit:noop};exports.default=_react2.default.createClass({displayName:"Form",childContextTypes:{formAPI:_react2.default.PropTypes.object},getChildContext:function(){return{formAPI:this.getAPI()}},getDefaultProps:function(){return FormDefaultProps},getInitialState:function(){var t=this.props,e=t.defaultValues,s=t.values,r=t.loadState,a=_extends({},_utils2.default.clone(e),_utils2.default.clone(s));return r(this.props,this)||{values:a,touched:{},errors:this.validate(a),nestedErrors:{}}},componentWillMount:function(){this.emitChange(this.state,!0)},componentWillReceiveProps:function(t){t.values!==this.props.values&&this.setFormState({values:_utils2.default.clone(t.values)||{}},!0)},componentWillUnmount:function(){this.props.willUnmount(this.state,this.props,this)},setValue:function(t,e,s){var r=this.state,a=_utils2.default.set(r.values,t,e);if(s)return this.setFormState({values:a});var o=_utils2.default.set(r.touched,t);this.setFormState({values:a,touched:o})},getValue:function(t,e){var s=this.state,r=_utils2.default.get(s.values,t);return"undefined"!=typeof r?r:e},setNestedError:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=_utils2.default.set(this.state.nestedErrors,t,e);this.setFormState({nestedErrors:s})},getError:function(t){return _utils2.default.get(this.state.errors,t)},setTouched:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=_utils2.default.set(this.state.touched,t,e);this.setFormState({touched:s})},getTouched:function(t){var e=this.state;return this.state.dirty===!0||this.props.touched===!0||_utils2.default.get(e.touched,t)},addValue:function(t,e){var s=this.state,r=_utils2.default.set(s.values,t,[].concat(_toConsumableArray(_utils2.default.get(s.values,t,[])),[e]));this.setFormState({values:r})},removeValue:function(t,e){var s=this.state,r=_utils2.default.get(s.values,t,[]),a=_utils2.default.set(s.values,t,[].concat(_toConsumableArray(r.slice(0,e)),_toConsumableArray(r.slice(e+1))));this.setFormState({values:a})},swapValues:function(t,e,s){var r=this.state,a=_utils2.default.get(r.values,t,[]),o=_utils2.default.set(r.values,t,[].concat(_toConsumableArray(a.slice(0,e)),[a[s]],_toConsumableArray(a.slice(e+1,s)),[a[e]],_toConsumableArray(a.slice(s+1))));this.setFormState({values:o})},setAllTouched:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0],e=arguments[1];this.setFormState(_extends({},e,{dirty:!!t}))},resetForm:function(){return this.setFormState(this.getInitialState())},submitForm:function(t){t&&t.preventDefault&&t.preventDefault(t);var e=this.state,s=this.validate(e.values,e,this.props);if(s)return e.dirty||this.setAllTouched(!0,{errors:s}),this.props.onValidationFail(e.values,e,this.props,this);var r=this.props.preSubmit(e.values,e,this.props,this);this.props.onSubmit(r,e,this.props,this),this.props.postSubmit(r,e,this.props,this)},getAPI:function(){return{setValue:this.setValue,getValue:this.getValue,setNestedError:this.setNestedError,getError:this.getError,setTouched:this.setTouched,getTouched:this.getTouched,addValue:this.addValue,removeValue:this.removeValue,swapValues:this.swapValues,setAllTouched:this.setAllTouched,resetForm:this.resetForm,submitForm:this.submitForm}},setFormState:function(t,e){var s=this;t&&t.values&&!t.errors&&(t.values=this.props.preValidate(t.values,t,this.props,this),t.errors=this.validate(t.values,t,this.props)),this.setState(t,function(){s.props.saveState(s.state,s.props,s),e||s.emitChange(s.state,s.props)})},emitChange:function(t,e){this.props.onChange(t,this.props,e,this)},validate:function(t,e,s){var r=this.props.validate(removeNestedErrorValues(t,this.state?this.state.nestedErrors:{}),e,s,this);return cleanErrors(r)},render:function(){var t=_extends({},this.props,this.state,this.getAPI()),e=t.children,s=_objectWithoutProperties(t,["children"]),r="function"==typeof e?e(s):e;return _react2.default.createElement("div",{className:"ReactForm"},r)}}); | ||
"use strict";function _interopRequireDefault(t){return t&&t.__esModule?t:{default:t}}function _objectWithoutProperties(t,e){var s={};for(var r in t)e.indexOf(r)>=0||Object.prototype.hasOwnProperty.call(t,r)&&(s[r]=t[r]);return s}function _toConsumableArray(t){if(Array.isArray(t)){for(var e=0,s=Array(t.length);e<t.length;e++)s[e]=t[e];return s}return Array.from(t)}function cleanErrors(t){if(_utils2.default.isObject(t)){var e=_utils2.default.mapValues(t,cleanErrors),s=_utils2.default.pickBy(e,function(t){return t});return Object.keys(s).length?e:void 0}if(_utils2.default.isArray(t)){var r=t.map(cleanErrors),o=r.find(function(t){return t});return o?r:void 0}return t}function removeNestedErrorValues(t,e){var s=function t(s){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];if(!_utils2.default.get(e,r))return _utils2.default.isObject(s)?_utils2.default.mapValues(s,function(e,s){return t(e,[].concat(_toConsumableArray(r),[s]))}):_utils2.default.isArray(s)?s.map(function(e,s){return t(e,[].concat(_toConsumableArray(r),[s]))}):s};return s(t)}Object.defineProperty(exports,"__esModule",{value:!0}),exports.FormDefaultProps=void 0;var _extends=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var s=arguments[e];for(var r in s)Object.prototype.hasOwnProperty.call(s,r)&&(t[r]=s[r])}return t},_react=require("react"),_react2=_interopRequireDefault(_react),_utils=require("./utils"),_utils2=_interopRequireDefault(_utils),noop=function(){},reop=function(t){return t},FormDefaultProps=exports.FormDefaultProps={loadState:noop,defaultValues:{},preValidate:reop,validate:function(){return null},onValidationFail:noop,onChange:noop,saveState:noop,willUnmount:noop,preSubmit:reop,onSubmit:noop,postSubmit:noop,component:"div"};exports.default=_react2.default.createClass({displayName:"Form",childContextTypes:{formAPI:_react2.default.PropTypes.object},getChildContext:function(){return{formAPI:this.getAPI()}},getDefaultProps:function(){return FormDefaultProps},getInitialState:function(){var t=this.props,e=t.defaultValues,s=t.values,r=t.loadState,o=_extends({},_utils2.default.clone(e),_utils2.default.clone(s));return r(this.props,this)||{values:o,touched:{},errors:this.validate(o),nestedErrors:{}}},componentWillMount:function(){this.emitChange(this.state,!0)},componentWillReceiveProps:function(t){t.values!==this.props.values&&this.setFormState({values:_utils2.default.clone(t.values)||{}},!0)},componentWillUnmount:function(){this.props.willUnmount(this.state,this.props,this)},setValue:function(t,e,s){var r=this.state,o=_utils2.default.set(r.values,t,e);if(s)return this.setFormState({values:o});var a=_utils2.default.set(r.touched,t);this.setFormState({values:o,touched:a})},getValue:function(t,e){var s=this.state,r=_utils2.default.get(s.values,t);return"undefined"!=typeof r?r:e},setNestedError:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=_utils2.default.set(this.state.nestedErrors,t,e);this.setFormState({nestedErrors:s})},getError:function(t){return _utils2.default.get(this.state.errors,t)},setTouched:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=_utils2.default.set(this.state.touched,t,e);this.setFormState({touched:s})},getTouched:function(t){var e=this.state;return this.state.dirty===!0||this.props.touched===!0||_utils2.default.get(e.touched,t)},addValue:function(t,e){var s=this.state,r=_utils2.default.set(s.values,t,[].concat(_toConsumableArray(_utils2.default.get(s.values,t,[])),[e]));this.setFormState({values:r})},removeValue:function(t,e){var s=this.state,r=_utils2.default.get(s.values,t,[]),o=_utils2.default.set(s.values,t,[].concat(_toConsumableArray(r.slice(0,e)),_toConsumableArray(r.slice(e+1))));this.setFormState({values:o})},swapValues:function(t,e,s){var r=this.state,o=_utils2.default.get(r.values,t,[]),a=_utils2.default.set(r.values,t,[].concat(_toConsumableArray(o.slice(0,e)),[o[s]],_toConsumableArray(o.slice(e+1,s)),[o[e]],_toConsumableArray(o.slice(s+1))));this.setFormState({values:a})},setAllTouched:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0],e=arguments[1];this.setFormState(_extends({},e,{dirty:!!t}))},resetForm:function(){return this.setFormState(this.getInitialState())},submitForm:function(t){t&&t.preventDefault&&t.preventDefault(t);var e=this.state,s=this.validate(e.values,e,this.props);if(s)return e.dirty||this.setAllTouched(!0,{errors:s}),this.props.onValidationFail(e.values,e,this.props,this);var r=this.props.preSubmit(e.values,e,this.props,this);this.props.onSubmit(r,e,this.props,this),this.props.postSubmit(r,e,this.props,this)},getAPI:function(){return{setValue:this.setValue,getValue:this.getValue,setNestedError:this.setNestedError,getError:this.getError,setTouched:this.setTouched,getTouched:this.getTouched,addValue:this.addValue,removeValue:this.removeValue,swapValues:this.swapValues,setAllTouched:this.setAllTouched,resetForm:this.resetForm,submitForm:this.submitForm}},setFormState:function(t,e){var s=this;t&&t.values&&!t.errors&&(t.values=this.props.preValidate(t.values,t,this.props,this),t.errors=this.validate(t.values,t,this.props)),this.setState(t,function(){s.props.saveState(s.state,s.props,s),e||s.emitChange(s.state,s.props)})},emitChange:function(t,e){this.props.onChange(t,this.props,e,this)},validate:function(t,e,s){var r=this.props.validate(removeNestedErrorValues(t,this.state?this.state.nestedErrors:{}),e,s,this);return cleanErrors(r)},render:function(){var t=_extends({},this.props,this.state,this.getAPI()),e=t.component,s=t.children,r=_objectWithoutProperties(t,["component","children"]),o="function"==typeof s?s(r):s,a=e;return _react2.default.createElement(a,{className:"ReactForm"},o)}}); | ||
@@ -4,0 +4,0 @@ },{"./utils":14,"react":"react"}],2:[function(require,module,exports){ |
@@ -510,2 +510,15 @@ <div align="center"> | ||
#### component (string or component) | ||
- If set, the form will use this tag or component as the root for the form. | ||
- Defaults to 'div' | ||
- If using a custom component, make sure to pass through all props, including `children` for your form to render correctly | ||
- Example: | ||
```javascript | ||
<Form | ||
component={props => ( | ||
<CustomComponent {...props} /> | ||
)} | ||
> | ||
``` | ||
--- | ||
@@ -512,0 +525,0 @@ |
204454
1006
1036