|  | @ -1,6 +1,7 @@ | 
			
		
	
		
		
			
				
					|  |  | import React, { useEffect, useState } from 'react'; |  |  | import React, { useEffect, useState } from 'react'; | 
			
		
	
		
		
			
				
					|  |  | import { connect } from 'react-redux'; |  |  | 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'; |  |  | import './qrCode.less'; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | const QrCode = (props) => { |  |  | const QrCode = (props) => { | 
			
		
	
	
		
		
			
				
					|  | @ -8,6 +9,7 @@ const QrCode = (props) => { | 
			
		
	
		
		
			
				
					|  |  |    const { projectRegime } = actions |  |  |    const { projectRegime } = actions | 
			
		
	
		
		
			
				
					|  |  |    const [firmList, setFirmList] = useState([]) |  |  |    const [firmList, setFirmList] = useState([]) | 
			
		
	
		
		
			
				
					|  |  |    const [tableList, settableList] = useState([]) |  |  |    const [tableList, settableList] = useState([]) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const [downloading, setDownloading] = useState(false) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    useEffect(() => { |  |  |    useEffect(() => { | 
			
		
	
		
		
			
				
					|  |  |       dispatch(projectRegime.getProjectList({ justStructure: true })).then(res => { |  |  |       dispatch(projectRegime.getProjectList({ justStructure: true })).then(res => { | 
			
		
	
	
		
		
			
				
					|  | @ -33,6 +35,44 @@ const QrCode = (props) => { | 
			
		
	
		
		
			
				
					|  |  |       img.onerror = null; |  |  |       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 ( |  |  |    return ( | 
			
		
	
		
		
			
				
					|  |  |       <div className='global-main'> |  |  |       <div className='global-main'> | 
			
		
	
		
		
			
				
					|  |  |          <div className='top'> |  |  |          <div className='top'> | 
			
		
	
	
		
		
			
				
					|  | @ -63,9 +103,8 @@ const QrCode = (props) => { | 
			
		
	
		
		
			
				
					|  |  |                   <Input placeholder="请输入点位名称" allowClear /> |  |  |                   <Input placeholder="请输入点位名称" allowClear /> | 
			
		
	
		
		
			
				
					|  |  |                </Form.Item> |  |  |                </Form.Item> | 
			
		
	
		
		
			
				
					|  |  |                <Form.Item wrapperCol={{}}> |  |  |                <Form.Item wrapperCol={{}}> | 
			
		
	
		
		
			
				
					
					|  |  |                   <Button htmlType="submit"> |  |  |                   <Button htmlType="submit" style={{ marginRight: 16 }}>搜索</Button> | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                      搜索 |  |  |                   <Button type="primary" onClick={batchDownload} loading={downloading}>导出</Button> | 
			
				
				
			
		
	
		
		
			
				
					|  |  |                   </Button> |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |                </Form.Item> |  |  |                </Form.Item> | 
			
		
	
		
		
			
				
					|  |  |             </Form> |  |  |             </Form> | 
			
		
	
		
		
			
				
					|  |  |          </div> |  |  |          </div> | 
			
		
	
	
		
		
			
				
					|  | @ -91,18 +130,12 @@ const QrCode = (props) => { | 
			
		
	
		
		
			
				
					|  |  |                      </div> |  |  |                      </div> | 
			
		
	
		
		
			
				
					|  |  |                      <div style={{ |  |  |                      <div style={{ | 
			
		
	
		
		
			
				
					|  |  |                         width: 234, height: 60, display: 'flex', |  |  |                         width: 234, height: 60, display: 'flex', | 
			
		
	
		
		
			
				
					
					|  |  |                         justifyContent: 'center', alignItems: 'center',  |  |  |                         justifyContent: 'center', alignItems: 'center', | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                      }}> |  |  |                      }}> | 
			
		
	
		
		
			
				
					|  |  |                         <Button type="primary" onClick={() => { |  |  |                         <Button type="primary" onClick={() => { | 
			
		
	
		
		
			
				
					
					|  |  |                            const a = document.createElement('a') |  |  |                            const tempArr = v.qrCode.split('/') | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                            const filenameArr = v.qrCode.split('/') |  |  |                            const filename = tempArr[tempArr.length - 1] | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                            const filename = filenameArr[filenameArr.length - 1] |  |  |                            downloadFile(`/_file-server/${v.qrCode}`, filename) | 
			
				
				
			
		
	
		
		
			
				
					|  |  |                            a.href = `/_file-server/${v.qrCode}` |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                            a.download = filename |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                            a.target = '_blank' |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                            document.body.appendChild(a) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                            a.click() |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                            document.body.removeChild(a) |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |                         }}>下载二维码</Button> |  |  |                         }}>下载二维码</Button> | 
			
		
	
		
		
			
				
					|  |  |                      </div> |  |  |                      </div> | 
			
		
	
		
		
			
				
					|  |  |                   </div> |  |  |                   </div> | 
			
		
	
	
		
		
			
				
					|  | @ -124,3 +157,13 @@ function mapStateToProps(state) { | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | export default connect(mapStateToProps)(QrCode); |  |  | 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); | 
			
		
	
		
		
			
				
					|  |  |  |  |  | } |