using Infrastructure.Attribute;
using DOAN.Repository;
using DOAN.Model.Factory_Model.Dto;
using DOAN.Model.Factory_Model;
using DOAN.Service.Factory_Model.IService;
using Mapster;
namespace DOAN.Service.Factory_Model
{
///
/// 设备台账Service业务层处理
///
[AppService(ServiceType = typeof(IBaseDeviceAccountService), ServiceLifetime = LifeTime.Transient)]
public class BaseDeviceAccountService : BaseService, IBaseDeviceAccountService
{
///
/// 查询设备台账列表
///
///
///
public PagedInfo GetList(BaseDeviceAccountQueryDto parm)
{
var predicate = QueryExp(parm);
var query = Queryable()
.Where(predicate.ToExpression());
var response = Context.Queryable(query).LeftJoin((q, c) => q.FkLineId == c.Id)
.Select((q, c) => new BaseDeviceAccountDto()
{
ProductionLineName = c.LineName
}, true).ToPage(parm);
return response;
}
public List GetList_NO_Page(BaseDeviceAccountQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.ToList()
.Adapt>();
return response;
}
///
/// 获取详情
///
///
///
public BaseDeviceAccount GetInfo(int Id)
{
var response = Queryable()
.Where(x => x.Id == Id)
.First();
return response;
}
///
/// 添加设备台账
///
///
///
public BaseDeviceAccount AddBaseDeviceAccount(BaseDeviceAccount model)
{
return Insertable(model).ExecuteReturnEntity();
}
///
/// 修改设备台账
///
///
///
public int UpdateBaseDeviceAccount(BaseDeviceAccount model)
{
return Update(model, true);
}
///
/// 查询导出表达式
///
///
///
private static Expressionable QueryExp(BaseDeviceAccountQueryDto parm)
{
var predicate = Expressionable.Create()
.AndIF(!string.IsNullOrEmpty(parm.DeviceCode), it => it.DeviceCode.Contains(parm.DeviceCode))
.AndIF(!string.IsNullOrEmpty(parm.DeviceName), it => it.DeviceName.Contains(parm.DeviceName))
.AndIF(parm.Status > -1, it => it.Status == parm.Status)
.AndIF(parm.FkLineId > -1, it => it.FkLineId == parm.FkLineId)
;
return predicate;
}
}
}