UNPKG

mindstream-react-gravity-form

Version:

A component for including Gravity Forms on React apps via the Wordpress API

2 lines 13.9 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;var _react=_interopRequireDefault(require("react")),_InputLabel=_interopRequireDefault(require("../FormElements/InputLabel"));function _interopRequireDefault(a){return a&&a.__esModule?a:{default:a}}function asyncGeneratorStep(a,b,c,d,e,f,g){try{var h=a[f](g),i=h.value}catch(a){return void c(a)}h.done?b(i):Promise.resolve(i).then(d,e)}function _asyncToGenerator(a){return function(){var b=this,c=arguments;return new Promise(function(d,e){function f(a){asyncGeneratorStep(h,d,e,f,g,"next",a)}function g(a){asyncGeneratorStep(h,d,e,f,g,"throw",a)}var h=a.apply(b,c);f(void 0)})}}function _objectWithoutProperties(a,b){if(null==a)return{};var c,d,e=_objectWithoutPropertiesLoose(a,b);if(Object.getOwnPropertySymbols){var f=Object.getOwnPropertySymbols(a);for(d=0;d<f.length;d++)c=f[d],!(0<=b.indexOf(c))&&Object.prototype.propertyIsEnumerable.call(a,c)&&(e[c]=a[c])}return e}function _objectWithoutPropertiesLoose(a,b){if(null==a)return{};var c,d,e={},f=Object.keys(a);for(d=0;d<f.length;d++)c=f[d],0<=b.indexOf(c)||(e[c]=a[c]);return e}var postcodeApi=require("postcode-nl").promises,_default=function(a){function b(){return c.apply(this,arguments)}function c(){return c=_asyncToGenerator(regeneratorRuntime.mark(function a(b){var c,d;return regeneratorRuntime.wrap(function(a){for(;;)switch(a.prev=a.next){case 0:if(f=b.target?b.target.value.toUpperCase():null,c){a.next=8;break}return a.next=4,L(f)["catch"](function(){c=!1});case 4:d=a.sent,d&&(c=!0,l({target:{value:f},street:d.street,city:d.city.label},e)),a.next=9;break;case 8:c=!1;case 9:case"end":return a.stop();}},a)})),c.apply(this,arguments)}var d=a.formValues,e=a.field,f=a.value,g=a.validationMessage,h=a.touched,i=a.setTouched,j=a.setErrorMessages,k=a.hideField,l=a.updateForm,m=a.styledComponents,n=a.error,o=a.unsetError,p=a.setFocusClass,q=a.cssClass,r=a.apiKeys,s=_objectWithoutProperties(a,["formValues","field","value","validationMessage","touched","setTouched","setErrorMessages","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass","apiKeys"]),t=e.id,u=e.formId,v=e.type,w=e.label,x=e.placeholder,y=e.isRequired,z=e.description,A=e.descriptionPlacement,B=e.labelPlacement,C=e.width,D=e.customName,E=m||!1,F=E.Input,G=void 0===F?"input":F,H=E.Label,I=void 0===H?"label":H,J=E.Box,K=void 0===J?"div":J,L=function(a){var b={returnRateLimit:!0,apiKey:r.postcode},c={postcode:a};return new Promise(function(a,d){postcodeApi.getAddresses(b,c).then(function(b){a(b.result._embedded.addresses[0])})["catch"](function(a){d(a)})})};return _react["default"].createElement(K,{width:C,className:g&&h||n?"form-field error ".concat(q):"form-field ".concat(q),style:{display:k?"none":void 0}},_react["default"].createElement("div",{className:v},_react["default"].createElement(_InputLabel["default"],{formId:u,id:t,label:w,labelPlacement:B,isRequired:y,styledComponent:m}),"above"===A&&z&&_react["default"].createElement("div",{className:"description"},z),_react["default"].createElement(G,{id:"input_".concat(u,"_").concat(t),name:D||"input_".concat(t),type:v,value:f?f:"",placeholder:x,maxLength:6,required:y,onChange:function onChange(a){l(a,e),o(t)},onBlur:function onBlur(a){l(a,e),b(a),i(t),p(""!==f)},onFocus:function onFocus(){return p(!0)},"aria-label":w,"aria-describedby":"error_".concat(u,"_").concat(t),"aria-invalid":!!g&&h||!!n}),"above"!==A&&z&&_react["default"].createElement("div",{className:"description"},z),(g&&h||n)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(u,"_").concat(t)},g||n)))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Postcode.jsx"],"names":["postcodeApi","require","promises","getAddress","event","value","target","toUpperCase","hasAddress","getAddressByPostalCode","response","updateForm","street","city","label","field","formValues","validationMessage","touched","setTouched","setErrorMessages","hideField","styledComponents","error","unsetError","setFocusClass","cssClass","apiKeys","props","id","formId","type","placeholder","isRequired","description","descriptionPlacement","labelPlacement","width","customName","Input","Label","Box","postalCode","options","returnRateLimit","apiKey","postcode","query","Promise","resolve","reject","getAddresses","then","resolved","result","_embedded","addresses","display"],"mappings":"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","sourcesContent":["import React from 'react';\n\nimport InputLabel from '../FormElements/InputLabel';\n\nconst postcodeApi = require('postcode-nl').promises;\n\nexport default ({\n  formValues,\n  field,\n  value,\n  validationMessage,\n  touched,\n  setTouched,\n  setErrorMessages,\n  hideField,\n  updateForm,\n  styledComponents,\n  error,\n  unsetError,\n  setFocusClass,\n  cssClass,\n  apiKeys,\n  ...props\n}) => {\n  const {\n    id,\n    formId,\n    type,\n    label,\n    placeholder,\n    isRequired,\n    description,\n    descriptionPlacement,\n    labelPlacement,\n    width,\n    customName,\n  } = field;\n  const { Input = 'input', Label = 'label', Box = 'div' } = styledComponents || false;\n\n  const getAddressByPostalCode = (postalCode) => {\n    const options = {\n      returnRateLimit: true,\n      apiKey: apiKeys.postcode,\n    };\n    const query = {\n      postcode: postalCode,\n    };\n    return new Promise(((resolve, reject) => {\n      postcodeApi\n        .getAddresses(options, query)\n        .then((resolved) => {\n          resolve(resolved.result._embedded.addresses[0]);\n        })\n        .catch((error) => {\n          reject(error);\n        });\n    }));\n  };\n\n  async function getAddress(\n    event,\n  ) {\n    value = event.target ? event.target.value.toUpperCase() : null;\n    let hasAddress;\n    if (!hasAddress) {\n      let response;\n      response = await getAddressByPostalCode(value).catch((err) => {\n        hasAddress = false;\n      });\n\n      if (response) {\n        hasAddress = true;\n        updateForm(\n          {\n            target: {\n              value,\n            },\n            street: response.street,\n            city: response.city.label,\n          },\n          field,\n        );\n      }\n    } else {\n      hasAddress = false;\n    }\n  }\n\n  return (\n    <Box\n      width={width}\n      className={\n        (validationMessage && touched) || error\n          ? `form-field error ${cssClass}`\n          : `form-field ${cssClass}`\n      }\n      style={{ display: hideField ? 'none' : undefined }}\n    >\n      <div className={type}>\n        <InputLabel\n          formId={formId}\n          id={id}\n          label={label}\n          labelPlacement={labelPlacement}\n          isRequired={isRequired}\n          styledComponent={styledComponents}\n        />\n        {descriptionPlacement === 'above' && description && (\n          <div className=\"description\">{description}</div>\n        )}\n        <Input\n          id={`input_${formId}_${id}`}\n          name={customName || `input_${id}`}\n          type={type}\n          value={!value ? '' : value}\n          placeholder={placeholder}\n          maxLength={6}\n          required={isRequired}\n          onChange={(event) => {\n            updateForm(event, field);\n            unsetError(id);\n          }}\n          onBlur={(event) => {\n            updateForm(event, field);\n            getAddress(event);\n            setTouched(id);\n            setFocusClass(value !== '');\n          }}\n          onFocus={() => setFocusClass(true)}\n          aria-label={label}\n          aria-describedby={`error_${formId}_${id}`}\n          aria-invalid={(!!validationMessage && touched) || !!error}\n        />\n        {descriptionPlacement !== 'above' && description && <div className=\"description\">{description}</div>}\n        {((validationMessage && touched) || error) && (\n          <span className=\"error-message\" id={`error_${formId}_${id}`}>\n            {validationMessage || error}\n          </span>\n        )}\n      </div>\n    </Box>\n  );\n};\n"]}