Ejemplo n.º 1
0
        public void Update(AddOrUpdateWmsInboundOrderTblReq obj)
        {
            var user = _auth.GetCurrentUser().User;

            UnitWork.ExecuteWithTransaction(() =>
            {
                if (obj.WmsInboundOrderDtblReqs != null && obj.WmsInboundOrderDtblReqs.Any())
                {
                    //id为空的添加
                    foreach (var detail in obj.WmsInboundOrderDtblReqs.Where(u => string.IsNullOrEmpty(u.Id)))
                    {
                        detail.OrderId = obj.Id;
                        _wmsInboundOrderDtblApp.AddNoSave(detail);
                    }

                    //id比数据库少的,删除
                    var containids = obj.WmsInboundOrderDtblReqs.Select(u => u.Id)
                                     .Where(u => !string.IsNullOrEmpty(u)).ToList();
                    if (containids.Any())
                    {
                        UnitWork.Delete <WmsInboundOrderDtbl>(u => (!containids.Contains(u.Id)) && u.OrderId == obj.Id);
                    }

                    //更新id相同的
                    foreach (var detail in obj.WmsInboundOrderDtblReqs.Where(u => !string.IsNullOrEmpty(u.Id)))
                    {
                        _wmsInboundOrderDtblApp.Update(detail);
                    }
                }

                UnitWork.Update <WmsInboundOrderTbl>(u => u.Id == obj.Id, u => new WmsInboundOrderTbl
                {
                    ExternalNo           = obj.ExternalNo,
                    ExternalType         = obj.ExternalType,
                    Status               = obj.Status,
                    OrderType            = obj.OrderType,
                    GoodsType            = obj.GoodsType,
                    PurchaseNo           = obj.PurchaseNo,
                    StockId              = obj.StockId,
                    OwnerId              = obj.OwnerId,
                    ShipperId            = obj.ShipperId,
                    SupplierId           = obj.SupplierId,
                    ScheduledInboundTime = obj.ScheduledInboundTime,
                    Remark               = obj.Remark,
                    Enable               = obj.Enable,
                    TransferType         = obj.TransferType,
                    InBondedArea         = obj.InBondedArea,
                    ReturnBoxNum         = obj.ReturnBoxNum,
                    UpdateTime           = DateTime.Now,
                    UpdateUserId         = user.Id,
                    UpdateUserName       = user.Name
                                           //todo:补充或调整自己需要的字段
                });

                UnitWork.Save();
            });
        }
 public string Update(AddOrUpdateWmsInboundOrderTblReq obj)
 {
     try
     {
         _app.Update(obj);
     }
     catch (Exception ex)
     {
         Result.Code    = 500;
         Result.Message = ex.Message;
     }
     return(JsonHelper.Instance.Serialize(Result));
 }
        public Response Update(AddOrUpdateWmsInboundOrderTblReq obj)
        {
            var result = new Response();

            try
            {
                _app.Update(obj);
            }
            catch (Exception ex)
            {
                result.Code    = 500;
                result.Message = ex.InnerException?.Message ?? ex.Message;
            }

            return(result);
        }
Ejemplo n.º 4
0
        public void Add(AddOrUpdateWmsInboundOrderTblReq req)
        {
            var obj = req.MapTo<WmsInboundOrderTbl>();
            //todo:补充或调整自己需要的字段
            obj.CreateTime = DateTime.Now;
            var user = _auth.GetCurrentUser().User;
            obj.CreateUserId = user.Id;
            obj.CreateUserName = user.Name;
            UnitWork.Add(obj);
            if (req.WmsInboundOrderDtblReqs != null && req.WmsInboundOrderDtblReqs.Any())
            {
                foreach (var detail in req.WmsInboundOrderDtblReqs)
                {
                    detail.OrderId = obj.Id;
                    _wmsInboundOrderDtblApp.AddNoSave(detail);
                }
            }

            UnitWork.Save();
        }