react-form-ali
Advanced tools
Comparing version 0.12.0 to 0.12.1
@@ -77,2 +77,10 @@ 'use strict'; | ||
componentWillReceiveProps: function componentWillReceiveProps(props) { | ||
if (props.addErrors) { | ||
this.setFormState({ | ||
errors: _utils2.default.clone(props.addErrors) || {} | ||
}, true); | ||
this.setAllTouched(); | ||
return; | ||
} | ||
if (props.values === this.props.values) { | ||
@@ -83,3 +91,4 @@ return; | ||
this.setFormState({ | ||
values: _utils2.default.clone(props.values) || {} | ||
values: _utils2.default.clone(props.values) || {}, | ||
errors: _utils2.default.clone(props.addErrors) || {} | ||
}, true); | ||
@@ -165,3 +174,2 @@ }, | ||
this.props.postSubmit(preSubmitValues, state, this.props); | ||
this.setState({ errors: this.props.addErrors }); | ||
}, | ||
@@ -258,2 +266,2 @@ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/form.js"],"names":["Form","noop","reop","d","FormDefaultProps","loadState","defaultValues","preValidate","validate","onValidationFail","onChange","saveState","willUnmount","preSubmit","onSubmit","postSubmit","addErrors","config","Comp","createClass","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","setState","newState","silent","initial","removeNestedErrorValues","cleanErrors","render","err","isObject","resolved","mapValues","found","pickBy","Object","keys","length","undefined","isArray","map","find","recurse","path","i","key"],"mappings":";;;;;;;;;kBAqBwBA,I;;AArBxB;;;;AACA;;;;;;;;AAEA,IAAMC,OAAO,SAAPA,IAAO,GAAM,CAAE,CAArB;AACA,IAAMC,OAAO,SAAPA,IAAO;AAAA,SAAKC,CAAL;AAAA,CAAb;;AAEO,IAAMC,8CAAmB;AAC9BC,aAAWJ,IADmB;AAE9BK,iBAAe,EAFe;AAG9BC,eAAaL,IAHiB;AAI9BM,YAAU;AAAA,WAAM,IAAN;AAAA,GAJoB;AAK9BC,oBAAkBR,IALY;AAM9BS,YAAUT,IANoB;AAO9BU,aAAWV,IAPmB;AAQ9BW,eAAaX,IARiB;AAS9BY,aAAWX,IATmB;AAU9BY,YAAUb,IAVoB;AAW9Bc,cAAYd,IAXkB;AAY9Be,aAAW;AAZmB,CAAzB;;AAeQ,SAAShB,IAAT,GAA4B;AAAA,MAAbiB,MAAa,uEAAJ,EAAI;;AACzC,SAAO,UAACC,IAAD,EAAU;AACf,WAAO,gBAAMC,WAAN,CAAkB;AACvBC,yBAAmB;AACjBC,iBAAS,gBAAMC,SAAN,CAAgBC;AADR,OADI;AAIvBC,qBAJuB,6BAIJ;AACjB,eAAO;AACLH,mBAAS,KAAKI,MAAL;AADJ,SAAP;AAGD,OARsB;;AASvB;AACAC,qBAVuB,6BAUJ;AACjB,eAAO,SAAc,EAAd,EAAkBtB,gBAAlB,EAAoCa,MAApC,CAAP;AACD,OAZsB;AAavBU,qBAbuB,6BAaJ;AACjB,YAAMC,SAAS,SAAc,EAAd,EAAkB,gBAAEC,KAAF,CAAQZ,OAAOX,aAAf,CAAlB,EAAiD,gBAAEuB,KAAF,CAAQ,KAAKC,KAAL,CAAWF,MAAnB,CAAjD,CAAf;AACA,eAAO,KAAKE,KAAL,CAAWzB,SAAX,CAAqB,KAAKyB,KAA1B,KAAoC;AACzCF,wBADyC;AAEzCG,mBAAS,EAFgC;AAGzCC,kBAAQ,KAAKxB,QAAL,CAAcoB,MAAd,CAHiC;AAIzCK,wBAAc;AAJ2B,SAA3C;AAMD,OArBsB;AAsBvBC,wBAtBuB,gCAsBD;AACpB,aAAKC,UAAL,CAAgB,KAAKC,KAArB,EAA4B,IAA5B;AACD,OAxBsB;AAyBvBC,+BAzBuB,qCAyBIP,KAzBJ,EAyBW;AAChC,YAAIA,MAAMF,MAAN,KAAiB,KAAKE,KAAL,CAAWF,MAAhC,EAAwC;AACtC;AACD;;AAED,aAAKU,YAAL,CAAkB;AAChBV,kBAAQ,gBAAEC,KAAF,CAAQC,MAAMF,MAAd,KAAyB;AADjB,SAAlB,EAEG,IAFH;AAGD,OAjCsB;AAkCvBW,0BAlCuB,kCAkCC;AACtB,aAAKT,KAAL,CAAWlB,WAAX,CAAuB,KAAKwB,KAA5B,EAAmC,KAAKN,KAAxC;AACD,OApCsB;;;AAsCvB;AACAU,cAvCuB,oBAuCbC,KAvCa,EAuCNC,KAvCM,EAuCCC,OAvCD,EAuCU;AAC/B,YAAMP,QAAQ,KAAKA,KAAnB;AACA,YAAMR,SAAS,gBAAEgB,GAAF,CAAMR,MAAMR,MAAZ,EAAoBa,KAApB,EAA2BC,KAA3B,CAAf;AACA;AACA,YAAIC,OAAJ,EAAa;AACX,iBAAO,KAAKL,YAAL,CAAkB,EAACV,cAAD,EAAlB,CAAP;AACD;AACD,YAAMG,UAAU,gBAAEa,GAAF,CAAMR,MAAML,OAAZ,EAAqBU,KAArB,EAA4BC,KAA5B,CAAhB;AACA,aAAKJ,YAAL,CAAkB,EAACV,cAAD,EAASG,gBAAT,EAAlB;AACD,OAhDsB;AAiDvBc,cAjDuB,oBAiDbJ,KAjDa,EAiDNK,QAjDM,EAiDI;AACzB,YAAMV,QAAQ,KAAKA,KAAnB;AACA,YAAMW,MAAM,gBAAEC,GAAF,CAAMZ,MAAMR,MAAZ,EAAoBa,KAApB,CAAZ;AACA,eAAO,OAAOM,GAAP,KAAe,WAAf,GAA6BA,GAA7B,GAAmCD,QAA1C;AACD,OArDsB;AAsDvBG,oBAtDuB,0BAsDPR,KAtDO,EAsDc;AAAA,YAAdC,KAAc,uEAAN,IAAM;;AACnC,YAAMT,eAAe,gBAAEW,GAAF,CAAM,KAAKR,KAAL,CAAWH,YAAjB,EAA+BQ,KAA/B,EAAsCC,KAAtC,CAArB;AACA,aAAKJ,YAAL,CAAkB,EAACL,0BAAD,EAAlB;AACD,OAzDsB;AA0DvBiB,cA1DuB,oBA0DbT,KA1Da,EA0DN;AACf,eAAO,gBAAEO,GAAF,CAAM,KAAKZ,KAAL,CAAWJ,MAAjB,EAAyBS,KAAzB,CAAP;AACD,OA5DsB;AA6DvBU,gBA7DuB,sBA6DXV,KA7DW,EA6DU;AAAA,YAAdC,KAAc,uEAAN,IAAM;;AAC/B,YAAMX,UAAU,gBAAEa,GAAF,CAAM,KAAKR,KAAL,CAAWL,OAAjB,EAA0BU,KAA1B,EAAiCC,KAAjC,CAAhB;AACA,aAAKJ,YAAL,CAAkB,EAACP,gBAAD,EAAlB;AACD,OAhEsB;AAiEvBqB,gBAjEuB,sBAiEXX,KAjEW,EAiEJ;AACjB,YAAML,QAAQ,KAAKA,KAAnB;AACA,YAAI,KAAKA,KAAL,CAAWiB,KAAX,KAAqB,IAArB,IAA6B,KAAKvB,KAAL,CAAWC,OAAX,KAAuB,IAAxD,EAA8D;AAC5D,iBAAO,IAAP;AACD;AACD,eAAO,gBAAEiB,GAAF,CAAMZ,MAAML,OAAZ,EAAqBU,KAArB,CAAP;AACD,OAvEsB;AAwEvBa,cAxEuB,oBAwEbb,KAxEa,EAwENC,KAxEM,EAwEC;AACtB,YAAMN,QAAQ,KAAKA,KAAnB;AACA,YAAMR,SAAS,gBAAEgB,GAAF,CAAMR,MAAMR,MAAZ,EAAoBa,KAApB,+BACV,gBAAEO,GAAF,CAAMZ,MAAMR,MAAZ,EAAoBa,KAApB,EAA2B,EAA3B,CADU,IAEbC,KAFa,GAAf;AAIA,aAAKJ,YAAL,CAAkB,EAACV,cAAD,EAAlB;AACD,OA/EsB;AAgFvB2B,iBAhFuB,uBAgFVd,KAhFU,EAgFHe,KAhFG,EAgFI;AACzB,YAAMpB,QAAQ,KAAKA,KAAnB;AACA,YAAMqB,aAAa,gBAAET,GAAF,CAAMZ,MAAMR,MAAZ,EAAoBa,KAApB,EAA2B,EAA3B,CAAnB;AACA,YAAMb,SAAS,gBAAEgB,GAAF,CAAMR,MAAMR,MAAZ,EAAoBa,KAApB,+BACVgB,WAAWC,KAAX,CAAiB,CAAjB,EAAoBF,KAApB,CADU,sBAEVC,WAAWC,KAAX,CAAiBF,QAAQ,CAAzB,CAFU,GAAf;AAIA,aAAKlB,YAAL,CAAkB,EAACV,cAAD,EAAlB;AACD,OAxFsB;AAyFvB+B,gBAzFuB,sBAyFXlB,KAzFW,EAyFJe,KAzFI,EAyFGI,SAzFH,EAyFc;AACnC,YAAMxB,QAAQ,KAAKA,KAAnB;AACA,YAAMyB,cAAc,gBAAEb,GAAF,CAAMZ,MAAMR,MAAZ,EAAoBa,KAApB,EAA2B,EAA3B,CAApB;AACA,YAAMb,SAAS,gBAAEgB,GAAF,CAAMR,MAAMR,MAAZ,EAAoBa,KAApB,+BACVoB,YAAYH,KAAZ,CAAkB,CAAlB,EAAqBF,KAArB,CADU,IAEbK,YAAYD,SAAZ,CAFa,sBAGVC,YAAYH,KAAZ,CAAkBF,QAAQ,CAA1B,EAA6BI,SAA7B,CAHU,IAIbC,YAAYL,KAAZ,CAJa,sBAKVK,YAAYH,KAAZ,CAAkBE,YAAY,CAA9B,CALU,GAAf;AAOA,aAAKtB,YAAL,CAAkB,EAACV,cAAD,EAAlB;AACD,OApGsB;AAqGvBkC,mBArGuB,2BAqGM;AAAA,YAAdT,KAAc,uEAAN,IAAM;;AAC3B,aAAKf,YAAL,CAAkB,EAACe,OAAO,CAAC,CAACA,KAAV,EAAlB;AACD,OAvGsB;AAwGvBU,gBAxGuB,sBAwGXC,CAxGW,EAwGR;AACbA,aAAKA,EAAEC,cAAP,IAAyBD,EAAEC,cAAF,CAAiBD,CAAjB,CAAzB;AACA,YAAM5B,QAAQ,KAAKA,KAAnB;AACA,YAAMJ,SAAS,KAAKxB,QAAL,CAAc4B,MAAMR,MAApB,EAA4BQ,KAA5B,EAAmC,KAAKN,KAAxC,CAAf;AACA,YAAIE,MAAJ,EAAY;AACV,cAAI,CAACI,MAAMiB,KAAX,EAAkB;AAChB,iBAAKS,aAAL;AACD;AACD,iBAAO,KAAKhC,KAAL,CAAWrB,gBAAX,CAA4B2B,KAA5B,EAAmC,KAAKN,KAAxC,CAAP;AACD;AACD,YAAMoC,kBAAkB,KAAKpC,KAAL,CAAWjB,SAAX,CAAqBuB,MAAMR,MAA3B,EAAmCQ,KAAnC,EAA0C,KAAKN,KAA/C,CAAxB;AACA,aAAKA,KAAL,CAAWhB,QAAX,CAAoBoD,eAApB,EAAqC9B,KAArC,EAA4C,KAAKN,KAAjD;AACA,aAAKA,KAAL,CAAWf,UAAX,CAAsBmD,eAAtB,EAAuC9B,KAAvC,EAA8C,KAAKN,KAAnD;AACA,aAAKqC,QAAL,CAAc,EAACnC,QAAQ,KAAKF,KAAL,CAAWd,SAApB,EAAd;AACD,OAtHsB;;;AAwHvB;AACAS,YAzHuB,oBAyHb;AACR,eAAO;AACLe,oBAAU,KAAKA,QADV;AAELK,oBAAU,KAAKA,QAFV;AAGLI,0BAAgB,KAAKA,cAHhB;AAILC,oBAAU,KAAKA,QAJV;AAKLC,sBAAY,KAAKA,UALZ;AAMLC,sBAAY,KAAKA,UANZ;AAOLE,oBAAU,KAAKA,QAPV;AAQLC,uBAAa,KAAKA,WARb;AASLI,sBAAY,KAAKA,UATZ;AAULG,yBAAe,KAAKA,aAVf;AAWLC,sBAAY,KAAKA;AAXZ,SAAP;AAaD,OAvIsB;AAwIvBzB,kBAxIuB,wBAwIT8B,QAxIS,EAwICC,MAxID,EAwIS;AAAA;;AAC9B,YAAID,YAAYA,SAASxC,MAAzB,EAAiC;AAC/BwC,mBAASxC,MAAT,GAAkB,KAAKE,KAAL,CAAWvB,WAAX,CAAuB6D,SAASxC,MAAhC,EAAwCwC,QAAxC,EAAkD,KAAKtC,KAAvD,CAAlB;AACAsC,mBAASpC,MAAT,GAAkB,KAAKxB,QAAL,CAAc4D,SAASxC,MAAvB,EAA+BwC,QAA/B,EAAyC,KAAKtC,KAA9C,CAAlB;AACD;AACD,aAAKqC,QAAL,CAAcC,QAAd,EAAwB,YAAM;AAC5B,gBAAKtC,KAAL,CAAWnB,SAAX,CAAqB,MAAKyB,KAA1B,EAAiC,MAAKN,KAAtC;AACA,cAAI,CAACuC,MAAL,EAAa;AACX,kBAAKlC,UAAL,CAAgB,MAAKC,KAArB,EAA4B,MAAKN,KAAjC;AACD;AACF,SALD;AAMD,OAnJsB;AAoJvBK,gBApJuB,sBAoJXC,KApJW,EAoJJkC,OApJI,EAoJK;AAC1B,aAAKxC,KAAL,CAAWpB,QAAX,CAAoB0B,KAApB,EAA2B,KAAKN,KAAhC,EAAuCwC,OAAvC;AACD,OAtJsB;AAuJvB9D,cAvJuB,oBAuJboB,MAvJa,EAuJLQ,KAvJK,EAuJEN,KAvJF,EAuJS;AAC9B,YAAME,SAAS,KAAKF,KAAL,CAAWtB,QAAX,CACb+D,wBAAwB3C,MAAxB,EAAgC,KAAKQ,KAAL,GAAa,KAAKA,KAAL,CAAWH,YAAxB,GAAuC,EAAvE,CADa,EAC+DG,KAD/D,EACsEN,KADtE,CAAf;AAGA,eAAO0C,YAAYxC,MAAZ,CAAP;AACD,OA5JsB;;AA6JvB;AACAyC,YA9JuB,oBA8Jb;AACR,YAAM3C,qBACD,KAAKA,KADJ,EAED,KAAKM,KAFJ,EAGD,KAAKX,MAAL,EAHC,CAAN;AAKA,eACE,8BAAC,IAAD,EAAUK,KAAV,CADF;AAGD;AAvKsB,KAAlB,CAAP;AAyKD,GA1KD;AA2KD;;AAED;;AAEA,SAAS0C,WAAT,CAAsBE,GAAtB,EAA2B;AACzB,MAAI,gBAAEC,QAAF,CAAWD,GAAX,CAAJ,EAAqB;AACnB,QAAME,WAAW,gBAAEC,SAAF,CAAYH,GAAZ,EAAiBF,WAAjB,CAAjB;AACA,QAAMM,QAAQ,gBAAEC,MAAF,CAASH,QAAT,EAAmB;AAAA,aAAKzE,CAAL;AAAA,KAAnB,CAAd;AACA,WAAO6E,OAAOC,IAAP,CAAYH,KAAZ,EAAmBI,MAAnB,GAA4BN,QAA5B,GAAuCO,SAA9C;AACD;AACD,MAAI,gBAAEC,OAAF,CAAUV,GAAV,CAAJ,EAAoB;AAClB,QAAME,YAAWF,IAAIW,GAAJ,CAAQb,WAAR,CAAjB;AACA,QAAMM,SAAQF,UAASU,IAAT,CAAc;AAAA,aAAKnF,CAAL;AAAA,KAAd,CAAd;AACA,WAAO2E,SAAQF,SAAR,GAAmBO,SAA1B;AACD;AACD,SAAOT,GAAP;AACD;;AAED,SAASH,uBAAT,CAAkC7B,KAAlC,EAAyCT,YAAzC,EAAuD;AACrD,MAAMsD,UAAU,SAAVA,OAAU,CAAC7C,KAAD,EAAsB;AAAA,QAAd8C,IAAc,uEAAP,EAAO;;AACpC,QAAI,gBAAExC,GAAF,CAAMf,YAAN,EAAoBuD,IAApB,CAAJ,EAA+B;AAC7B,aAAOL,SAAP;AACD;AACD,QAAI,gBAAER,QAAF,CAAWjC,KAAX,CAAJ,EAAuB;AACrB,aAAO,gBAAEmC,SAAF,CAAYnC,KAAZ,EAAmB,UAACvC,CAAD,EAAIsF,CAAJ,EAAU;AAClC,eAAOF,QAAQpF,CAAR,+BAAeqF,IAAf,IAAqBC,CAArB,GAAP;AACD,OAFM,CAAP;AAGD;AACD,QAAI,gBAAEL,OAAF,CAAU1C,KAAV,CAAJ,EAAsB;AACpB,aAAOA,MAAM2C,GAAN,CAAU,UAAClF,CAAD,EAAIuF,GAAJ,EAAY;AAC3B,eAAOH,QAAQpF,CAAR,+BAAeqF,IAAf,IAAqBE,GAArB,GAAP;AACD,OAFM,CAAP;AAGD;AACD,WAAOhD,KAAP;AACD,GAfD;AAgBA,SAAO6C,QAAQ7C,KAAR,CAAP;AACD","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  addErrors: {}\n}\n\nexport default function Form (config = {}) {\n  return (Comp) => {\n    return React.createClass({\n      childContextTypes: {\n        formAPI: React.PropTypes.object\n      },\n      getChildContext () {\n        return {\n          formAPI: this.getAPI()\n        }\n      },\n      // Lifecycle\n      getDefaultProps () {\n        return Object.assign({}, FormDefaultProps, config)\n      },\n      getInitialState () {\n        const values = Object.assign({}, _.clone(config.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, value)\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) {\n        this.setFormState({dirty: !!dirty})\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()\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        this.setState({errors: this.props.addErrors})\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) {\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 : {}), state, 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        return (\n          <Comp {...props} />\n        )\n      }\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":["Form","noop","reop","d","FormDefaultProps","loadState","defaultValues","preValidate","validate","onValidationFail","onChange","saveState","willUnmount","preSubmit","onSubmit","postSubmit","addErrors","config","Comp","createClass","childContextTypes","formAPI","PropTypes","object","getChildContext","getAPI","getDefaultProps","getInitialState","values","clone","props","touched","errors","nestedErrors","componentWillMount","emitChange","state","componentWillReceiveProps","setFormState","setAllTouched","componentWillUnmount","setValue","field","value","noTouch","set","getValue","fallback","val","get","setNestedError","getError","setTouched","getTouched","dirty","addValue","removeValue","index","fieldValue","slice","swapValues","destIndex","fieldValues","submitForm","e","preventDefault","preSubmitValues","newState","silent","setState","initial","removeNestedErrorValues","cleanErrors","render","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  addErrors: {}\n}\n\nexport default function Form (config = {}) {\n  return (Comp) => {\n    return React.createClass({\n      childContextTypes: {\n        formAPI: React.PropTypes.object\n      },\n      getChildContext () {\n        return {\n          formAPI: this.getAPI()\n        }\n      },\n      // Lifecycle\n      getDefaultProps () {\n        return Object.assign({}, FormDefaultProps, config)\n      },\n      getInitialState () {\n        const values = Object.assign({}, _.clone(config.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.addErrors) {\n          this.setFormState({\n            errors: _.clone(props.addErrors) || {}\n          }, true)\n          this.setAllTouched()\n          return\n        }\n\n        if (props.values === this.props.values) {\n          return\n        }\n\n        this.setFormState({\n          values: _.clone(props.values) || {},\n          errors: _.clone(props.addErrors) || {}\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, value)\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) {\n        this.setFormState({dirty: !!dirty})\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()\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) {\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 : {}), state, 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        return (\n          <Comp {...props} />\n        )\n      }\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-ali", | ||
"version": "0.12.0", | ||
"version": "0.12.1", | ||
"description": "A fast, lightweight, opinionated table and datagrid built on React-Form", | ||
@@ -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 _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 Form(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function(e){return _react2.default.createClass({childContextTypes:{formAPI:_react2.default.PropTypes.object},getChildContext:function(){return{formAPI:this.getAPI()}},getDefaultProps:function(){return _extends({},FormDefaultProps,t)},getInitialState:function(){var e=_extends({},_utils2.default.clone(t.defaultValues),_utils2.default.clone(this.props.values));return this.props.loadState(this.props)||{values:e,touched:{},errors:this.validate(e),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,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,e);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];this.setFormState({dirty:!!t})},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(),this.props.onValidationFail(e,this.props);var r=this.props.preSubmit(e.values,e,this.props);this.props.onSubmit(r,e,this.props),this.props.postSubmit(r,e,this.props),this.setState({errors:this.props.addErrors})},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 s=this;t&&t.values&&(t.values=this.props.preValidate(t.values,t,this.props),t.errors=this.validate(t.values,t,this.props)),this.setState(t,function(){s.props.saveState(s.state,s.props),e||s.emitChange(s.state,s.props)})},emitChange:function(t,e){this.props.onChange(t,this.props,e)},validate:function(t,e,s){var r=this.props.validate(removeNestedErrorValues(t,this.state?this.state.nestedErrors:{}),e,s);return cleanErrors(r)},render:function(){var t=_extends({},this.props,this.state,this.getAPI());return _react2.default.createElement(e,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};exports.default=Form;var _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,addErrors:{}}; | ||
"use strict";function _interopRequireDefault(t){return t&&t.__esModule?t:{default:t}}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 Form(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function(e){return _react2.default.createClass({childContextTypes:{formAPI:_react2.default.PropTypes.object},getChildContext:function(){return{formAPI:this.getAPI()}},getDefaultProps:function(){return _extends({},FormDefaultProps,t)},getInitialState:function(){var e=_extends({},_utils2.default.clone(t.defaultValues),_utils2.default.clone(this.props.values));return this.props.loadState(this.props)||{values:e,touched:{},errors:this.validate(e),nestedErrors:{}}},componentWillMount:function(){this.emitChange(this.state,!0)},componentWillReceiveProps:function(t){return t.addErrors?(this.setFormState({errors:_utils2.default.clone(t.addErrors)||{}},!0),void this.setAllTouched()):void(t.values!==this.props.values&&this.setFormState({values:_utils2.default.clone(t.values)||{},errors:_utils2.default.clone(t.addErrors)||{}},!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,e);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];this.setFormState({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(),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.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());return _react2.default.createElement(e,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};exports.default=Form;var _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,addErrors:{}}; | ||
@@ -4,0 +4,0 @@ },{"./utils":12,"react":"react"}],2:[function(require,module,exports){ |
189912
879