tuiwucarrer/Admin.NET/Admin.NET.Application/Service/SysWeChatUserExtend/SysWeChatUserExtendService.cs

151 lines
5.4 KiB
C#

using Admin.NET.Core.Service;
using Admin.NET.Core.Util;
using DocumentFormat.OpenXml.Wordprocessing;
using Elastic.Clients.Elasticsearch.Sql;
using Microsoft.AspNetCore.Http;
namespace Admin.NET.Application;
/// <summary>
/// 用户拓展字段表服务
/// </summary>
[ApiDescriptionSettings(Order = 100)]
public class SysWeChatUserExtendService : IDynamicApiController, ITransient
{
private readonly SqlSugarRepository<SysWeChatUserExtend> _rep;
private readonly SqlSugarRepository<SysWechatUser> _userrep;
public SysWeChatUserExtendService(SqlSugarRepository<SysWeChatUserExtend> rep, SqlSugarRepository<SysWechatUser> userrep)
{
_rep = rep;
_userrep = userrep;
}
/// <summary>
/// 分页查询用户拓展字段表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Page")]
public async Task<SqlSugarPagedList<SysWeChatUserExtendOutput>> Page(SysWeChatUserExtendInput input)
{
var query = _rep.AsQueryable()
.WhereIF(!string.IsNullOrWhiteSpace(input.SearchKey), u =>
u.SchoolName.Contains(input.SearchKey.Trim())
|| u.ClassName.Contains(input.SearchKey.Trim())
|| u.subjectGroup.Contains(input.SearchKey.Trim())
|| u.VipCode.Contains(input.SearchKey.Trim())
|| u.UUID.Contains(input.SearchKey.Trim())
)
//.WhereIF(input.UserId>0, u => u.UserId == input.UserId)
.WhereIF(!string.IsNullOrWhiteSpace(input.SchoolName), u => u.SchoolName.Contains(input.SchoolName.Trim()))
.WhereIF(!string.IsNullOrWhiteSpace(input.ClassName), u => u.ClassName.Contains(input.ClassName.Trim()))
.WhereIF(!string.IsNullOrWhiteSpace(input.subjectGroup), u => u.subjectGroup.Contains(input.subjectGroup.Trim()))
.WhereIF(!string.IsNullOrWhiteSpace(input.VipCode), u => u.VipCode.Contains(input.VipCode.Trim()))
.WhereIF(input.IsUpdateScore > 0, u => u.IsUpdateScore == input.IsUpdateScore)
.WhereIF(input.Year > 0, u => u.Year == input.Year)
.WhereIF(!string.IsNullOrWhiteSpace(input.UUID), u => u.UUID.Contains(input.UUID.Trim()))
.Select<SysWeChatUserExtendOutput>();
var response = await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize);
var items = response.Items.Select(s => s.WxId).ToList();
var userinfo = await _userrep.AsQueryable().Where(e => items.Contains(e.Id)).ToListAsync();
response.Items.ToList().ForEach(a =>
{
if (string.IsNullOrEmpty(a.SchoolName))
{
a.SchoolName = SchoolNameHelper.getName();
}
if (string.IsNullOrEmpty(a.ClassName))
{
a.ClassName = SchoolNameHelper.getClassName();
}
a.IsUpdateScore = a.IsUpdateScore == "0" ? "否" : "是";
a.Mobile = userinfo.FirstOrDefault(e => e.Id == a.WxId)?.Mobile;
a.NickName = MarkPhoneUtil.MaskPhoneNumber(userinfo.FirstOrDefault(e => e.Id == a.WxId)?.Mobile);
a.Score = a.expectedScore.ToString();
a.UUID = userinfo.FirstOrDefault(e => e.Id == a.WxId)?.OpenId;
});
return response;
}
/// <summary>
/// 增加用户拓展字段表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Add")]
public async Task<long> Add(AddSysWeChatUserExtendInput input)
{
var entity = input.Adapt<SysWeChatUserExtend>();
await _rep.InsertAsync(entity);
return entity.Id;
}
/// <summary>
/// 删除用户拓展字段表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPost]
[ApiDescriptionSettings(Name = "Delete")]
public async Task Delete(DeleteSysWeChatUserExtendInput 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(UpdateSysWeChatUserExtendInput input)
{
var entity = input.Adapt<SysWeChatUserExtend>();
await _rep.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync();
}
/// <summary>
/// 获取用户拓展字段表
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpGet]
[ApiDescriptionSettings(Name = "Detail")]
public async Task<SysWeChatUserExtend> Detail([FromQuery] QueryByIdSysWeChatUserExtendInput 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<SysWeChatUserExtendOutput>> List([FromQuery] SysWeChatUserExtendInput input)
{
return await _rep.AsQueryable().Select<SysWeChatUserExtendOutput>().ToListAsync();
}
}