通用评论

1
  1. {"version":3,"sources":["../../../src/components/Editor/Upload.js"],"names":["client","window","OSS","Wrapper","accessKeyId","oss","access_key_id","accessKeySecret","access_key_secret","stsToken","security_token","endpoint","OSS_ENDPOINT","bucket","OSS_BUCKET","uploadPath","path","file","format","shortid","generate","type","split","UploadToOss","url","Promise","resolve","reject","multipartUpload","then","data","catch","error","App","props","state","previewVisible","previewImage","handleCancel","bind","handlePreview","handleChange","customRequest","app","sOssSts","setState","thumbUrl","fileList","onChangeFileList","info","onProgress","percent","reader","FileReader","readAsDataURL","onloadend","DRIVER_LICENSE_PATH","onSuccess","onUpload","name","uid","e","message","ERROR_DEFAULT","onError","uploadButton","length","MAX_UPLOAD_NUMBER","width","React","Component"],"mappings":"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","file":"Upload.js","sourcesContent":["import React from \"react\";\nimport { Upload, Icon, Modal, message } from \"antd\";\nimport dayjs from \"dayjs\";\nimport shortid from \"shortid\";\nimport {\n OSS_ENDPOINT,\n OSS_BUCKET,\n DRIVER_LICENSE_PATH,\n ERROR_DEFAULT,\n MAX_UPLOAD_NUMBER\n} from \"../../constant\";\nimport Comment from \"../../Comment\";\n// import styles from \"./Upload.less\";\nimport \"./Upload.css\";\n\nconst client = oss => {\n return new window.OSS.Wrapper({\n accessKeyId: oss.access_key_id,\n accessKeySecret: oss.access_key_secret,\n stsToken: oss.security_token,\n endpoint: OSS_ENDPOINT, //常量,你可以自己定义\n bucket: OSS_BUCKET\n });\n};\n\nconst uploadPath = (path, file) => {\n return `${path}/${dayjs().format(\"YYYYMMDD\")}/${shortid.generate()}.${\n file.type.split(\"/\")[1]\n }`;\n};\n\nconst UploadToOss = (oss, path, file) => {\n const url = uploadPath(path, file);\n return new Promise((resolve, reject) => {\n client(oss)\n .multipartUpload(url, file)\n .then(data => {\n resolve(data);\n })\n .catch(error => {\n reject(error);\n });\n });\n};\n\nclass App extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n previewVisible: false,\n previewImage: \"\"\n };\n this.handleCancel = this.handleCancel.bind(this);\n this.handlePreview = this.handlePreview.bind(this);\n this.handleChange = this.handleChange.bind(this);\n this.customRequest = this.customRequest.bind(this);\n }\n\n componentDidMount() {\n this.props.app.sOssSts();\n }\n\n handleCancel() {\n this.setState({ previewVisible: false });\n }\n\n handlePreview(file) {\n this.setState({\n previewImage: file.url || file.thumbUrl,\n previewVisible: true\n });\n }\n\n handleChange({ fileList }) {\n this.props.onChangeFileList(fileList);\n }\n\n customRequest(info) {\n const { file } = info;\n info.onProgress({ percent: 10 });\n let reader = new FileReader();\n reader.readAsDataURL(info.file);\n reader.onloadend = () => {\n info.onProgress({ percent: 20 });\n // DRIVER_LICENSE_PATH oss 的存储路径位置\n UploadToOss(this.props.app.oss, DRIVER_LICENSE_PATH, file)\n .then(data => {\n info.onProgress({ percent: 100 });\n info.onSuccess();\n this.props.onUpload({ path: data.name, uid: file.uid });\n })\n .catch(e => {\n message.error(e.message || ERROR_DEFAULT);\n info.onError(e);\n });\n };\n }\n\n render() {\n const { previewVisible, previewImage } = this.state;\n const { fileList } = this.props;\n const uploadButton = (\n <div>\n <Icon type=\"plus\" />\n <div className=\"ant-upload-text\">上传</div>\n </div>\n );\n return (\n <div>\n <Upload\n accept=\"image/jpg,image/jpeg,image/png,image/bmp\"\n listType=\"picture-card\"\n fileList={fileList}\n customRequest={this.customRequest}\n onPreview={this.handlePreview}\n onChange={this.handleChange}\n >\n {fileList.length >= MAX_UPLOAD_NUMBER ? null : uploadButton}\n </Upload>\n <Modal\n visible={previewVisible}\n footer={null}\n onCancel={this.handleCancel}\n >\n <img alt=\"upload\" style={{ width: \"100%\" }} src={previewImage} />\n </Modal>\n </div>\n );\n }\n}\n\nexport default Comment(App);\n"]}