在 MmInventoryQueryDto 中新增了 WarehouseCode 和 MaterialCode 属性(MaterialCode 属性重复添加,建议修正)。在库存服务层的 QueryExp 方法中,增加了对 WarehouseCode 的条件过滤,支持按仓库编码模糊查询。
80 lines
2.3 KiB
C#
80 lines
2.3 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(IMmInventoryService), ServiceLifetime = LifeTime.Transient)]
|
|
public class MmInventoryService : BaseService<MmInventory>, IMmInventoryService
|
|
{
|
|
/// <summary>
|
|
/// 查询库存表列表
|
|
/// </summary>
|
|
/// <param name="parm"></param>
|
|
/// <returns></returns>
|
|
public PagedInfo<MmInventoryDto> GetList(MmInventoryQueryDto parm)
|
|
{
|
|
var predicate = QueryExp(parm);
|
|
|
|
var response = Queryable()
|
|
.Where(predicate.ToExpression())
|
|
.ToPage<MmInventory, MmInventoryDto>(parm);
|
|
|
|
return response;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 获取详情
|
|
/// </summary>
|
|
/// <param name="Id"></param>
|
|
/// <returns></returns>
|
|
public MmInventory GetInfo(int Id)
|
|
{
|
|
var response = Queryable()
|
|
.Where(x => x.Id == Id)
|
|
.First();
|
|
|
|
return response;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 添加库存表
|
|
/// </summary>
|
|
/// <param name="model"></param>
|
|
/// <returns></returns>
|
|
public MmInventory AddMmInventory(MmInventory model)
|
|
{
|
|
return Insertable(model).ExecuteReturnEntity();
|
|
}
|
|
|
|
/// <summary>
|
|
/// 修改库存表
|
|
/// </summary>
|
|
/// <param name="model"></param>
|
|
/// <returns></returns>
|
|
public int UpdateMmInventory(MmInventory model)
|
|
{
|
|
return Update(model, true);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 查询导出表达式
|
|
/// </summary>
|
|
/// <param name="parm"></param>
|
|
/// <returns></returns>
|
|
private static Expressionable<MmInventory> QueryExp(MmInventoryQueryDto parm)
|
|
{
|
|
var predicate = Expressionable.Create<MmInventory>()
|
|
.AndIF(!string.IsNullOrEmpty(parm.WarehouseCode), m => m.WarehouseCode.Contains(parm.WarehouseCode));
|
|
|
|
return predicate;
|
|
}
|
|
}
|
|
} |