コード例 #1
0
        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);
            }
        }
コード例 #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();
        }