using NetAdmin.Application.Repositories; using NetAdmin.Application.Services; using NetAdmin.Domain.DbMaps.Sys; using NetAdmin.Domain.Dto.Dependency; using NetAdmin.Domain.Dto.Sys.Dic.Content; using NetAdmin.SysComponent.Application.Services.Sys.Dependency; namespace NetAdmin.SysComponent.Application.Services.Sys; /// public sealed class DicContentService(DefaultRepository rpo) // : RepositoryService(rpo), IDicContentService { /// public async Task BulkDeleteAsync(BulkReq req) { var sum = 0; foreach (var item in req.Items) { sum += await DeleteAsync(item); } return sum; } /// /// Dictionary_directory_does_not_exist public async Task CreateAsync(CreateDicContentReq req) { if (!await Rpo.Orm.Select().Where(a => a.Id == req.CatalogId).ForUpdate().AnyAsync()) { throw new NetAdminInvalidOperationException(Ln.字典目录不存在); } var ret = await Rpo.InsertAsync(req); return ret.Adapt(); } /// public Task DeleteAsync(DelReq req) { return Rpo.DeleteAsync(a => a.Id == req.Id); } /// public Task ExistAsync(QueryReq req) { return QueryInternal(req).AnyAsync(); } /// public async Task GetAsync(QueryDicContentReq req) { var ret = await QueryInternal(new QueryReq { Filter = req }).ToOneAsync(); return ret.Adapt(); } /// public async Task> PagedQueryAsync(PagedQueryReq req) { var list = await QueryInternal(req).Page(req.Page, req.PageSize).Count(out var total).ToListAsync(); return new PagedQueryRsp(req.Page, req.PageSize, total , list.Adapt>()); } /// public async Task> QueryAsync(QueryReq req) { var ret = await QueryInternal(req).Take(req.Count).ToListAsync(); return ret.Adapt>(); } /// /// Dictionary_directory_does_not_exist /// NetAdminUnexpectedException public async Task UpdateAsync(UpdateDicContentReq req) { if (!await Rpo.Orm.Select().Where(a => a.Id == req.CatalogId).ForUpdate().AnyAsync()) { throw new NetAdminInvalidOperationException(Ln.字典目录不存在); } if (await Rpo.UpdateDiy.SetSource(req).ExecuteAffrowsAsync() <= 0) { throw new NetAdminUnexpectedException(); } var ret = await Rpo.Where(a => a.Id == req.Id).ToOneAsync(); return ret.Adapt(); } /// protected override Task UpdateForSqliteAsync(Sys_DicContent req) { throw new NotImplementedException(); } private ISelect QueryInternal(QueryReq req) { var ret = Rpo.Select.WhereDynamicFilter(req.DynamicFilter) .WhereDynamic(req.Filter) .OrderByPropertyNameIf(req.Prop?.Length > 0, req.Prop, req.Order == Orders.Ascending); if (!req.Prop?.Equals(nameof(req.Filter.Id), StringComparison.OrdinalIgnoreCase) ?? true) { ret = ret.OrderByDescending(a => a.Id); } return ret; } }