Пример #1
0
        public override bool UpdateData(int userId, int id, ref object dtoItem, out Library.DTO.Notification notification)
        {
            notification = new Library.DTO.Notification()
            {
                Type = Library.DTO.NotificationType.Success
            };
            DTO.FactoryNorm dtoFactoryNorm = ((Newtonsoft.Json.Linq.JObject)dtoItem).ToObject <DTO.FactoryNorm>();
            try
            {
                using (FactoryNormEntities context = CreateContext())
                {
                    FactoryNorm dbItem = null;
                    if (id > 0)
                    {
                        dbItem = context.FactoryNorm.Where(o => o.FactoryNormID == id).FirstOrDefault();
                    }
                    else
                    {
                        dbItem = new FactoryNorm();
                        context.FactoryNorm.Add(dbItem);
                    }

                    if (dbItem == null)
                    {
                        notification.Message = "data not found!";
                        return(false);
                    }
                    else
                    {
                        //convert dto to db
                        converter.DTO2DB_FactoryNorm(dtoFactoryNorm, ref dbItem);
                        //remove orphan item
                        context.FactoryMaterialNorm.Local.Where(o => o.FactoryFinishedProductNorm == null).ToList().ForEach(o => context.FactoryMaterialNorm.Remove(o));
                        context.FactoryFinishedProductNorm.Local.Where(o => o.FactoryNorm == null).ToList().ForEach(o => context.FactoryFinishedProductNorm.Remove(o));
                        //save data
                        context.SaveChanges();
                        //get return data
                        dtoItem = GetData(dbItem.FactoryNormID, 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_FactoryNorm(DTO.FactoryNorm dtoItem, ref FactoryNorm dbItem)
 {
     //if (dtoItem.FactoryFinishedProductNorms != null)
     //{
     //    //user remove factory finished product in dto => check to remove in db
     //    foreach (var item in dbItem.FactoryFinishedProductNorm.ToArray())
     //    {
     //        if (!dtoItem.FactoryFinishedProductNorms.Select(s => s.FactoryFinishedProductNormID).Contains(item.FactoryFinishedProductNormID))
     //        {
     //            foreach (var mItem in item.FactoryMaterialNorm.ToArray())
     //            {
     //                item.FactoryMaterialNorm.Remove(mItem);
     //            }
     //            dbItem.FactoryFinishedProductNorm.Remove(item);
     //        }
     //        else
     //        {
     //            //user remove factory material in dto => check to remove in db
     //            foreach (var mItem in item.FactoryMaterialNorm.ToArray())
     //            {
     //                var x = dtoItem.FactoryFinishedProductNorms.Where(o => o.FactoryFinishedProductNormID == item.FactoryFinishedProductNormID).FirstOrDefault().FactoryMaterialNorms;
     //                if (!x.Select(s => s.FactoryMaterialNormID).Contains(mItem.FactoryMaterialNormID))
     //                {
     //                    item.FactoryMaterialNorm.Remove(mItem);
     //                }
     //            }
     //        }
     //    }
     //    //read factory finished product
     //    FactoryFinishedProductNorm dbFinishedProductNorm;
     //    FactoryMaterialNorm dbMaterialNorm;
     //    foreach (var item in dtoItem.FactoryFinishedProductNorms)
     //    {
     //        if (item.FactoryFinishedProductNormID > 0)
     //        {
     //            dbFinishedProductNorm = dbItem.FactoryFinishedProductNorm.Where(o => o.FactoryFinishedProductNormID == item.FactoryFinishedProductNormID).FirstOrDefault();
     //            if (dbFinishedProductNorm != null && item.FactoryMaterialNorms != null)
     //            {
     //                foreach (var mItem in item.FactoryMaterialNorms)
     //                {
     //                    if (mItem.FactoryMaterialNormID > 0)
     //                    {
     //                        dbMaterialNorm = dbFinishedProductNorm.FactoryMaterialNorm.Where(o => o.FactoryMaterialNormID == mItem.FactoryMaterialNormID).FirstOrDefault();
     //                    }
     //                    else
     //                    {
     //                        dbMaterialNorm = new FactoryMaterialNorm();
     //                        dbFinishedProductNorm.FactoryMaterialNorm.Add(dbMaterialNorm);
     //                    }
     //                    if (dbMaterialNorm != null)
     //                    {
     //                        AutoMapper.Mapper.Map<DTO.FactoryMaterialNorm, FactoryMaterialNorm>(mItem, dbMaterialNorm);
     //                    }
     //                }
     //            }
     //        }
     //        else
     //        {
     //            dbFinishedProductNorm = new FactoryFinishedProductNorm();
     //            dbItem.FactoryFinishedProductNorm.Add(dbFinishedProductNorm);
     //            if (item.FactoryMaterialNorms != null)
     //            {
     //                foreach (var mItem in item.FactoryMaterialNorms)
     //                {
     //                    dbMaterialNorm = new FactoryMaterialNorm();
     //                    dbFinishedProductNorm.FactoryMaterialNorm.Add(dbMaterialNorm);
     //                    AutoMapper.Mapper.Map<DTO.FactoryMaterialNorm, FactoryMaterialNorm>(mItem, dbMaterialNorm);
     //                }
     //            }
     //        }
     //        //mapping
     //        if (dbFinishedProductNorm != null)
     //        {
     //            AutoMapper.Mapper.Map<DTO.FactoryFinishedProductNorm, FactoryFinishedProductNorm>(item, dbFinishedProductNorm);
     //        }
     //    }
     //}
     AutoMapper.Mapper.Map <DTO.FactoryNorm, FactoryNorm>(dtoItem, dbItem);
 }