Пример #1
0
        // ---Phần in QrCodeId khi vào Menu 8.1 QrCode Print => Print (Sorting Form)------//
        public async Task <object> FindByQrCodeIDAgain(QrCodeIDVersion data)
        {
            var qrCodeMan = await _repoQrcode.GetAll()
                            .Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                   x.QRCode_Version == data.QRCode_Version).FirstOrDefaultAsync();

            var     packingListDetailModel  = new List <PackingListDetailViewModel>();
            var     packingListDetailModel1 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel2 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel3 = new List <PackingListDetailViewModel>();
            decimal?totalPQty   = 0;
            decimal?totalRQty   = 0;
            var     transaction = await _repoTransactionMain.GetAll().Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                                                            x.QRCode_Version == data.QRCode_Version).FirstOrDefaultAsync();

            var transactionDetails = await _repoTransactionDetail.GetAll()
                                     .Where(x => x.Transac_No.Trim() == transaction.Transac_No.Trim()).ToListAsync();

            var lists = await _repoPackingListDetail.GetAll()
                        .Where(x => x.Receive_No.Trim() == qrCodeMan.Receive_No.Trim()).ToListAsync();

            foreach (var item in lists)
            {
                var packingItem = new PackingListDetailViewModel();
                packingItem.Receive_No   = item.Receive_No;
                packingItem.Order_Size   = item.Order_Size;
                packingItem.Model_Size   = item.Model_Size;
                packingItem.Tool_Size    = item.Tool_Size;
                packingItem.Spec_Size    = item.Spec_Size;
                packingItem.MO_Qty       = item.MO_Qty;
                packingItem.Purchase_Qty = item.Purchase_Qty;
                foreach (var item1 in transactionDetails)
                {
                    if (item1.Tool_Size.Trim() == item.Tool_Size.Trim() && item1.Order_Size.Trim() == item.Order_Size.Trim())
                    {
                        packingItem.Received_Qty = item1.Qty;
                        packingItem.Act          = item1.Instock_Qty;
                        packingItem.Bal          = item1.Untransac_Qty;
                        totalRQty = totalRQty + item1.Instock_Qty;
                    }
                }
                totalPQty = totalPQty + item.Purchase_Qty;
                packingListDetailModel.Add(packingItem);
            }

            //----------------- Xử lý mảng dữ liệu cho 1 số dòng cùng tool size.----------------//
            // List các Tool Size mà có nhiều Order Size trong bảng Packing List Detail
            var toolSizeMoreOrderSize = lists.Where(x => x.Tool_Size.Trim() != x.Order_Size.Trim()).Select(x => x.Tool_Size).Distinct().ToList();

            if (toolSizeMoreOrderSize.Count() > 0)
            {
                foreach (var itemToolSize in toolSizeMoreOrderSize)
                {
                    var model1 = packingListDetailModel.Where(x => x.Tool_Size.Trim() == itemToolSize.Trim())
                                 .GroupBy(x => x.Tool_Size).Select(x => new {
                        Purchase_Qty = x.Sum(cl => cl.Purchase_Qty),
                        Received_Qty = x.Sum(cl => cl.Received_Qty),
                        Act          = x.Sum(cl => cl.Act),
                        Bal          = x.Sum(cl => cl.Bal)
                    }).FirstOrDefault();
                    var packingListByToolSize = packingListDetailModel
                                                .Where(x => x.Tool_Size.Trim() == itemToolSize.Trim()).ToList();
                    for (var i = 0; i < packingListByToolSize.Count; i++)
                    {
                        if (i != 0)
                        {
                            packingListByToolSize[i].Purchase_Qty = null;
                            packingListByToolSize[i].Received_Qty = null;
                            packingListByToolSize[i].Act          = null;
                            packingListByToolSize[i].Bal          = null;
                        }
                        else
                        {
                            packingListByToolSize[i].Purchase_Qty = model1.Purchase_Qty;
                            packingListByToolSize[i].Received_Qty = model1.Received_Qty;
                            packingListByToolSize[i].Act          = model1.Act;
                            packingListByToolSize[i].Bal          = model1.Bal;
                        }
                    }
                }
            }
            var count = packingListDetailModel.Count();

            if (count > 0 && count <= 8)
            {
                packingListDetailModel1 = packingListDetailModel;
            }
            else if (count > 8 && count <= 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < count; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
            }
            else if (count > 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < 16; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
                for (int i = 16; i < count; i++)
                {
                    packingListDetailModel3.Add(packingListDetailModel[i]);
                }
            }
            // Lấy dữ liệu show phần Suggested Location Material Form
            var transactionMain = await _repoTransactionMain.GetAll().ToListAsync();

            var transactionMain1 = transactionMain.Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                                         (x.Transac_Type == "I" || x.Transac_Type == "M" || x.Transac_Type == "R") &&
                                                         x.Can_Move.Trim() == "Y");
            var suggestedReturn1 = transactionMain1.Select(x => new {
                rack_Location = x.Rack_Location
            }).Distinct().ToList();
            // Lấy dữ liệu show phần Suggested Location Sorting Form
            var transactionMain2 = transactionMain
                                   .Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                          x.Can_Move.Trim() == "Y");
            var suggestedReturn2 = transactionMain2.Select(x => new {
                rack_Location = x.Rack_Location
            }).Distinct().ToList();
            var result = new {
                totalPQty,
                totalRQty,
                packingListDetailModel1,
                packingListDetailModel2,
                packingListDetailModel3,
                suggestedReturn1,
                suggestedReturn2,
            };

            return(result);
        }
Пример #2
0
        // ---Phần in QrCodeId khi vào Menu 2.QrGenerate => Print (Material Form)-------//
        public async Task <object> FindByQrCodeID(QrCodeIDVersion data)
        {
            var qrCodeMan = await _repoQrcode.GetAll()
                            .Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                   x.QRCode_Version == data.QRCode_Version).FirstOrDefaultAsync();

            var packingList = await _repoPackingList.GetAll().ToListAsync();

            // Tìm kiếm Purchase và Sheet_Type của qrcodeid với version đó.
            var packingListFind = packingList
                                  .Where(x => x.Receive_No.Trim() == qrCodeMan.Receive_No.Trim()).FirstOrDefault();
            // Tìm List ReceiveNo tương ứng với Purchase và Sheet_Type ở trên
            var ReceiveNoList = packingList
                                .Where(x => x.Sheet_Type.Trim() == packingListFind.Sheet_Type.Trim() &&
                                       x.Purchase_No.Trim() == packingListFind.Purchase_No.Trim() &&
                                       x.Receive_Date <= packingListFind.Receive_Date)
                                .Select(x => x.Receive_No).ToList();

            var packingListDetailAll = await _repoPackingListDetail.GetAll().ToListAsync();

            var packingDetailList = new List <WMSB_PackingList_Detail>();

            foreach (var item in ReceiveNoList)
            {
                var packingdetailitem = packingListDetailAll.Where(x => x.Receive_No.Trim() == item.Trim()).ToList();
                packingDetailList.AddRange(packingdetailitem);
            }

            // Gộp theo từng tool size và tính tổng Purchase, Received Qty theo tool size đó.
            var BalByToolSize = packingDetailList.GroupBy(x => x.Tool_Size).Select(x => new {
                Tool_Size = x.FirstOrDefault().Tool_Size,
                Bal       = x.Sum(cl => cl.Purchase_Qty) / (ReceiveNoList.Count()) - x.Sum(cl => cl.Received_Qty)
            });

            var     packingListDetailModel  = new List <PackingListDetailViewModel>();
            var     packingListDetailModel1 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel2 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel3 = new List <PackingListDetailViewModel>();
            decimal?totalPQty = 0;
            decimal?totalRQty = 0;

            var lists = packingListDetailAll
                        .Where(x => x.Receive_No.Trim() == qrCodeMan.Receive_No.Trim()).ToList();

            foreach (var item in lists)
            {
                var packingItem1 = new PackingListDetailViewModel();
                packingItem1.Receive_No   = item.Receive_No;
                packingItem1.Order_Size   = item.Order_Size;
                packingItem1.Model_Size   = item.Model_Size;
                packingItem1.Tool_Size    = item.Tool_Size;
                packingItem1.Spec_Size    = item.Spec_Size;
                packingItem1.MO_Qty       = item.MO_Qty;
                packingItem1.Purchase_Qty = item.Purchase_Qty;
                packingItem1.Received_Qty = item.Received_Qty;
                packingItem1.Act          = 0;
                foreach (var itemByToolSize in BalByToolSize)
                {
                    if (itemByToolSize.Tool_Size.Trim() == item.Tool_Size.Trim())
                    {
                        packingItem1.Bal = itemByToolSize.Bal;
                    }
                }
                totalPQty = totalPQty + item.Purchase_Qty;
                totalRQty = totalRQty + item.Received_Qty;
                packingListDetailModel.Add(packingItem1);
            }

            //----------------- Xử lý mảng dữ liệu cho 1 số dòng cùng tool size.----------------//
            // List các Tool Size mà có nhiều Order Size trong bảng Packing List Detail
            var toolSizeMoreOrderSize = lists.Where(x => x.Tool_Size.Trim() != x.Order_Size.Trim()).Select(x => x.Tool_Size).Distinct().ToList();

            if (toolSizeMoreOrderSize.Count() > 0)
            {
                foreach (var itemToolSize in toolSizeMoreOrderSize)
                {
                    var model1 = packingListDetailModel.Where(x => x.Tool_Size.Trim() == itemToolSize.Trim())
                                 .GroupBy(x => x.Tool_Size).Select(x => new {
                        Purchase_Qty = x.Sum(cl => cl.Purchase_Qty),
                        Received_Qty = x.Sum(cl => cl.Received_Qty),
                        Act          = x.Sum(cl => cl.Act),
                        Bal          = x.First().Bal
                    }).FirstOrDefault();
                    var packingDetailByToolSize = packingListDetailModel
                                                  .Where(x => x.Tool_Size.Trim() == itemToolSize.Trim()).ToList();
                    for (var i = 0; i < packingDetailByToolSize.Count; i++)
                    {
                        if (i != 0)
                        {
                            packingDetailByToolSize[i].Purchase_Qty = null;
                            packingDetailByToolSize[i].Received_Qty = null;
                            packingDetailByToolSize[i].Act          = null;
                            packingDetailByToolSize[i].Bal          = null;
                        }
                        else
                        {
                            packingDetailByToolSize[i].Purchase_Qty = model1.Purchase_Qty;
                            packingDetailByToolSize[i].Received_Qty = model1.Received_Qty;
                            packingDetailByToolSize[i].Act          = model1.Act;
                            packingDetailByToolSize[i].Bal          = model1.Bal;
                        }
                    }
                }
            }

            var count = packingListDetailModel.Count();

            if (count > 0 && count <= 8)
            {
                packingListDetailModel1 = packingListDetailModel;
            }
            else if (count > 8 && count <= 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < count; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
            }
            else if (count > 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < 16; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
                for (int i = 16; i < count; i++)
                {
                    packingListDetailModel3.Add(packingListDetailModel[i]);
                }
            }
            // Lấy dữ liệu show phần Suggested Location Material Form
            var transactionMain = await _repoTransactionMain.GetAll().ToListAsync();

            var transactionMain1 = transactionMain.Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                                         (x.Transac_Type == "I" || x.Transac_Type == "M" || x.Transac_Type == "R") &&
                                                         x.Can_Move.Trim() == "Y");
            var suggestedReturn1 = transactionMain1.Select(x => new {
                rack_Location = x.Rack_Location
            }).Distinct().ToList();
            // Lấy dữ liệu show phần Suggested Location Sorting Form
            var transactionMain2 = transactionMain
                                   .Where(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                          x.Transac_Type == "I" &&
                                          x.Can_Move.Trim() == "Y");
            var suggestedReturn2 = transactionMain2.Select(x => new {
                rack_Location = x.Rack_Location
            }).Distinct().ToList();
            var result = new {
                totalPQty,
                totalRQty,
                packingListDetailModel1,
                packingListDetailModel2,
                packingListDetailModel3,
                suggestedReturn1,
                suggestedReturn2,
            };

            return(result);
        }
Пример #3
0
        // ---Phần in QrCodeId khi vào Menu 2.QrGenerate => Print (Material Form)-------//
        public async Task <object> FindByQrCodeID(QrCodeIDVersion data)
        {
            var qrCodeMan = _repoQrcode.FindSingle(x => x.QRCode_ID.Trim() == data.QRCode_ID.Trim() &&
                                                   x.QRCode_Version == data.QRCode_Version);

            // Tìm kiếm Purchase và Sheet_Type của qrcodeid với version đó.
            var packingListFind = _repoPackingList.FindSingle(x => x.Receive_No.Trim() == qrCodeMan.Receive_No.Trim());
            // Tìm List ReceiveNo tương ứng với Purchase và Sheet_Type ở trên
            var ReceiveNoList = await _repoPackingList.FindAll(x =>
                                                               x.Purchase_No.Trim() == packingListFind.Purchase_No.Trim() &&
                                                               x.Material_ID.Trim() == packingListFind.Material_ID.Trim() &&
                                                               x.Sheet_Type.Trim() == packingListFind.Sheet_Type.Trim() &&
                                                               x.MO_Seq == packingListFind.MO_Seq &&
                                                               x.MO_No.Trim() == data.MO_No.Trim() &&
                                                               x.Receive_Date <= packingListFind.Receive_Date)
                                .Select(x => x.Receive_No).ToListAsync();

            var packingDetailList = new List <WMSB_PackingList_Detail>();

            foreach (var item in ReceiveNoList)
            {
                var packingdetailitem = await _repoPackingListDetail.FindAll(x => x.Receive_No.Trim() == item.Trim()).ToListAsync();

                packingDetailList.AddRange(packingdetailitem);
            }

            // Gộp theo từng tool size và tính tổng Purchase, Received Qty theo tool size đó.
            var BalByToolSize = packingDetailList.GroupBy(x => x.Tool_Size).Select(x => new {
                Tool_Size = x.FirstOrDefault().Tool_Size,
                Bal       = x.Sum(cl => cl.Purchase_Qty) / (ReceiveNoList.Count()) - x.Sum(cl => cl.Received_Qty)
            });

            var     packingListDetailModel  = new List <PackingListDetailViewModel>();
            var     packingListDetailModel1 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel2 = new List <PackingListDetailViewModel>();
            var     packingListDetailModel3 = new List <PackingListDetailViewModel>();
            decimal?totalPQty = 0;
            decimal?totalRQty = 0;

            var lists = await _repoPackingListDetail.FindAll(x => x.Receive_No.Trim() == qrCodeMan.Receive_No.Trim()).ToListAsync();

            foreach (var item in lists)
            {
                var packingItem1 = new PackingListDetailViewModel();
                packingItem1.Receive_No   = item.Receive_No;
                packingItem1.Order_Size   = item.Order_Size;
                packingItem1.Model_Size   = item.Model_Size;
                packingItem1.Tool_Size    = item.Tool_Size;
                packingItem1.Spec_Size    = item.Spec_Size;
                packingItem1.MO_Qty       = item.MO_Qty;
                packingItem1.Purchase_Qty = item.Purchase_Qty;
                packingItem1.Received_Qty = item.Received_Qty;
                packingItem1.Act          = 0;
                foreach (var itemByToolSize in BalByToolSize)
                {
                    if (itemByToolSize.Tool_Size.Trim() == item.Tool_Size.Trim())
                    {
                        packingItem1.Bal = itemByToolSize.Bal;
                    }
                }
                totalPQty = totalPQty + item.Purchase_Qty;
                totalRQty = totalRQty + item.Received_Qty;
                packingListDetailModel.Add(packingItem1);
            }

            //----------------- Xử lý mảng dữ liệu cho 1 số dòng cùng tool size.----------------//
            // List các Tool Size mà có nhiều Order Size trong bảng Packing List Detail
            var toolSizeMoreOrderSize = lists.Where(x => x.Tool_Size.Trim() != x.Order_Size.Trim()).Select(x => x.Tool_Size).Distinct().ToList();

            if (toolSizeMoreOrderSize.Count() > 0)
            {
                foreach (var itemToolSize in toolSizeMoreOrderSize)
                {
                    var model1 = packingListDetailModel.Where(x => x.Tool_Size.Trim() == itemToolSize.Trim())
                                 .GroupBy(x => x.Tool_Size).Select(x => new {
                        Purchase_Qty = x.Sum(cl => cl.Purchase_Qty),
                        Received_Qty = x.Sum(cl => cl.Received_Qty),
                        Act          = x.Sum(cl => cl.Act),
                        Bal          = x.First().Bal
                    }).FirstOrDefault();
                    var packingDetailByToolSize = packingListDetailModel
                                                  .Where(x => x.Tool_Size.Trim() == itemToolSize.Trim()).ToList();
                    for (var i = 0; i < packingDetailByToolSize.Count; i++)
                    {
                        if (i != 0)
                        {
                            packingDetailByToolSize[i].Purchase_Qty = null;
                            packingDetailByToolSize[i].Received_Qty = null;
                            packingDetailByToolSize[i].Act          = null;
                            packingDetailByToolSize[i].Bal          = null;
                        }
                        else
                        {
                            packingDetailByToolSize[i].Purchase_Qty = model1.Purchase_Qty;
                            packingDetailByToolSize[i].Received_Qty = model1.Received_Qty;
                            packingDetailByToolSize[i].Act          = model1.Act;
                            packingDetailByToolSize[i].Bal          = model1.Bal;
                        }
                    }
                }
            }

            // Sắp xếp lại theo Tool-Size và Order_Size theo thứ tự tăng dần.
            packingListDetailModel = packingListDetailModel
                                     .OrderBy(x => decimal.Parse(x.Tool_Size)).ThenBy(x => decimal.Parse(x.Order_Size)).ToList();

            var count = packingListDetailModel.Count();

            if (count > 0 && count <= 8)
            {
                packingListDetailModel1 = packingListDetailModel;
            }
            else if (count > 8 && count <= 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < count; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
            }
            else if (count > 16)
            {
                for (int i = 0; i < 8; i++)
                {
                    packingListDetailModel1.Add(packingListDetailModel[i]);
                }
                for (int i = 8; i < 16; i++)
                {
                    packingListDetailModel2.Add(packingListDetailModel[i]);
                }
                for (int i = 16; i < count; i++)
                {
                    packingListDetailModel3.Add(packingListDetailModel[i]);
                }
            }

            var result = new {
                totalPQty,
                totalRQty,
                packingListDetailModel1,
                packingListDetailModel2,
                packingListDetailModel3,
            };

            return(result);
        }