| <template> | 
|   <!-- 面包屑导航区 -->    | 
|   <div class="indexs"> | 
|     <!-- <el-breadcrumb separator-class="el-icon-arrow-right"> | 
|       <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item> | 
|       <el-breadcrumb-item>系统设置</el-breadcrumb-item> | 
|       <el-breadcrumb-item>人员管理</el-breadcrumb-item> | 
|     </el-breadcrumb> --> | 
|     <!-- 卡片视图区 --> | 
|     <el-card> | 
|       <!-- 搜索与添加   clearable "toggleSelection([tableData[1], tableData[2]])"        --> | 
|       <el-row> | 
|         <el-button type="success" plain @click="exportExcel" >导出Excel</el-button> | 
|         <!-- <el-button type="warning" plain @click="deleteStock" >删除</el-button> | 
|         <el-button type="info" plain @click="updataStock" >修改库存</el-button> --> | 
|          <el-select v-model="selectTypeValue" placeholder="选择任务类型" class="selectTypeValue"> | 
|                <el-option | 
|                     v-for="item in selectType" | 
|                     :key="item.value" | 
|                     :label="item.label" | 
|                     :value="item.value"> | 
|                </el-option> | 
|          </el-select>  | 
|          | 
|            <el-input v-model="searchParam.materialName" placeholder="物料名称" class="search"></el-input> | 
|            <el-input v-model="searchParam.materialCode" placeholder="物料编号" class="search"></el-input> | 
|             <el-input v-model="searchParam.tranckNnmber" placeholder="跟踪号" class="search"></el-input> | 
|             <el-input v-model="searchParam.positionName" placeholder="库位号" class="search"></el-input> | 
|             <el-input v-model="searchParam.placeCode" placeholder="托盘号" class="search"></el-input> | 
|             <el-input v-model="searchParam.creator" 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 show-summary :cell-style="cellStyle" :summary-method="getSummaries" > | 
|         <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="数据ID" prop="id" width="80 " v-if="false"></el-table-column> | 
|         <el-table-column label="任务名称" prop="taskName" width="100"></el-table-column> | 
|         <el-table-column label="来源单号" prop="orderCode" width="200"></el-table-column> | 
|         <el-table-column label="跟踪号" prop="trackNumber" width="100" ></el-table-column> | 
|         <el-table-column label="物料编号" prop="materialNumber" width="200"></el-table-column> | 
|         <el-table-column label="物料名称" prop="materialName" width="350"></el-table-column> | 
|         <el-table-column label="库存单位" prop="unit" width="110"></el-table-column> | 
|         <el-table-column label="数量" prop="quantity" width="110"></el-table-column> | 
|          <el-table-column label="当时该货位库存(同跟踪号)" prop="ext3" width="110"></el-table-column> | 
|           <el-table-column label="当时该货位库存" prop="ext2" width="110"></el-table-column> | 
|         <el-table-column label="当时常规货位库存" prop="CGHW_ProductStorage" width="110"></el-table-column> | 
|         <el-table-column label="当时暂存区库存" prop="ZCG_ProductStorage" width="110"></el-table-column> | 
|         <el-table-column label="库位号" prop="PositionName" width="100" ></el-table-column> | 
|          <el-table-column label="托盘号" prop="ext1" width="100" ></el-table-column> | 
|         <el-table-column label="创建人" prop="Creator" width="100"></el-table-column> | 
|         <el-table-column label="创建时间" prop="creatDate" width="180"></el-table-column> | 
|          <el-table-column label="备注" prop="Remark" width="180"></el-table-column> | 
|       </el-table> | 
|       <el-pagination | 
|         :current-page="queryInfo.pagenum" | 
|         :page-sizes="[5,10, 15, 20,50,100,1000]" | 
|         :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 } from '@/utils' | 
| import { getDate } from '@/utils/dateTime' | 
| export default { | 
|   data() { | 
|     return { | 
|       tableHeight:window.innerHeight-194, | 
|       searchParam: { | 
|         materialName: null, | 
|         materialCode: null, | 
|         tranckNnmber: null, | 
|         positionName:null, | 
|         placeCode:null, | 
|         creator:null | 
|       }, | 
|       queryInfo: { | 
|         // 当前页 | 
|         pagenum: 1, | 
|         // 每页显示多少条信息s | 
|         pagesize: 15 | 
|       }, | 
|       TakeStocklist: [], | 
|       TakeStocklistAll: [], | 
|       total: 0, | 
|       datatime: '', | 
|       selectType: [{ value: '99', label: '不筛选' },{ value: '0', label: '收货任务' },{ value: '1', label: '入库任务' }, { value: '2', label: '出库任务' },{ value: '3', label: '清库任务' },{ value: '4', label: '退货任务' },{ value: '5', label: '移库任务' }], | 
|       selectTypeValue: '99', | 
|       dialogFormVisible: false, | 
|       productList: [], | 
|       updateDate: null | 
|     } | 
|   }, | 
|   created() {}, | 
|   mounted() { | 
|     this.find(1) | 
|   }, | 
|   methods: { | 
|     // 监听 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 != 8) { | 
|           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 === 'timestamp') { | 
|             return parseTime(v[j]) | 
|           } else { | 
|             return v[j] | 
|           } | 
|         }) | 
|       ) | 
|     }, | 
|     cellStyle({ row, rowIndex }) { | 
|       ////debugger | 
|       if (row.taskName === '出库任务') { | 
|         return 'background: #99aa8a;color:white' | 
|       } | 
|       else if (row.taskName === '入库任务') { | 
|         return 'background: #8888aa;color:white' | 
|       }  | 
|      else if (row.taskName === '收货任务') { | 
|         return 'background: #1db5b5;color:white' //浅绿色 | 
|       }  | 
|       else if (row.taskName === '退货任务') { | 
|         return 'background: #2a5caa;color:white' //浅绿色 | 
|       }else if (row.taskName === '移库任务') { | 
|         return 'background: #00ccff;color:white' //浅绿色 | 
|       } | 
|       else { | 
|         return '' | 
|       } | 
|     }, | 
|     find(ischang = 1) { | 
|       if (ischang == 1) { | 
|         this.queryInfo.pagenum = 1 | 
|       } | 
|       const url = '/api/task/outInTaskList' | 
|       const params = { | 
|         search: this.searchParam, | 
|         queryInfo: this.queryInfo, //分页 | 
|         positionTypeValue: this.selectTypeValue, //下拉框的值 | 
|         datatime: this.datatime //日期 | 
|       } | 
|       var callback = res => { | 
|         ////debugger | 
|         if (res.result === true) { | 
|           res.data.forEach(item => { | 
|             //   if (item.IsBoosterArm === 0) item.IsBoosterArm = "否"; | 
|             //   if (item.IsBoosterArm === 1) item.IsBoosterArm = "是"; | 
|             item.creatDate = getDate(item.creatDate) | 
|           }) | 
|   | 
|           this.TakeStocklist = res.data | 
|           this.TakeStocklistAll = res.data2 | 
|           this.total = res.countPrint | 
|         } else { | 
|            this.TakeStocklist =null | 
|           this.TakeStocklistAll = null | 
|           this.total = 0 | 
|           //return this.$message.error('获取失败') | 
|         } | 
|       } | 
|       this.common.ajax(url, params, callback, true) | 
|     }, | 
|     find_export(ischang = 1) { | 
|       if (ischang == 1) { | 
|         this.queryInfo.pagenum = 1 | 
|       } | 
|       const url = '/api/task/outInTaskList' | 
|       const params = { | 
|         IsLoadAllData:true,//加载全部 | 
|         search: this.searchParam, | 
|         queryInfo: this.queryInfo, //分页 | 
|         positionTypeValue: this.selectTypeValue, //下拉框的值 | 
|         datatime: this.datatime //日期 | 
|       } | 
|       var callback = res => { | 
|         ////debugger | 
|         if (res.result === true) { | 
|           res.data2.forEach(item => { | 
|             //   if (item.IsBoosterArm === 0) item.IsBoosterArm = "否"; | 
|             //   if (item.IsBoosterArm === 1) item.IsBoosterArm = "是"; | 
|             item.creatDate = getDate(item.creatDate) | 
|           }) | 
|   | 
|           this.TakeStocklistAll = res.data2 | 
|           this.exportExcel_export() | 
|         } else { | 
|           return this.$message.error('获取失败') | 
|         } | 
|       } | 
|       this.common.ajax(url, params, callback, true) | 
|     }, | 
|     exportExcel_export() { | 
|       // import("@/vendor/Export2Excel") | 
|       this.downloadLoading = true | 
|       import('@/vendor/Export2Excel').then(excel => { | 
|         const tHeader = ['数据ID', '任务名称', '来源单号', '跟踪号', '物料编号', '物料名称', '库存单位', '数量', '创建时间'] | 
|         const filterVal = ['id', 'taskName', 'orderCode', 'trackNumber', 'materialNumber', 'materialName', 'unit', 'quantity', 'creatDate'] | 
|         const data = this.formatJson(filterVal, this.TakeStocklistAll) | 
|         excel.export_json_to_excel({ | 
|           header: tHeader, | 
|           data, | 
|           filename: '出入库记录' | 
|         }) | 
|         this.downloadLoading = false | 
|       }) | 
|     }, | 
|     exportExcel() { | 
|       this.find_export(1) | 
|     }, | 
|     reset() { | 
|       this.searchParam.materialName = null | 
|       this.searchParam.materialCode = null | 
|       this.searchParam.tranckNnmber = null | 
|       this.searchParam.positionName = null | 
|       this.searchParam.placeCode = null | 
|       this.searchParam.creator = null | 
|       this.selectTypeValue = '99' | 
|       this.datatime = '' | 
|       this.find(1) | 
|     }, | 
|     deleteStock() { | 
|       ////debugger | 
|       var ss = this.$refs.table.selection | 
|       if (!ss.length) { | 
|         this.$message.error('请选中一行!') | 
|         return | 
|       } | 
|       if (ss.length !== 1) { | 
|         this.$message.error('只能选中一行!') | 
|         return | 
|       } | 
|       var deleteid = ss[0].ProductPosition_Id | 
|       this.$confirm('确定要进行删除操作吗?', '删除', { | 
|         confirmButtonText: '确定', | 
|         cancelButtonText: '取消', | 
|         type: 'warning' | 
|       }) | 
|         .then(() => { | 
|           const url = '/api/task/deleteProductStock' | 
|           const params = { | 
|             id: deleteid | 
|           } | 
|           ////debugger | 
|           const ref = this.dataList | 
|           var callback = res => { | 
|             this.common.showMsg(res) | 
|   | 
|             if (res.result) { | 
|               this.$refs.table.clearSelection() | 
|               this.find(1) | 
|               return this.$message.success('删除成功') | 
|             } else { | 
|               this.$refs.table.clearSelection() | 
|   | 
|               return this.$message.error('托盘只有一条数据不可以删除') | 
|             } | 
|           } | 
|           this.common.ajax(url, params, callback, ref) | 
|         }) | 
|         .catch(() => { | 
|           this.$message({ | 
|             type: 'info', | 
|             message: '已取消' | 
|           }) | 
|         }) | 
|     }, | 
|     updataStock() { | 
|       var ss = this.$refs.table.selection | 
|       this.updateDate = ss | 
|       if (!ss.length) { | 
|         this.$message.error('请选中一行!') | 
|         return | 
|       } | 
|       if (ss.length !== 1) { | 
|         this.$message.error('只能选中一行!') | 
|         return | 
|       } | 
|       this.dialogFormVisible = true | 
|       var rows = JSON.parse(JSON.stringify(ss)) | 
|       rows.forEach(item => { | 
|         this.taskForm.productCode = item.ProductCode | 
|         this.taskForm.stockId = item.ProductPosition_Id | 
|         this.taskForm.tracknumber = item.ExtendField04 //跟踪号 | 
|         this.taskForm.saleCode = item.SaleCode //销售单号 | 
|         this.taskForm.saleItem = item.ExtendField08 //销售项号 | 
|         this.taskForm.productStorage = item.ProductStorage //库存数量 | 
|       }) | 
|       this.$refs.table.clearSelection() | 
|     }, | 
|     // 获取所有商品信息 | 
|     remoteMethod(query) { | 
|       const url = 'api/basicInfo/base/productInfo/getList' | 
|       const params = { name: query } | 
|       //debugger | 
|       var callback = res => { | 
|         if (res.result) { | 
|           //debugger | 
|           // this.ALLproductList = res.data; | 
|           this.productList = res.data | 
|         } | 
|       } | 
|       this.common.ajax(url, params, callback, true) | 
|     } | 
|   } | 
| } | 
| </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> |