using Admin.NET.Core; using Furion.DatabaseAccessor; using Furion.DependencyInjection; using Furion.DynamicApiController; using Furion.FriendlyException; using Mapster; using Microsoft.AspNetCore.Mvc; using System.Collections.Generic; using System.Linq; using System.Linq.Dynamic.Core; using System.Threading.Tasks; namespace Admin.NET.Application { /// /// 学年表服务 /// [ApiDescriptionSettings("测评服务", Name = "BusStudyYears", Order = 100)] public class BusStudyYearsService : IDynamicApiController, ITransient { private readonly SqlSugarRepository _busStudyYearsRep; private readonly UserManager _userManager; public BusStudyYearsService( SqlSugarRepository busStudyYearsRep, UserManager userManager ) { _busStudyYearsRep = busStudyYearsRep; _userManager = userManager; } /// /// 分页查询学年表 /// /// /// [HttpGet("page")] public async Task> Page([FromQuery] BusStudyYearsInput input) { var busStudyYearss = await _busStudyYearsRep.AsQueryable() .WhereIF(!string.IsNullOrEmpty(input.Name), u => u.Name == input.Name) //.Where(u => u.StartDays == input.StartDays) //.Where(u => u.EndDays == input.EndDays) //.Where(u => u.Status == input.Status) //.Where(u => u.Sort == input.Sort) .Where(u => u.TenantId == _userManager.TenantId) .OrderBy(u => u.CreateTime, OrderByType.Desc) .OrderBuilder(input) .Select(s=>new BusStudyYearsOutput() { Name=s.Name, StartDays=s.StartDays, EndDays=s.EndDays, Status=s.Status, Sort=s.Sort, TenantId=s.TenantId.Value, Id=s.Id }) .ToPagedListAsync(input.Page, input.PageSize); return busStudyYearss; } /// /// 增加学年表 /// /// /// [HttpPost("add")] public async Task Add(AddBusStudyYearsInput input) { var busStudyYears = input.Adapt(); await _busStudyYearsRep.InsertAsync(busStudyYears); } /// /// 删除学年表 /// /// /// [HttpPost("delete")] public async Task Delete(DeleteBusStudyYearsInput input) { var busStudyYears = await _busStudyYearsRep.AsQueryable().FirstAsync(u => u.Id == input.Id); await _busStudyYearsRep.FakeDeleteAsync(busStudyYears); } /// /// 更新学年表 /// /// /// [HttpPost("edit")] public async Task Update(UpdateBusStudyYearsInput input) { var isExist = await _busStudyYearsRep.AsQueryable().AnyAsync(u => u.Id == input.Id); if (!isExist) throw Oops.Oh(ErrorCodeEnum.D3000); var busStudyYears = input.Adapt(); await _busStudyYearsRep.UpdateAsync(busStudyYears); } /// /// 获取学年表 /// /// /// [HttpGet("detail")] public async Task Get([FromQuery] QueryeBusStudyYearsInput input) { return (await _busStudyYearsRep.AsQueryable().FirstAsync(u => u.Id == input.Id)).Adapt(); } /// /// 获取学年表列表 /// /// /// [HttpGet("list")] public async Task> List([FromQuery] BusStudyYearsInput input) { return await _busStudyYearsRep.AsQueryable().Select().ToListAsync(); } } }