| <template> | 
|   <!-- 面包屑导航区 -->    | 
|   <div class="indexs"> | 
|     <el-card> | 
|       <el-row> | 
|         <el-button type="success" plain @click="exportExcel" >导出Excel</el-button> | 
|         <el-input v-model="searchParam.PoCode" placeholder="PO单号" class="search"></el-input> | 
|            <el-input v-model="searchParam.ProductName" placeholder="物料名称" class="search"></el-input> | 
|             <el-input v-model="searchParam.ItemNumber" placeholder="项号" class="search"></el-input> | 
|             <el-date-picker | 
|             v-model="datatime" | 
|             size="large" | 
|             type="datetimerange" | 
|             value-format="yyyy-MM-dd HH:mm:ss" | 
|             range-separator="至" | 
|             start-placeholder="开始日期" | 
|             end-placeholder="结束日期" | 
|           > | 
|           </el-date-picker> | 
|             <el-button type="success" plain @click="find(1)" >查询</el-button> | 
|              <el-button type="info" plain @click="reset" >重置</el-button> | 
|       </el-row> | 
|       <!-- 显示人员列表 --> | 
|       <el-table ref= "table"  :max-height="tableHeight" :data="TakeStocklist" bottom= "10%" border stripe > | 
|         <el-table-column | 
|       type="selection" | 
|       width="55"> | 
|     </el-table-column> | 
|         <el-table-column | 
|         label="序号" | 
|       type="index" | 
|       width="50"> | 
|     </el-table-column> | 
|         <el-table-column label="PO单号" prop="PoCode" width="200"></el-table-column> | 
|         <el-table-column label="物料名称" prop="ProductName" width="300" ></el-table-column> | 
|          <el-table-column label="项号" prop="ItemNumber" width="300" ></el-table-column> | 
|         <el-table-column label="时间" prop="CreateTime" width="170" :formatter="formatterDateTime" ></el-table-column> | 
|         <el-table-column label="备注" prop="Remark" width="120"></el-table-column> | 
|       </el-table> | 
|       <el-pagination | 
|         :current-page="queryInfo.pagenum" | 
|         :page-sizes="[5,10, 15, 20,50,100,1000,10000]" | 
|         :page-size="queryInfo.pagesize" | 
|         :total="total" | 
|         layout="total, sizes, prev, pager, next, jumper" | 
|         @size-change="handleSizeChange" | 
|         @current-change="handleCurrentChange" | 
|       > | 
|       </el-pagination> | 
|     </el-card> | 
|    | 
|   </div> | 
| </template> | 
| <script> | 
| import { parseTime,formatDate} from '@/utils' | 
| import { getThisWeekRange} from '@/utils/formatTime.js' | 
|   | 
| export default { | 
|   data() { | 
|     return { | 
|       tableHeight:window.innerHeight-204, | 
|       searchParam: { | 
|         ProductName: null, | 
|         MaterialCode: null, | 
|         ItemNumber: null | 
|       }, | 
|       queryInfo: { | 
|         // 当前页 | 
|         pagenum: 1, | 
|         // 每页显示多少条信息s | 
|         pagesize: 10 | 
|       }, | 
|   | 
|       TakeStocklist: [], | 
|       TakeStocklistAll: [], | 
|       total: 0, | 
|       datatime: '', | 
|       selectType: [ | 
|         { value: '1', label: '出库' }, { value: '2', label: '移库' }, { value: '3', label: '收货' }, { value: '4', label: '按凭证退货' }], | 
|       selectTypeValue: '', | 
|       dialogFormVisible: false, | 
|       productList: [], | 
|       updateDate: null | 
|     } | 
|   }, | 
|   created() {}, | 
|   mounted() { | 
|     this.initTimeData(); | 
|     this.find(1) | 
|   }, | 
|   methods: { | 
|     initTimeData(){ | 
|       this.datatime= ''; | 
|       this.datatime= getThisWeekRange(30);//启用了 | 
|     }, | 
|      // 时间转换 | 
|     formatterDateTime (row, column, cellValue, index) { | 
|       if (cellValue === null || cellValue === '') { | 
|         return '' | 
|       } | 
|       var NewDtime = new Date(cellValue) | 
|       return formatDate(NewDtime, 'yyyy-MM-dd hh:mm:ss') | 
|     }, | 
|   | 
|     // 监听 pagesize 改变 | 
|     handleSizeChange(newSizd) { | 
|       this.queryInfo.pagesize = newSizd | 
|       this.queryInfo.pagenum = 1 | 
|       this.find(1) | 
|     }, | 
|     // 监听 页码值改变 | 
|     handleCurrentChange(newpage) { | 
|       this.queryInfo.pagenum = newpage | 
|   | 
|       this.find(2) | 
|     }, | 
|     userStatusChange(userinfo) { | 
|       console.log(userinfo) | 
|     }, | 
|     getSummaries(param) { | 
|       const { columns, data } = param | 
|       const sums = [] | 
|       columns.forEach((column, index) => { | 
|         if (index === 0) { | 
|           sums[index] = '合计' | 
|           return | 
|         } | 
|         if (index != 5) { | 
|           sums[index] = '' | 
|           return | 
|         } | 
|         const values = data.map(item => Number(item[column.property])) | 
|         if (!values.every(value => isNaN(value))) { | 
|           sums[index] = values.reduce((prev, curr) => { | 
|             const value = Number(curr) | 
|             if (!isNaN(value)) { | 
|               return prev + curr | 
|             } else { | 
|               return prev | 
|             } | 
|           }, 0) | 
|           sums[index] += ' ' | 
|         } else { | 
|           sums[index] = 'N/A' | 
|         } | 
|         sums[index] = Number(sums[index]).toFixed(2) | 
|       }) | 
|   | 
|       return sums | 
|     }, | 
|      | 
|     formatJson(filterVal, jsonData) { | 
|       return jsonData.map(v => | 
|         filterVal.map(j => { | 
|           if (j === 'CreateTime') { | 
|             return parseTime(v[j]) | 
|           }  | 
|           else if (j === 'moveType') { | 
|             return this.setMoveTypeStr(v[j]) | 
|           }  | 
|           else if (j === 'isFinish') { | 
|             return this.setIsFinishStr(v[j]) | 
|           } else { | 
|             return v[j] | 
|           } | 
|         }) | 
|       ) | 
|     }, | 
|     find(ischang = 1) { | 
|       if (ischang == 1) { | 
|         this.queryInfo.pagenum = 1 | 
|       } | 
|       const url = '/api/task/queryPagePurchaseEmptyMaterialCode' | 
|       const params = { | 
|         search: this.searchParam, | 
|         queryInfo: this.queryInfo, //分页 | 
|         positionTypeValue: this.selectTypeValue, //下拉框的值 | 
|         datatime: this.datatime, //日期 | 
|         alarmValue: 1 | 
|       } | 
|       var callback = res => { | 
|         //debugger | 
|         if (res.result === true) { | 
|           res.data.forEach(item => { | 
|             item.moveType =this.setMoveTypeStr(item.moveType) | 
|              item.isFinish =this.setIsFinishStr(item.isFinish) | 
|           }) | 
|   | 
|           this.TakeStocklist = res.data | 
|           this.TakeStocklistAll = res.data2 | 
|           this.total = res.countPrint | 
|         } else { | 
|           this.TakeStocklist = [] | 
|           this.TakeStocklistAll = [] | 
|           this.total = 0 | 
|           return this.$message.success('当前条件 查不到数据!') | 
|         } | 
|       } | 
|       this.common.ajax(url, params, callback, true) | 
|     }, | 
|     find_export(ischang = 1) { | 
|       if (ischang == 1) { | 
|         this.queryInfo.pagenum = 1 | 
|       } | 
|       const url = '/api/task/queryPagePurchaseEmptyMaterialCode' | 
|       const params = { | 
|          IsLoadAllData:true,//加载全部 | 
|         search: this.searchParam, | 
|         queryInfo: this.queryInfo, //分页 | 
|         positionTypeValue: this.selectTypeValue, //下拉框的值 | 
|         datatime: this.datatime, //日期 | 
|         alarmValue: 1 | 
|       } | 
|       var callback = res => { | 
|         //debugger | 
|         if (res.result === true) { | 
|           res.data2.forEach(item => { | 
|             item.moveType =this.setMoveTypeStr(item.moveType) | 
|              item.isFinish =this.setIsFinishStr(item.isFinish) | 
|           }) | 
|           this.TakeStocklistAll = res.data2 | 
|           this.do_exportExcel() | 
|         } else { | 
|           this.TakeStocklistAll = [] | 
|           return this.$message.success('当前条件 查不到数据!') | 
|         } | 
|       } | 
|       this.common.ajax(url, params, callback, true) | 
|     }, | 
|     do_exportExcel() { | 
|       // import("@/vendor/Export2Excel") | 
|       this.downloadLoading = true | 
|       import('@/vendor/Export2Excel').then(excel => { | 
|         const tHeader = ['PO单号', '物料名称', '项号', '时间','备注'] | 
|         const filterVal = ['PoCode', 'ProductName', 'ItemNumber', 'CreateTime', 'Remark'] | 
|         const data = this.formatJson(filterVal, this.TakeStocklistAll) | 
|         excel.export_json_to_excel({ | 
|           header: tHeader, | 
|           data, | 
|           filename: 'PO明细空物料号信息' | 
|         }) | 
|         this.downloadLoading = false | 
|       }) | 
|     }, | 
|       exportExcel() { | 
|       this.find_export(1) | 
|     }, | 
|     setMoveTypeStr(moveType){ | 
|         if (moveType === 1) return'出库' | 
|         if (moveType === 2) return '移库' | 
|         if (moveType === 3) return '收货' | 
|         if (moveType === 4) return '按凭证退货' | 
|         return '' | 
|     }, | 
|     setIsFinishStr(isFinish){ | 
|         if (isFinish === 1) { | 
|                 return '已完成'                | 
|              }else{ | 
|                return '未完成' | 
|              } | 
|     }, | 
|     reset() { | 
|       this.searchParam.ProductName = null | 
|       this.searchParam.MaterialCode = null | 
|       this.searchParam.ItemNumber = null | 
|       this.selectTypeValue = '' | 
|       this.datatime = '' | 
|       this.initTimeData();//重置时间 | 
|       this.find() | 
|     } | 
|   } | 
| } | 
| </script> | 
| <style lang="postcss" scoped> | 
| .el-table .el-pagination { | 
|   margin-top: 10px; | 
|   line-height: 30px; | 
|   margin-bottom: 0%; | 
| } | 
| .el-row { | 
|   text-align: left; | 
| } | 
| .selectValues { | 
|   width: 420px; | 
| } | 
| .search { | 
|   width: 200px; | 
| } | 
| .selectTypeValue { | 
|   width: 150px; | 
| } | 
| .el-card { | 
|   padding: 0%; | 
|   margin-bottom: 0%; | 
|     /* 84 = navbar + tags-view = 50 +34 */ | 
|   max-height: calc(100vh - 104px); | 
| } | 
| thead .el-table-column--selection .cell { | 
|   display: none; | 
| } | 
| .el-scrollbar{ | 
|     .el-scrollbar__bar.is-vertical { | 
|       opacity: 1;/* 改为0不显示滚动条*/ | 
|       width:5; | 
|     } | 
|   } | 
|   | 
| </style> |