UNPKG

mindstream-react-gravity-form

Version:

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

2 lines 13.4 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=a.field,c=a.value,d=a.validationMessage,e=a.touched,f=a.setTouched,g=a.updateForm,h=a.hideField,i=a.styledComponents,j=a.error,k=a.unsetError,l=a.cssClass,m=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","updateForm","hideField","styledComponents","error","unsetError","cssClass"]),n=b.id,o=b.formId,p=b.type,q=b.label,r=b.isRequired,s=b.choices,t=b.placeholder,u=b.description,v=b.descriptionPlacement,w=b.labelPlacement,x=b.width,y=b.customName,z=s.map(function(a){return{value:a.value,label:a.text}}),A=s.filter(function(a){return a.isSelected});A=A.length?[{label:A[0].text,value:A[0].value}]:"";var B=(0,_react.useState)(c||A),C=_slicedToArray(B,2),D=C[0],E=C[1],F=function(a){E(a);g({target:{value:a}},b),k(n)},G=function(){g({target:{value:D}},b),f(n)},H=i||!1,I=H.SelectStyles,J=H.Label,K=void 0===J?"label":J,L=H.Box,M=void 0===L?"div":L;return _react["default"].createElement(M,{width:x,className:d&&e||j?"form-field error ".concat(l):"form-field ".concat(l),style:{display:h?"none":void 0}},_react["default"].createElement("div",{className:p},_react["default"].createElement(_InputLabel["default"],{formId:o,id:n,label:q,labelPlacement:w,isRequired:r,styledComponent:i}),"above"===v&&u&&_react["default"].createElement("div",{className:"description"},u),_react["default"].createElement(_reactSelect["default"],{name:y||"input_".concat(n,"[]"),required:r,value:D,onChange:function onChange(a){F(a,b)},onBlur:function onBlur(){return G()},placeholder:t,options:z,isMulti:!0,inputId:"input_".concat(o,"_").concat(n),styles:I}),"above"!==v&&u&&_react["default"].createElement("div",{className:"description"},u),(d&&e||j)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(o,"_").concat(n)},d||j)))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Multiselect.jsx"],"names":["field","value","validationMessage","touched","setTouched","updateForm","hideField","styledComponents","error","unsetError","cssClass","props","id","formId","type","label","isRequired","choices","placeholder","description","descriptionPlacement","labelPlacement","width","customName","options","map","choice","text","preselected","filter","isSelected","length","selectedOption","selectOption","handleChange","option","target","handleBlur","SelectStyles","Label","Box","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  updateForm,\r\n  hideField,\r\n  styledComponents,\r\n  error,\r\n  unsetError,\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    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  // Map options\r\n  const options = choices.map(choice => ({\r\n    value: choice.value,\r\n    label: choice.text,\r\n  }));\r\n  let preselected = 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  // 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    unsetError(id);\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  };\r\n  const { SelectStyles, Label = 'label', Box = 'div' } = styledComponents || false;\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        <Select\r\n          name={customName || `input_${id}[]`}\r\n          required={isRequired}\r\n          value={selectedOption}\r\n          onChange={(option) => {\r\n            handleChange(option, field);\r\n          }}\r\n          onBlur={() => handleBlur()}\r\n          placeholder={placeholder}\r\n          options={options}\r\n          isMulti\r\n          inputId={`input_${formId}_${id}`}\r\n          styles={SelectStyles}\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"]}