using System; using SqlSugar; using Infrastructure.Attribute; using ZR.Model; using ZR.Model.Dto; using ZR.Model.Models; using ZR.Repository; using ZR.Service.Business.IBusinessService; using System.Linq; using Infrastructure; namespace ZR.Service.Business { /// /// 入库管理/退料记录表Service业务层处理 /// /// @author admin /// @date 2023-04-14 /// [AppService(ServiceType = typeof(IInRetreatRecordService), ServiceLifetime = LifeTime.Transient)] public class InRetreatRecordService : BaseService, IInRetreatRecordService { #region 业务逻辑代码 /// /// 查询入库管理/退料记录表列表 /// /// /// public PagedInfo GetList(InRetreatRecordQueryDto parm) { //开始拼装查询条件 var predicate = Expressionable.Create(); if (parm.BeginTime != null && parm.EndTime != null) { parm.BeginTime = DateTimeHelper.GetBeginTime(parm.BeginTime, -1); parm.EndTime = DateTimeHelper.GetBeginTime(parm.EndTime, 1); predicate.And(it => it.CreateTime >= parm.BeginTime && it.CreateTime <= parm.EndTime); } predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialCode), it => it.MaterialCode.Contains(parm.MaterialCode)); predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialName), it => it.MaterialName.Contains(parm.MaterialName)); predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialSpec), it => it.MaterialSpec.Contains(parm.MaterialSpec)); predicate.AndIF(!string.IsNullOrEmpty(parm.BnSnCode), it => it.BnSnCode.Contains(parm.BnSnCode)); predicate.AndIF(!string.IsNullOrEmpty(parm.Category), it => it.Category == parm.Category); predicate.AndIF(parm.KeyFlag!=null, it => it.KeyFlag == parm.KeyFlag); //搜索条件查询语法参考Sqlsugar var response = Queryable() .Where(predicate.ToExpression()) .ToPage(parm); return response; } /// /// 添加入库管理/退料记录表 /// /// /// public int AddInRetreatRecord(InRetreatRecord model) { return Add(model, true); } /// /// 修改入库管理/退料记录表 /// /// /// public int UpdateInRetreatRecord(InRetreatRecord model) { //var response = Update(w => w.RetreatId == model.RetreatId, it => new InRetreatRecord() //{ // RetreatNo = model.RetreatNo, // BomNo = model.BomNo, // MaterialCode = model.MaterialCode, // MaterialName = model.MaterialName, // Category = model.Category, // KeyFlag = model.KeyFlag, // RetreatQty = model.RetreatQty, // Result = model.Result, // UpdateBy = model.UpdateBy, // UpdateTime = model.UpdateTime, // Remark = model.Remark, // BomDtlId = model.BomDtlId, // MaterialSpec = model.MaterialSpec, // BnSnCode = model.BnSnCode, // ReceiveQty = model.ReceiveQty, // ReasonType = model.ReasonType, // ReasonDesc = model.ReasonDesc, //}); //return response; return Update(model, true); } /// /// 清空入库管理/退料记录表 /// /// public void TruncateInRetreatRecord() { Truncate(); } #endregion } }