import request from '@/utils/request' import XLSX from 'xlsx' const 技术准备=()=>{ const list=()=>{ request({url:'/jszb/getFlowInfoList',method:'get',params:data.formData}) .then(res => { console.log(res.data) data.options.data=res.data }) } const importMethod=({file})=>{ const formBody = new FormData() formBody.append('file', file) return fetch(`${process.env.VUE_APP_BASE_API}jszb/importFLowInfo`, { method: 'POST', body: formBody }) .then(response => { console.log(response) }).then(data => { console.log(data) }).catch((e) => { console.log(e) VXETable.modal.message({ content: '导入失败,请检查数据是否正确!', status: 'error' }) }) } //NCA,NCB,NCC,NCG,NCJ,NCL,NCP,NCT,SG2,SG3,XCX const exportMethod=({options})=>{ const workBook = XLSX.utils.book_new(); const T型材Group=['SG2'] const {sheet:T型材重量sheet}=处理数据(T型材Group,(list)=>{ return list.map(item=>{ return { 船名:item.ch, 段号:item.fd, 零件号:item.partName, 材质:item.material, 规格:item.specification, 工序:item.type0, 左:item.p, 中:item.c, 右:item.s, 重量:item, 数量:(item.p||0)+(item.c||0)+(item.s||0), 长度:item.xxSize, 宽度:item.yySize, } }) }) XLSX.utils.book_append_sheet(workBook, T型材重量sheet, "T型材重量"); const {sheet:T型材数量sheet}=处理数据(T型材Group,(list)=>{ const data={} list.forEach(item=>{ const _data=data[item.pl+'_'+item.fd] if (_data){ if (item.option3==='X'){ _data.小组数量++ _data.小组重量 += item.weight||0 } if (item.option3!=='X'){ _data.大组数量++ _data.大组重量 += item.weight||0 } }else{ _data.小组数量=0 _data.大组数量=0 _data.小组重量=0 _data.大组重量=0 } }) return Object.keys(data).map(key=>{ const item=data[key] const pl=key.split("_")[0] const fd=key.split("_")[1] return { 批量:pl, 分段:fd, 小组数量:item.小组数量, 小组:item.小组重量, 大组数量:item.大组数量, 大组:item.大组重量 } }) }) XLSX.utils.book_append_sheet(workBook, T型材数量sheet, "T型材数量"); const {sheet:曲平铁sheet}=处理数据(['SG2','SG3','XCX'],(list)=>{ return list.map(item=>{ return { 船名:item.ch, 段号:item.fd, 批量:item.pl, 零件号:item.partName, 材质:item.material, 规格:item.specification, 工序:item.type0, 左:item.p, 中:item.c, 右:item.s, 长度:item.xxSize, 宽度:item.yySize, } }) }) XLSX.utils.book_append_sheet(workBook, 曲平铁sheet, "曲平铁"); const {sheet:曲外板sheet}=处理数据(['NCA','NCB','NCC','NCG','NCJ','NCL','NCP','NCT'],(list)=>{ return list.map(item=>{ return { 船名:item.ch, 段号:item.fd, 批量:item.pl, 零件号:item.partName, 材质:item.material, 规格:item.specification, 工序:item.type0, 左:item.p, 中:item.c, 右:item.s, 长度:item.xxSize, 宽度:item.yySize, } }) }) XLSX.utils.book_append_sheet(workBook, 曲外板sheet, "曲外板"); const {sheet:lastSheet}=处理数据(['NCA','NCB','NCC','NCG','NCJ','NCL','NCP','NCT'],(list)=>{ return list.map(item=>{ return { 船名:item.ch, 分段号:item.fd, 批量:item.pl, 零件名称:item.partName, 种类:item.type, 规格:item.specification, 数量:(item.p||0)+(item.c||0)+(item.s||0), 材质:item.material, 工序:item.type0, 特征:item.feature, 流向:item.flow, 下级:item.nextLevel, 套料图信息:item.nestingInfo, } }) }) XLSX.utils.book_append_sheet(workBook, lastSheet, "流向(M、L);组立(大、中);种类(板)"); XLSX.writeFile(workBook, `${data.formData.ch}船技术准备.xlsx`) } const 处理数据=(groups,fun)=>{ const list=data.filter(item=>groups.includes(item.type0)) return {list:fun(list),sheet:XLSX.utils.json_to_sheet(_data)} } const data={ formData:{ ch:'', begin:'', end:'', }, formItems:[ { field: 'ch', title: '船号', span: 4, itemRender: { name: '$input', props: {placeholder: '船号' } } }, { field: 'begin', title: '批次', span: 4 , itemRender: { name: '$input', props: {placeholder: '起始批次' } } }, { field: 'end', title: '批次', span: 4 , itemRender: { name: '$input', props: {placeholder: '结束批次' } } }, {align:'right', span: 12 , itemRender: { name: '$button', props: {content:'查询',status:'primary'},events:{click:list} } }, ], options:{ height:765, align:'center', border: true, // resizable: true, keepSource:true, size:'mini', showOverflow: true, // scrollY:{enable:true,gt:10}, // scrollX:{enable:true,gt:10,scrollToLeftOnChange:true}, highlightCurrentRow:true, data:[], toolbarConfig: { import: true, export: true, custom: true }, importConfig: { remote: true, importMethod: importMethod, types: ['xls','xlsx'], modes: ['insert'] }, exportConfig: { remote: true, exportMethod: exportMethod, types: ['xlsx'], modes: ['current', 'selected', 'all'] }, }, columns:[ { type: 'seq', width: 60, title: '序号' ,}, { field: 'ch', title: '船号', width: 120 }, { field: 'pl', title: '批量', width: 100, filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }], filterRender: { name: 'FilterCombination', }, }, { field: 'fd', title: '分段号', width: 120 , filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }], filterRender: { name: 'FilterCombination', }, }, { field: 'partName', title: '零件名称', width: 150, filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }], filterRender: { name: 'FilterCombination', }, }, { field: 'type', title: '种类', width: 100, filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }], filterRender: { name: 'FilterCombination', }, }, { field: 'specification', title: '规格', width: 130 }, { field: 'quantity', title: '数量', width: 100 }, { field: 'material', title: '材质', width: 120 }, { field: 'feature', title: '特征', width: 120 }, { field: 'flow', title: '流向', width: 120 }, { field: 'nextLevel', title: '下级', width: 120 }, { field: 'nestingInfo', title: '套料图信息', width: 150 }, { field: 'location', title: '场地', width: 120 }, { field: 'project', title: 'PROJECT', width: 120 }, { field: 'block', title: 'BLOCK', width: 120 }, { field: 'partName0', title: 'PARTNAME', width: 120 }, { field: 'partNo', title: 'PARTNO', width: 120 }, { field: 'material0', title: 'MATERIAL', width: 120 }, { field: 'thickness', title: 'THICK', width: 120 }, { field: 'type0', title: 'TYPE', width: 120 }, { field: 'p', title: 'P', width: 80 }, { field: 'c', title: 'C', width: 80 }, { field: 's', title: 'S', width: 80 }, { field: 'np', title: 'NP', width: 80 }, { field: 'nc', title: 'NC', width: 80 }, { field: 'ns', title: 'NS', width: 80 }, { field: 'area', title: 'AREA', width: 120 }, { field: 'weight', title: 'WEIGHT', width: 120 }, { field: 'cutLength', title: 'CUTLEN', width: 120 }, { field: 'markLength', title: 'MARKLEN', width: 120 }, { field: 'xxSize', title: 'X-SIZE', width: 120 }, { field: 'yySize', title: 'Y-SIZE', width: 120 }, { field: 'option', title: 'OPTION0', width: 120 }, { field: 'm_part_name', title: 'MPARTNAME', width: 120 }, { field: 's_part_name', title: 'SPARTNAME', width: 120 }, { field: 'lot', title: 'LOT', width: 120 }, { field: 'bbArea', title: 'BAREA', width: 120 }, { field: 'ssAngle', title: 'SANGLE', width: 120 }, { field: 'ssSizeX', title: 'SSIZE-X', width: 120 }, { field: 'ssSizeY', title: 'SSIZE-Y', width: 120 }, { field: 'goid', title: 'GOID', width: 120 }, { field: 'date', title: 'DATE', width: 120 }, { field: 'time', title: 'TIME', width: 120 }, { field: 'shape', title: 'SHAPE', width: 120 }, { field: 'assembly', title: 'ASSEMBLY', width: 120 }, { field: 'option1', title: 'OPTION1', width: 120 }, { field: 'option2', title: 'OPTION2', width: 120 }, { field: 'option3', title: 'OPTION3', width: 120 }, { field: 'option4', title: 'OPTION4', width: 120 }, { field: 'option5', title: 'OPTION5', width: 120 }, { field: 'direction', title: 'DIRECTION', width: 120 }, { field: 'isModify', title: 'ISMODIFY', width: 120 }, { field: 'nestName', title: 'NESTNAME', width: 120 } ], } return data } export default 技术准备