tuiwucarrer/Admin.NET/Admin.NET.Application/Service/SysFeedBack/SysFeedBackService.cs

119 lines
3.8 KiB
C#

using Admin.NET.Core.Service;
using Microsoft.AspNetCore.Http;
namespace Admin.NET.Application;
/// <summary>
/// 用户反馈表服务
/// </summary>
[ApiDescriptionSettings(ApplicationConst.ZYGroupName, Order = 900)]
public class SysFeedBackService : IDynamicApiController, ITransient
{
private readonly SqlSugarRepository<SysFeedBack> _rep;
private readonly UserManager _userManager;
public SysFeedBackService(SqlSugarRepository<SysFeedBack> rep, UserManager userManager)
{
_rep = rep;
_userManager = userManager;
}
/// <summary>
/// 分页查询用户反馈表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Page")]
public async Task<SqlSugarPagedList<SysFeedBackOutput>> Page(SysFeedBackInput input)
{
var query = _rep.AsQueryable()
.WhereIF(!string.IsNullOrWhiteSpace(input.SearchKey), u =>
u.Title.Contains(input.SearchKey.Trim())
|| u.Content.Contains(input.SearchKey.Trim())
)
.WhereIF(input.CId > 0, u => u.CId == input.CId)
.WhereIF(!string.IsNullOrWhiteSpace(input.Title), u => u.Title.Contains(input.Title.Trim()))
.WhereIF(!string.IsNullOrWhiteSpace(input.Content), u => u.Content.Contains(input.Content.Trim()))
.Select<SysFeedBackOutput>();
return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize);
}
/// <summary>
/// 增加用户反馈表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Add")]
public async Task<long> Add(AddSysFeedBackInput input)
{
var entity = input.Adapt<SysFeedBack>();
entity.CId = _userManager.UserId;
entity.CreateTime = DateTime.Now;
entity.UpdateTime = DateTime.Now;
entity.CreateUserId = _userManager.UserId;
entity.UpdateUserId = _userManager.UserId;
entity.CreateUserName = _userManager.RealName;
entity.UpdateUserName = _userManager.RealName;
await _rep.InsertAsync(entity);
return entity.Id;
}
/// <summary>
/// 删除用户反馈表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Delete")]
public async Task Delete(DeleteSysFeedBackInput input)
{
var entity = await _rep.GetFirstAsync(u => u.Id == input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D1002);
await _rep.FakeDeleteAsync(entity); //假删除
//await _rep.DeleteAsync(entity); //真删除
}
/// <summary>
/// 更新用户反馈表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Update")]
public async Task Update(UpdateSysFeedBackInput input)
{
var entity = input.Adapt<SysFeedBack>();
await _rep.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync();
}
/// <summary>
/// 获取用户反馈表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpGet]
[ApiDescriptionSettings(Name = "Detail")]
public async Task<SysFeedBack> Detail([FromQuery] QueryByIdSysFeedBackInput input)
{
return await _rep.GetFirstAsync(u => u.Id == input.Id);
}
/// <summary>
/// 获取用户反馈表列表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpGet]
[ApiDescriptionSettings(Name = "List")]
public async Task<List<SysFeedBackOutput>> List([FromQuery] SysFeedBackInput input)
{
return await _rep.AsQueryable().Select<SysFeedBackOutput>().ToListAsync();
}
}