public List <GatewayTransmitalViewModel> Match(List <GatewayTransmittal> _transmital) { List <GatewayTransmitalViewModel> _results = new List <GatewayTransmitalViewModel>(); CommodityBL commodityService = new CommodityBL(); GatewayTransmittalBL transmitalService = new GatewayTransmittalBL(); ShipmentBL shipmentService = new ShipmentBL(); PackageNumberBL _packageNumberService = new PackageNumberBL(); BundleBL bundleService = new BundleBL(); UserStore _userService = new UserStore(); foreach (GatewayTransmittal transmital in _transmital) { GatewayTransmitalViewModel model = new GatewayTransmitalViewModel(); Shipment _shipment = new Shipment(); string _airwaybill = ""; //List<string> listCargo = new List<string>(); //List<string> listAirwayBill = new List<string>(); List <Tuple <string, decimal> > listofSack = new List <Tuple <string, decimal> >(); int numberOfCargo = 0; decimal WeightOfCargo = 0; decimal totalWeightOfCargo = 0; _shipment = shipmentService.FilterActive().Where(x => x.AirwayBillNo == transmital.AirwayBillNo).FirstOrDefault(); // _shipment = shipmentService.FilterActive().Where(x => x.AirwayBillNo == transmital.AirwayBillNo && x.Booking.BookedBy.AssignedToArea.City.BranchCorpOffice.BranchCorpOfficeId == GlobalVars.DeviceBcoId).FirstOrDefault(); if (_shipment == null) { listofSack = bundleService.FilterActive().Where(x => x.SackNo == transmital.AirwayBillNo).Select(x => new Tuple <string, decimal>(x.Cargo, x.Weight)).ToList(); if (listofSack != null) { for (int i = 0; i < listofSack.Count; i++) { WeightOfCargo = listofSack[i].Item2; totalWeightOfCargo += WeightOfCargo; numberOfCargo++; } GatewayTransmitalViewModel model1 = new GatewayTransmitalViewModel(); GatewayTransmitalViewModel isExistSackNo = _results.Find(x => x.AirwayBillNo == transmital.AirwayBillNo); if (isExistSackNo != null) { isExistSackNo.QTY++; isExistSackNo.AGW += Convert.ToDecimal(totalWeightOfCargo); } else { model1.AirwayBillNo = transmital.AirwayBillNo; model1.Shipper = "N/A"; model1.Consignee = "N/A"; model1.Address = "N/A"; model1.CommodityType = transmital.CommodityType.CommodityTypeName; model1.Commodity = "N/A"; model1.QTY = listofSack.Count; model1.AGW = Convert.ToDecimal(totalWeightOfCargo); model1.ServiceMode = "N/A"; model1.PaymentMode = "N/A"; model1.Gateway = transmital.Gateway; model1.Destination = transmital.BranchCorpOffice.BranchCorpOfficeName; model1.Batch = transmital.Batch.BatchName; model1.CreatedDate = transmital.CreatedDate; model1.PlateNo = transmital.PlateNo; model1.MAWB = transmital.MasterAirwayBillNo; //model1.ScannedBy = AppUser.User.Employee.FullName; model1.ScannedBy = "N/A"; //string employee = _userService.FilterActive().Find(x => x.UserId == _bundle.CreatedBy).Employee.FullName; string employee = _userService.FindById(transmital.CreatedBy).Employee.FullName; if (employee != "") { model1.ScannedBy = employee; } _results.Add(model1); } } } else { _airwaybill = _shipment.AirwayBillNo; GatewayTransmitalViewModel isExist = _results.Find(x => x.AirwayBillNo == _airwaybill); if (isExist != null) { isExist.QTY++; isExist.AGW += Convert.ToDecimal(shipmentService.FilterActive().Find(x => x.AirwayBillNo == transmital.AirwayBillNo).Weight); } else { model.AirwayBillNo = transmital.AirwayBillNo; model.Shipper = _shipment.Shipper.FullName; model.Consignee = _shipment.Consignee.FullName; model.Address = _shipment.Consignee.Address1; model.CommodityType = transmital.CommodityType.CommodityTypeName; model.Commodity = _shipment.Commodity.CommodityName; model.QTY++; model.AGW = _shipment.Weight; model.ServiceMode = _shipment.ServiceMode.ServiceModeName; model.PaymentMode = _shipment.PaymentMode.PaymentModeName; model.Gateway = transmital.Gateway; model.Destination = transmital.BranchCorpOffice.BranchCorpOfficeName; model.Batch = transmital.Batch.BatchName; model.CreatedDate = transmital.CreatedDate; model.PlateNo = transmital.PlateNo; model.MAWB = transmital.MasterAirwayBillNo; //model.ScannedBy = AppUser.User.Employee.FullName; model.ScannedBy = "N/A"; //string employee = _userService.FilterActive().Find(x => x.UserId == _bundle.CreatedBy).Employee.FullName; string employee = _userService.FindById(transmital.CreatedBy).Employee.FullName; if (employee != "") { model.ScannedBy = employee; } _results.Add(model); } } } return(_results); }
public DataTable getGWDatabyFilter(DateTime date, Guid?bcoid, string driver, string gateway, Guid?batchid, Guid?commodityTypeId, string mawb, int num) { GatewayTransmittalBL gatewayBl = new GatewayTransmittalBL(); List <GatewayTransmittal> list = new List <GatewayTransmittal>(); if (num == 0) { //list = gatewayBl.GetAll().Where(x => x.RecordStatus == 1 && x.CreatedDate.ToShortDateString() == date.ToShortDateString() && x.MasterAirwayBillNo == mawb).ToList(); list = gatewayBl.GetAll().Where(x => x.RecordStatus == 1 && x.MasterAirwayBillNo == mawb && x.TransmittalBy.Employee.AssignedToArea.City.BranchCorpOffice.BranchCorpOfficeId == GlobalVars.DeviceBcoId).ToList(); } else if (num == 1) { list = gatewayBl.GetAll().Where (x => x.RecordStatus == 1 && ((x.DestinationID == bcoid && x.DestinationID != Guid.Empty) || (x.DestinationID == x.DestinationID && bcoid == Guid.Empty)) && ((x.Driver == driver && x.Driver != "All") || (x.Driver == x.Driver && driver == "All")) && ((x.Gateway == gateway && x.Gateway != "All") || (x.Gateway == x.Gateway && gateway == "All")) && ((x.BatchID == batchid && x.BatchID != Guid.Empty) || (x.BatchID == x.BatchID && batchid == Guid.Empty)) && ((x.CommodityTypeID == commodityTypeId && x.CommodityTypeID != Guid.Empty) || (x.CommodityTypeID == x.CommodityTypeID && commodityTypeId == Guid.Empty)) && x.CreatedDate.ToShortDateString() == date.ToShortDateString() && x.TransmittalBy.Employee.AssignedToArea.City.BranchCorpOffice.BranchCorpOfficeId == GlobalVars.DeviceBcoId ).ToList(); } List <GatewayTransmitalViewModel> modelList = Match(list); DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("No", typeof(string))); dt.Columns.Add(new DataColumn("AWB", typeof(string))); dt.Columns.Add(new DataColumn("Shipper", typeof(string))); dt.Columns.Add(new DataColumn("Consignee", typeof(string))); dt.Columns.Add(new DataColumn("Address", typeof(string))); dt.Columns.Add(new DataColumn("Commodity Type", typeof(string))); dt.Columns.Add(new DataColumn("Commodity", typeof(string))); dt.Columns.Add(new DataColumn("Qty", typeof(string))); dt.Columns.Add(new DataColumn("AGW", typeof(string))); dt.Columns.Add(new DataColumn("Service Mode", typeof(string))); dt.Columns.Add(new DataColumn("Payment Mode", typeof(string))); dt.Columns.Add(new DataColumn("Gateway", typeof(string))); dt.Columns.Add(new DataColumn("Destination", typeof(string))); dt.Columns.Add(new DataColumn("Batch", typeof(string))); dt.Columns.Add(new DataColumn("CreatedDate", typeof(string))); dt.Columns.Add(new DataColumn("Driver", typeof(string))); dt.Columns.Add(new DataColumn("PlateNo", typeof(string))); dt.Columns.Add(new DataColumn("MAWB", typeof(string))); dt.Columns.Add(new DataColumn("ScannedBy", typeof(string))); dt.BeginLoadData(); int ctr = 1; foreach (GatewayTransmitalViewModel item in modelList) { DataRow row = dt.NewRow(); row[0] = (ctr++).ToString(); row[1] = item.AirwayBillNo; row[2] = item.Shipper; row[3] = item.Consignee; row[4] = item.Address; row[5] = item.CommodityType; row[6] = item.Commodity; row[7] = item.QTY; row[8] = item.AGW; row[9] = item.ServiceMode; row[10] = item.PaymentMode; row[11] = item.Gateway; row[12] = item.Destination; row[13] = item.Batch; row[14] = item.CreatedDate.ToShortDateString(); row[15] = item.Driver; row[16] = item.PlateNo; row[17] = item.MAWB; row[18] = item.ScannedBy; dt.Rows.Add(row); } dt.EndLoadData(); return(dt); }
public DataTable getData(DateTime date) { GatewayTransmittalBL gatewayBl = new GatewayTransmittalBL(); //List<GatewayTransmittal> list = gatewayBl.FilterActive().Where(x => x.RecordStatus == 1 && x.CreatedDate.ToShortDateString() == date.ToShortDateString()).ToList(); List <GatewayTransmittal> list = gatewayBl.FilterActive().Where(x => x.RecordStatus == 1 && x.CreatedDate.ToShortDateString() == date.ToShortDateString() && x.TransmittalBy.Employee.AssignedToArea.City.BranchCorpOffice.BranchCorpOfficeId == GlobalVars.DeviceBcoId).ToList(); List <GatewayTransmitalViewModel> modelList = Match(list); DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("No", typeof(string))); dt.Columns.Add(new DataColumn("AWB", typeof(string))); dt.Columns.Add(new DataColumn("Shipper", typeof(string))); dt.Columns.Add(new DataColumn("Consignee", typeof(string))); dt.Columns.Add(new DataColumn("Address", typeof(string))); dt.Columns.Add(new DataColumn("Commodity Type", typeof(string))); dt.Columns.Add(new DataColumn("Commodity", typeof(string))); dt.Columns.Add(new DataColumn("Qty", typeof(string))); dt.Columns.Add(new DataColumn("AGW", typeof(string))); dt.Columns.Add(new DataColumn("Service Mode", typeof(string))); dt.Columns.Add(new DataColumn("Payment Mode", typeof(string))); dt.Columns.Add(new DataColumn("Gateway", typeof(string))); dt.Columns.Add(new DataColumn("Destination", typeof(string))); dt.Columns.Add(new DataColumn("Batch", typeof(string))); dt.Columns.Add(new DataColumn("CreatedDate", typeof(string))); dt.Columns.Add(new DataColumn("Driver", typeof(string))); dt.Columns.Add(new DataColumn("PlateNo", typeof(string))); dt.Columns.Add(new DataColumn("MAWB", typeof(string))); dt.Columns.Add(new DataColumn("ScannedBy", typeof(string))); dt.BeginLoadData(); int ctr = 1; foreach (GatewayTransmitalViewModel item in modelList) { DataRow row = dt.NewRow(); row[0] = (ctr++).ToString(); row[1] = item.AirwayBillNo; row[2] = item.Shipper; row[3] = item.Consignee; row[4] = item.Address; row[5] = item.CommodityType; row[6] = item.Commodity; row[7] = item.QTY; row[8] = item.AGW; row[9] = item.ServiceMode; row[10] = item.PaymentMode; row[11] = item.Gateway; row[12] = item.Destination; row[13] = item.Batch; row[14] = item.CreatedDate.ToShortDateString(); row[15] = item.Driver; row[16] = item.PlateNo; row[17] = item.MAWB; row[18] = item.ScannedBy; dt.Rows.Add(row); } dt.EndLoadData(); return(dt); }