using SqlSugar;
using Volo.Abp;
using Volo.Abp.Application.Dtos;
using Volo.Abp.Application.Services;
using Yi.Framework.Ddd.Application;
using Yi.Framework.Rbac.Application.Contracts.Dtos.Dept;
using Yi.Framework.Rbac.Application.Contracts.IServices;
using Yi.Framework.Rbac.Domain.Entities;
using Yi.Framework.Rbac.Domain.Repositories;
namespace Yi.Framework.Rbac.Application.Services.System
{
///
/// Dept服务实现
///
public class DeptService : YiCrudAppService, IDeptService
{
private IDeptRepository _deptRepository;
public DeptService(IDeptRepository deptRepository) : base(deptRepository)
{ _deptRepository = deptRepository; }
[RemoteService(false)]
public async Task> GetChildListAsync(Guid deptId)
{
return await _deptRepository.GetChildListAsync(deptId);
}
///
/// 通过角色id查询该角色全部部门
///
///
//[Route("{roleId}")]
public async Task> GetRoleIdAsync(Guid roleId)
{
var entities = await _deptRepository.GetListRoleIdAsync(roleId);
return await MapToGetListOutputDtosAsync(entities);
}
///
/// 多查
///
///
///
public override async Task> GetListAsync(DeptGetListInputVo input)
{
RefAsync total = 0;
var entities = await _deptRepository._DbQueryable
.WhereIF(!string.IsNullOrEmpty(input.DeptName), u => u.DeptName.Contains(input.DeptName!))
.WhereIF(input.State is not null, u => u.State == input.State)
.OrderBy(u => u.OrderNum, OrderByType.Asc)
.ToPageListAsync(input.SkipCount, input.MaxResultCount, total);
return new PagedResultDto
{
Items = await MapToGetListOutputDtosAsync(entities),
TotalCount = total
};
}
}
}