New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

react-form

Package Overview
Dependencies
Maintainers
1
Versions
122
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-form - npm Package Compare versions

Comparing version 1.1.1 to 1.1.2

37

lib/form.js

@@ -61,7 +61,12 @@ 'use strict';

getInitialState: function getInitialState() {
var values = _extends({}, _utils2.default.clone(this.props.defaultValues), _utils2.default.clone(this.props.values));
return this.props.loadState(this.props) || {
values: values,
var _props = this.props,
defaultValues = _props.defaultValues,
values = _props.values,
loadState = _props.loadState;
var mergedValues = _extends({}, _utils2.default.clone(defaultValues), _utils2.default.clone(values));
return loadState(this.props, this) || {
values: mergedValues,
touched: {},
errors: this.validate(values),
errors: this.validate(mergedValues),
nestedErrors: {}

@@ -83,3 +88,3 @@ };

componentWillUnmount: function componentWillUnmount() {
this.props.willUnmount(this.state, this.props);
this.props.willUnmount(this.state, this.props, this);
},

@@ -151,2 +156,5 @@

},
resetForm: function resetForm() {
return this.setState(this.getInitialState());
},
submitForm: function submitForm(e) {

@@ -160,7 +168,7 @@ e && e.preventDefault && e.preventDefault(e);

}
return this.props.onValidationFail(state, this.props);
return this.props.onValidationFail(state.values, state, this.props, this);
}
var preSubmitValues = this.props.preSubmit(state.values, state, this.props);
this.props.onSubmit(preSubmitValues, state, this.props);
this.props.postSubmit(preSubmitValues, state, this.props);
var preSubmitValues = this.props.preSubmit(state.values, state, this.props, this);
this.props.onSubmit(preSubmitValues, state, this.props, this);
this.props.postSubmit(preSubmitValues, state, this.props, this);
},

@@ -182,2 +190,3 @@

setAllTouched: this.setAllTouched,
resetForm: this.resetForm,
submitForm: this.submitForm

@@ -190,7 +199,7 @@ };

if (newState && newState.values && !newState.errors) {
newState.values = this.props.preValidate(newState.values, newState, this.props);
newState.values = this.props.preValidate(newState.values, newState, this.props, this);
newState.errors = this.validate(newState.values, newState, this.props);
}
this.setState(newState, function () {
_this.props.saveState(_this.state, _this.props);
_this.props.saveState(_this.state, _this.props, _this);
if (!silent) {

@@ -202,6 +211,6 @@ _this.emitChange(_this.state, _this.props);

emitChange: function emitChange(state, initial) {
this.props.onChange(state, this.props, initial);
this.props.onChange(state, this.props, initial, this);
},
validate: function validate(values, state, props) {
var errors = this.props.validate(removeNestedErrorValues(values, this.state ? this.state.nestedErrors : {}), state, props);
var errors = this.props.validate(removeNestedErrorValues(values, this.state ? this.state.nestedErrors : {}), state, props, this);
return cleanErrors(errors);

@@ -267,2 +276,2 @@ },

}
//# 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","values","clone","props","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","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 values = Object.assign({}, _.clone(this.props.defaultValues), _.clone(this.props.values))\n    return this.props.loadState(this.props) || {\n      values,\n      touched: {},\n      errors: this.validate(values),\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)\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  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, this.props)\n    }\n    const preSubmitValues = this.props.preSubmit(state.values, state, this.props)\n    this.props.onSubmit(preSubmitValues, state, this.props)\n    this.props.postSubmit(preSubmitValues, state, this.props)\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      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)\n      newState.errors = this.validate(newState.values, newState, this.props)\n    }\n    this.setState(newState, () => {\n      this.props.saveState(this.state, this.props)\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)\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    )\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","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","setState","submitForm","e","preventDefault","preSubmitValues","newState","silent","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    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.setState(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"]}
{
"name": "react-form",
"version": "1.1.1",
"version": "1.1.2",
"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 r={};for(var s in t)e.indexOf(s)>=0||Object.prototype.hasOwnProperty.call(t,s)&&(r[s]=t[s]);return r}function _toConsumableArray(t){if(Array.isArray(t)){for(var e=0,r=Array(t.length);e<t.length;e++)r[e]=t[e];return r}return Array.from(t)}function cleanErrors(t){if(_utils2.default.isObject(t)){var e=_utils2.default.mapValues(t,cleanErrors),r=_utils2.default.pickBy(e,function(t){return t});return Object.keys(r).length?e:void 0}if(_utils2.default.isArray(t)){var s=t.map(cleanErrors),a=s.find(function(t){return t});return a?s:void 0}return t}function removeNestedErrorValues(t,e){var r=function t(r){var s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];if(!_utils2.default.get(e,s))return _utils2.default.isObject(r)?_utils2.default.mapValues(r,function(e,r){return t(e,[].concat(_toConsumableArray(s),[r]))}):_utils2.default.isArray(r)?r.map(function(e,r){return t(e,[].concat(_toConsumableArray(s),[r]))}):r};return r(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 r=arguments[e];for(var s in r)Object.prototype.hasOwnProperty.call(r,s)&&(t[s]=r[s])}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=_extends({},_utils2.default.clone(this.props.defaultValues),_utils2.default.clone(this.props.values));return this.props.loadState(this.props)||{values:t,touched:{},errors:this.validate(t),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)},setValue:function(t,e,r){var s=this.state,a=_utils2.default.set(s.values,t,e);if(r)return this.setFormState({values:a});var o=_utils2.default.set(s.touched,t);this.setFormState({values:a,touched:o})},getValue:function(t,e){var r=this.state,s=_utils2.default.get(r.values,t);return"undefined"!=typeof s?s:e},setNestedError:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],r=_utils2.default.set(this.state.nestedErrors,t,e);this.setFormState({nestedErrors:r})},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],r=_utils2.default.set(this.state.touched,t,e);this.setFormState({touched:r})},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 r=this.state,s=_utils2.default.set(r.values,t,[].concat(_toConsumableArray(_utils2.default.get(r.values,t,[])),[e]));this.setFormState({values:s})},removeValue:function(t,e){var r=this.state,s=_utils2.default.get(r.values,t,[]),a=_utils2.default.set(r.values,t,[].concat(_toConsumableArray(s.slice(0,e)),_toConsumableArray(s.slice(e+1))));this.setFormState({values:a})},swapValues:function(t,e,r){var s=this.state,a=_utils2.default.get(s.values,t,[]),o=_utils2.default.set(s.values,t,[].concat(_toConsumableArray(a.slice(0,e)),[a[r]],_toConsumableArray(a.slice(e+1,r)),[a[e]],_toConsumableArray(a.slice(r+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}))},submitForm:function(t){t&&t.preventDefault&&t.preventDefault(t);var e=this.state,r=this.validate(e.values,e,this.props);if(r)return e.dirty||this.setAllTouched(!0,{errors:r}),this.props.onValidationFail(e,this.props);var s=this.props.preSubmit(e.values,e,this.props);this.props.onSubmit(s,e,this.props),this.props.postSubmit(s,e,this.props)},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,submitForm:this.submitForm}},setFormState:function(t,e){var r=this;t&&t.values&&!t.errors&&(t.values=this.props.preValidate(t.values,t,this.props),t.errors=this.validate(t.values,t,this.props)),this.setState(t,function(){r.props.saveState(r.state,r.props),e||r.emitChange(r.state,r.props)})},emitChange:function(t,e){this.props.onChange(t,this.props,e)},validate:function(t,e,r){var s=this.props.validate(removeNestedErrorValues(t,this.state?this.state.nestedErrors:{}),e,r);return cleanErrors(s)},render:function(){var t=_extends({},this.props,this.state,this.getAPI()),e=t.children,r=_objectWithoutProperties(t,["children"]),s="function"==typeof e?e(r):e;return _react2.default.createElement("div",{className:"ReactForm"},s)}});
"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.setState(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)}});

@@ -4,0 +4,0 @@ },{"./utils":14,"react":"react"}],2:[function(require,module,exports){

@@ -41,2 +41,4 @@ <div align="center">

## [Webpack-Bin](http://www.webpackbin.com/V1AI--xtz)
## Table of Contents

@@ -423,7 +425,7 @@ - [Installation](#installation)

#### loadState (props)
#### loadState (props, instance)
- When a form mounts, `loadState` is called. If a saved form state object is returned, it will hydrate the form state from this object.
- An ideal callback to load the form state from an external state manager (Redux/MobX/other)
#### preValidate (values, state, props)
#### preValidate (values, state, props, instance)
- This method is a value filter that happens before each validation.

@@ -442,3 +444,3 @@ - Use it to scrub and/or clean your values before they are validated.

#### validate (values, state, props)
#### validate (values, state, props, instance)
- Using the current values, you may return an object of error strings that map 1:1 to any fields that do not meet any condition you specify

@@ -459,18 +461,18 @@ - Any falsey errors will be recursively stripped from the object you return, so if a field is valid, simply return a falsey value of your choice.

#### onValidationFail (values, state, props)
#### onValidationFail (values, state, props, instance)
- If and when a forms validation fails, you can handle it here
#### onChange (state, props, initial)
#### onChange (state, props, initial, instance)
- Called any time a form's `values` change
- If `initial` is set to true, this indicates that the component just mounted and is firing `onChange` for the first time (this is utilized by nested forms)
#### saveState (state, props)
#### saveState (state, props, instance)
- Called anytime a form's internal `state` is changed.
- An ideal callback to export/save the form state from an external state manager (Redux/MobX/other)
#### willUnmount (state, props)
#### willUnmount (state, props, instance)
- Called when a form is about to unmount
- An ideal callback to remove the form state from an external state manager (Redux/MobX/other)
#### preSubmit (state, props)
#### preSubmit (values, state, props, instance)
- This method is a value filter that happens after validation and before a successful submission.

@@ -489,3 +491,3 @@ - Use it to scrub and/or clean your values before they are submitted.

#### onSubmit (values, state, props)
#### onSubmit (values, state, props, instance)
- When a form is successfully submitted via [`submitForm`](#submitform-), this method will be called with the values of the parent form.

@@ -502,3 +504,3 @@ - Example:

#### postSubmit (values, state, props)
#### postSubmit (values, state, props, instance)
- After a form is successfully submitted via `submitForm`, this method will be called.

@@ -793,2 +795,17 @@ - Example:

#### resetForm ()
- Resets all of the values of the form back to it's default values.
- Example:
```javascript
<Form>
{({resetForm}) => {
return (
<button onClick={resetForm}>
Start over!
</button>
)
}}
</Form>
```
#### submitForm ()

@@ -795,0 +812,0 @@ - Submits the form with the following optional lifecycle events:

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc