UNPKG

mindstream-react-gravity-form

Version:

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

2 lines 17.6 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")),_reactSelect=_interopRequireDefault(require("react-select")),_InputLabel=_interopRequireDefault(require("../FormElements/InputLabel"));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}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,c=a.field,d=a.value,e=a.validationMessage,f=a.touched,g=a.setTouched,h=a.hideField,i=a.updateForm,j=a.styledComponents,k=a.error,l=a.unsetError,m=a.setFocusClass,n=a.cssClass,o=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass"]),p=c.id,q=c.formId,r=c.type,s=c.label,t=c.placeholder,u=c.isRequired,v=c.inputs,w=c.maxLength,x=c.description,y=c.descriptionPlacement,z=c.labelPlacement,A=c.width,B=c.customName,C=j||!1,D=C.ReactSelect,E=C.Input,F=void 0===E?"input":E,G=C.Label,H=void 0===G?"label":G,I=C.Box,J=void 0===I?"div":I,K=D||_reactSelect["default"],L=v[0],M=null===L||void 0===L||null===(b=L.choices)||void 0===b?void 0:b.map(function(a){return{value:a.value,label:a.text}}),N=null===L||void 0===L?void 0:L.choices.filter(function(a){return a.isSelected});N=N.length?[{label:N[0].text,value:N[0].value}]:"";var O=(0,_react.useState)(d||N),P=_slicedToArray(O,2),Q=P[0],R=P[1],S=function(a){R(a)};return _react["default"].createElement(J,{width:A,className:e&&f||k?"form-field error ".concat(n):"form-field ".concat(n),style:{display:h?"none":void 0}},v.map(function(a){return!a.isHidden&&_react["default"].createElement("div",{className:r,key:a.id},_react["default"].createElement(_InputLabel["default"],{formId:q,id:a.id,label:a.label,labelPlacement:z,isRequired:u,styledComponent:j}),"above"===y&&x&&_react["default"].createElement("div",{className:"description"},x),"radio"===a.inputType?_react["default"].createElement(K,{name:B||"input_".concat(a.id),required:u,value:Q&&Q.value?Q:"",onChange:function onChange(b){S(b,c),l(a.id)},onFocus:function onFocus(){return m(!0)},placeholder:a.placeholder,options:M,className:"form-select",autoFocus:!1,inputId:"input_".concat(q,"_").concat(a.id)}):_react["default"].createElement(F,{id:"input_".concat(q,"_").concat(a.id),key:a.id,name:B||"input_".concat(a.id),type:r,value:d?d[a.id]:"",placeholder:a.placeholder,maxLength:w,required:u,onChange:function onChange(b){i(b,c,a.id),l(a.id)},onBlur:function onBlur(b){i(b,c),g(a.id),m(""!==d)},onFocus:function onFocus(){return m(!0)},"aria-label":a.label,"aria-describedby":"error_".concat(q,"_").concat(a.id),"aria-invalid":!!e&&f||!!k}),"above"!==y&&x&&_react["default"].createElement("div",{className:"description"},x),(e&&f||k)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(q,"_").concat(p)},e||k))}))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Name.jsx"],"names":["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass","props","id","formId","type","label","placeholder","isRequired","inputs","maxLength","description","descriptionPlacement","labelPlacement","width","customName","ReactSelect","Input","Label","Box","RSelect","Select","prefixField","options","choices","map","choice","text","preselected","filter","isSelected","length","selectedOption","selectOption","selectChange","option","display","input","isHidden","inputType","event"],"mappings":"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","sourcesContent":["import React, { useState } from 'react';\r\nimport Select from 'react-select';\r\nimport InputLabel from '../FormElements/InputLabel';\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  setFocusClass,\r\n  cssClass,\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    inputs,\r\n    maxLength,\r\n    description,\r\n    descriptionPlacement,\r\n    labelPlacement,\r\n    width,\r\n    customName,\r\n  } = field;\r\n\r\n  const {\r\n    ReactSelect, Input = 'input', Label = 'label', Box = 'div',\r\n  } = styledComponents || false;\r\n\r\n  const RSelect = ReactSelect || Select;\r\n\r\n  const prefixField = inputs[0];\r\n\r\n  const options = prefixField?.choices?.map(choice => ({\r\n    value: choice.value,\r\n    label: choice.text,\r\n  }));\r\n  let preselected = prefixField?.choices.filter(choice => choice.isSelected);\r\n  if (preselected.length) {\r\n    preselected = [\r\n      {\r\n        label: preselected[0].text,\r\n        value: preselected[0].value,\r\n      },\r\n    ];\r\n  } else {\r\n    preselected = '';\r\n  }\r\n  // Handle State\r\n  const [selectedOption, selectOption] = useState(value || preselected);\r\n\r\n  // Handle change\r\n  const selectChange = (option) => {\r\n    selectOption(option);\r\n  };\r\n  \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      {inputs.map(input => (\r\n        !input.isHidden && (\r\n          <div className={type} key={input.id}>\r\n            <InputLabel\r\n              formId={formId}\r\n              id={input.id}\r\n              label={input.label}\r\n              labelPlacement={labelPlacement}\r\n              isRequired={isRequired}\r\n              styledComponent={styledComponents}\r\n            />\r\n            {descriptionPlacement === 'above' && description && (\r\n              <div className=\"description\">{description}</div>\r\n            )}\r\n            {input.inputType === 'radio' ? (\r\n              <RSelect\r\n                name={customName || `input_${input.id}`}\r\n                required={isRequired}\r\n                value={selectedOption && selectedOption.value ? selectedOption : ''}\r\n                onChange={(option) => {\r\n                  selectChange(option, field);\r\n                  unsetError(input.id);\r\n                }}\r\n                onFocus={() => setFocusClass(true)}\r\n                placeholder={input.placeholder}\r\n                options={options}\r\n                className=\"form-select\"\r\n                autoFocus={false}\r\n                // styles={customStyles}\r\n                inputId={`input_${formId}_${input.id}`}\r\n              />\r\n            )\r\n              : (\r\n                <Input\r\n                  id={`input_${formId}_${input.id}`}\r\n                  key={input.id}\r\n                  name={customName || `input_${input.id}`}\r\n                  type={type}\r\n                  value={!value ? '' : value[input.id]}\r\n                  placeholder={input.placeholder}\r\n                  maxLength={maxLength}\r\n                  required={isRequired}\r\n                  onChange={(event) => {\r\n                    updateForm(event, field, input.id);\r\n                    unsetError(input.id);\r\n                  }}\r\n                  onBlur={(event) => {\r\n                    updateForm(event, field);\r\n                    setTouched(input.id);\r\n                    setFocusClass(value !== '');\r\n                  }}\r\n                  onFocus={() => setFocusClass(true)}\r\n                  aria-label={input.label}\r\n                  aria-describedby={`error_${formId}_${input.id}`}\r\n                  aria-invalid={(!!validationMessage && touched) || !!error}\r\n                />\r\n              )}\r\n            {descriptionPlacement !== 'above' && description && <div className=\"description\">{description}</div>}\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        )\r\n      ))}\r\n    </Box>\r\n  );\r\n};\r\n"]}