151 lines
5.4 KiB
C#
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();
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|