mindstream-gravity-form
Version:
Mindstream Fork of Gravity Forms on React apps via the Wordpress API
2 lines • 13.8 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"));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.isDisabled,B="",C=t.map(function(a){var b={value:a.value,label:a.text};return a.isSelected&&(B=b),b}),D=(0,_react.useState)(c||B),E=_slicedToArray(D,2),F=E[0],G=E[1],H=function(a){G(a);i({target:{value:a}},b)},I=function(){i({target:{value:F}},b),f(o),g(F&&F.value)},J=j||!1,K=J.ReactSelect,L=J.Label,M=void 0===L?"label":L,N=J.Box,O=void 0===N?"div":N,P=K||_reactSelect["default"];return _react["default"].createElement(O,{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(M,{htmlFor:"input_".concat(p,"_").concat(o),className:"gf-label ".concat(x)},r,s?_react["default"].createElement("abbr",null,"*"):null),"above"===w&&v&&_react["default"].createElement("div",{className:"description"},v),_react["default"].createElement(P,{name:z||"input_".concat(o),required:s,value:F&&F.value?F:"",onChange:function onChange(a){H(a,b),m(o)},onBlur:function onBlur(){return I()},onFocus:function onFocus(){return g(!0)},placeholder:u,options:C,className:"form-select",autoFocus:!1,inputId:"input_".concat(p,"_").concat(o),isDisabled:A}),"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","isDisabled","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\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    isDisabled,\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        <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        <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          isDisabled={isDisabled}\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"]}