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(); } }