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
     }));
 }
Esempio n. 2
0
        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();
        }