UNPKG

mindstream-gravity-form

Version:

Mindstream Fork of Gravity Forms on React apps via the Wordpress API

2 lines 11.8 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;var _react=_interopRequireDefault(require("react")),_reactInputMask=_interopRequireDefault(require("react-input-mask"));function _interopRequireDefault(a){return a&&a.__esModule?a:{default:a}}function _extends(){return _extends=Object.assign||function(a){for(var b,c=1;c<arguments.length;c++)for(var d in b=arguments[c],b)Object.prototype.hasOwnProperty.call(b,d)&&(a[d]=b[d]);return a},_extends.apply(this,arguments)}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.hideField,h=a.updateForm,i=a.styledComponents,j=a.error,k=a.unsetError,l=a.setFocusClass,m=a.cssClass,n=a.formatChars,o=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass","formatChars"]),p=b.id,q=b.formId,r=b.type,s=b.label,t=b.placeholder,u=b.isRequired,v=b.maxLength,w=b.description,x=b.descriptionPlacement,y=b.labelPlacement,z=b.width,A=b.customName,B=b.inputMask,C=b.inputMaskValue,D=i||!1,E=D.Input,F=void 0===E?"input":E,G=D.Label,H=void 0===G?"label":G,I=D.Box,J=void 0===I?"div":I;return _react["default"].createElement(J,{width:z,className:d&&e||j?"form-field error ".concat(m):"form-field ".concat(m),style:{display:g?"none":void 0}},_react["default"].createElement("div",{className:r},_react["default"].createElement(H,{htmlFor:"input_".concat(q,"_").concat(p),className:"gf-label ".concat(y)},s,u?_react["default"].createElement("abbr",null,"*"):null),"above"===x&&w&&_react["default"].createElement("div",{className:"description"},w),_react["default"].createElement(_reactInputMask["default"],{formatChars:n,value:c?c:"",defaultValue:c?c:"",mask:B&&C,onChange:function onChange(a){h(a,b),k(p)},onBlur:function onBlur(a){h(a,b,!0),f(p),l(""!==c)},beforeMaskedValueChange:function beforeMaskedValueChange(a){return B&&"9999 aa"===C&&(a.value=a.value.toUpperCase()),a},onFocus:function onFocus(){return l(!0)}},function(a){return _react["default"].createElement(F,_extends({},a,{id:"input_".concat(q,"_").concat(p),name:A||"input_".concat(p),type:r,placeholder:t,maxLength:v,required:u,"aria-label":s,"aria-describedby":"error_".concat(q,"_").concat(p),"aria-invalid":!!d&&e||!!j}))}),"above"!==x&&w&&_react["default"].createElement("div",{className:"description"},w),(d&&e||j)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(q,"_").concat(p)},d||j)))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Text.jsx"],"names":["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass","formatChars","props","id","formId","type","label","placeholder","isRequired","maxLength","description","descriptionPlacement","labelPlacement","width","customName","inputMask","inputMaskValue","Input","Label","Box","display","event","beforeMaskedValueChange","newState","toUpperCase","inputProps"],"mappings":"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","sourcesContent":["import React from \"react\";\r\nimport InputMask from \"react-input-mask\";\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  formatChars,\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    maxLength,\r\n    description,\r\n    descriptionPlacement,\r\n    labelPlacement,\r\n    width,\r\n    customName,\r\n    inputMask,\r\n    inputMaskValue,\r\n  } = field;\r\n  const { Input = \"input\", Label = \"label\", Box = \"div\" } =\r\n    styledComponents || false;\r\n\r\n  const beforeMaskedValueChange = (newState, oldState, userInput) => {\r\n    // if input mask is Zip code -> make last chars uppercase automatically\r\n    if (inputMask && inputMaskValue === \"9999 aa\") {\r\n      newState.value = newState.value.toUpperCase();\r\n    }\r\n    return newState;\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      <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\r\n        <InputMask\r\n          formatChars={formatChars}\r\n          value={!value ? '' : value}\r\n          defaultValue={!value ? '' : value}\r\n          mask={inputMask && inputMaskValue}\r\n          onChange={(event) => {\r\n            updateForm(event, field);\r\n            unsetError(id);\r\n          }}\r\n          onBlur={(event) => {\r\n            updateForm(event, field, true);\r\n            setTouched(id);\r\n            setFocusClass(value !== \"\");\r\n          }}\r\n          beforeMaskedValueChange={beforeMaskedValueChange}\r\n          onFocus={() => setFocusClass(true)}\r\n        >\r\n          {(inputProps) => (\r\n            <Input\r\n              {...inputProps}\r\n              id={`input_${formId}_${id}`}\r\n              name={customName || `input_${id}`}\r\n              type={type}\r\n              placeholder={placeholder}\r\n              maxLength={maxLength}\r\n              required={isRequired}\r\n              aria-label={label}\r\n              aria-describedby={`error_${formId}_${id}`}\r\n              aria-invalid={(!!validationMessage && touched) || !!error}\r\n            />\r\n          )}\r\n        </InputMask>\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"]}