Files
kunshan-bzfm-mes-backend/DOAN.Service/MES/Material/MmRecordOutboundService.cs
Carl 28dcf5678c 新增出库记录交易类型字段及查询支持
在 MmRecordOutboundDto 中新增 TransactionType 字段;
在 MmRecordOutboundService 的 QueryExp 方法中,增加对 TransactionType 的模糊查询条件,支持按交易类型筛选出库记录。
2026-01-04 14:06:29 +08:00

84 lines
2.7 KiB
C#

using Infrastructure.Attribute;
using Infrastructure.Extensions;
using DOAN.Model.BZFM.Dto;
using DOAN.Model.BZFM;
using DOAN.Repository;
using DOAN.Service.BZFM.IBZFMService;
namespace DOAN.Service.BZFM
{
/// <summary>
/// 出库记录表Service业务层处理
/// </summary>
[AppService(ServiceType = typeof(IMmRecordOutboundService), ServiceLifetime = LifeTime.Transient)]
public class MmRecordOutboundService : BaseService<MmRecordOutbound>, IMmRecordOutboundService
{
/// <summary>
/// 查询出库记录表列表
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<MmRecordOutboundDto> GetList(MmRecordOutboundQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.ToPage<MmRecordOutbound, MmRecordOutboundDto>(parm);
return response;
}
/// <summary>
/// 获取详情
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
public MmRecordOutbound GetInfo(int Id)
{
var response = Queryable()
.Where(x => x.Id == Id)
.First();
return response;
}
/// <summary>
/// 添加出库记录表
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public MmRecordOutbound AddMmRecordOutbound(MmRecordOutbound model)
{
return Insertable(model).ExecuteReturnEntity();
}
/// <summary>
/// 修改出库记录表
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public int UpdateMmRecordOutbound(MmRecordOutbound model)
{
return Update(model, true);
}
/// <summary>
/// 查询导出表达式
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
private static Expressionable<MmRecordOutbound> QueryExp(MmRecordOutboundQueryDto parm)
{
var predicate = Expressionable.Create<MmRecordOutbound>()
.AndIF(!string.IsNullOrEmpty(parm.MaterialCode), it => it.MaterialCode.Contains(parm.MaterialCode))
.AndIF(!string.IsNullOrEmpty(parm.OutboundNo), it => it.OutboundNo.Contains(parm.OutboundNo))
.AndIF(!string.IsNullOrEmpty(parm.TransactionType), it => it.TransactionType.Contains(parm.TransactionType))
.AndIF(parm.CreatedTime > DateTime.MinValue, it => it.CreatedTime < parm.CreatedTime)
;
return predicate;
}
}
}