UNPKG

mindstream-gravity-form

Version:

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

2 lines 25.6 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"));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()}),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 _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(L,{htmlFor:"input_".concat(o,"_").concat(u),className:"gf-label ".concat(B)},w,y?_react["default"].createElement("abbr",null,"*"):null),"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){a.onChangeHandler(b),n(b,h),l(u),s(u)},onBlur:function onBlur(a){n(a,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"),_react["default"].createElement("span",null,d)),z&&_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","state","validationMessage","touched","setTouched","hideField","updateForm","formID","fieldError","styledComponents","dropzoneText","type","label","cssClass","isRequired","description","descriptionPlacement","labelPlacement","width","buttonText","maxFileSize","Button","Label","FileWrapper","Box","hasDropzone","display","onChangeHandler","prepareAllowedTypes","backgroundImage","removeFilePreview","onButtonClickHandler","Component"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\r\nimport Dropzone from 'react-dropzone';\r\nimport GFDropzone from './GFDropzone';\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] ? event.target.files[0].name : '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({ imagePreviewUrl: null, selectedFile: null, previewID: false });\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  render() {\r\n    const { selectedFile, uploadFileText, imagePreviewUrl, previewID } = 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 { Button = 'button', Label = 'label', FileWrapper = 'div', Box = 'div' } =\r\n      styledComponents || false;\r\n\r\n    const hasDropzone = cssClass.indexOf('dropzone') > -1;\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        <FileWrapper className={type}>\r\n          <Label htmlFor={`input_${formID}_${id}`} className={`gf-label ${labelPlacement}`}>\r\n            {label}\r\n            {isRequired ? <abbr>*</abbr> : null}\r\n          </Label>\r\n          {descriptionPlacement === 'above' && description ? (\r\n            description && <div className=\"description\">{description}</div>\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            <React.Fragment>\r\n              {maxFileSize && (\r\n                <input type=\"hidden\" name=\"MAX_FILE_SIZE\" value={maxFileSize * 1048576} />\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(event, field);\r\n                  setTouched(id);\r\n                  unsetError(id);\r\n                }}\r\n                onBlur={(event) => {\r\n                  updateForm(event, field);\r\n                  setTouched(id);\r\n                }}\r\n                accept={this.prepareAllowedTypes(allowedExtensions) || undefined}\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 type=\"hidden\" name=\"file-upload-preview\" value={previewID} />\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                <span>{uploadFileText}</span>\r\n              </div>\r\n\r\n              {description && <div className=\"description\">{description}</div>}\r\n            </React.Fragment>\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\r\n"]}