UNPKG

mindstream-gravity-form

Version:

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

2 lines 24 kB
"use strict";var _react=_interopRequireWildcard(require("react"));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;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 ownKeys(a,b){var c=Object.keys(a);if(Object.getOwnPropertySymbols){var d=Object.getOwnPropertySymbols(a);b&&(d=d.filter(function(b){return Object.getOwnPropertyDescriptor(a,b).enumerable})),c.push.apply(c,d)}return c}function _objectSpread(a){for(var b,c=1;c<arguments.length;c++)b=null==arguments[c]?{}:arguments[c],c%2?ownKeys(Object(b),!0).forEach(function(c){_defineProperty(a,c,b[c])}):Object.getOwnPropertyDescriptors?Object.defineProperties(a,Object.getOwnPropertyDescriptors(b)):ownKeys(Object(b)).forEach(function(c){Object.defineProperty(a,c,Object.getOwnPropertyDescriptor(b,c))});return a}function _defineProperty(a,b,c){return b in a?Object.defineProperty(a,b,{value:c,enumerable:!0,configurable:!0,writable:!0}):a[b]=c,a}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.hideField,h=a.updateForm,i=a.styledComponents,j=a.error,k=a.unsetError,l=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError"]),m=b.id,n=b.formId,o=b.type,p=b.label,q=b.placeholder,r=b.isRequired,s=b.maxLength,t=b.description,u=b.descriptionPlacement,v=b.labelPlacement,w=b.width,x=b.customName,y=b.inputs,z=b.cssClass,A=b.passwordStrengthEnabled,B=b.minPasswordStrength,C=i||!1,D=C.Input,E=void 0===D?"input":D,F=C.Label,G=void 0===F?"label":F,H=C.Box,I=void 0===H?"div":H,J=(0,_react.useState)(y),K=_slicedToArray(J,2),L=K[0],M=K[1],N=(0,_react.useState)("blank"),O=_slicedToArray(N,2),P=O[0],Q=O[1],R=function(a,b){var c=_objectSpread({},L);c[b].cssClass=a?"filled":"",M(c)},S=function(a){var e,f,b=Math.LN2,c=Math.log,d=Math.pow,g=0;return 0>=a.length?"blank":4>a.length?"short":(a.match(/[0-9]/)&&(g+=10),a.match(/[a-z]/)&&(g+=26),a.match(/[A-Z]/)&&(g+=26),a.match(/[^a-zA-Z0-9]/)&&(g+=31),e=c(d(g,a.length)),f=e/b,40>f?"bad":56>f?"good":"strong")},T=function(a){var b=S(a);Q(b)};return _react["default"].createElement(I,{width:w,className:d&&e||j?"form-field error ".concat(z):"form-field ".concat(z),style:{display:g?"none":void 0}},_react["default"].createElement("div",{className:o},_react["default"].createElement(G,{className:"gf-label ".concat(v)},p,r?_react["default"].createElement("abbr",null,"*"):null),"above"===u&&t&&_react["default"].createElement("div",{className:"description",dangerouslySetInnerHTML:{__html:t.replace(/\n/g,"<br />")}}),_react["default"].createElement("div",{className:"ginput_container ginput_container_password"},y&&y.length&&y.map(function(a,g){return!a.isHidden&&_react["default"].createElement("span",{key:"input_".concat(n,"_").concat(a.id),className:"".concat(1<y.length?"ginput_".concat(0===g?"left":"right"):"medim"," ").concat(L[g].cssClass?L[g].cssClass:"")},_react["default"].createElement(E,{id:"input_".concat(n,"_").concat(a.id,"_").concat(g),name:x||"input_".concat(m).concat(1===g?"_".concat(g+1):""),type:o,value:c&&c[g]&&c[g].val?c[g].val:"",placeholder:a.placeholder?a.placeholder:q,required:r,autoComplete:"off",onChange:function onChange(a){b.subId=g,h(a,b),k(m),A&&0===g&&T(a.target.value)},onBlur:function onBlur(a){b.subId=g,h(a,b),f(m),R(c&&c[g]&&c[g].val&&""!==c[g].val,g)},onFocus:function onFocus(){return R(!0,g)},"aria-label":p,"aria-describedby":"error_".concat(n,"_").concat(a.id,"_").concat(g),"aria-invalid":!!d&&e}),_react["default"].createElement("label",{htmlFor:"input_".concat(n,"_").concat(a.id,"_").concat(g)},a.placeholder||a.label))})),(d&&e||j)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(n,"_").concat(m),dangerouslySetInnerHTML:{__html:d||j}}),"above"!==u&&t&&_react["default"].createElement("div",{className:"description",dangerouslySetInnerHTML:{__html:t.replace(/\n/g,"<br />")}}),!(d&&e||j)&&A&&_react["default"].createElement(_react["default"].Fragment,null,_react["default"].createElement("div",{id:"input_".concat(n,"_").concat(m,"_strength_indicator"),className:"gfield_password_strength ".concat(P)},P&&"blank"!==P?P:"Strength indicator"),_react["default"].createElement("input",{type:"hidden",className:"gform_hidden",id:"input_".concat(n,"_").concat(m,"_strength"),name:"input_".concat(m,"_strength"),value:P}))))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Fields/Password.jsx"],"names":["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","props","id","formId","type","label","placeholder","isRequired","maxLength","description","descriptionPlacement","labelPlacement","width","customName","inputs","cssClass","passwordStrengthEnabled","minPasswordStrength","Input","Label","Box","passwords","setPasswords","passwordStrength","setPasswordStrength","setFocusClass","action","i","pass","gformPasswordStrength","password1","natLog","score","Math","LN2","log","pow","symbolSize","length","match","setGFPwdStrength","password","result","display","__html","replace","map","input","isHidden","val","event","subId","target"],"mappings":"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","sourcesContent":["import React, { useState } from \"react\";\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  ...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    inputs,\r\n    cssClass,\r\n    passwordStrengthEnabled,\r\n    minPasswordStrength,\r\n  } = field;\r\n\r\n  const { Input = \"input\", Label = \"label\", Box = \"div\" } =\r\n    styledComponents || false;\r\n\r\n  const [passwords, setPasswords] = useState(inputs);\r\n  const [passwordStrength, setPasswordStrength] = useState(\"blank\");\r\n\r\n  const setFocusClass = (action, i) => {\r\n    const pass = { ...passwords };\r\n    if (action) {\r\n      pass[i].cssClass = \"filled\";\r\n    } else {\r\n      pass[i].cssClass = \"\";\r\n    }\r\n    setPasswords(pass);\r\n  };\r\n\r\n  const gformPasswordStrength = (password1) => {\r\n    const shortPass = 1;\r\n    const badPass = 2;\r\n    const goodPass = 3;\r\n    const strongPass = 4;\r\n    const mismatch = 5;\r\n    let symbolSize = 0;\r\n    let natLog;\r\n    let score;\r\n\r\n    if (password1.length <= 0) return \"blank\";\r\n\r\n    // password < 4\r\n    if (password1.length < 4) return \"short\";\r\n\r\n    if (password1.match(/[0-9]/)) symbolSize += 10;\r\n    if (password1.match(/[a-z]/)) symbolSize += 26;\r\n    if (password1.match(/[A-Z]/)) symbolSize += 26;\r\n    if (password1.match(/[^a-zA-Z0-9]/)) symbolSize += 31;\r\n\r\n    natLog = Math.log(Math.pow(symbolSize, password1.length));\r\n    score = natLog / Math.LN2;\r\n\r\n    if (score < 40) return \"bad\";\r\n\r\n    if (score < 56) return \"good\";\r\n\r\n    return \"strong\";\r\n  };\r\n\r\n  const setGFPwdStrength = (password) => {\r\n    const result = gformPasswordStrength(password);\r\n    setPasswordStrength(result);\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 className={`gf-label ${labelPlacement}`}>\r\n          {label}\r\n          {isRequired ? <abbr>*</abbr> : null}\r\n        </Label>\r\n        {descriptionPlacement === \"above\" && description && (\r\n          <div\r\n            className=\"description\"\r\n            dangerouslySetInnerHTML={{\r\n              __html: description.replace(/\\n/g, \"<br />\"),\r\n            }}\r\n          />\r\n        )}\r\n        <div className=\"ginput_container ginput_container_password\">\r\n          {inputs &&\r\n            inputs.length &&\r\n            inputs.map(\r\n              (input, i) =>\r\n                !input.isHidden && (\r\n                  <span\r\n                    key={`input_${formId}_${input.id}`}\r\n                    className={`${\r\n                      inputs.length > 1\r\n                        ? `ginput_${i === 0 ? \"left\" : \"right\"}`\r\n                        : \"medim\"\r\n                    } ${passwords[i].cssClass ? passwords[i].cssClass : \"\"}`}\r\n                  >\r\n                    <Input\r\n                      id={`input_${formId}_${input.id}_${i}`}\r\n                      name={\r\n                        customName || `input_${id}${i === 1 ? `_${i + 1}` : \"\"}`\r\n                      }\r\n                      type={type}\r\n                      value={\r\n                        value && value[i] && value[i].val ? value[i].val : \"\"\r\n                      }\r\n                      placeholder={\r\n                        input.placeholder ? input.placeholder : placeholder\r\n                      }\r\n                      required={isRequired}\r\n                      autoComplete=\"off\"\r\n                      onChange={(event) => {\r\n                        field.subId = i;\r\n                        updateForm(event, field);\r\n                        unsetError(id);\r\n                        if (passwordStrengthEnabled && i === 0) {\r\n                          setGFPwdStrength(event.target.value);\r\n                        }\r\n                      }}\r\n                      onBlur={(event) => {\r\n                        field.subId = i;\r\n                        updateForm(event, field);\r\n                        setTouched(id);\r\n                        setFocusClass(\r\n                          value &&\r\n                            value[i] &&\r\n                            value[i].val &&\r\n                            value[i].val !== \"\",\r\n                          i\r\n                        );\r\n                      }}\r\n                      onFocus={() => setFocusClass(true, i)}\r\n                      aria-label={label}\r\n                      aria-describedby={`error_${formId}_${input.id}_${i}`}\r\n                      aria-invalid={!!validationMessage && touched}\r\n                    />\r\n                    <label htmlFor={`input_${formId}_${input.id}_${i}`}>\r\n                      {input.placeholder || input.label}\r\n                    </label>\r\n                  </span>\r\n                )\r\n            )}\r\n        </div>\r\n        {((validationMessage && touched) || error) && (\r\n          <span\r\n            className=\"error-message\"\r\n            id={`error_${formId}_${id}`}\r\n            dangerouslySetInnerHTML={{ __html: validationMessage || error }}\r\n          />\r\n        )}\r\n        {descriptionPlacement !== \"above\" && description && (\r\n          <div\r\n            className=\"description\"\r\n            dangerouslySetInnerHTML={{\r\n              __html: description.replace(/\\n/g, \"<br />\"),\r\n            }}\r\n          />\r\n        )}\r\n        {!((validationMessage && touched) || error) && passwordStrengthEnabled && (\r\n          <React.Fragment>\r\n            <div\r\n              id={`input_${formId}_${id}_strength_indicator`}\r\n              className={`gfield_password_strength ${passwordStrength}`}\r\n            >\r\n              {passwordStrength && passwordStrength !== \"blank\"\r\n                ? passwordStrength\r\n                : \"Strength indicator\"}\r\n            </div>\r\n            <input\r\n              type=\"hidden\"\r\n              className=\"gform_hidden\"\r\n              id={`input_${formId}_${id}_strength`}\r\n              name={`input_${id}_strength`}\r\n              value={passwordStrength}\r\n            />\r\n          </React.Fragment>\r\n        )}\r\n      </div>\r\n    </Box>\r\n  );\r\n};\r\n"]}