public override bool UpdateData(int id, ref DTO.ShowroomReceiptMng.ShowroomReceipt dtoItem, out Library.DTO.Notification notification) { notification = new Library.DTO.Notification() { Type = Library.DTO.NotificationType.Success }; try { using (ShowroomReceiptMngEntities context = CreateContext()) { ShowroomReceipt dbItem = null; if (id == 0) { dbItem = new ShowroomReceipt(); context.ShowroomReceipt.Add(dbItem); } else { dbItem = context.ShowroomReceipt.FirstOrDefault(o => o.ShowroomReceiptID == id); } if (dbItem == null) { notification.Message = "data not found!"; return(false); } else { // check concurrency //if (dbItem.ConcurrencyFlag != null && !dbItem.ConcurrencyFlag.SequenceEqual(Convert.FromBase64String(dtoItem.ConcurrencyFlag_String))) //{ // throw new Exception(DALBase.Helper.TEXT_CONCURRENCY_CONFLICT); //} if (dtoItem.ReceiptTypeID == 2) // 2: EXPORT { DAL.Support.DataFactory support_factory = new Support.DataFactory(); Hashtable support_filters = new Hashtable(); foreach (var item in dtoItem.ShowroomReceiptDetails) { if (item.ShowroomReceiptDetailID > 0) { foreach (var area in item.ShowroomReceiptAreaDetails) { if (area.ShowroomReceiptAreaDetailID > 0) { var physicalByArea = support_factory.QuickSearchShowroomAreaByPhysicalQnt(support_filters, out notification).Where(o => o.ShowroomItemID == item.ShowroomItemID && o.ShowroomAreaID == area.ShowroomAreaID).FirstOrDefault(); var currentArea = context.ShowroomReceiptAreaDetail.Where(o => o.ShowroomReceiptAreaDetailID == area.ShowroomReceiptAreaDetailID).FirstOrDefault(); if (physicalByArea == null) { throw new Exception("Could not find this product in area. You should select another area"); } else if (area.Quantity - currentArea.Quantity > physicalByArea.Quantity) { throw new Exception("Quantity must be less than current physical quantity"); } } else { var physicalByArea = support_factory.QuickSearchShowroomAreaByPhysicalQnt(support_filters, out notification).Where(o => o.ShowroomItemID == item.ShowroomItemID && o.ShowroomAreaID == area.ShowroomAreaID).FirstOrDefault(); if (physicalByArea == null) { throw new Exception("Could not find this product in area. You should select another area"); } else if (area.Quantity > physicalByArea.Quantity) { throw new Exception("Quantity must be less than current physical quantity"); } } } } else { foreach (var area in item.ShowroomReceiptAreaDetails) { var physicalByArea = support_factory.QuickSearchShowroomAreaByPhysicalQnt(support_filters, out notification).Where(o => o.ShowroomItemID == item.ShowroomItemID && o.ShowroomAreaID == area.ShowroomAreaID).FirstOrDefault(); if (physicalByArea == null) { throw new Exception("Could not find this product in area. You should select another area"); } else if (area.Quantity > physicalByArea.Quantity) { throw new Exception("Quantity must be less than current physical quantity"); } } } } } //convert dto to db converter.DTO2DB_ShowroomReceipt(dtoItem, ref dbItem); //reove orphan context.ShowroomReceiptAreaDetail.Local.Where(o => o.ShowroomReceiptDetail == null).ToList().ForEach(o => context.ShowroomReceiptAreaDetail.Remove(o)); context.ShowroomReceiptDetail.Local.Where(o => o.ShowroomReceipt == null).ToList().ForEach(o => context.ShowroomReceiptDetail.Remove(o)); //save data context.SaveChanges(); //update receipt no context.ShowroomReceiptMng_function_GenerateReceipNo(dbItem.ShowroomReceiptID, dbItem.Season, dbItem.ReceiptTypeID); //get return data dtoItem = GetData(dbItem.ShowroomReceiptID, out notification).Data; return(true); } } } catch (Exception ex) { notification.Type = Library.DTO.NotificationType.Error; notification.Message = ex.Message; notification.DetailMessage.Add(ex.Message); if (ex.GetBaseException() != null) { notification.DetailMessage.Add(ex.GetBaseException().Message); } return(false); } }
public void DTO2DB_ShowroomReceipt(DTO.ShowroomReceiptMng.ShowroomReceipt dtoItem, ref ShowroomReceipt dbItem) { //List<ShowroomReceiptDetail> product_tobedeleted = new List<ShowroomReceiptDetail>(); //if (dtoItem.ShowroomReceiptDetails != null) //{ // //CHECK // foreach (var dbDetail in dbItem.ShowroomReceiptDetail.Where(o => !dtoItem.ShowroomReceiptDetails.Select(s => s.ShowroomReceiptDetailID).Contains(o.ShowroomReceiptDetailID))) // { // product_tobedeleted.Add(dbDetail); // } // foreach (var dbDetail in product_tobedeleted) // { // dbItem.ShowroomReceiptDetail.Remove(dbDetail); // } // //MAP // foreach (var dtoDetail in dtoItem.ShowroomReceiptDetails) // { // ShowroomReceiptDetail dbDetail; // if (dtoDetail.ShowroomReceiptDetailID < 0) // { // dbDetail = new ShowroomReceiptDetail(); // dbItem.ShowroomReceiptDetail.Add(dbDetail); // } // else // { // dbDetail = dbItem.ShowroomReceiptDetail.FirstOrDefault(o => o.ShowroomReceiptDetailID == dtoDetail.ShowroomReceiptDetailID); // } // if (dbDetail != null) // { // AutoMapper.Mapper.Map<DTO.ShowroomReceiptMng.ShowroomReceiptDetail, ShowroomReceiptDetail>(dtoDetail, dbDetail); // } // } //} List <ShowroomReceiptDetail> itemNeedDelete_Product = new List <ShowroomReceiptDetail>(); List <ShowroomReceiptAreaDetail> itemNeedDelete_Area; if (dtoItem.ShowroomReceiptDetails != null) { //CHECK foreach (var dbProduct in dbItem.ShowroomReceiptDetail) { //DB NOT EXIST IN DTO if (!dtoItem.ShowroomReceiptDetails.Select(s => s.ShowroomReceiptDetailID).Contains(dbProduct.ShowroomReceiptDetailID)) { itemNeedDelete_Product.Add(dbProduct); } else //DB IS EXIST IN DB { itemNeedDelete_Area = new List <ShowroomReceiptAreaDetail>(); foreach (var dbArea in dbProduct.ShowroomReceiptAreaDetail) { if (!dtoItem.ShowroomReceiptDetails.Where(o => o.ShowroomReceiptDetailID == dbProduct.ShowroomReceiptDetailID).FirstOrDefault().ShowroomReceiptAreaDetails.Select(x => x.ShowroomReceiptAreaDetailID).Contains(dbArea.ShowroomReceiptAreaDetailID)) { itemNeedDelete_Area.Add(dbArea); } } foreach (var dbArea in itemNeedDelete_Area) { dbProduct.ShowroomReceiptAreaDetail.Remove(dbArea); } } } foreach (var dbProduct in itemNeedDelete_Product) { List <ShowroomReceiptAreaDetail> item_deleteds = new List <ShowroomReceiptAreaDetail>(); foreach (var dbArea in dbProduct.ShowroomReceiptAreaDetail) { item_deleteds.Add(dbArea); } foreach (var item in item_deleteds) { dbItem.ShowroomReceiptDetail.Where(o => o.ShowroomReceiptDetailID == dbProduct.ShowroomReceiptDetailID).FirstOrDefault().ShowroomReceiptAreaDetail.Remove(item); } dbItem.ShowroomReceiptDetail.Remove(dbProduct); } //MAP ShowroomReceiptDetail _dbProduct; ShowroomReceiptAreaDetail _dbArea; foreach (var dtoProduct in dtoItem.ShowroomReceiptDetails) { if (dtoProduct.ShowroomReceiptDetailID < 0) { _dbProduct = new ShowroomReceiptDetail(); if (dtoProduct.ShowroomReceiptAreaDetails != null) { foreach (var dtoArea in dtoProduct.ShowroomReceiptAreaDetails) { _dbArea = new ShowroomReceiptAreaDetail(); _dbProduct.ShowroomReceiptAreaDetail.Add(_dbArea); AutoMapper.Mapper.Map <DTO.ShowroomReceiptMng.ShowroomReceiptAreaDetail, ShowroomReceiptAreaDetail>(dtoArea, _dbArea); } } dbItem.ShowroomReceiptDetail.Add(_dbProduct); } else { _dbProduct = dbItem.ShowroomReceiptDetail.FirstOrDefault(o => o.ShowroomReceiptDetailID == dtoProduct.ShowroomReceiptDetailID); if (_dbProduct != null && dtoProduct.ShowroomReceiptAreaDetails != null) { foreach (var dtoArea in dtoProduct.ShowroomReceiptAreaDetails) { if (dtoArea.ShowroomReceiptAreaDetailID < 0) { _dbArea = new ShowroomReceiptAreaDetail(); _dbProduct.ShowroomReceiptAreaDetail.Add(_dbArea); } else { _dbArea = _dbProduct.ShowroomReceiptAreaDetail.FirstOrDefault(o => o.ShowroomReceiptAreaDetailID == dtoArea.ShowroomReceiptAreaDetailID); } if (_dbArea != null) { AutoMapper.Mapper.Map <DTO.ShowroomReceiptMng.ShowroomReceiptAreaDetail, ShowroomReceiptAreaDetail>(dtoArea, _dbArea); } } } } if (_dbProduct != null) { AutoMapper.Mapper.Map <DTO.ShowroomReceiptMng.ShowroomReceiptDetail, ShowroomReceiptDetail>(dtoProduct, _dbProduct); } } } AutoMapper.Mapper.Map <DTO.ShowroomReceiptMng.ShowroomReceipt, ShowroomReceipt>(dtoItem, dbItem); if (dtoItem.ShowroomReceiptID > 0) { dbItem.UpdatedDate = DateTime.Now; dbItem.UpdatedBy = dtoItem.UpdatedBy; } else { dbItem.CreatedDate = DateTime.Now; dbItem.CreatedBy = dtoItem.UpdatedBy; } dbItem.ReceiptDate = dtoItem.ReceiptDate.ConvertStringToDateTime(); }