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;
}
}