UNPKG

mindstream-react-gravity-form

Version:

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

2 lines 20.6 kB
"use strict";var _react=_interopRequireWildcard(require("react"));function _typeof(a){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},_typeof(a)}Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;function _getRequireWildcardCache(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;return _getRequireWildcardCache=function(){return a},a}function _interopRequireWildcard(a){if(a&&a.__esModule)return a;if(null===a||"object"!==_typeof(a)&&"function"!=typeof a)return{default:a};var b=_getRequireWildcardCache();if(b&&b.has(a))return b.get(a);var c={},d=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var e in a)if(Object.prototype.hasOwnProperty.call(a,e)){var f=d?Object.getOwnPropertyDescriptor(a,e):null;f&&(f.get||f.set)?Object.defineProperty(c,e,f):c[e]=a[e]}return c["default"]=a,b&&b.set(a,c),c}function ownKeys(a,b){var c=Object.keys(a);if(Object.getOwnPropertySymbols){var d=Object.getOwnPropertySymbols(a);b&&(d=d.filter(function(b){return Object.getOwnPropertyDescriptor(a,b).enumerable})),c.push.apply(c,d)}return c}function _objectSpread(a){for(var b,c=1;c<arguments.length;c++)b=null==arguments[c]?{}:arguments[c],c%2?ownKeys(Object(b),!0).forEach(function(c){_defineProperty(a,c,b[c])}):Object.getOwnPropertyDescriptors?Object.defineProperties(a,Object.getOwnPropertyDescriptors(b)):ownKeys(Object(b)).forEach(function(c){Object.defineProperty(a,c,Object.getOwnPropertyDescriptor(b,c))});return a}function _defineProperty(a,b,c){return b in a?Object.defineProperty(a,b,{value:c,enumerable:!0,configurable:!0,writable:!0}):a[b]=c,a}function _slicedToArray(a,b){return _arrayWithHoles(a)||_iterableToArrayLimit(a,b)||_unsupportedIterableToArray(a,b)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(a,b){if(a){if("string"==typeof a)return _arrayLikeToArray(a,b);var c=Object.prototype.toString.call(a).slice(8,-1);return"Object"===c&&a.constructor&&(c=a.constructor.name),"Map"===c||"Set"===c?Array.from(a):"Arguments"===c||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(c)?_arrayLikeToArray(a,b):void 0}}function _arrayLikeToArray(a,b){(null==b||b>a.length)&&(b=a.length);for(var c=0,d=Array(b);c<b;c++)d[c]=a[c];return d}function _iterableToArrayLimit(a,b){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(a)){var c=[],d=!0,e=!1,f=void 0;try{for(var g,h=a[Symbol.iterator]();!(d=(g=h.next()).done)&&(c.push(g.value),!(b&&c.length===b));d=!0);}catch(a){e=!0,f=a}finally{try{d||null==h["return"]||h["return"]()}finally{if(e)throw f}}return c}}function _arrayWithHoles(a){if(Array.isArray(a))return a}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 _default=function(a){var b=a.field,c=a.value,d=a.validationMessage,e=a.touched,f=a.setTouched,g=a.hideField,h=a.updateForm,i=a.styledComponents,j=a.error,k=a.unsetError,l=a.cssClass,m=a.setFocusClass,n=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","cssClass","setFocusClass"]),o=b.id,p=b.formId,q=b.type,r=b.label,s=b.placeholder,t=b.isRequired,u=b.maxLength,v=b.description,w=b.descriptionPlacement,x=b.labelPlacement,y=b.width,z=b.customName,A=b.emailConfirmEnabled,B=b.inputs,C=(0,_react.useState)(B),D=_slicedToArray(C,2),E=D[0],F=D[1],G=function(a,b){var c=_objectSpread({},E);c[b]&&(c[b].cssClass=a&&c&&0<!!c.length?"filled":"",F(c))},H=i||!1,I=H.Input,J=void 0===I?"input":I,K=H.Label,L=void 0===K?"label":K,M=H.Box,N=void 0===M?"div":M;return _react["default"].createElement(N,{width:y,className:d&&e||j?"form-field error ".concat(l):"form-field ".concat(l),style:{display:g?"none":void 0}},_react["default"].createElement("div",{className:q},_react["default"].createElement(L,{htmlFor:"input_".concat(p,"_").concat(o),className:"gf-label ".concat(x)},r,t?_react["default"].createElement("abbr",null,"*"):null),"above"===w&&v&&_react["default"].createElement("div",{className:"description"},v),A?_react["default"].createElement(_react["default"].Fragment,null,B&&B.length&&B.map(function(a,g){return _react["default"].createElement("span",{key:"input_".concat(p,"_").concat(a.id),className:"".concat(1<B.length?"ginput_".concat(0===g?"left":"right"):"medim"," ").concat(E[g].cssClass?E[g].cssClass:"")},_react["default"].createElement(L,{className:"gf-label ".concat(x),htmlFor:"input_".concat(p,"_").concat(a.id,"_").concat(g)},a.customLabel||a.label,t?_react["default"].createElement("abbr",null,"*"):null),_react["default"].createElement(J,{id:"input_".concat(p,"_").concat(a.id,"_").concat(g),name:z||"input_".concat(o).concat(1===g?"_".concat(g+1):""),type:q,value:c&&c[g]&&c[g].val?c[g].val:"",placeholder:a.placeholder?a.placeholder:s,required:t,autoComplete:"off",onChange:function onChange(a){b.subId=g,h(a,b),k(o)},onBlur:function onBlur(a){b.subId=g,h(a,b),f(o),G(c&&c[g]&&c[g].val&&""!==c[g].val,g)},onFocus:function onFocus(){return G(!0,g)},"aria-label":r,"aria-describedby":"error_".concat(p,"_").concat(a.id,"_").concat(g),"aria-invalid":!!d&&e}))})):_react["default"].createElement(_react["default"].Fragment,null,_react["default"].createElement(J,{id:"input_".concat(p,"_").concat(o),name:z||"input_".concat(o),type:q,value:c?c:"",placeholder:s,maxLength:u,required:t,onChange:function onChange(a){h(a,b),k(o)},onBlur:function onBlur(a){h(a,b),f(o),m(""!==c)},onFocus:function onFocus(){return m(!0)},"aria-label":r,"aria-describedby":"error_".concat(p,"_").concat(o),"aria-invalid":!!d&&e||!!j})),"above"!==w&&v&&_react["default"].createElement("div",{className:"description"},v),(d&&e||j)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(p,"_").concat(o)},d||j)))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Email.jsx"],"names":["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","cssClass","setFocusClass","props","id","formId","type","label","placeholder","isRequired","maxLength","description","descriptionPlacement","labelPlacement","width","customName","emailConfirmEnabled","inputs","emails","setEmails","setFocusClassMultiple","action","i","email","length","Input","Label","Box","display","map","input","customLabel","val","event","subId"],"mappings":"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","sourcesContent":["import React, { useState } from \"react\";\r\n\r\nexport default ({\r\n  field,\r\n  value,\r\n  validationMessage,\r\n  touched,\r\n  setTouched,\r\n  hideField,\r\n  updateForm,\r\n  styledComponents,\r\n  error,\r\n  unsetError,\r\n  cssClass,\r\n  setFocusClass,\r\n  ...props\r\n}) => {\r\n  const {\r\n    id,\r\n    formId,\r\n    type,\r\n    label,\r\n    placeholder,\r\n    isRequired,\r\n    maxLength,\r\n    description,\r\n    descriptionPlacement,\r\n    labelPlacement,\r\n    width,\r\n    customName,\r\n    emailConfirmEnabled,\r\n    inputs,\r\n  } = field;\r\n\r\n  const [emails, setEmails] = useState(inputs);\r\n\r\n  const setFocusClassMultiple = (action, i) => {\r\n    const email = { ...emails };\r\n    if (!email[i]) return;\r\n    if (action && email && !!email.length > 0) {\r\n      email[i].cssClass = \"filled\";\r\n    } else {\r\n      email[i].cssClass = \"\";\r\n    }\r\n    setEmails(email);\r\n  };\r\n\r\n  const { Input = \"input\", Label = \"label\", Box = \"div\" } =\r\n    styledComponents || false;\r\n  return (\r\n    <Box\r\n      width={width}\r\n      className={\r\n        (validationMessage && touched) || error\r\n          ? `form-field error ${cssClass}`\r\n          : `form-field ${cssClass}`\r\n      }\r\n      style={{ display: hideField ? \"none\" : undefined }}\r\n    >\r\n      <div className={type}>\r\n        <Label\r\n          htmlFor={`input_${formId}_${id}`}\r\n          className={`gf-label ${labelPlacement}`}\r\n        >\r\n          {label}\r\n          {isRequired ? <abbr>*</abbr> : null}\r\n        </Label>\r\n        {descriptionPlacement === \"above\" && description && (\r\n          <div className=\"description\">{description}</div>\r\n        )}\r\n        {emailConfirmEnabled ? (\r\n          <>\r\n            {inputs &&\r\n              inputs.length &&\r\n              inputs.map((input, i) => (\r\n                <span\r\n                  key={`input_${formId}_${input.id}`}\r\n                  className={`${\r\n                    inputs.length > 1\r\n                      ? `ginput_${i === 0 ? \"left\" : \"right\"}`\r\n                      : \"medim\"\r\n                  } ${emails[i].cssClass ? emails[i].cssClass : \"\"}`}\r\n                >\r\n                  <Label\r\n                    className={`gf-label ${labelPlacement}`}\r\n                    htmlFor={`input_${formId}_${input.id}_${i}`}\r\n                  >\r\n                    {input.customLabel || input.label}\r\n                    {isRequired ? <abbr>*</abbr> : null}\r\n                  </Label>\r\n                  <Input\r\n                    id={`input_${formId}_${input.id}_${i}`}\r\n                    name={\r\n                      customName || `input_${id}${i === 1 ? `_${i + 1}` : \"\"}`\r\n                    }\r\n                    type={type}\r\n                    value={\r\n                      value && value[i] && value[i].val ? value[i].val : \"\"\r\n                    }\r\n                    placeholder={\r\n                      input.placeholder ? input.placeholder : placeholder\r\n                    }\r\n                    required={isRequired}\r\n                    autoComplete=\"off\"\r\n                    onChange={(event) => {\r\n                      field.subId = i;\r\n                      updateForm(event, field);\r\n                      unsetError(id);\r\n                    }}\r\n                    onBlur={(event) => {\r\n                      field.subId = i;\r\n                      updateForm(event, field);\r\n                      setTouched(id);\r\n                      setFocusClassMultiple(\r\n                        value &&\r\n                          value[i] &&\r\n                          value[i].val &&\r\n                          value[i].val !== \"\",\r\n                        i\r\n                      );\r\n                    }}\r\n                    onFocus={() => setFocusClassMultiple(true, i)}\r\n                    aria-label={label}\r\n                    aria-describedby={`error_${formId}_${input.id}_${i}`}\r\n                    aria-invalid={!!validationMessage && touched}\r\n                  />\r\n                </span>\r\n              ))}\r\n          </>\r\n        ) : (\r\n          <>\r\n            <Input\r\n              id={`input_${formId}_${id}`}\r\n              name={customName || `input_${id}`}\r\n              type={type}\r\n              value={!value ? \"\" : value}\r\n              placeholder={placeholder}\r\n              maxLength={maxLength}\r\n              required={isRequired}\r\n              onChange={(event) => {\r\n                updateForm(event, field);\r\n                unsetError(id);\r\n              }}\r\n              onBlur={(event) => {\r\n                updateForm(event, field);\r\n                setTouched(id);\r\n                setFocusClass(value !== \"\");\r\n              }}\r\n              onFocus={() => setFocusClass(true)}\r\n              aria-label={label}\r\n              aria-describedby={`error_${formId}_${id}`}\r\n              aria-invalid={(!!validationMessage && touched) || !!error}\r\n            />\r\n          </>\r\n        )}\r\n        {descriptionPlacement !== \"above\" && description && (\r\n          <div className=\"description\">{description}</div>\r\n        )}\r\n        {((validationMessage && touched) || error) && (\r\n          <span className=\"error-message\" id={`error_${formId}_${id}`}>\r\n            {validationMessage || error}\r\n          </span>\r\n        )}\r\n      </div>\r\n    </Box>\r\n  );\r\n};\r\n"]}