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
}
}