diff --git a/web/client/src/sections/projectRegime/containers/qrCode.js b/web/client/src/sections/projectRegime/containers/qrCode.js index 8fa9b90..57b1a71 100644 --- a/web/client/src/sections/projectRegime/containers/qrCode.js +++ b/web/client/src/sections/projectRegime/containers/qrCode.js @@ -1,6 +1,7 @@ import React, { useEffect, useState } from 'react'; import { connect } from 'react-redux'; -import { Form, Input, Select, Button } from 'antd'; +import { Form, Input, Select, Button, message } from 'antd'; +import JSZip from 'jszip'; import './qrCode.less'; const QrCode = (props) => { @@ -8,6 +9,7 @@ const QrCode = (props) => { const { projectRegime } = actions const [firmList, setFirmList] = useState([]) const [tableList, settableList] = useState([]) + const [downloading, setDownloading] = useState(false) useEffect(() => { dispatch(projectRegime.getProjectList({ justStructure: true })).then(res => { @@ -33,6 +35,44 @@ const QrCode = (props) => { img.onerror = null; } + const batchDownload = () => { + setDownloading(true) + let promiseArr = [], nameArr = [] + tableList.forEach(l => { + promiseArr.push( + window.fetch(`/_file-server/${l.qrCode}`, { + method: 'get', + headers: { + "Accept": "application/json", + "Content-Type": "application/json", + "X-Requested-With": "XMLHttpRequest", + }, + }) + ) + nameArr.push(l.name + '.jpeg') + }) + try { + Promise.all(promiseArr).then(async resArr => { + const zip = new JSZip() + for (let i = 0; i < resArr.length; i++) { + const response = resArr[i] + const blob = await response.blob() + zip.file(nameArr[i], blob) + } + zip.generateAsync({ type: "blob" }).then(blob => { + const url = window.URL.createObjectURL(blob) + downloadFile(url, "点位二维码.zip") + setDownloading(false) + message.success('下载成功') + }); + }) + } catch (error) { + console.log(error) + setDownloading(false) + message.error('下载失败') + } + } + return (
@@ -63,9 +103,8 @@ const QrCode = (props) => { - + +
@@ -91,18 +130,12 @@ const QrCode = (props) => {
@@ -124,3 +157,13 @@ function mapStateToProps(state) { } export default connect(mapStateToProps)(QrCode); + +function downloadFile(url, fileName) { + const a = document.createElement('a'); + a.style.display = 'none'; + a.href = url; + a.download = fileName; + document.body.appendChild(a); + a.click(); + document.body.removeChild(a); +} \ No newline at end of file diff --git a/web/package.json b/web/package.json index 2cd6963..f2ee917 100644 --- a/web/package.json +++ b/web/package.json @@ -87,6 +87,7 @@ "fs-attachment": "^1.0.0", "fs-web-server-scaffold": "^1.0.6", "i": "^0.3.6", + "jszip": "^3.10.1", "koa-better-http-proxy": "^0.2.5", "koa-proxy": "^1.0.0-alpha.3", "koa-view": "^2.1.4",