| import * as sql from "mssql"; | 
| import { SaleOrderPrint } from "../../entity/outbound/manufacture/saleOrderPrint"; | 
| import { Post } from "egg-shell-decorators"; | 
| import BaseController from "../baseController"; | 
| import { SaleOrderPrintList } from "../../entity/outbound/manufacture/saleOrderPrintList"; | 
| import { SaleOrderPicking } from "../../entity/outbound/manufacture/saleOrderPicking"; | 
|   | 
| /** | 
|  * 按拍下架 | 
|  */ | 
| export default class OrderPlatePickingController extends BaseController { | 
|   //#region GetData | 
|   /** | 
|    * 回车获取数据 | 
|    */ | 
|   @Post() | 
|   public async getData() { | 
|     let { ctx } = this; | 
|     let body = ctx.request.body; | 
|     let userInfo = await ctx.helper.userInfo(); | 
|     let batchCode = body.batchCode; | 
|   | 
|     try { | 
|       // let where = ""; | 
|   | 
|       if (!batchCode) { | 
|         this.info.msg = "波次不能为空!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|       let orderPrint = await this.dbRead.findOne(SaleOrderPrint, { | 
|         orderPrintCode: batchCode, | 
|         userProduct_Id: userInfo.userProduct_Id | 
|       }); | 
|       if (orderPrint == null) { | 
|         this.info.msg = "波次不存在!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|   | 
|       let model: any = {}; | 
|       model.orderPrint_Id = orderPrint.orderPrint_Id; | 
|       model.orderPrintCode = orderPrint.orderPrintCode; | 
|   | 
|       if (["待拣货", "拣货中", "部分拣货", "波次完成", "等待打包"].indexOf(orderPrint.statusText) < 0) { | 
|         this.info.msg = `波次单必须是"待拣货", "拣货中", "部分拣货", "波次完成", "等待打包"才允许下架操作,当前状态是[${orderPrint.statusText}]`; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|       let query = ""; | 
|   | 
|       query = ` | 
|                 SELECT  l.productModel , | 
|                                 l.productCode , | 
|                                 MAX(l.productName) AS productName , | 
|                                 SUM(l.QuantityOrderOrign) AS quantityOrder , | 
|                                 SUM(l.pickQuantity) as pickQuantity, | 
|                                 SUM(placeholderStorage) AS placeholderStorage, | 
|                                 MAX(v.salePrice) AS salePrice , | 
|                                 MAX(v.Remark) AS Remark , | 
|                                 0 AS orderList_Id , | 
|                                 0 AS orderPrintList_Id , | 
|                                 l.plateCode , | 
|                                 l.positionName, | 
|                                 l.productSpec, | 
|                                 MAX(v.SmallUnit) AS smallUnit, | 
|                                 v.relationCode, v.relationCode2, v.relationCode3, v.relationCode4, v.relationCode5, | 
|                                 v.middleBarcode, v.middleUnitConvert, v.bigBarcode, v.unitConvert,MAX(l.weight)AS weight,MAX(l.totalWeight) AS totalWeight, | 
|                 l.order_Id | 
|                 FROM    dbo.Sale_OrderPrint m | 
|                                 INNER JOIN dbo.Sale_OrderPrintList l ON m.orderPrint_Id = l.orderPrint_Id | 
|                                 INNER JOIN vBase_ProductInfo_SKU v ON l.Product_Id = v.Product_Id | 
|                                 INNER JOIN dbo.Base_ProductPlaceHolder h ON l.Placeholder_Id = h.Placeholder_Id | 
|                 WHERE   m.orderPrint_Id =@0 AND PositionType IS NULL | 
|                 GROUP BY  | 
|                                 l.productModel , | 
|                                 l.productCode , | 
|                                 l.plateCode , | 
|                                 l.positionName, | 
|                 l.productSpec, | 
|                 l.order_Id, | 
|                                 v.relationCode, v.relationCode2, v.relationCode3, v.relationCode4, v.relationCode5, | 
|                                 v.middleBarcode, v.middleUnitConvert, v.bigBarcode, v.unitConvert | 
|                 ORDER BY l.positionName , | 
|                                 l.productModel; | 
|                 `; | 
|   | 
|       let dataList = await this.dbRead.query(query, [orderPrint.orderPrint_Id]); | 
|       if (dataList.length == 0) { | 
|         this.info.msg = "未找到对应的订单明细数据"; | 
|       } else { | 
|         dataList = dataList.filter(o => o.quantityOrder > o.pickQuantity); | 
|         this.info.result = true; | 
|         model.dataList = dataList; | 
|         model.isSupportPlate = false; | 
|         //创建拣货记录 | 
|         await ctx.service.outbound.outScanService.pickingStart(batchCode, orderPrint, dataList); | 
|   | 
|         model.offPositionList = await ctx.service.outbound.outScanService.getOffPosition(orderPrint.storage_Id); | 
|         this.info.data = model; | 
|       } | 
|     } catch (error) { | 
|       this.info.result = false; | 
|       this.info.msg = "错误:" + error.message; | 
|     } | 
|   | 
|     ctx.body = this.info; | 
|   } | 
|   //#endregion | 
|   | 
|   //#region  保存扫描结果 | 
|   /** | 
|    * 拣货完成 | 
|    */ | 
|   @Post() | 
|   public async saveScan() { | 
|     let { ctx } = this; | 
|     let body = ctx.request.body; | 
|     let userInfo = await ctx.helper.userInfo(); | 
|   | 
|     try { | 
|       let batchCode = body.batchCode; //波次号 | 
|       // let cartCode = body.cartCode; //车号 | 
|       let dataList = body.dataList; | 
|       let orderPrint: SaleOrderPrint = await this.dbRead.findOne(SaleOrderPrint, { | 
|         orderPrintCode: batchCode | 
|       }); | 
|   | 
|       let printListModel = await this.dbRead.find(SaleOrderPrintList, { | 
|         orderPrint_Id: orderPrint.orderPrint_Id | 
|       }); | 
|   | 
|       //#region 校验 | 
|       if (!batchCode) { | 
|         this.info.msg = "波次不能为空!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|   | 
|       if (!dataList || dataList.length == 0) { | 
|         this.info.msg = "请先扫描条码!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|   | 
|       if (orderPrint == null) { | 
|         this.info.msg = "波次不存在!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|       let orderPicking = await this.dbRead.find(SaleOrderPicking, { | 
|         orderPrintCode: batchCode, | 
|         user_Id: userInfo.user_Id | 
|       }); | 
|       if (orderPicking == null) { | 
|         this.info.msg = "拣货记录不存在!"; | 
|         ctx.body = this.info; | 
|         return; | 
|       } | 
|   | 
|       //#endregion | 
|   | 
|       //#region 存储过程 | 
|       let data = new sql.Table(); | 
|       data.columns.add("productModel", sql.NVarChar(50)); | 
|       data.columns.add("productCode", sql.NVarChar(50)); | 
|       data.columns.add("positionName", sql.NVarChar(50)); | 
|       data.columns.add("offPosition", sql.NVarChar(50)); | 
|       data.columns.add("plateCode", sql.NVarChar(50)); | 
|       data.columns.add("scanCount", sql.BigInt); | 
|       data.columns.add("weight", sql.Decimal(14, 4)); | 
|       data.columns.add("totalWeight", sql.Decimal(14, 4)); | 
|       for (var _detail of dataList) { | 
|         data.rows.add( | 
|           _detail.productModel, | 
|           _detail.productCode, | 
|           _detail.positionName, | 
|           _detail.offPosition, | 
|           _detail.plateCode, | 
|           _detail.scanCount, | 
|           _detail.weight, | 
|           _detail.totalWeight | 
|         ); | 
|       } | 
|       const connection: any = await this.dbWrite.connection; | 
|       let request = new sql.Request(connection.driver.master); | 
|       request.input("batchCode", batchCode); | 
|       request.input("user_Id", userInfo.user_Id); | 
|       request.input("data", data); | 
|       request.output("msg", sql.NVarChar(2000)); | 
|       let result = await request.execute("sp_ScanPickingSave_Plate"); | 
|       let msg = result.output.msg; | 
|   | 
|       if (msg && msg != "部分拣货") { | 
|         this.info.result = false; | 
|         this.info.msg = msg; | 
|         ctx.body = this.info; | 
|         return; | 
|       } else { | 
|         this.info.result = true; | 
|         this.info.msg = "拣货完成"; | 
|       } | 
|       //#endregion | 
|   | 
|       if (msg == "部分拣货") { | 
|         this.info.result = true; | 
|         this.info.state = "部分下架"; | 
|         this.info.msg = "提交成功,已部分下架成功!"; | 
|       } else { | 
|         // 对单据进行分组 | 
|         let groupData = printListModel.reduce( | 
|           (all: Array<any>, next) => (all.some(item => item["order_Id"] == next["order_Id"]) ? all : [...all, next]), | 
|           [] | 
|         ); | 
|         for (var g of groupData) { | 
|           ctx.service.outbound.orderHelper.setStatusHistory(g.order_Id, 5, 6, "订单状态", "订单拣货"); | 
|         } | 
|       } | 
|   | 
|       ctx.body = this.info; | 
|     } catch (ex) { | 
|       this.info.result = false; | 
|       this.info.msg = "错误信息:" + ex.message; | 
|     } | 
|     ctx.body = this.info; | 
|   } | 
|   //#endregion | 
| } |