Blame view

Yi.Abp.Net8/module/rbac/Yi.Framework.Rbac.Application/Services/System/MenuService.cs 3.15 KB
515fceeb   “wangming”   框架初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  using Microsoft.AspNetCore.Mvc;
  using SqlSugar;
  using Volo.Abp.Application.Dtos;
  using Yi.Framework.Ddd.Application;
  using Yi.Framework.Rbac.Application.Contracts.Dtos.Menu;
  using Yi.Framework.Rbac.Application.Contracts.IServices;
  using Yi.Framework.Rbac.Domain.Entities;
  using Yi.Framework.Rbac.Domain.Shared.Consts;
  using Yi.Framework.Rbac.Domain.Shared.Dtos;
  using Yi.Framework.SqlSugarCore.Abstractions;
  
  namespace Yi.Framework.Rbac.Application.Services.System
  {
      /// <summary>
      /// Menu服务实现
      /// </summary>
      public class MenuService : YiCrudAppService<MenuAggregateRoot, MenuGetOutputDto, MenuGetListOutputDto, Guid, MenuGetListInputVo, MenuCreateInputVo, MenuUpdateInputVo>,
         IMenuService
      {
          private readonly ISqlSugarRepository<MenuAggregateRoot, Guid> _repository;
          public MenuService(ISqlSugarRepository<MenuAggregateRoot, Guid> repository) : base(repository)
          {
              _repository = repository;
          }
  
          public override async Task<PagedResultDto<MenuGetListOutputDto>> GetListAsync(MenuGetListInputVo input)
          {
              RefAsync<int> total = 0;
              var entities = await _repository._DbQueryable.WhereIF(!string.IsNullOrEmpty(input.MenuName), x => x.MenuName.Contains(input.MenuName!))
                          .WhereIF(input.State is not null, x => x.State == input.State)
                          .Where(x=>x.MenuSource==input.MenuSource)
                          .OrderByDescending(x => x.OrderNum)
                          .ToListAsync();
              return new PagedResultDto<MenuGetListOutputDto>(total, await MapToGetListOutputDtosAsync(entities));
          }
  
          /// <summary>
          /// 查询当前角色的菜单
          /// </summary>
          /// <param name="roleId"></param>
          /// <returns></returns>
          public async Task<List<MenuGetListOutputDto>> GetListRoleIdAsync(Guid roleId)
          {
              var entities = await _repository._DbQueryable.Where(m => SqlFunc.Subqueryable<RoleMenuEntity>().Where(rm => rm.RoleId == roleId && rm.MenuId == m.Id).Any()).ToListAsync();
  
              return await MapToGetListOutputDtosAsync(entities);
          }
          
          /// <summary>
          /// 获取所有菜单
          /// </summary>
          /// <param name="input"></param>
          /// <returns></returns>
          [Route("menu/list")]
          public async Task<List<MenuGetListOutputDto>> GetAllListAsync(MenuGetListInputVo input)
          {
              var entities = await _repository._DbQueryable.WhereIF(!string.IsNullOrEmpty(input.MenuName), x => x.MenuName.Contains(input.MenuName!))
                  .WhereIF(input.State is not null, x => x.State == input.State)
                  .Where(x=>x.MenuSource==input.MenuSource)
                  .OrderByDescending(x => x.OrderNum)
                  .ToListAsync();
              return await MapToGetListOutputDtosAsync(entities);
          }
          
          /// <summary>
          /// 获取菜单树
          /// </summary>
          /// <returns></returns>
          public async Task<List<MenuTreeDto>> GetTreeAsync()
          {
              var menuList = await _repository._DbQueryable.ToListAsync();
              return menuList.TreeDtoBuild();
          }
      }
  }