UNPKG

mindstream-react-gravity-form

Version:

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

2 lines 29.9 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;var _react=_interopRequireWildcard(require("react")),_reactDropzone=_interopRequireDefault(require("react-dropzone")),_GFDropzone=_interopRequireDefault(require("./GFDropzone")),_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 _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)}function _classCallCheck(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}function _defineProperties(a,b){for(var c,d=0;d<b.length;d++)c=b[d],c.enumerable=c.enumerable||!1,c.configurable=!0,"value"in c&&(c.writable=!0),Object.defineProperty(a,c.key,c)}function _createClass(a,b,c){return b&&_defineProperties(a.prototype,b),c&&_defineProperties(a,c),a}function _inherits(a,b){if("function"!=typeof b&&null!==b)throw new TypeError("Super expression must either be null or a function");a.prototype=Object.create(b&&b.prototype,{constructor:{value:a,writable:!0,configurable:!0}}),b&&_setPrototypeOf(a,b)}function _setPrototypeOf(a,b){return _setPrototypeOf=Object.setPrototypeOf||function(a,b){return a.__proto__=b,a},_setPrototypeOf(a,b)}function _createSuper(a){var b=_isNativeReflectConstruct();return function(){var c,d=_getPrototypeOf(a);if(b){var e=_getPrototypeOf(this).constructor;c=Reflect.construct(d,arguments,e)}else c=d.apply(this,arguments);return _possibleConstructorReturn(this,c)}}function _possibleConstructorReturn(a,b){return b&&("object"===_typeof(b)||"function"==typeof b)?b:_assertThisInitialized(a)}function _assertThisInitialized(a){if(void 0===a)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return a}function _isNativeReflectConstruct(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Date.prototype.toString.call(Reflect.construct(Date,[],function(){})),!0}catch(a){return!1}}function _getPrototypeOf(a){return _getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf:function(a){return a.__proto__||Object.getPrototypeOf(a)},_getPrototypeOf(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}var Fileupload=function(a){function b(){var a;_classCallCheck(this,b);for(var d=arguments.length,e=Array(d),f=0;f<d;f++)e[f]=arguments[f];return a=c.call.apply(c,[this].concat(e)),_defineProperty(_assertThisInitialized(a),"state",{imagePreviewUrl:a.props.field.preview||null,selectedFile:!!a.props.field.preview||null,uploadFileText:"No file chosen",previewID:a.props.value||null,errorText:a.props.error||!1}),_defineProperty(_assertThisInitialized(a),"inputFile",_react["default"].createRef()),_defineProperty(_assertThisInitialized(a),"onChangeHandler",function(b){var c=a.props.field,d=c.hasPreview,e=c.allowedExtensions;if(a.setState({imagePreviewUrl:null,selectedFile:b.target.files[0],uploadFileText:b.target.files[0]?b.target.files[0].name:"No file chosen"}),d&&b.target&&b.target.files[0]){var f=b.target.files[0].name.split(".").pop().toLowerCase(),g=-1<e.indexOf(f);if(g){var h=new FileReader;h.onloadend=function(){a.setState({imagePreviewUrl:h.result,previewID:!1})},h.readAsDataURL(b.target.files[0])}}}),_defineProperty(_assertThisInitialized(a),"removeFilePreview",function(){var b=a.props,c=b.field,d=b.unsetError;a.inputFile.current.value="",a.setState({imagePreviewUrl:null,selectedFile:null,previewID:!1}),d(c.id)}),_defineProperty(_assertThisInitialized(a),"prepareAllowedTypes",function(a){var b=a.split(",");return b=b.map(function(a){return".".concat(a.replace(/\s/g,""))}).join(", "),b}),_defineProperty(_assertThisInitialized(a),"onButtonClickHandler",function(){a.inputFile.current.click()}),_defineProperty(_assertThisInitialized(a),"removeFile",function(b,c){b.preventDefault();var d=a.props.updateForm;d({target:{value:""}},c),a.inputFile.current.value="",a.setState({imagePreviewUrl:!1,selectedFile:!1,previewID:!1,uploadFileText:"No file chosen"})}),a}_inherits(b,a);var c=_createSuper(b);return _createClass(b,[{key:"render",value:function render(){var a=this,b=this.state,c=b.selectedFile,d=b.uploadFileText,e=b.imagePreviewUrl,f=b.previewID,g=this.props,h=g.field,i=g.value,j=g.validationMessage,k=g.touched,l=g.setTouched,m=g.hideField,n=g.updateForm,o=g.formID,p=g.fieldError,q=g.styledComponents,r=g.error,s=g.unsetError,t=g.dropzoneText,u=h.id,v=h.type,w=h.label,x=h.cssClass,y=h.isRequired,z=h.description,A=h.descriptionPlacement,B=h.labelPlacement,C=h.width,D=h.allowedExtensions,E=h.buttonText,F=h.hasPreview,G=h.maxFileSize,H=q||!1,I=H.Button,J=void 0===I?"button":I,K=H.Label,L=void 0===K?"label":K,M=H.FileWrapper,N=void 0===M?"div":M,O=H.Box,P=void 0===O?"div":O,Q=-1<x.indexOf("dropzone");return console.log("hasDropzone",Q),_react["default"].createElement(P,{width:C,className:j&&k||r?"form-field error ".concat(x):"form-field ".concat(x),style:{display:m?"none":void 0}},_react["default"].createElement(N,{className:v},_react["default"].createElement(_InputLabel["default"],{formId:o,id:u,label:w,labelPlacement:B,isRequired:y,styledComponent:q}),"above"===A&&z&&z&&_react["default"].createElement("div",{className:"description"},z),Q?_react["default"].createElement(_GFDropzone["default"],{dropzoneText:t,field:h,id:u,formID:o,isRequired:y,updateForm:n,setTouched:l,unsetError:s}):_react["default"].createElement(_react["default"].Fragment,null,G&&_react["default"].createElement("input",{type:"hidden",name:"MAX_FILE_SIZE",value:1048576*G}),_react["default"].createElement("input",{id:"input_".concat(o,"_").concat(u),name:"input_".concat(u),type:"file",required:y,ref:this.inputFile,onChange:function onChange(b){var c,d,e;a.onChangeHandler(b),n({target:{value:null===b||void 0===b||null===(c=b.target)||void 0===c||null===(d=c.files)||void 0===d||null===(e=d[0])||void 0===e?void 0:e.name}},h),l(u),s(u)},onBlur:function onBlur(a){var b,c,d;n({target:{value:null===a||void 0===a||null===(b=a.target)||void 0===b||null===(c=b.files)||void 0===c||null===(d=c[0])||void 0===d?void 0:d.name}},h),l(u)},accept:this.prepareAllowedTypes(D)||void 0,"aria-label":w,"aria-describedby":"error_".concat(o,"_").concat(u),"aria-invalid":!!j||!!r,hidden:"hidden"}),f&&h.preview&&_react["default"].createElement("input",{type:"hidden",name:"file-upload-preview",value:f}),F&&_react["default"].createElement("div",{className:"file-preview",style:c&&e?{backgroundImage:"url(".concat(e,")")}:void 0},c&&e&&_react["default"].createElement("button",{type:"button",className:"remove-file",onClick:function onClick(){return a.removeFilePreview()}})),_react["default"].createElement("div",{"aria-pressed":"false",tabIndex:"0",role:"button",className:"fileUpload",onClick:this.onButtonClickHandler},_react["default"].createElement(J,{color:"yellow",tabIndex:"-1",type:"button"},E||"Choose a file"),!c&&_react["default"].createElement("span",{className:"no-file"},d)),c&&_react["default"].createElement("div",null,_react["default"].createElement("button",{type:"button",onClick:function onClick(b){return a.removeFile(b,h)}},"remove file"),_react["default"].createElement("span",null,d)),z&&"above"!==A&&_react["default"].createElement("div",{className:"description"},z)),(j&&k||r)&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(u)},j||r),p&&_react["default"].createElement("span",{className:"error-message",id:"error_".concat(o,"_").concat(u)},p)))}}]),b}(_react.Component),_default=Fileupload;exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Fields/Fileupload/Fileupload.jsx"],"names":["Fileupload","imagePreviewUrl","props","field","preview","selectedFile","uploadFileText","previewID","value","errorText","error","React","createRef","event","hasPreview","allowedExtensions","setState","target","files","name","extension","split","pop","toLowerCase","isSuccess","indexOf","reader","FileReader","onloadend","result","readAsDataURL","unsetError","inputFile","current","id","types","accept","map","str","replace","join","click","e","preventDefault","updateForm","state","validationMessage","touched","setTouched","hideField","formID","fieldError","styledComponents","dropzoneText","type","label","cssClass","isRequired","description","descriptionPlacement","labelPlacement","width","buttonText","maxFileSize","Button","Label","FileWrapper","Box","hasDropzone","console","log","display","onChangeHandler","prepareAllowedTypes","backgroundImage","removeFilePreview","onButtonClickHandler","removeFile","Component"],"mappings":"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","sourcesContent":["import React, { Component } from \"react\";\r\nimport Dropzone from \"react-dropzone\";\r\nimport GFDropzone from \"./GFDropzone\";\r\nimport InputLabel from \"../../FormElements/InputLabel\";\r\n\r\nclass Fileupload extends Component {\r\n  state = {\r\n    imagePreviewUrl: this.props.field.preview || null,\r\n    selectedFile: this.props.field.preview ? true : null,\r\n    uploadFileText: \"No file chosen\",\r\n    previewID: this.props.value || null,\r\n    errorText: this.props.error || false,\r\n  };\r\n\r\n  inputFile = React.createRef();\r\n\r\n  onChangeHandler = (event) => {\r\n    const { hasPreview, allowedExtensions } = this.props.field;\r\n    this.setState({\r\n      imagePreviewUrl: null,\r\n      selectedFile: event.target.files[0],\r\n      uploadFileText: event.target.files[0]\r\n        ? event.target.files[0].name\r\n        : \"No file chosen\",\r\n    });\r\n\r\n    if (hasPreview && event.target && event.target.files[0]) {\r\n      // check file type\r\n      const extension = event.target.files[0].name\r\n        .split(\".\")\r\n        .pop()\r\n        .toLowerCase(); // file extension from input file\r\n      const isSuccess = allowedExtensions.indexOf(extension) > -1; // is extension in acceptable types\r\n      if (isSuccess) {\r\n        const reader = new FileReader();\r\n\r\n        reader.onloadend = () => {\r\n          this.setState({\r\n            imagePreviewUrl: reader.result,\r\n            previewID: false,\r\n          });\r\n        };\r\n\r\n        reader.readAsDataURL(event.target.files[0]);\r\n      }\r\n    }\r\n  };\r\n\r\n  removeFilePreview = () => {\r\n    const { field, unsetError } = this.props;\r\n    this.inputFile.current.value = \"\";\r\n    this.setState({\r\n      imagePreviewUrl: null,\r\n      selectedFile: null,\r\n      previewID: false,\r\n    });\r\n    unsetError(field.id);\r\n  };\r\n\r\n  prepareAllowedTypes = (types) => {\r\n    let accept = types.split(\",\");\r\n    accept = accept.map((str) => `.${str.replace(/\\s/g, \"\")}`).join(\", \");\r\n    return accept;\r\n  };\r\n\r\n  onButtonClickHandler = () => {\r\n    this.inputFile.current.click();\r\n  };\r\n\r\n  removeFile = (e, field) => {\r\n    e.preventDefault();\r\n    const { updateForm } = this.props;\r\n    updateForm({ target: { value: \"\" } }, field);\r\n    this.inputFile.current.value = \"\";\r\n    this.setState({\r\n      imagePreviewUrl: false,\r\n      selectedFile: false,\r\n      previewID: false,\r\n      uploadFileText: \"No file chosen\",\r\n    });\r\n  };\r\n\r\n  render() {\r\n    const { selectedFile, uploadFileText, imagePreviewUrl, previewID } =\r\n      this.state;\r\n\r\n    const {\r\n      field,\r\n      value,\r\n      validationMessage,\r\n      touched,\r\n      setTouched,\r\n      hideField,\r\n      updateForm,\r\n      formID,\r\n      fieldError,\r\n      styledComponents,\r\n      error,\r\n      unsetError,\r\n      dropzoneText,\r\n    } = this.props;\r\n    const {\r\n      id,\r\n      type,\r\n      label,\r\n      cssClass,\r\n      isRequired,\r\n      description,\r\n      descriptionPlacement,\r\n      labelPlacement,\r\n      width,\r\n      allowedExtensions,\r\n      buttonText,\r\n      hasPreview,\r\n      maxFileSize,\r\n    } = field;\r\n    const {\r\n      Button = \"button\",\r\n      Label = \"label\",\r\n      FileWrapper = \"div\",\r\n      Box = \"div\",\r\n    } = styledComponents || false;\r\n\r\n    const hasDropzone = cssClass.indexOf(\"dropzone\") > -1;\r\n\r\n    console.log(\"hasDropzone\", hasDropzone);\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        <FileWrapper 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 && description && (\r\n            <div className=\"description\">{description}</div>\r\n          )}\r\n          {hasDropzone ? (\r\n            <GFDropzone\r\n              dropzoneText={dropzoneText}\r\n              field={field}\r\n              id={id}\r\n              formID={formID}\r\n              isRequired={isRequired}\r\n              updateForm={updateForm}\r\n              setTouched={setTouched}\r\n              unsetError={unsetError}\r\n            />\r\n          ) : (\r\n            <>\r\n              {maxFileSize && (\r\n                <input\r\n                  type=\"hidden\"\r\n                  name=\"MAX_FILE_SIZE\"\r\n                  value={maxFileSize * 1048576}\r\n                />\r\n              )}\r\n              <input\r\n                id={`input_${formID}_${id}`}\r\n                name={`input_${id}`}\r\n                type=\"file\"\r\n                required={isRequired}\r\n                ref={this.inputFile}\r\n                onChange={(event) => {\r\n                  this.onChangeHandler(event);\r\n                  updateForm(\r\n                    { target: { value: event?.target?.files?.[0]?.name } },\r\n                    field\r\n                  );\r\n                  setTouched(id);\r\n                  unsetError(id);\r\n                }}\r\n                onBlur={(event) => {\r\n                  updateForm(\r\n                    { target: { value: event?.target?.files?.[0]?.name } },\r\n                    field\r\n                  );\r\n                  setTouched(id);\r\n                }}\r\n                accept={\r\n                  this.prepareAllowedTypes(allowedExtensions) || undefined\r\n                }\r\n                aria-label={label}\r\n                aria-describedby={`error_${formID}_${id}`}\r\n                aria-invalid={!!validationMessage || !!error}\r\n                hidden=\"hidden\"\r\n              />\r\n              {previewID && field.preview && (\r\n                <input\r\n                  type=\"hidden\"\r\n                  name=\"file-upload-preview\"\r\n                  value={previewID}\r\n                />\r\n              )}\r\n              {hasPreview && (\r\n                <div\r\n                  className=\"file-preview\"\r\n                  style={\r\n                    selectedFile && imagePreviewUrl\r\n                      ? { backgroundImage: `url(${imagePreviewUrl})` }\r\n                      : undefined\r\n                  }\r\n                >\r\n                  {selectedFile && imagePreviewUrl && (\r\n                    <button\r\n                      type=\"button\"\r\n                      className=\"remove-file\"\r\n                      onClick={() => this.removeFilePreview()}\r\n                    />\r\n                  )}\r\n                </div>\r\n              )}\r\n              <div\r\n                aria-pressed=\"false\"\r\n                tabIndex=\"0\"\r\n                role=\"button\"\r\n                className=\"fileUpload\"\r\n                onClick={this.onButtonClickHandler}\r\n              >\r\n                <Button color=\"yellow\" tabIndex=\"-1\" type=\"button\">\r\n                  {buttonText || \"Choose a file\"}\r\n                </Button>\r\n                {!selectedFile && (\r\n                  <span className=\"no-file\">{uploadFileText}</span>\r\n                )}\r\n              </div>\r\n              {selectedFile && (\r\n                <div>\r\n                  <button\r\n                    type=\"button\"\r\n                    onClick={(e) => this.removeFile(e, field)}\r\n                  >\r\n                    remove file\r\n                  </button>\r\n                  <span>{uploadFileText}</span>\r\n                </div>\r\n              )}\r\n              {description && descriptionPlacement !== \"above\" && (\r\n                <div className=\"description\">{description}</div>\r\n              )}\r\n            </>\r\n          )}\r\n          {((validationMessage && touched) || error) && (\r\n            <span className=\"error-message\" id={`error_${id}`}>\r\n              {validationMessage || error}\r\n            </span>\r\n          )}\r\n          {fieldError && (\r\n            <span className=\"error-message\" id={`error_${formID}_${id}`}>\r\n              {fieldError}\r\n            </span>\r\n          )}\r\n        </FileWrapper>\r\n      </Box>\r\n    );\r\n  }\r\n}\r\n\r\nexport default Fileupload;\r\n"]}