mindstream-react-gravity-form
Version:
A component for including Gravity Forms on React apps via the Wordpress API
2 lines • 13.7 kB
JavaScript
;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=a.field,c=a.value,d=a.validationMessage,e=a.touched,f=a.setTouched,g=a.setFocusClass,h=a.hideField,i=a.updateForm,j=a.styledComponents,k=a.error,l=a.cssClass,m=a.unsetError,n=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","setFocusClass","hideField","updateForm","styledComponents","error","cssClass","unsetError"]),o=b.id,p=b.formId,q=b.type,r=b.label,s=b.isRequired,t=b.choices,u=b.placeholder,v=b.description,w=b.descriptionPlacement,x=b.labelPlacement,y=b.width,z=b.customName,A="",B=t.map(function(a){var b={value:a.value,label:a.text};return a.isSelected&&(A=b),b}),C=(0,_react.useState)(c||A),D=_slicedToArray(C,2),E=D[0],F=D[1],G=function(a){F(a);i({target:{value:a}},b)},H=function(){i({target:{value:E}},b),f(o),g(E&&E.value)},I=j||!1,J=I.ReactSelect,K=I.Label,L=void 0===K?"label":K,M=I.Box,N=void 0===M?"div":M,O=J||_reactSelect["default"];return _react["default"].createElement(N,{width:y,className:d&&e||k?"form-field error ".concat(l):"form-field ".concat(l),style:{display:h?"none":void 0}},_react["default"].createElement("div",{className:q},_react["default"].createElement(_InputLabel["default"],{formId:p,id:o,label:r,labelPlacement:x,isRequired:s,styledComponent:j}),"above"===w&&v&&_react["default"].createElement("div",{className:"description"},v),_react["default"].createElement(O,{name:z||"input_".concat(o),required:s,value:E&&E.value?E:"",onChange:function onChange(a){G(a,b),m(o)},onBlur:function onBlur(){return H()},onFocus:function onFocus(){return g(!0)},placeholder:u,options:B,className:"form-select",autoFocus:!1,inputId:"input_".concat(p,"_").concat(o)}),"above"!==w&&v&&_react["default"].createElement("div",{className:"description"},v),(d&&e||k)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(p,"_").concat(o)},d||k)))};exports["default"]=_default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Select.jsx"],"names":["field","value","validationMessage","touched","setTouched","setFocusClass","hideField","updateForm","styledComponents","error","cssClass","unsetError","props","id","formId","type","label","isRequired","choices","placeholder","description","descriptionPlacement","labelPlacement","width","customName","selected","options","map","choice","item","text","isSelected","selectedOption","selectOption","handleChange","option","target","handleBlur","ReactSelect","Label","Box","RSelect","Select","display"],"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  setFocusClass,\r\n  hideField,\r\n  updateForm,\r\n  styledComponents,\r\n  error,\r\n  cssClass,\r\n  unsetError,\r\n  ...props\r\n}) => {\r\n  const {\r\n    id,\r\n    formId,\r\n    type,\r\n    label,\r\n    isRequired,\r\n    choices,\r\n    placeholder,\r\n    description,\r\n    descriptionPlacement,\r\n    labelPlacement,\r\n    width,\r\n    customName\r\n  } = field;\r\n\r\n  let selected = '';\r\n  // Map options\r\n  const options = choices.map(choice => {\r\n    const item = {\r\n      value: choice.value,\r\n      label: choice.text\r\n    };\r\n    if (choice.isSelected) {\r\n      selected = item;\r\n    }\r\n    return item;\r\n  });\r\n  // Handle State\r\n  const [selectedOption, selectOption] = useState(value || selected);\r\n  // Handle change\r\n  const handleChange = option => {\r\n    selectOption(option);\r\n    const event = {\r\n      target: {\r\n        value: option\r\n      }\r\n    };\r\n    updateForm(event, field);\r\n  };\r\n  // Handle Blur\r\n  const handleBlur = () => {\r\n    const event = {\r\n      target: {\r\n        value: selectedOption\r\n      }\r\n    };\r\n    updateForm(event, field);\r\n    setTouched(id);\r\n    setFocusClass(selectedOption && selectedOption.value);\r\n  };\r\n  const { ReactSelect, Label = \"label\", Box = \"div\" } =\r\n    styledComponents || false;\r\n\r\n  const RSelect = ReactSelect || Select;\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      <div className={type}>\r\n        <InputLabel\r\n          formId={formId}\r\n          id={id}\r\n          label={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        <RSelect\r\n          name={customName || `input_${id}`}\r\n          required={isRequired}\r\n          value={selectedOption && selectedOption.value ? selectedOption : ''}\r\n          onChange={option => {\r\n            handleChange(option, field);\r\n            unsetError(id);\r\n          }}\r\n          onBlur={() => handleBlur()}\r\n          onFocus={() => setFocusClass(true)}\r\n          placeholder={placeholder}\r\n          options={options}\r\n          className=\"form-select\"\r\n          autoFocus={false}\r\n          // styles={customStyles}\r\n          inputId={`input_${formId}_${id}`}\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    </Box>\r\n  );\r\n};\r\n"]}