MenuService.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Common;
  4. using System.Linq;
  5. using System.Linq.Expressions;
  6. using System.Threading.Tasks;
  7. using YiSha.Data;
  8. using YiSha.Data.Repository;
  9. using YiSha.Entity.SystemManage;
  10. using YiSha.Enum;
  11. using YiSha.IService.SystemManage;
  12. using YiSha.Model.Param.SystemManage;
  13. using YiSha.Util;
  14. using YiSha.Util.Extension;
  15. namespace YiSha.Service.SystemManage
  16. {
  17. public partial class MenuService
  18. {
  19. private IRepositoryFactory _baseRepository;
  20. private IMenuAuthorizeService _menuAuthorizeService;
  21. public MenuService(IRepositoryFactory baseRepository,IMenuAuthorizeService menuAuthorizeService)
  22. {
  23. _baseRepository = baseRepository;
  24. _menuAuthorizeService = menuAuthorizeService;
  25. }
  26. #region 获取数据
  27. public async Task<List<MenuEntity>> GetListPartial(MenuListParam param)
  28. {
  29. var expression = ListFilterPartial(param);
  30. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<MenuEntity>(expression);
  31. return list.OrderBy(p => p.MenuSort).ToList();
  32. }
  33. public async Task<MenuEntity> GetEntityPartial(int id)
  34. {
  35. return await _baseRepository.BaseRepository(dbConnectType).FindEntity<MenuEntity>(id);
  36. }
  37. public async Task<int> GetMaxSortPartial(long parentId)
  38. {
  39. string where = string.Empty;
  40. if (parentId > 0)
  41. {
  42. where += " AND ParentId = " + parentId;
  43. }
  44. object result = await _baseRepository.BaseRepository(dbConnectType).FindObject("SELECT MAX(MenuSort) FROM SysMenu where BaseIsDelete = 0 " + where);
  45. int sort = result.ParseToInt();
  46. sort++;
  47. return sort;
  48. }
  49. public bool ExistMenuNamePartial(MenuEntity entity)
  50. {
  51. var expression = LinqExtensions.True<MenuEntity>();
  52. expression = expression.And(t => t.BaseIsDelete == 0);
  53. if (entity.Id.IsNullOrZero())
  54. {
  55. expression = expression.And(t => t.MenuName == entity.MenuName && t.MenuType == entity.MenuType);
  56. }
  57. else
  58. {
  59. expression = expression.And(t => t.MenuName == entity.MenuName && t.MenuType == entity.MenuType && t.Id != entity.Id);
  60. }
  61. return _baseRepository.BaseRepository(dbConnectType).IQueryable(expression).Count() > 0 ? true : false;
  62. }
  63. #endregion
  64. #region 提交数据
  65. public async Task SaveFormPartial(MenuEntity entity)
  66. {
  67. if (entity.Id.IsNullOrZero())
  68. {
  69. await entity.Create();
  70. await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  71. }
  72. else
  73. {
  74. await entity.Modify();
  75. await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  76. }
  77. }
  78. public async Task DeleteFormPartial(string ids)
  79. {
  80. var db = await _baseRepository.BaseRepository(dbConnectType).BeginTrans();
  81. try
  82. {
  83. ids = $"{ string.Join(",", ids.Split(","))}";
  84. List<DbParameter> parameters = new List<DbParameter>();
  85. parameters.Add(DbParameterExtension.CreateDbParameter("@id", ids, dbConnectType));
  86. //删除菜单
  87. await DeleteFormByWhere(" FIND_IN_SET (id,@id) or FIND_IN_SET (parentid,@id) ", parameters);
  88. parameters.Clear();//清除上一个删除操作中的@baseisdelete数据
  89. parameters.Add(DbParameterExtension.CreateDbParameter("@menuid", ids, dbConnectType));
  90. //删除菜单权限
  91. await _menuAuthorizeService.DeleteFormByWhere(" FIND_IN_SET (menuid,@menuid) ", parameters);
  92. await db.CommitTrans();
  93. }
  94. catch
  95. {
  96. await db.RollbackTrans();
  97. throw;
  98. }
  99. }
  100. #endregion
  101. #region 私有方法
  102. private Expression<Func<MenuEntity, bool>> ListFilterPartial(MenuListParam param)
  103. {
  104. var expression = LinqExtensions.True<MenuEntity>();
  105. expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  106. if (param != null)
  107. {
  108. if (!string.IsNullOrEmpty(param.MenuName))
  109. {
  110. expression = expression.And(t => t.MenuName.Contains(param.MenuName));
  111. }
  112. if (param.MenuStatus > -1)
  113. {
  114. expression = expression.And(t => t.MenuStatus == param.MenuStatus);
  115. }
  116. }
  117. return expression;
  118. }
  119. #endregion
  120. }
  121. }