react-gravity-form
Version:
A component for including Gravity Forms on React apps via the Wordpress API
2 lines • 17.3 kB
JavaScript
"use strict";var _interopRequireDefault=require("@babel/runtime/helpers/interopRequireDefault"),_typeof=require("@babel/runtime/helpers/typeof");Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;var _toConsumableArray2=_interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")),_slicedToArray2=_interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")),_objectWithoutProperties2=_interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")),_react=_interopRequireWildcard(require("react")),_reactSelect=_interopRequireDefault(require("react-select")),_InputLabel=_interopRequireDefault(require("../FormElements/InputLabel")),_excluded=["field","value","validationMessage","touched","setTouched","setFocusClass","updateForm","hideField","styledComponents","error","unsetError","cssClass"];function _getRequireWildcardCache(a){if("function"!=typeof WeakMap)return null;var b=new WeakMap,c=new WeakMap;return(_getRequireWildcardCache=function(a){return a?c:b})(a)}function _interopRequireWildcard(b,c){if(!c&&b&&b.__esModule)return b;if(null===b||"object"!=_typeof(b)&&"function"!=typeof b)return{default:b};var d=_getRequireWildcardCache(c);if(d&&d.has(b))return d.get(b);var e={__proto__:null},f=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var a in b)if("default"!=a&&Object.prototype.hasOwnProperty.call(b,a)){var g=f?Object.getOwnPropertyDescriptor(b,a):null;g&&(g.get||g.set)?Object.defineProperty(e,a,g):e[a]=b[a]}return e["default"]=b,d&&d.set(b,e),e}var _default=exports["default"]=function(a){var b,c=a.field,d=a.value,e=a.validationMessage,f=a.touched,g=a.setTouched,h=a.setFocusClass,i=a.updateForm,j=a.hideField,k=a.styledComponents,l=a.error,m=a.unsetError,n=a.cssClass,o=(0,_objectWithoutProperties2["default"])(a,_excluded),p=c.id,q=c.formId,r=c.type,s=c.label,t=c.isRequired,u=c.choices,v=c.placeholder,w=c.description,x=c.descriptionPlacement,y=c.labelPlacement,z=c.width,A=c.customName,B=(0,_react.useState)(""),C=(0,_slicedToArray2["default"])(B,2),D=C[0],E=C[1],F=u.map(function(a){return{value:a.value,label:a.text}}),G=u.filter(function(a){return a.isSelected});G=G.length?[{label:G[0].text,value:G[0].value}]:"";var H=(0,_react.useState)(d||G),I=(0,_slicedToArray2["default"])(H,2),J=I[0],K=I[1],L=function(a){K(a);var b={target:{value:a&&0<a.length?a.map(function(a){return a.value}):""}};i(b,c),m(p)},M=function(){var a={target:{value:J&&0<J.length?J.map(function(a){return a.value}):""}};i(a,c),g(p),E("")},N=k||!1,O=N.ReactSelect,P=N.Label,Q=void 0===P?"label":P,R=N.Box,S=void 0===R?"div":R,T=O||_reactSelect["default"],U=(0,_toConsumableArray2["default"])(J);return J&&0<K.length&&U.shift(),_react["default"].createElement(S,{width:z,className:e&&f||l?"form-field error ".concat(n," ").concat(D):"form-field ".concat(n," ").concat(D),style:{display:j?"none":void 0}},_react["default"].createElement("div",{className:r},_react["default"].createElement(_InputLabel["default"],{formId:q,id:p,label:s,labelPlacement:y,isRequired:t,styledComponent:k}),"above"===x&&w&&_react["default"].createElement("div",{className:"description",dangerouslySetInnerHTML:{__html:w}}),_react["default"].createElement(T,{name:A||"input_".concat(p),required:t,value:J,onChange:function onChange(a){L(a,c),m(p)},onBlur:function onBlur(){return M()},onFocus:function onFocus(){h(!0),E("is-open")},placeholder:v,options:F,autoFocus:!1,isMulti:!0,inputId:"input_".concat(q,"_").concat(p)}),_react["default"].createElement("input",{type:"hidden",name:"input_".concat(p,"[]"),required:t,value:J&&null!==(b=J[0])&&void 0!==b&&b.value?J[0].value:""}),U&&0<U.length&&U.map(function(a){return _react["default"].createElement("input",{type:"hidden",name:"input_".concat(p,"[]"),value:a.value})}),"above"!==x&&w&&_react["default"].createElement("div",{className:"description",dangerouslySetInnerHTML:{__html:w}}),(e&&f||l)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(q,"_").concat(p)},e||l)))};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["a","b","field","value","validationMessage","touched","setTouched","setFocusClass","updateForm","hideField","styledComponents","error","unsetError","cssClass","props","_objectWithoutProperties2","_excluded","id","formId","type","label","isRequired","choices","placeholder","description","descriptionPlacement","labelPlacement","width","customName","B","useState","C","_slicedToArray2","focusClass","setFocusClasses","options","map","choice","text","preselected","filter","isSelected","length","H","I","selectedOption","selectOption","handleChange","option","event","target","item","handleBlur","N","ReactSelect","P","Label","R","Box","RSelect","Select","selectValues","_toConsumableArray2","shift","_react","createElement","S","className","concat","style","display","_InputLabel","styledComponent","dangerouslySetInnerHTML","__html","T","name","required","onChange","onBlur","onFocus","autoFocus","isMulti","inputId"],"sources":["../../src/Fields/Multiselect.jsx"],"sourcesContent":["import React, { useState } from \"react\";\nimport Select from \"react-select\";\nimport InputLabel from \"../FormElements/InputLabel\";\n\nexport default ({\n  field,\n  value,\n  validationMessage,\n  touched,\n  setTouched,\n  setFocusClass,\n  updateForm,\n  hideField,\n  styledComponents,\n  error,\n  unsetError,\n  cssClass,\n  ...props\n}) => {\n  const {\n    id,\n    formId,\n    type,\n    label,\n    isRequired,\n    choices,\n    placeholder,\n    description,\n    descriptionPlacement,\n    labelPlacement,\n    width,\n    customName,\n  } = field;\n  const [focusClass, setFocusClasses] = useState(\"\");\n  // Map options\n  const options = choices.map(choice => ({\n    value: choice.value,\n    label: choice.text,\n  }));\n  let preselected = choices.filter(choice => choice.isSelected);\n  if (preselected.length) {\n    preselected = [\n      {\n        label: preselected[0].text,\n        value: preselected[0].value,\n      },\n    ];\n  } else {\n    preselected = \"\";\n  }\n  // Handle State\n  const [selectedOption, selectOption] = useState(value || preselected);\n  // Handle change\n  const handleChange = option => {\n    selectOption(option);\n    const event = {\n      target: {\n        value:\n          option && option.length > 0 ? option.map(item => item.value) : \"\",\n      },\n    };\n\n    updateForm(event, field);\n    unsetError(id);\n  };\n  // Handle Blur\n  const handleBlur = () => {\n    const event = {\n      target: {\n        value:\n          selectedOption && selectedOption.length > 0\n            ? selectedOption.map(item => item.value)\n            : \"\",\n      },\n    };\n    updateForm(event, field);\n    setTouched(id);\n    setFocusClasses(\"\");\n  };\n  const {\n    ReactSelect,\n    Label = \"label\",\n    Box = \"div\",\n  } = styledComponents || false;\n\n  const RSelect = ReactSelect || Select;\n  const selectValues = [...selectedOption];\n  if (selectedOption && selectOption.length > 0) {\n    selectValues.shift();\n  }\n  return (\n    <Box\n      width={width}\n      className={\n        (validationMessage && touched) || error\n          ? `form-field error ${cssClass} ${focusClass}`\n          : `form-field ${cssClass} ${focusClass}`\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\n            className=\"description\"\n            dangerouslySetInnerHTML={{ __html: description }}\n          />\n        )}\n        <RSelect\n          name={customName || `input_${id}`}\n          required={isRequired}\n          value={selectedOption}\n          onChange={option => {\n            handleChange(option, field);\n            unsetError(id);\n          }}\n          onBlur={() => handleBlur()}\n          onFocus={() => {\n            setFocusClass(true);\n            setFocusClasses(\"is-open\");\n          }}\n          placeholder={placeholder}\n          options={options}\n          autoFocus={false}\n          isMulti\n          inputId={`input_${formId}_${id}`}\n        />\n        <input\n          type=\"hidden\"\n          name={`input_${id}[]`}\n          required={isRequired}\n          value={\n            selectedOption && selectedOption[0]?.value\n              ? selectedOption[0].value\n              : \"\"\n          }\n        />\n        {selectValues &&\n          selectValues.length > 0 &&\n          selectValues.map(item => (\n            <input type=\"hidden\" name={`input_${id}[]`} value={item.value} />\n          ))}\n\n        {descriptionPlacement !== \"above\" && description && (\n          <div\n            className=\"description\"\n            dangerouslySetInnerHTML={{ __html: description }}\n          />\n        )}\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"],"mappings":"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"}