2024-08-26 11:20:57 +08:00

94 lines
2.8 KiB
C#

using Infrastructure.Attribute;
using Infrastructure.Extensions;
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
{
/// <summary>
/// 公司Service业务层处理
/// </summary>
[AppService(ServiceType = typeof(IBaseCompanyService), ServiceLifetime = LifeTime.Transient)]
public class BaseCompanyService : BaseService<BaseCompany>, IBaseCompanyService
{
/// <summary>
/// 查询公司列表
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<BaseCompanyDto> GetList(BaseCompanyQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.ToPage<BaseCompany, BaseCompanyDto>(parm);
return response;
}
public List<BaseCompanyDto> GetList_No_page(BaseCompanyQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression()).ToList().Adapt<List<BaseCompanyDto>>();
return response;
}
/// <summary>
/// 获取详情
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
public BaseCompany GetInfo(int Id)
{
var response = Queryable()
.Where(x => x.Id == Id)
.First();
return response;
}
/// <summary>
/// 添加公司
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public BaseCompany AddBaseCompany(BaseCompany model)
{
return Insertable(model).ExecuteReturnEntity();
}
/// <summary>
/// 修改公司
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public int UpdateBaseCompany(BaseCompany model)
{
return Update(model, true);
}
/// <summary>
/// 查询导出表达式
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
private static Expressionable<BaseCompany> QueryExp(BaseCompanyQueryDto parm)
{
var predicate = Expressionable.Create<BaseCompany>()
.AndIF(!string.IsNullOrEmpty(parm.CompanyCode),it=>it.CompanyCode.Contains(parm.CompanyCode))
.AndIF(!string.IsNullOrEmpty(parm.CompanyName),it=>it.CompanyName.Contains(parm.CompanyName))
.AndIF(parm.Status>-1,it=>it.Status==parm.Status)
.AndIF(parm.IsOutsource > -1,it=>it.IsOutsource == parm.IsOutsource)
;
return predicate;
}
}
}