public IHttpActionResult Update(int id, DTO.ShowroomReceiptMng.ShowroomReceipt dtoItem) { Library.DTO.Notification notification; Module.Framework.BLL fwBll = new Module.Framework.BLL(); if (id > 0 && !fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanUpdate)) { return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED))); } else if (id == 0 && !fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanCreate)) { return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED))); } // validation if (!Helper.CommonHelper.ValidateDTO <DTO.ShowroomReceiptMng.ShowroomReceipt>(dtoItem, out notification)) { return(Ok(new Library.DTO.ReturnData <DTO.ShowroomReceiptMng.ShowroomReceipt>() { Data = dtoItem, Message = notification })); } // save data BLL.ShowroomReceiptMng bll = new BLL.ShowroomReceiptMng(); bll.UpdateData(id, ref dtoItem, ControllerContext.GetAuthUserId(), out notification); return(Ok(new Library.DTO.ReturnData <DTO.ShowroomReceiptMng.ShowroomReceipt>() { Data = dtoItem, Message = notification })); }
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(); }