using Admin.NET.Plugin.AiDOP.Entity.S8; namespace Admin.NET.Plugin.AiDOP.Service.S8; public class S8SceneConfigService : ITransient { private readonly SqlSugarRepository _rep; public S8SceneConfigService(SqlSugarRepository rep) => _rep = rep; public async Task> ListAsync(long tenantId, long factoryId) => await _rep.AsQueryable() .Where(x => x.TenantId == tenantId && x.FactoryId == factoryId) .OrderBy(x => x.SortNo) .ToListAsync(); public async Task CreateAsync(AdoS8SceneConfig body) { if (string.IsNullOrWhiteSpace(body.SceneCode) || string.IsNullOrWhiteSpace(body.SceneName)) throw new S8BizException("场景编码和名称必填"); var exists = await _rep.AsQueryable() .AnyAsync(x => x.TenantId == body.TenantId && x.FactoryId == body.FactoryId && x.SceneCode == body.SceneCode); if (exists) throw new S8BizException("场景编码已存在"); body.Id = 0; body.CreatedAt = DateTime.Now; await _rep.InsertAsync(body); return body; } public async Task UpdateAsync(long id, AdoS8SceneConfig body) { var e = await _rep.GetByIdAsync(id) ?? throw new S8BizException("记录不存在"); if (string.IsNullOrWhiteSpace(body.SceneCode) || string.IsNullOrWhiteSpace(body.SceneName)) throw new S8BizException("场景编码和名称必填"); var exists = await _rep.AsQueryable() .AnyAsync(x => x.Id != id && x.TenantId == body.TenantId && x.FactoryId == body.FactoryId && x.SceneCode == body.SceneCode); if (exists) throw new S8BizException("场景编码已存在"); body.Id = id; body.CreatedAt = e.CreatedAt; body.UpdatedAt = DateTime.Now; await _rep.UpdateAsync(body); return body; } public async Task DeleteAsync(long id) => await _rep.DeleteByIdAsync(id); }