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;
///
/// 用户拓展字段表服务
///
[ApiDescriptionSettings(Order = 100)]
public class SysWeChatUserExtendService : IDynamicApiController, ITransient
{
private readonly SqlSugarRepository _rep;
private readonly SqlSugarRepository _userrep;
public SysWeChatUserExtendService(SqlSugarRepository rep, SqlSugarRepository userrep)
{
_rep = rep;
_userrep = userrep;
}
///
/// 分页查询用户拓展字段表
///
///
///
[HttpPost]
[ApiDescriptionSettings(Name = "Page")]
public async Task> 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();
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;
}
///
/// 增加用户拓展字段表
///
///
///
[HttpPost]
[ApiDescriptionSettings(Name = "Add")]
public async Task Add(AddSysWeChatUserExtendInput input)
{
var entity = input.Adapt();
await _rep.InsertAsync(entity);
return entity.Id;
}
///
/// 删除用户拓展字段表
///
///
///
[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); //真删除
}
///
/// 更新用户拓展字段表
///
///
///
[HttpPost]
[ApiDescriptionSettings(Name = "Update")]
public async Task Update(UpdateSysWeChatUserExtendInput input)
{
var entity = input.Adapt();
await _rep.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync();
}
///
/// 获取用户拓展字段表
///
///
///
[HttpGet]
[ApiDescriptionSettings(Name = "Detail")]
public async Task Detail([FromQuery] QueryByIdSysWeChatUserExtendInput input)
{
return await _rep.GetFirstAsync(u => u.Id == input.Id);
}
///
/// 获取用户拓展字段表列表
///
///
///
[HttpGet]
[ApiDescriptionSettings(Name = "List")]
public async Task> List([FromQuery] SysWeChatUserExtendInput input)
{
return await _rep.AsQueryable().Select().ToListAsync();
}
}