UNPKG

mindstream-react-gravity-form

Version:

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

2 lines 19.7 kB
"use strict";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;var _react=_interopRequireWildcard(require("react")),_RenderField=_interopRequireDefault(require("./RenderField"));function _interopRequireDefault(a){return a&&a.__esModule?a:{default:a}}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 _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}var divideFieldsIntoPages=function(a,b){for(var c,d=b.map(function(){return[]}),e=0;e<a.length;e++)c=d[a[e].pageNumber],d[a[e].pageNumber-1]&&("page"===a[e].type?d[a[e].pageNumber-2].push(a[e]):d[a[e].pageNumber-1].push(a[e]));return d},getMaxFieldId=function(a){for(var b=0,c=0;c<a.length;c++)parseInt(a[c].id)>b&&(b=parseInt(a[c].id));return b+1},fieldTypes=["checkbox","email","hidden","html","number","phone","radio","select","multiselect","text","textarea","website","page","date","fileupload","consent","password","section","scustom","name","address","buckarooideal","postcode"],honeyPotLables=["Name","Email","Phone","Comments"],honeypotLabel=honeyPotLables[Math.floor(Math.random()*Math.floor(4))],_default=function(a){function b(a){return _react["default"].createElement(_RenderField["default"],{key:"".concat(a.formId,"-").concat(a.id),field:a,formValues:d,submitFailed:f,setTouched:i,setErrorMessages:j,submitSuccess:g,updateForm:e,touched:h,pages:k&&k.pages.length,prevStep:m,nextStep:n,isNextDisabled:o,checkConditionalLogic:p,saveStateToHtmlField:q,styledComponents:s,customComponents:t,error:!!(v&&v[a.id])&&v[a.id],unsetError:u,dropzoneText:w,language:y,apiKeys:z})}var c=a.fields,d=a.formValues,e=a.updateForm,f=a.submitFailed,g=a.submitSuccess,h=a.touched,i=a.setTouched,j=a.setErrorMessages,k=a.pagination,l=a.activePage,m=a.prevStep,n=a.nextStep,o=a.isNextDisabled,p=a.checkConditionalLogic,q=a.saveStateToHtmlField,r=a.enableHoneypot,s=a.styledComponents,t=a.customComponents,u=a.unsetError,v=a.errors,w=a.dropzoneText,x=a.pageClicked,y=a.language,z=a.apiKeys,A=k?divideFieldsIntoPages(c,k.pages):void 0,B=getMaxFieldId(c),C=(0,_react.useState)(""),D=_slicedToArray(C,2),E=D[0],F=D[1],G=(0,_react.useRef)();(0,_react.useEffect)(function(){G.current=l});var H=G.current;return _react["default"].createElement("div",{className:"form-fields".concat(k&&1<k.pages.length?" hasPages ".concat(x?"":" noPageClicked"):"")},k&&1<k.pages.length?k.pages.map(function(a,c){return _react["default"].createElement("div",{className:"page".concat(l===c+1?" active":"").concat(H&&c===H&&l!==c+1&&H!==l?" prevStep":""),key:"page-".concat(c)},a&&_react["default"].createElement("div",{className:"gf_step"},_react["default"].createElement("span",null,a)),A[c].map(function(a){return fieldTypes.includes(a.type)&&b(a)}))}):c.map(function(a){return fieldTypes.includes(a.type)&&b(a)}),r&&_react["default"].createElement("div",{className:"form-field gform_validation_container"},_react["default"].createElement("label",{htmlFor:"input_".concat(B),className:"gf-label "},honeypotLabel),_react["default"].createElement("input",{type:"text",name:"input_".concat(B),id:"input_".concat(B),value:E,onChange:function onChange(a){return F(a.target.value)},autoComplete:"off"})))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/FormElements/RenderFields.jsx"],"names":["divideFieldsIntoPages","fields","pages","arr","tmpFields","map","i","length","pageNumber","type","push","getMaxFieldId","max","parseInt","id","fieldTypes","honeyPotLables","honeypotLabel","Math","floor","random","props","renderFiled","field","formId","formValues","submitFailed","setTouched","setErrorMessages","submitSuccess","updateForm","touched","pagination","prevStep","nextStep","isNextDisabled","checkConditionalLogic","saveStateToHtmlField","styledComponents","customComponents","errors","unsetError","dropzoneText","language","apiKeys","activePage","enableHoneypot","pageClicked","dividedFields","maxID","honeypotValue","setHoneypotValue","prevSteptRef","current","prevCount","page","index","includes","e","target","value"],"mappings":"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","sourcesContent":["import React, { useState, useRef, useEffect } from \"react\";\r\nimport RenderField from \"./RenderField\";\r\n\r\nconst divideFieldsIntoPages = (fields, pages) => {\r\n  const tmpFields = pages.map((item) => []);\r\n\r\n  for (let i = 0; i < fields.length; i++) {\r\n    const arr = tmpFields[fields[i].pageNumber];\r\n    if (tmpFields[fields[i].pageNumber - 1]) {\r\n      // move page field to the first group\r\n      if (fields[i].type === \"page\") {\r\n        tmpFields[fields[i].pageNumber - 2].push(fields[i]);\r\n      } else {\r\n        tmpFields[fields[i].pageNumber - 1].push(fields[i]);\r\n      }\r\n    }\r\n  }\r\n  return tmpFields;\r\n};\r\n\r\nconst getMaxFieldId = (fields) => {\r\n  let max = 0;\r\n  for (let i = 0; i < fields.length; i++) {\r\n    if (parseInt(fields[i].id) > max) {\r\n      max = parseInt(fields[i].id);\r\n    }\r\n  }\r\n  return max + 1;\r\n};\r\n\r\nconst fieldTypes = [\r\n  \"checkbox\",\r\n  \"email\",\r\n  \"hidden\",\r\n  \"html\",\r\n  \"number\",\r\n  \"phone\",\r\n  \"radio\",\r\n  \"select\",\r\n  \"multiselect\",\r\n  \"text\",\r\n  \"textarea\",\r\n  \"website\",\r\n  \"page\",\r\n  \"date\",\r\n  \"fileupload\",\r\n  \"consent\",\r\n  \"password\",\r\n  \"section\",\r\n  \"scustom\",\r\n  \"name\",\r\n  \"address\",\r\n  \"buckarooideal\",\r\n  \"postcode\",\r\n];\r\n\r\nconst honeyPotLables = [\"Name\", \"Email\", \"Phone\", \"Comments\"];\r\nconst honeypotLabel = honeyPotLables[Math.floor(Math.random() * Math.floor(4))];\r\n\r\nexport default (props) => {\r\n  const {\r\n    fields,\r\n    formValues,\r\n    updateForm,\r\n    submitFailed,\r\n    submitSuccess,\r\n    touched,\r\n    setTouched,\r\n    setErrorMessages,\r\n    pagination,\r\n    activePage,\r\n    prevStep,\r\n    nextStep,\r\n    isNextDisabled,\r\n    checkConditionalLogic,\r\n    saveStateToHtmlField,\r\n    enableHoneypot,\r\n    styledComponents,\r\n    customComponents,\r\n    unsetError,\r\n    errors,\r\n    dropzoneText,\r\n    pageClicked,\r\n    language,\r\n    apiKeys,\r\n  } = props;\r\n\r\n  // get page indexes\r\n  const dividedFields = pagination\r\n    ? divideFieldsIntoPages(fields, pagination.pages)\r\n    : undefined;\r\n  const maxID = getMaxFieldId(fields);\r\n  const [honeypotValue, setHoneypotValue] = useState(\"\");\r\n\r\n  const prevSteptRef = useRef();\r\n  useEffect(() => {\r\n    prevSteptRef.current = activePage;\r\n  });\r\n  const prevCount = prevSteptRef.current;\r\n\r\n  function renderFiled(field) {\r\n    return (\r\n      <RenderField\r\n        key={`${field.formId}-${field.id}`}\r\n        field={field}\r\n        formValues={formValues}\r\n        submitFailed={submitFailed}\r\n        setTouched={setTouched}\r\n        setErrorMessages={setErrorMessages}\r\n        submitSuccess={submitSuccess}\r\n        updateForm={updateForm}\r\n        touched={touched}\r\n        pages={pagination && pagination.pages.length}\r\n        prevStep={prevStep}\r\n        nextStep={nextStep}\r\n        isNextDisabled={isNextDisabled}\r\n        checkConditionalLogic={checkConditionalLogic}\r\n        saveStateToHtmlField={saveStateToHtmlField}\r\n        styledComponents={styledComponents}\r\n        customComponents={customComponents}\r\n        error={errors && errors[field.id] ? errors[field.id] : false}\r\n        unsetError={unsetError}\r\n        dropzoneText={dropzoneText}\r\n        language={language}\r\n        apiKeys={apiKeys}\r\n      />\r\n    );\r\n  }\r\n\r\n  return (\r\n    <div\r\n      className={`form-fields${\r\n        pagination && pagination.pages.length > 1\r\n          ? ` hasPages ${!pageClicked ? \" noPageClicked\" : \"\"}`\r\n          : \"\"\r\n      }`}\r\n    >\r\n      {pagination && pagination.pages.length > 1\r\n        ? pagination.pages.map((page, index) => (\r\n            <div\r\n              className={`page${activePage === index + 1 ? \" active\" : \"\"}${\r\n                prevCount &&\r\n                index === prevCount &&\r\n                activePage !== index + 1 &&\r\n                prevCount !== activePage\r\n                  ? \" prevStep\"\r\n                  : \"\"\r\n              }`}\r\n              key={`page-${index}`}\r\n            >\r\n              {page && (\r\n                <div className=\"gf_step\">\r\n                  <span>{page}</span>\r\n                </div>\r\n              )}\r\n              {dividedFields[index].map(\r\n                (field) => fieldTypes.includes(field.type) && renderFiled(field)\r\n              )}\r\n            </div>\r\n          ))\r\n        : fields.map(\r\n            (field) => fieldTypes.includes(field.type) && renderFiled(field)\r\n          )}\r\n      {enableHoneypot && (\r\n        <div className=\"form-field gform_validation_container\">\r\n          <label htmlFor={`input_${maxID}`} className=\"gf-label \">\r\n            {honeypotLabel}\r\n          </label>\r\n          <input\r\n            type=\"text\"\r\n            name={`input_${maxID}`}\r\n            id={`input_${maxID}`}\r\n            value={honeypotValue}\r\n            onChange={(e) => setHoneypotValue(e.target.value)}\r\n            autoComplete=\"off\"\r\n          />\r\n        </div>\r\n      )}\r\n    </div>\r\n  );\r\n};\r\n"]}