using System.Diagnostics; using AutoMapper; using DMS.Core.Enums; using DMS.Core.Helper; using DMS.Core.Interfaces.Repositories; using DMS.Core.Models; using DMS.Infrastructure.Data; using DMS.Infrastructure.Entities; namespace DMS.Infrastructure.Repositories; public class MenuRepository : BaseRepository, IMenuRepository { private readonly IMapper _mapper; public MenuRepository(IMapper mapper, SqlSugarDbContext dbContext) : base(dbContext) { _mapper = mapper; } public async Task> GetMenuTreesAsync() { var stopwatch = new Stopwatch(); stopwatch.Start(); var dbMenuTree = await Db.Queryable() .ToTreeAsync(dm => dm.Childrens, dm => dm.ParentId, 0); stopwatch.Stop(); NlogHelper.Info($"获取菜单树耗时:{stopwatch.ElapsedMilliseconds}ms"); return _mapper.Map>(dbMenuTree); } public async Task GetByIdAsync(int id) { var dbMenu = await base.GetByIdAsync(id); return _mapper.Map(dbMenu); } public async Task> GetAllAsync() { var dbList = await base.GetAllAsync(); return _mapper.Map>(dbList); } public async Task AddAsync(MenuBean entity) { var dbMenu = await base.AddAsync(_mapper.Map(entity)); return _mapper.Map(dbMenu, entity); } public async Task UpdateAsync(MenuBean entity) => await base.UpdateAsync(_mapper.Map(entity)); public async Task DeleteAsync(MenuBean entity) => await base.DeleteAsync(_mapper.Map(entity)); public async Task DeleteByIdAsync(int id) { var stopwatch = new Stopwatch(); stopwatch.Start(); var result = await Db.Deleteable(new DbMenu { Id = id }) .ExecuteCommandAsync(); stopwatch.Stop(); NlogHelper.Info($"Delete {typeof(DbMenu)},ID={id},耗时:{stopwatch.ElapsedMilliseconds}ms"); return result; } public async Task DeleteMenuTreeByIdAsync(int id) { var stopwatch = new Stopwatch(); stopwatch.Start(); int delConut = 0; var childList = await Db.Queryable() .ToChildListAsync(c => c.ParentId, id); delConut = await Db.Deleteable(childList) .ExecuteCommandAsync(); delConut += await Db.Deleteable() .Where(m => m.Id == id) .ExecuteCommandAsync(); stopwatch.Stop(); NlogHelper.Info($"Delete {typeof(DbMenu)},ID={id},耗时:{stopwatch.ElapsedMilliseconds}ms"); return delConut; } public async Task DeleteMenuTreeByTargetIdAsync(MenuType menuType, int targetId) { var stopwatch = new Stopwatch(); stopwatch.Start(); var menu = await Db.Queryable().FirstAsync(m => m.MenuType == menuType && m.TargetId == targetId); if (menu == null) return 0; var childList = await Db.Queryable() .ToChildListAsync(c => c.ParentId, menu.Id); var delConut = await Db.Deleteable(childList) .ExecuteCommandAsync(); delConut += await Db.Deleteable() .Where(m => m.Id == menu.Id) .ExecuteCommandAsync(); stopwatch.Stop(); NlogHelper.Info($"Delete {typeof(DbMenu)},TargetId={targetId},耗时:{stopwatch.ElapsedMilliseconds}ms"); return delConut; } public async Task GetMenuByTargetIdAsync(MenuType menuType, int targetId) { var dbMenu = await Db.Queryable().FirstAsync(m => m.MenuType == menuType && m.TargetId == targetId); return _mapper.Map(dbMenu); } public new async Task> TakeAsync(int number) { var dbList = await base.TakeAsync(number); return _mapper.Map>(dbList); } }